:root {
  /* Surfaces */
  --bg:            #F4F4F6;
  --bg-soft:       #ECECEF;
  --surface:       #FFFFFF;
  --surface-2:     #FAFAFB;
  --surface-3:     #F4F4F6;

  /* Lignes & ombres */
  --line:          rgba(12, 12, 16, 0.07);
  --line-strong:   rgba(12, 12, 16, 0.12);
  --shadow-1:      0 1px 0 rgba(12,12,16,0.04), 0 1px 2px rgba(12,12,16,0.04);
  --shadow-2:      0 1px 0 rgba(12,12,16,0.04), 0 8px 24px -10px rgba(12,12,16,0.12);
  --shadow-pop:    0 4px 14px -2px rgba(12,12,16,0.18), 0 1px 2px rgba(12,12,16,0.08);

  /* Texte */
  --t1:            #0C0C10;
  --t2:            #46464C;
  --t3:            #76767E;
  --t4:            #A6A6AE;

  /* Accent — orange Hostaway */
  --accent-rgb:    245, 135, 77;
  --accent:        #F5874D;
  --accent-2:      #ED6B2D;
  --accent-soft:   #FEF1E8;
  --accent-ring:   rgba(var(--accent-rgb), 0.18);

  /* Status */
  --blue:          #3478F6;
  --blue-soft:     #EAF1FE;
  --green:         #1E9E5F;
  --green-soft:    #E6F6EE;
  --purple:        #7B5CF6;
  --purple-soft:   #EFEAFD;
  --rose:          #E0457B;
  --rose-soft:     #FCE9F0;

  /* Aliases compat (ancien systeme --ms-*) */
  --ms-bg:           var(--bg);
  --ms-surface:      var(--surface);
  --ms-surface-2:    var(--surface-3);
  --ms-border:       var(--line-strong);
  --ms-border-light: var(--line);
  --ms-text-1:       var(--t1);
  --ms-text-2:       var(--t2);
  --ms-text-3:       var(--t3);
  --ms-blue:         var(--blue);
  --ms-blue-bg:      var(--blue-soft);
  --ms-green:        var(--green);
  --ms-orange:       var(--accent);
  --ms-red:          var(--rose);
  --ms-list-panel-width: 320px;
}

[data-theme="dark"] {
  --bg:            #08080A;
  --bg-soft:       #0F0F12;
  --surface:       #16161A;
  --surface-2:     #1C1C21;
  --surface-3:     #25252B;

  --line:          rgba(255, 255, 255, 0.07);
  --line-strong:   rgba(255, 255, 255, 0.14);
  --shadow-1:      0 1px 0 rgba(255,255,255,0.02), 0 1px 2px rgba(0,0,0,0.5);
  --shadow-2:      0 1px 0 rgba(255,255,255,0.02), 0 8px 24px -10px rgba(0,0,0,0.6);
  --shadow-pop:    0 4px 14px -2px rgba(0,0,0,0.7), 0 1px 2px rgba(0,0,0,0.5);

  --t1:            #FAFAFB;
  --t2:            #C4C4CA;
  --t3:            #76767E;
  --t4:            #46464C;

  --accent-soft:   rgba(var(--accent-rgb), 0.18);
  --accent-ring:   rgba(var(--accent-rgb), 0.4);

  --blue:          #6CA6FF;
  --blue-soft:     rgba(108, 166, 255, 0.18);
  --green:         #3BC683;
  --green-soft:    rgba(59, 198, 131, 0.18);
  --purple:        #9881FF;
  --purple-soft:   rgba(152, 129, 255, 0.18);
  --rose:          #F46796;
  --rose-soft:     rgba(244, 103, 150, 0.18);
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

[hidden] {
  display: none !important;
}

body {
  font-family: 'Inter Tight', -apple-system, BlinkMacSystemFont, 'SF Pro Display', 'Segoe UI', system-ui, sans-serif;
  font-size: 13.5px;
  letter-spacing: -0.005em;
  color: var(--t2);
  background: var(--bg);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* ── Checkbox globale : coche toujours blanche ──────────────────────────────── */
input[type="checkbox"]:not(.ms-ios-sw) {
  -webkit-appearance: none;
  appearance: none;
  width: 16px;
  height: 16px;
  border: 1.5px solid var(--line-strong);
  border-radius: 3px;
  background: var(--surface);
  cursor: pointer;
  position: relative;
  flex-shrink: 0;
  vertical-align: middle;
  transition: background 0.15s, border-color 0.15s;
}

input[type="checkbox"]:not(.ms-ios-sw):checked {
  background: var(--cb-accent, var(--accent));
  border-color: var(--cb-accent, var(--accent));
}

input[type="checkbox"]:not(.ms-ios-sw):checked::after {
  content: '';
  position: absolute;
  left: 5px;
  top: 1.5px;
  width: 4px;
  height: 8px;
  border: solid #fff;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}

.app {
  display: flex;
  height: 100vh;
  height: 100dvh;
  min-height: 0;
  overflow: hidden;
}

.sidebar {
  width: 236px;
  background: var(--surface);
  border-right: 1px solid var(--line);
  flex-shrink: 0;
  padding: 14px;
  display: flex;
  flex-direction: column;
  transition: width 0.25s ease, transform 0.25s ease, padding 0.25s ease;
  z-index: 300;
}

.sidebar-logo {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 4px 6px 14px;
  text-decoration: none;
  white-space: nowrap;
}

.sidebar-mark {
  width: 30px;
  height: 30px;
  flex-shrink: 0;
  border-radius: 9px;
  background: linear-gradient(135deg, #F5874D, #ED6B2D);
  color: #ffffff;
  font-family: 'Instrument Serif', Georgia, serif;
  font-style: italic;
  font-size: 22px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 6px -1px rgba(var(--accent-rgb), 0.5);
}

.sidebar-wordmark {
  font-size: 16px;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--t1);
}

.sidebar-nav {
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex: 1;
  min-height: 0;
  overflow-y: auto;
}

.sidebar-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 10px;
  border-radius: 8px;
  font-size: 13px;
  color: var(--t2);
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
  text-decoration: none;
}

.sidebar-item:hover {
  background: var(--surface-3);
}

.sidebar-item.active {
  background: var(--t1);
  color: var(--surface);
  font-weight: 600;
}

.sidebar-item.active .sidebar-chevron,
.sidebar-item.active .icon {
  color: var(--surface);
}

.sidebar-item .left {
  display: flex;
  align-items: center;
  gap: 11px;
  min-width: 0;
}

.sidebar-item .left span {
  overflow: hidden;
  text-overflow: ellipsis;
}

.sidebar-item .icon {
  width: 18px;
  text-align: center;
  font-size: 15px;
  color: var(--t3);
}

.sidebar-chevron {
  color: var(--t3);
  font-size: 11px;
  transform: rotate(-90deg);
  transition: transform 0.2s;
}

.sidebar-item.submenu-open .sidebar-chevron {
  transform: rotate(0deg);
}

.sidebar-submenu {
  display: none;
  gap: 2px;
  margin: 2px 0 4px 39px;
}

.sidebar-submenu.open {
  display: grid;
}

.sidebar-subitem {
  border-radius: 7px;
  color: var(--t3);
  font-size: 12.5px;
  font-weight: 500;
  padding: 7px 10px;
  text-decoration: none;
}

.sidebar-subitem:hover {
  background: var(--surface-3);
  color: var(--t2);
}

.sidebar-subitem.active {
  background: var(--accent-soft);
  color: var(--accent-2);
  font-weight: 600;
}

.sidebar-footer {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 10px;
  padding: 8px;
  border-radius: 10px;
  background: var(--surface-3);
}

.sidebar-footer-avatar {
  width: 32px;
  height: 32px;
  flex-shrink: 0;
  border-radius: 8px;
  object-fit: cover;
}

.sidebar-footer-initials {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #F5874D, #ED6B2D);
  color: #ffffff;
  font-size: 12px;
  font-weight: 700;
}

.sidebar-footer-info {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.sidebar-footer-name {
  font-size: 12.5px;
  font-weight: 600;
  color: var(--t1);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.sidebar-footer-org {
  font-size: 11px;
  color: var(--t3);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.sidebar-locked {
  background: var(--bg-soft);
}

.sidebar-locked .sidebar-item {
  color: var(--t3);
  cursor: not-allowed;
  pointer-events: none;
}

.sidebar-locked .sidebar-item.active {
  background: var(--surface-3);
  color: var(--t2);
}

.main {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-width: 0;
  min-height: 0;
  overflow-y: auto;
}

.topbar {
  height: 56px;
  background: var(--surface);
  border-bottom: 1px solid var(--line);
  display: flex;
  align-items: center;
  padding: 0 24px;
  gap: 16px;
  position: sticky;
  top: 0;
  flex-shrink: 0;
  z-index: 200;
}

@supports ((-webkit-backdrop-filter: blur(1px)) or (backdrop-filter: blur(1px))) {
  .topbar {
    background: rgba(255, 255, 255, 0.72);
    -webkit-backdrop-filter: saturate(180%) blur(20px);
    backdrop-filter: saturate(180%) blur(20px);
  }
  [data-theme="dark"] .topbar {
    background: rgba(22, 22, 26, 0.72);
  }
}

.menu-toggle {
  border: 0;
  background: transparent;
  border-radius: 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 17px;
  color: var(--t2);
  cursor: pointer;
  padding: 6px 10px;
}

.topbar-title {
  font-size: 14.5px;
  font-weight: 600;
  color: var(--t1);
  margin-right: auto;
  letter-spacing: -0.01em;
}

.topbar-actions {
  display: flex;
  align-items: center;
  gap: 12px;
}

.topbar-theme-toggle {
  width: 34px;
  height: 34px;
  border: 1px solid var(--line);
  border-radius: 9px;
  background: var(--surface-3);
  color: var(--t2);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}

.topbar-theme-toggle:hover {
  background: var(--accent-soft);
  color: var(--accent-2);
  border-color: var(--accent-ring);
}

.content {
  flex: 1;
  padding: 26px 32px 28px;
}

.page-header {
  background: #ffffff;
  padding: 22px 26px;
  border-radius: 4px;
  margin-bottom: 22px;
  display: flex;
  align-items: center;
  gap: 12px;
  box-shadow: 0 1px 2px rgba(0,0,0,0.04);
}

.page-header i {
  font-size: 20px;
  color: #4a4a4a;
}

.page-header h1 {
  font-size: 20px;
  font-weight: 700;
  color: #3a3a3a;
}

.grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.card {
  background: #ffffff;
  border-radius: 4px;
  box-shadow: 0 1px 2px rgba(0,0,0,0.04);
  overflow: hidden;
}

.card.allow-overflow {
  overflow: visible;
}

.card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px 12px;
  border-bottom: 1px solid #f0f0f2;
}

.card-title {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  font-weight: 600;
  color: #3a3a3a;
}

.card-body {
  padding: 18px 20px 16px;
}

.card.allow-overflow .card-body {
  position: relative;
}

.tag {
  font-size: 11px;
  padding: 4px 12px;
  border-radius: 3px;
  font-weight: 600;
  color: #ffffff;
  background: #0071e3;
  white-space: nowrap;
}

.metric {
  font-size: 36px;
  color: #3a3a3a;
  line-height: 1.1;
}

.muted {
  color: #8a8f97;
  margin-top: 5px;
}

.list {
  display: grid;
  gap: 10px;
}

.list-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 12px 0;
  border-bottom: 1px solid #f0f0f2;
}

.list-item.clickable {
  cursor: pointer;
  border-radius: 4px;
  padding-left: 10px;
  padding-right: 10px;
}

.list-item.clickable:hover {
  background: #f7f9fb;
}

.list-item:last-child {
  border-bottom: 0;
}

.property-list-item {
  justify-content: flex-start;
}

.property-list-main {
  min-width: 0;
  margin-right: auto;
}

.property-photo-thumb,
.calendar-property-photo,
.property-sort-photo {
  border-radius: 4px;
  object-fit: cover;
  flex: 0 0 auto;
  border: 1px solid #e1e4e8;
  background: #eef0f2;
}

.property-photo-thumb {
  width: 56px;
  height: 42px;
}

.calendar-property-photo {
  width: 72px;
  height: 72px;
}

.property-sort-photo {
  width: 38px;
  height: 30px;
}

.property-photo-fallback {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #5a6068;
  font-weight: 800;
}

.property-visibility {
  color: #5a6068;
  font-weight: 700;
}

.property-photo-preview {
  margin-top: 10px;
}

.property-photo-preview img {
  width: 120px;
  height: 76px;
  border-radius: 4px;
  object-fit: cover;
  border: 1px solid #d9dde2;
}

.property-gallery-uploader {
  margin-bottom: 14px;
}

.property-gallery-drop {
  align-items: center;
  background: #f7f9fb;
  border: 1.5px dashed var(--ms-border);
  border-radius: 12px;
  cursor: pointer;
  display: grid;
  gap: 5px;
  justify-items: center;
  padding: 20px;
  text-align: center;
  transition: border-color .13s, background .13s, box-shadow .13s;
}

.property-gallery-drop:hover {
  background: #f4f8ff;
  border-color: var(--ms-blue);
  box-shadow: 0 0 0 3px var(--ms-blue-bg);
}

.property-gallery-drop input {
  display: none;
}

.property-gallery-drop-icon {
  align-items: center;
  background: var(--ms-blue-bg);
  border-radius: 10px;
  color: var(--ms-blue);
  display: flex;
  font-size: 16px;
  height: 34px;
  justify-content: center;
  width: 34px;
}

.property-gallery-drop-text {
  color: var(--ms-text-1);
  font-size: 13px;
  font-weight: 700;
}

.property-gallery-drop-meta {
  color: var(--ms-text-2);
  font-size: 12px;
}

.property-gallery {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
}

.property-gallery-empty {
  align-items: center;
  background: #f7f9fb;
  border: 1px solid var(--ms-border-light);
  border-radius: 12px;
  color: var(--ms-text-2);
  display: flex;
  font-size: 13px;
  min-height: 74px;
  padding: 16px;
}

.property-gallery-item {
  background: #ffffff;
  border: 1px solid var(--ms-border-light);
  border-radius: 12px;
  cursor: grab;
  overflow: hidden;
  position: relative;
  touch-action: manipulation;
}

.property-gallery-item.is-main {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

.property-gallery-item.dragging {
  cursor: grabbing;
  opacity: .58;
}

.property-gallery-item.drag-over {
  border-color: var(--ms-blue);
  box-shadow: inset 0 0 0 2px var(--ms-blue);
}

.property-gallery-image-wrap {
  aspect-ratio: 4 / 3;
  background: #eef2f7;
  overflow: hidden;
  position: relative;
}

.property-gallery-image-wrap img {
  display: block;
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.property-gallery-badge {
  background: rgba(29, 29, 31, .78);
  border-radius: 999px;
  color: #ffffff;
  font-size: 11px;
  font-weight: 700;
  left: 8px;
  padding: 4px 8px;
  position: absolute;
  top: 8px;
}

.property-gallery-item.is-main .property-gallery-badge {
  background: var(--accent);
  color: #ffffff;
}

.property-gallery-badge i {
  color: currentColor;
  font-size: 10px;
}

.property-gallery-summary {
  color: var(--t2);
  font-size: 12px;
  font-weight: 650;
  line-height: 1.35;
  min-height: 42px;
  overflow: hidden;
  padding: 10px;
  text-overflow: ellipsis;
}

.property-gallery-actions {
  align-items: center;
  background: #ffffff;
  border-top: 1px solid var(--ms-border-light);
  display: grid;
  gap: 4px;
  grid-template-columns: 1fr 34px 34px;
  padding: 6px;
}

.property-gallery-grip {
  align-items: center;
  color: var(--ms-text-3);
  display: flex;
  font-size: 14px;
  height: 30px;
  padding: 0 8px;
}

.property-gallery-btn {
  align-items: center;
  background: #f7f9fb;
  border: 1px solid transparent;
  border-radius: 8px;
  color: var(--ms-text-2);
  cursor: pointer;
  display: flex;
  height: 30px;
  justify-content: center;
  gap: 6px;
  padding: 0 9px;
}

.property-gallery-btn {
  padding: 0;
  width: 34px;
}

.property-gallery-btn:hover {
  background: var(--accent-soft);
  color: var(--accent);
}

.property-gallery-btn.danger:hover {
  background: #fff1f0;
  color: var(--ms-red);
}

.property-gallery-item.is-main .property-gallery-btn[data-gallery-main] {
  background: var(--accent-soft);
  color: var(--accent);
}

.property-gallery-edit {
  align-items: center;
  background: rgba(12, 12, 16, 0.58);
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 999px;
  bottom: 8px;
  color: #ffffff;
  cursor: pointer;
  display: inline-flex;
  font: inherit;
  font-size: 11px;
  font-weight: 750;
  gap: 5px;
  min-height: 28px;
  opacity: 0.78;
  padding: 0 9px;
  position: absolute;
  right: 8px;
  transition: background 0.15s, opacity 0.15s, transform 0.15s;
  z-index: 4;
}

.property-gallery-edit:hover,
.property-gallery-edit:focus-visible {
  background: rgba(12, 12, 16, 0.78);
  opacity: 1;
  transform: translateY(-1px);
}

.property-gallery-edit i {
  font-size: 10px;
}

.property-photo-modal {
  max-width: 760px;
  padding: 0;
  overflow: hidden;
}

.property-photo-modal-head {
  align-items: flex-start;
  border-bottom: 1px solid var(--line);
  display: flex;
  gap: 12px;
  justify-content: space-between;
  padding: 18px 20px 14px;
}

.property-photo-modal-head .app-modal-message {
  margin-bottom: 0;
}

.property-photo-modal-close {
  align-items: center;
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 10px;
  color: var(--t2);
  cursor: pointer;
  display: inline-flex;
  height: 36px;
  justify-content: center;
  width: 36px;
}

.property-photo-modal-image {
  background: var(--surface-2);
  max-height: 48vh;
  overflow: hidden;
}

.property-photo-modal-image img {
  display: block;
  max-height: 48vh;
  object-fit: contain;
  width: 100%;
}

.property-photo-modal-fields {
  display: grid;
  gap: 12px;
  padding: 18px 20px;
}

.property-photo-modal-fields textarea.ms-field-input,
.property-photo-modal-fields textarea.pg-input {
  min-height: 92px;
  padding: 12px;
  resize: vertical;
}

.property-photo-modal .app-modal-actions {
  border-top: 1px solid var(--line);
  margin-top: 0;
  padding: 14px 20px 18px;
}

@media (max-width: 700px) {
  .property-photo-modal-backdrop {
    align-items: stretch;
    place-items: stretch;
    padding: 12px;
  }

  .property-photo-modal {
    max-height: calc(100vh - 24px);
    overflow-y: auto;
  }

  .property-photo-modal-image,
  .property-photo-modal-image img {
    max-height: 34vh;
  }

  .property-photo-modal .app-modal-actions {
    flex-wrap: wrap;
  }

  .property-photo-modal .app-modal-actions button {
    flex: 1 1 140px;
  }
}

.smart-lock-provider-group {
  margin-top: 8px;
}

.smart-lock-connect {
  align-items: center;
  border-top: 1px solid var(--ms-border-light);
  display: flex;
  gap: 12px;
  justify-content: flex-end;
  margin-top: 16px;
  padding-top: 16px;
}

.smart-lock-connect .btn {
  flex: 0 0 auto;
  min-height: 34px;
  padding: 0 12px;
  width: auto;
}

.smart-lock-connect[data-smart-lock-generic] {
  align-items: end;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  justify-content: stretch;
}

.smart-lock-connect[data-smart-lock-generic][hidden] {
  display: none !important;
}

.smart-lock-confirmation {
  align-items: center;
  background: #eafaf0;
  border: 1px solid #b9ebca;
  border-radius: 10px;
  color: #15803d;
  display: flex;
  font-size: 13px;
  font-weight: 700;
  grid-column: 1 / -1;
  min-height: 36px;
  padding: 9px 12px;
}

.ttlock-fields {
  border-top: 1px solid var(--ms-border-light);
  display: grid;
  gap: 16px;
  grid-column: 1 / -1;
  margin-top: 16px;
  padding-top: 16px;
}

.ttlock-fields[hidden] {
  display: none !important;
}

.ttlock-locks {
  display: grid;
  gap: 8px;
  margin-top: 12px;
}

.ttlock-lock-item {
  align-items: center;
  background: #f7f9fb;
  border: 1px solid var(--ms-border-light);
  border-radius: 10px;
  color: var(--ms-text-1);
  cursor: pointer;
  display: flex;
  font-family: inherit;
  justify-content: space-between;
  padding: 10px 12px;
  text-align: left;
}

.ttlock-lock-item:hover,
.ttlock-lock-item.active {
  background: var(--ms-blue-bg);
  border-color: var(--ms-blue);
}

.ttlock-lock-item strong,
.ttlock-lock-item small {
  display: block;
}

.ttlock-lock-item small {
  color: var(--ms-text-2);
  font-size: 12px;
  margin-top: 2px;
}

.tag.smart-lock-ok {
  background: #eafaf0;
  color: #15803d;
}

@media (max-width: 640px) {
  .property-gallery {
    grid-template-columns: 1fr;
  }

  .smart-lock-connect {
    align-items: stretch;
    justify-content: stretch;
  }

  .smart-lock-connect .btn {
    width: 100%;
  }
}

.toggle-line {
  height: 38px;
  display: flex !important;
  align-items: center;
  gap: 8px;
  margin: 0 !important;
  color: #3a3a3a !important;
  font-weight: 600 !important;
}

.toggle-line input {
  --cb-accent: var(--ms-blue);
  width: auto;
}

.form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px 18px;
}

.form-field {
  display: flex;
  flex-direction: column;
}

.form-field.full {
  grid-column: 1 / -1;
}

.form-field label {
  font-size: 12px;
  font-weight: 600;
  color: var(--t3);
  margin-bottom: 7px;
}

.form-field input,
.form-field select,
.form-field textarea {
  width: 100%;
  border: 1px solid var(--line-strong);
  border-radius: 8px;
  padding: 0 12px;
  font: inherit;
  color: var(--t1);
  background: var(--surface);
  outline: none;
  transition: border-color .13s, box-shadow .13s;
}

.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-ring);
}

[data-theme="dark"] .form-field input,
[data-theme="dark"] .form-field select,
[data-theme="dark"] .form-field textarea {
  background: var(--surface-2);
}

.form-field input,
.form-field select {
  height: 38px;
}

.form-field textarea {
  min-height: 98px;
  padding-top: 10px;
  resize: vertical;
}

.permission-grid {
  display: flex;
  flex-direction: column;
  border: 1px solid var(--line);
  border-radius: 10px;
  overflow: hidden;
}

.cleaning-check {
  align-items: center;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 8px;
  color: var(--t2);
  cursor: pointer;
  display: flex;
  font-size: 12.5px;
  gap: 9px;
  padding: 10px 12px;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
  user-select: none;
}

.cleaning-check:hover { background: var(--surface-2); color: var(--t1); }

.cleaning-check:has(input:checked) {
  background: var(--accent-soft);
  border-color: var(--accent-ring);
  color: var(--accent-2);
}

.cleaning-check input { --cb-accent: var(--accent); width: auto; }

/* ── Main permission toggle rows ── */
.perm-main-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 16px;
  border-bottom: 1px solid var(--line);
  background: var(--surface);
  cursor: pointer;
  transition: background .1s;
  user-select: none;
}
.permission-grid > .perm-main-toggle:last-child,
.permission-grid > .perm-item-wrap:last-child { border-bottom: none; }
.perm-main-toggle:hover { background: var(--surface-2); }
.perm-main-label {
  display: flex;
  align-items: center;
  gap: 11px;
  font-size: 13.5px;
  font-weight: 500;
  color: var(--t1);
}
.perm-main-label > i {
  font-size: 13px;
  color: var(--t3);
  width: 16px;
  text-align: center;
  flex-shrink: 0;
  transition: color .12s;
}
.perm-main-toggle:has(input:checked) .perm-main-label > i { color: var(--accent); }
.perm-main-toggle:has(input:checked) .perm-toggle-track { background: var(--accent); }
.perm-main-toggle:has(input:checked) .perm-toggle-thumb { transform: translateX(16px); }

/* ── perm-item-wrap (rows that expand sub-sections) ── */
.perm-item-wrap {
  display: flex;
  flex-direction: column;
  border-bottom: 1px solid var(--line);
}
.perm-item-wrap:last-child { border-bottom: none; }
.perm-item-wrap > .perm-main-toggle { border-bottom: none; }

.perm-sub-wrap {
  background: var(--surface-2);
  border-top: 1px solid var(--line);
  overflow: hidden;
}
.perm-sub-section {
  padding: 14px 16px 16px;
}
.perm-sub-header {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 11px;
  font-weight: 700;
  color: var(--t3);
  text-transform: uppercase;
  letter-spacing: .5px;
  margin-bottom: 10px;
}
.perm-sub-header i { font-size: 10px; }

/* ── Toggle list (privacy settings) ── */
.perm-toggle-list {
  display: flex;
  flex-direction: column;
}
.perm-toggle-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 9px 0;
  border-bottom: 1px solid var(--line);
  cursor: pointer;
  transition: background .1s;
}
.perm-toggle-row:last-child { border-bottom: none; }
.perm-toggle-label {
  display: flex;
  align-items: center;
  gap: 9px;
  font-size: 13px;
  font-weight: 500;
  color: var(--t1);
}
.perm-toggle-label i {
  font-size: 11px;
  color: var(--t4);
  width: 14px;
  text-align: center;
  flex-shrink: 0;
}
/* Switch track + thumb */
.perm-toggle-switch {
  position: relative;
  display: inline-flex;
  width: 38px;
  height: 22px;
  flex-shrink: 0;
  cursor: pointer;
}
.perm-toggle-switch input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
  pointer-events: none;
}
.perm-toggle-track {
  position: absolute;
  inset: 0;
  background: var(--line-strong);
  border-radius: 11px;
  transition: background .18s;
}
.perm-toggle-thumb {
  position: absolute;
  top: 3px;
  left: 3px;
  width: 16px;
  height: 16px;
  background: #fff;
  border-radius: 50%;
  box-shadow: 0 1px 4px rgba(0,0,0,.22);
  transition: transform .18s;
}
.perm-toggle-row:has(input:checked) .perm-toggle-track { background: var(--accent); }
.perm-toggle-row:has(input:checked) .perm-toggle-thumb { transform: translateX(16px); }
.perm-toggle-row:has(input:checked) .perm-toggle-label { color: var(--t1); }
/* Generic checked state for any standalone toggle switch */
.perm-toggle-switch:has(input:checked) .perm-toggle-track { background: var(--accent); }
.perm-toggle-switch:has(input:checked) .perm-toggle-thumb { transform: translateX(16px); }

.automation-time-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.automation-time-item {
  display: grid;
  gap: 6px;
}

.automation-time-item span {
  color: #7b8492;
  font-size: 12px;
  font-weight: 700;
}

.nightly-rates {
  display: grid;
  gap: 10px;
}

.nightly-rate-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 160px;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  border: 1px solid #eef0f2;
  border-radius: 4px;
  background: #fafbfc;
}

.nightly-rate-row span {
  font-weight: 600;
  color: #5a6068;
}

.nightly-rate-row input {
  height: 34px;
}

.date-picker {
  position: relative;
}

.date-picker input[readonly] {
  cursor: pointer;
  background: var(--surface);
}

.date-picker-panel {
  display: none;
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  width: 292px;
  padding: 12px;
  background: var(--surface);
  border: 1px solid var(--line-strong);
  border-radius: 12px;
  box-shadow: var(--shadow-pop);
  z-index: 500;
}

.date-picker.open .date-picker-panel {
  display: block;
}

.date-picker-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
}

.date-picker-head button,
.date-picker-day {
  border: 0;
  border-radius: 4px;
  background: transparent;
  cursor: pointer;
}

.date-picker-head button {
  width: 30px;
  height: 30px;
  color: var(--t2);
}

.date-picker-title {
  font-weight: 700;
  color: var(--t1);
}

.date-picker-week,
.date-picker-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
}

.date-picker-week span {
  text-align: center;
  font-size: 11px;
  font-weight: 700;
  color: var(--t3);
  padding: 4px 0;
}

.date-picker-day {
  height: 34px;
  color: var(--t2);
  font: inherit;
}

.date-picker-day:hover {
  background: var(--blue-soft);
  color: var(--blue);
}

.date-picker-day.is-empty {
  cursor: default;
}

.date-picker-day.is-today {
  border: 1px solid var(--accent);
  color: var(--accent);
  font-weight: 800;
  position: relative;
}

.date-picker-day.is-today::after {
  background: var(--accent);
  border-radius: 999px;
  bottom: 4px;
  content: "";
  height: 4px;
  left: 50%;
  position: absolute;
  transform: translateX(-50%);
  width: 4px;
}

.date-picker-day.is-selected {
  background: var(--accent);
  color: #ffffff;
  font-weight: 700;
}

.date-picker-day.is-selected.is-today {
  color: #ffffff;
}

.date-picker-day.is-selected.is-today::after {
  background: #ffffff;
}

.time-select {
  display: inline-grid;
  grid-template-columns: 74px auto 74px;
  align-items: center;
  gap: 6px;
  width: max-content;
  max-width: 100%;
}

.time-select::before {
  content: "";
  display: none;
}

.time-select::after {
  content: "";
  display: none;
}

.time-select select {
  width: 74px;
  padding: 0 8px;
}

.time-select .time-separator {
  color: #5a6068;
  font-weight: 700;
}

.reservation-tools {
  display: grid;
  gap: 14px;
  padding-bottom: 16px;
  margin-bottom: 6px;
  border-bottom: 1px solid #f0f0f2;
}

.filters-row {
  display: flex;
  align-items: flex-end;
  flex-wrap: wrap;
  gap: 12px;
}

.filter-dropdown {
  position: relative;
}

.filter-menu {
  display: none;
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  width: 260px;
  max-height: 260px;
  overflow-y: auto;
  padding: 10px;
  background: #ffffff;
  border: 1px solid #d9dde2;
  border-radius: 4px;
  box-shadow: 0 12px 28px rgba(20, 28, 36, 0.14);
  z-index: 520;
}

.filter-dropdown.open .filter-menu {
  display: grid;
  gap: 8px;
}

.filter-option {
  display: flex;
  align-items: center;
  gap: 8px;
  color: #4a4a4a;
  font-weight: 600;
}

.filter-option input {
  width: auto;
}

.filter-section {
  display: grid;
  gap: 6px;
}

.filter-section + .filter-section {
  border-top: 1px solid #eef0f3;
  padding-top: 8px;
}

.filter-section-title {
  color: var(--ms-text-2);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .03em;
  padding: 0 2px;
  text-transform: uppercase;
}

.filter-option.is-group-covered {
  background: #f7faff;
  border-color: #d8e8f8;
  color: var(--ms-blue);
}

.filter-clear {
  margin-bottom: 0;
}

.sort-button,
.table-sort {
  height: 32px;
  border: 1px solid #d9dde2;
  border-radius: 4px;
  background: #ffffff;
  color: #5a6068;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 0 10px;
  font: inherit;
  font-weight: 600;
  cursor: pointer;
}

.sort-button.active,
.table-sort.active {
  border-color: #2196d4;
  color: #2196d4;
  background: #e8f4fc;
}

.sort-button span,
.table-sort span {
  display: inline-flex;
  gap: 3px;
  font-size: 10px;
}

.table-sort {
  height: auto;
  min-height: 26px;
  width: 100%;
  justify-content: space-between;
  border: 0;
  background: transparent;
  color: inherit;
  padding: 0;
}

.table-sort.active {
  background: transparent;
  border: 0;
  color: #2196d4;
}

.reservations-table-wrap {
  overflow-x: auto;
  margin-top: 8px;
}

.reservations-mobile-list {
  display: none;
}

.reservations-table {
  width: 100%;
  min-width: 1180px;
  border-collapse: collapse;
  font-size: 12px;
}

.reservations-table th,
.reservations-table td {
  border: 1px solid #eef0f2;
  padding: 8px 9px;
  text-align: left;
  vertical-align: middle;
  white-space: nowrap;
}

.reservations-table th {
  background: #f7f9fb;
  color: #344052;
  font-weight: 700;
}

.reservations-table tr {
  cursor: pointer;
}

.reservations-table tbody tr:hover {
  background: #f7f9fb;
}

.status-pill,
.source-pill {
  display: inline-flex;
  align-items: center;
  min-height: 22px;
  padding: 2px 9px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.01em;
}

.status-confirmed {
  background: var(--green-soft);
  color: var(--green);
}

.status-pending {
  background: var(--accent-soft);
  color: var(--accent-2);
}

.status-cancelled {
  background: var(--rose-soft);
  color: var(--rose);
}

.source-direct {
  color: #126b5b;
  background: #a7f0df;
}

.source-airbnb {
  color: #6b1e24;
  background: #ffb3b7;
}

.source-booking {
  color: #ffffff;
  background: #003580;
}

.source-google,
.source-expedia,
.source-vrbo,
.source-abritel,
.source-beds24 {
  color: #344052;
  background: #e8eef5;
}

.source-logo {
  width: 28px;
  height: 28px;
  border-radius: 4px;
  object-fit: cover;
  display: block;
}

.source-logo-fallback {
  width: 28px;
  height: 28px;
  border-radius: 4px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #eef0f2;
  color: #5a6068;
  font-weight: 700;
}

.logo-preview {
  margin-top: 10px;
}

.logo-preview img {
  width: 42px;
  height: 42px;
  border-radius: 4px;
  object-fit: cover;
  border: 1px solid var(--line);
}

.logo-cropper {
  display: grid;
  gap: 14px;
  margin-top: 14px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 9px;
  background: var(--surface-2);
  width: fit-content;
  max-width: 100%;
}

.logo-cropper[hidden] {
  display: none;
}

.language-settings-grid {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
}

.language-settings-option {
  align-items: center;
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 9px;
  cursor: pointer;
  display: grid;
  gap: 8px;
  grid-template-columns: auto minmax(0, 1fr) auto;
  padding: 10px 12px;
  transition: background 0.15s, border-color 0.15s;
}

.language-settings-option:has(input:checked) {
  background: var(--accent-soft);
  border-color: var(--accent-ring);
}

.language-settings-option input {
  --cb-accent: var(--accent);
}

.language-settings-option span {
  color: var(--t1);
  font-size: 12.5px;
  font-weight: 600;
  min-width: 0;
}

.language-settings-option small {
  color: var(--t3);
  font-size: 10.5px;
  font-weight: 700;
}

.logo-cropper canvas {
  width: 180px;
  height: 180px;
  border-radius: 4px;
  border: 1px solid var(--line);
  background: var(--surface);
}

.cropper-controls {
  display: grid;
  gap: 10px;
  width: min(360px, 100%);
}

.cropper-controls label {
  display: grid;
  grid-template-columns: 90px minmax(140px, 1fr);
  align-items: center;
  gap: 10px;
  margin: 0;
}

.numeric {
  text-align: right !important;
}

.reservation-mobile-card {
  width: 100%;
  border: 1px solid #eef0f2;
  border-radius: 4px;
  background: #ffffff;
  padding: 12px;
  display: grid;
  gap: 8px;
  text-align: left;
  color: #4a4a4a;
  font: inherit;
  cursor: pointer;
}

.reservation-mobile-card:hover {
  background: #f7f9fb;
}

.reservation-mobile-top,
.reservation-mobile-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.reservations-mode .page-split-list {
  width: var(--ms-list-panel-width);
}

.reservation-list-actions,
.reservation-filter-row {
  align-items: center;
  display: flex;
  gap: 8px;
}

.reservation-filter-stack {
  border-bottom: 1px solid var(--line);
  display: grid;
  gap: 10px;
  padding: 12px 16px 14px;
}

.reservation-focus-mode .reservation-filter-stack {
  display: none;
}

.reservation-focus-banner {
  align-items: center;
  background: var(--blue-soft);
  border-bottom: 1px solid var(--line);
  display: flex;
  gap: 12px;
  justify-content: space-between;
  padding: 12px 16px;
}

.reservation-focus-banner strong {
  color: var(--t1);
  display: block;
  font-size: 13px;
}

.reservation-focus-banner span {
  color: var(--t2);
  display: block;
  font-size: 12px;
  line-height: 1.35;
  margin-top: 2px;
}

.reservation-focus-banner .ms-btn-ghost {
  flex: 0 0 auto;
  white-space: nowrap;
}

.reservation-filter-row .date-picker,
.reservation-property-filter {
  flex: 1;
  min-width: 0;
}

.reservation-property-filter .filter-menu {
  border-radius: 12px;
  max-height: 360px;
  width: 100%;
}

.reservation-property-filter .filter-option {
  border: 1px solid transparent;
  border-radius: 9px;
  min-height: 34px;
  padding: 0 8px;
}

.reservation-property-filter .filter-option:hover {
  background: var(--surface-2);
}

.reservation-filter-row .date-picker:last-child .date-picker-panel {
  left: auto;
  right: 0;
}

.reservation-filter-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  width: 100%;
  height: 36px;
  padding: 0 14px;
  border: 1px solid var(--line-strong);
  border-radius: 9px;
  background: var(--surface);
  color: var(--t2);
  font-family: inherit;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: background .14s, border-color .14s, color .14s;
}
.reservation-filter-btn:hover {
  border-color: var(--accent);
  color: var(--accent);
  background: var(--accent-soft);
}

.reservation-search-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  width: 100%;
  height: 36px;
  padding: 0 14px;
  border: none;
  border-radius: 9px;
  background: var(--accent);
  color: #ffffff;
  font-family: inherit;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  transition: opacity .14s, transform .1s;
}
.reservation-search-btn:hover { opacity: 0.85; }
.reservation-search-btn:active { transform: scale(0.97); }

.reservation-icon-btn {
  height: 36px;
  justify-content: center;
  padding: 0;
  width: 36px;
}

/* ── Reservation search input ── */
.res-search-wrap {
  position: relative;
  display: flex;
  align-items: center;
}
.res-search-icon {
  position: absolute;
  left: 11px;
  color: var(--t4);
  font-size: 12px;
  pointer-events: none;
}
.res-search-input {
  width: 100%;
  height: 36px;
  padding: 0 12px 0 32px;
  border: 1px solid var(--line-strong);
  border-radius: 9px;
  background: var(--surface-2);
  color: var(--t1);
  font: inherit;
  font-size: 13px;
  outline: none;
  transition: border-color .13s, background .13s;
  -webkit-appearance: none;
}
.res-search-input:focus {
  border-color: var(--accent);
  background: var(--surface);
}
.res-search-input::placeholder { color: var(--t4); }

.reservation-choice-list {
  display: grid;
  gap: 8px;
  padding: 12px;
}

.reservation-choice {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 14px;
  color: var(--t1);
  cursor: pointer;
  display: grid;
  gap: 9px;
  padding: 12px;
  text-align: left;
  transition: background .14s, border-color .14s, box-shadow .14s;
  width: 100%;
}

.reservation-choice:hover,
.reservation-choice.active {
  background: var(--surface-2);
  border-color: var(--accent);
  box-shadow: var(--shadow-2);
}

.reservation-choice-top,
.reservation-choice-bottom {
  align-items: center;
  display: flex;
  gap: 10px;
  justify-content: space-between;
  min-width: 0;
}

.reservation-choice-name {
  font-size: 14px;
  font-weight: 700;
  color: var(--t1);
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.reservation-choice-property,
.reservation-choice-dates {
  color: var(--t3);
  font-size: 12px;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.reservation-choice-total {
  color: var(--t1);
  font-size: 12px;
  font-weight: 700;
  white-space: nowrap;
}

.reservation-detail-card .detail-section {
  margin-bottom: 0;
}

.reservation-detail-card .detail-section + .detail-section {
  margin-top: 18px;
}

.reservation-detail-card .detail-note {
  border-radius: 12px;
}

.reservations-mode [data-reservation-form] .form-field label {
  color: var(--ms-text-3);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .4px;
  margin-bottom: 8px;
  text-transform: uppercase;
}

.reservations-mode [data-reservation-form] .form-field input,
.reservations-mode [data-reservation-form] .form-field select,
.reservations-mode [data-reservation-form] .form-field textarea,
.reservations-mode .nightly-rate-row input {
  border: 1px solid var(--ms-border);
  border-radius: 8px;
  color: var(--ms-text-1);
  font-family: inherit;
  font-size: 13px;
  outline: none;
  transition: border-color .13s, box-shadow .13s;
}

.reservations-mode [data-reservation-form] .form-field input:focus,
.reservations-mode [data-reservation-form] .form-field select:focus,
.reservations-mode [data-reservation-form] .form-field textarea:focus,
.reservations-mode .nightly-rate-row input:focus {
  border-color: var(--ms-blue);
  box-shadow: 0 0 0 3px var(--ms-blue-bg);
}

@media (max-width: 640px) {
  .page-split.reservations-mode {
    flex-direction: column;
    overflow-y: auto;
  }

  .page-split.reservations-mode .page-split-list {
    border-bottom: none;
    border-right: none;
    max-height: none;
    overflow: visible;
    width: 100%;
  }

  .reservation-focus-banner {
    align-items: stretch;
    flex-direction: column;
  }

  .page-split.reservations-mode .page-split-detail {
    overflow-y: visible;
    padding: 16px;
  }

  .page-split.reservations-mode[data-res-panel="detail"] .page-split-list {
    display: none;
  }

  .page-split.reservations-mode:not([data-res-panel="detail"]) .page-split-detail {
    display: none;
  }
}

.calendar-planner {
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--surface);
  overflow: auto;
  position: relative;
  box-shadow: var(--shadow-1);
  height: 100%;
  min-height: 0;
}

.calendar-grid-shell {
  width: 100%;
}

.calendar-header-row,
.calendar-row {
  display: grid;
  grid-template-columns: 200px repeat(var(--calendar-days), 1fr);
}

.calendar-property-head,
.calendar-day-head,
.calendar-property-cell,
.calendar-day-cell {
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}

.calendar-property-head,
.calendar-day-head {
  min-height: 48px;
  background: var(--surface-2);
  display: flex;
  align-items: center;
  padding: 8px 10px;
  font-weight: 700;
  color: var(--t2);
  position: sticky;
  top: 0;
  z-index: 3;
}

.calendar-property-head,
.calendar-property-cell {
  z-index: 2;
}

.calendar-property-head {
  z-index: 4;
  background: var(--surface-2);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--t3);
}

.calendar-property-sort-button {
  border: 0;
  background: transparent;
  color: var(--t2);
  font: inherit;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  cursor: pointer;
  min-width: 0;
}

.calendar-property-sort-button:hover {
  color: var(--blue);
}

.calendar-sort-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  position: relative;
  margin-bottom: 10px;
}

.property-sort-menu {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  z-index: 530;
  width: min(430px, calc(100vw - 48px));
  max-height: min(620px, calc(100vh - 210px));
  overflow: auto;
  margin-top: 0;
  padding: 12px;
  border: 1px solid var(--line-strong);
  border-radius: 16px;
  background: var(--surface);
  box-shadow: var(--shadow-pop);
}

.calendar-filter-panel-head {
  align-items: center;
  display: flex;
  gap: 12px;
  justify-content: space-between;
  padding: 2px 2px 10px;
}

.calendar-filter-panel-head strong,
.calendar-filter-panel-head span {
  display: block;
}

.calendar-filter-panel-head strong {
  color: var(--ms-text-1);
  font-size: 14px;
}

.calendar-filter-panel-head span {
  color: var(--ms-text-2);
  font-size: 12px;
  margin-top: 2px;
}

.calendar-filter-reset {
  background: var(--ms-blue-bg);
  border: 1px solid transparent;
  border-radius: 9px;
  color: var(--ms-blue);
  cursor: pointer;
  font: inherit;
  font-size: 12px;
  font-weight: 800;
  height: 30px;
  padding: 0 10px;
}

.calendar-filter-section {
  display: grid;
  gap: 7px;
  padding: 10px 0;
}

.calendar-filter-section + .calendar-filter-section,
.property-sort-options,
.property-sort-custom {
  border-top: 1px solid var(--line);
}

.calendar-filter-section-title {
  color: var(--ms-text-2);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .03em;
  padding: 0 2px;
  text-transform: uppercase;
}

.calendar-filter-check {
  align-items: center;
  background: var(--surface);
  border: 1px solid transparent;
  border-radius: 10px;
  color: var(--ms-text-1);
  cursor: pointer;
  display: flex;
  font-size: 13px;
  font-weight: 700;
  gap: 9px;
  min-height: 36px;
  padding: 0 9px;
}

.calendar-filter-check:hover,
.calendar-filter-check:has(input:checked) {
  background: var(--blue-soft);
  border-color: var(--line);
}

.calendar-filter-check.is-group-covered {
  color: var(--ms-blue);
}

.calendar-filter-check input {
  --cb-accent: var(--ms-blue);
  width: auto;
}

.calendar-filter-check span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}

.property-sort-options {
  display: grid;
  gap: 6px;
  margin-bottom: 0;
  padding-top: 10px;
}

.property-sort-option {
  align-items: center;
  display: flex;
  gap: 9px;
  min-height: 34px;
  border: 0;
  border-radius: 10px;
  background: var(--surface);
  color: var(--t1);
  font: inherit;
  font-weight: 700;
  text-align: left;
  padding: 0 10px;
  cursor: pointer;
}

.property-sort-option i {
  color: var(--ms-blue);
  width: 16px;
}

.property-sort-option:hover,
.property-sort-option.active {
  background: var(--blue-soft);
  color: var(--blue);
}

.property-sort-custom {
  display: grid;
  gap: 6px;
  margin-top: 10px;
  padding-top: 10px;
}

.property-sort-row {
  display: grid;
  grid-template-columns: 28px 38px minmax(0, 1fr) 34px;
  align-items: center;
  gap: 6px;
  padding: 6px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface);
  transition: background 0.12s ease, border-color 0.12s ease, box-shadow 0.12s ease, opacity 0.12s ease;
}

.property-sort-row.dragging {
  opacity: 0.55;
  border-color: var(--blue);
  box-shadow: 0 8px 18px rgba(20, 28, 36, 0.14);
}

.property-sort-menu.is-dragging .property-sort-row:not(.dragging) {
  background: var(--surface-2);
}

.property-sort-row span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-weight: 700;
  color: var(--t1);
}

.property-sort-handle,
.property-sort-drag,
.property-sort-eye {
  width: 28px;
  height: 28px;
  border: 0;
  border-radius: 8px;
  background: var(--surface-3);
  color: var(--t2);
  cursor: pointer;
}

.property-sort-drag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: grab;
}

.property-sort-mobile-move {
  display: none;
}

.property-sort-eye {
  width: 34px;
}

.property-sort-handle:hover,
.property-sort-drag:hover,
.property-sort-eye:hover {
  background: var(--blue-soft);
  color: var(--blue);
}

.calendar-property-cell {
  background: var(--surface);
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  min-width: 0;
  overflow: hidden;
}

.calendar-property-cell.is-expandable {
  cursor: pointer;
}

.calendar-property-cell > div {
  min-width: 0;
}

.calendar-property-menu-button {
  width: 28px;
  height: 28px;
  margin-left: auto;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface-2);
  color: var(--t3);
  cursor: pointer;
  flex: 0 0 auto;
  transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
}

.calendar-property-menu-button:hover {
  background: var(--blue-soft);
  color: var(--blue);
  border-color: var(--line-strong);
}

.calendar-property-menu-button.open i {
  transform: rotate(180deg);
}

.calendar-property-name {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-weight: 600;
  font-size: 15px;
  color: var(--t1);
}

.calendar-property-meta {
  color: var(--t3);
  font-size: 11px;
  margin-top: 1px;
}

.calendar-day-head {
  justify-content: center;
  text-align: center;
  flex-direction: column;
  gap: 3px;
  border-top: 0;
  border-left: 0;
  transition: background 0.15s ease;
  position: relative;
}

.calendar-day-head .cal-day-abbr {
  font-size: 10px;
  font-weight: 600;
  color: var(--t3);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.calendar-day-head .cal-day-num {
  width: 24px;
  height: 24px;
  border-radius: 7px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  font-weight: 700;
  color: var(--t1);
}

.cal-day-note-preview {
  background: transparent;
  border: 0;
  color: var(--accent-2);
  cursor: pointer;
  display: block;
  font: inherit;
  font-size: 9.5px;
  font-weight: 700;
  line-height: 1.1;
  margin-top: 1px;
  max-width: calc(100% - 8px);
  overflow: hidden;
  padding: 0 2px;
  text-align: center;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.cal-day-note-preview:hover {
  text-decoration: underline;
}

.calendar-day-head.has-note {
  background: var(--accent-soft);
}

.calendar-day-head.has-note::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--accent);
}

.calendar-day-head.is-weekend {
  background: var(--surface-3);
}

.calendar-day-cell.is-weekend {
  background: var(--surface-2);
}

.calendar-day-head.is-today {
  background: transparent;
}

.calendar-day-cell.is-today {
  background: linear-gradient(180deg, rgba(var(--accent-rgb),0.05), rgba(var(--accent-rgb),0.02));
}

.calendar-day-head.is-today .cal-day-abbr {
  color: var(--accent-2);
}

.calendar-day-head.is-today .cal-day-num {
  background: var(--accent);
  color: #ffffff;
  box-shadow: 0 2px 6px -1px var(--accent-ring);
}

.calendar-day-head i {
  color: var(--accent);
  font-size: 9px;
}

.cal-day-note-btn {
  align-items: center;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--t3);
  cursor: pointer;
  display: inline-flex;
  height: 20px;
  justify-content: center;
  padding: 0;
  position: absolute;
  right: 4px;
  top: 4px;
  width: 20px;
  z-index: 6;
}

.cal-day-note-btn:hover,
.cal-day-note-btn.has-note {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}

.calendar-day-head .cal-day-note-btn i {
  color: currentColor;
  font-size: 10px;
}

.calendar-note-modal-backdrop {
  align-items: center;
  background: rgba(12, 12, 16, 0.42);
  display: flex;
  inset: 0;
  justify-content: center;
  padding: 18px;
  position: fixed;
  z-index: 3000;
}

.calendar-note-modal-backdrop[hidden] {
  display: none;
}

.calendar-note-modal {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 14px;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.24);
  display: grid;
  gap: 14px;
  padding: 18px;
  width: min(440px, calc(100vw - 32px));
}

.calendar-note-modal-head {
  align-items: center;
  display: flex;
  justify-content: space-between;
  gap: 12px;
}

.calendar-note-modal-head strong {
  color: var(--t1);
  font-size: 15px;
}

.calendar-note-modal-head button {
  align-items: center;
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 8px;
  color: var(--t2);
  cursor: pointer;
  display: inline-flex;
  height: 30px;
  justify-content: center;
  width: 30px;
}

.calendar-note-modal textarea {
  background: var(--surface);
  border: 1px solid var(--line-strong);
  border-radius: 10px;
  color: var(--t1);
  font: inherit;
  line-height: 1.45;
  min-height: 118px;
  padding: 10px 12px;
  resize: vertical;
  width: 100%;
}

.calendar-note-modal-actions {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
}

.calendar-note-modal-actions [data-calendar-note-delete] {
  margin-right: auto;
}

.calendar-row {
  min-height: 54px;
  position: relative;
}

.calendar-group-header-row {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 16px 0 4px 8px;
  user-select: none;
}

.calendar-group-header-row.dragging { opacity: .55; }
.calendar-group-header-row.drag-over { box-shadow: inset 0 2px 0 var(--ms-blue); }

.calendar-group-header-row {
  background: var(--surface-2);
  padding: 12px 0 6px 18px;
}

.calendar-group-label {
  color: var(--t3);
  font-size: 11px;
  font-style: italic;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.calendar-property-row {
  background: var(--surface);
  transition: background 0.1s ease;
}

.calendar-property-row.is-even .calendar-property-cell,
.calendar-property-row.is-even .calendar-day-cell {
  background-color: var(--surface-2);
}

.calendar-property-row.is-expanded .calendar-property-cell {
  box-shadow: inset 4px 0 0 var(--accent);
  background-color: var(--accent-soft) !important;
}

.calendar-property-row:hover .calendar-property-cell,
.calendar-property-row:hover .calendar-day-cell {
  background-color: var(--surface-3) !important;
}

.calendar-property-row.dragging {
  opacity: .55;
}

.calendar-property-row.drag-over .calendar-property-cell,
.calendar-property-row.drag-over .calendar-day-cell {
  box-shadow: inset 0 2px 0 var(--ms-blue);
}

.calendar-property-row.is-reorder-hidden .calendar-property-cell,
.calendar-property-row.is-reorder-hidden .calendar-day-cell,
.calendar-property-row.is-reorder-hidden .calendar-booking {
  opacity: .42;
}

.calendar-row-grip {
  align-items: center;
  background: var(--surface-3);
  border: 0;
  border-radius: 8px;
  color: var(--t2);
  display: inline-flex;
  flex: 0 0 auto;
  height: 28px;
  justify-content: center;
  width: 28px;
}

.calendar-row-grip {
  cursor: grab;
}

.calendar-row-grip:hover,
.calendar-reorder-eye:hover {
  background: var(--ms-blue-bg);
  color: var(--ms-blue);
}

.calendar-reorder-eye.is-hidden {
  color: var(--ms-text-3);
}

.calendar-reorder-actions {
  align-items: center;
  background: var(--surface);
  border: 1px solid var(--line-strong);
  border-radius: 14px;
  bottom: 18px;
  box-shadow: 0 12px 34px rgba(20, 28, 36, .14);
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  margin-top: 12px;
  padding: 10px;
  position: sticky;
  z-index: 580;
}

.calendar-reorder-actions[hidden] {
  display: none;
}

.calendar-setting-row {
  min-height: 34px;
}

.calendar-setting-label {
  min-height: 34px;
  font-weight: 600;
  font-size: 11px;
  color: var(--t3);
  background: var(--surface-2);
  padding-left: 20px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.calendar-empty-row {
  padding: 24px 20px;
  color: var(--t3);
  font-size: 13px;
  border-bottom: 1px solid var(--line);
}

.calendar-row-track {
  grid-column: 2 / -1;
  display: grid;
  grid-template-columns: repeat(var(--calendar-days), 1fr);
  height: 54px;
  align-content: center;
  grid-row: 1;
  position: relative;
}

.calendar-setting-track {
  grid-template-rows: 34px;
}

.calendar-day-cell {
  min-height: 54px;
  background: var(--surface);
  position: relative;
  z-index: 1;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-top: 9px;
}

.calendar-day-cell.is-booked {
  padding-top: 0;
}

.calendar-row .calendar-day-cell.is-weekend,
.calendar-property-row.is-even .calendar-day-cell.is-weekend {
  background-color: var(--surface-2);
}

.calendar-property-row:hover .calendar-day-cell.is-weekend {
  background-color: var(--surface-3) !important;
}

.calendar-row .calendar-day-cell.is-today,
.calendar-property-row.is-even .calendar-day-cell.is-today {
  background-color: rgba(var(--accent-rgb), 0.06);
}

.calendar-property-row:hover .calendar-day-cell.is-today {
  background-color: rgba(var(--accent-rgb), 0.12) !important;
}

.calendar-price-button {
  width: calc(100% - 10px);
  min-width: 0;
  height: 26px;
  border: 1px solid transparent;
  border-radius: 7px;
  background: transparent;
  color: var(--t3);        /* même couleur que .cal-inv-num */
  font: inherit;
  font-weight: 700;        /* même graisse que .cal-inv-num */
  font-size: 10px;
  cursor: pointer;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  transition: background 0.14s ease, border-color 0.14s ease, color 0.14s ease, box-shadow 0.14s ease;
  position: relative;
}

/* Badge inventaire disponible — petit chiffre en bas à droite de la cellule prix */
.cal-cell-inv-badge {
  position: absolute;
  bottom: 1px;
  right: 3px;
  font-size: 7px;
  font-weight: 800;
  color: var(--t3);
  opacity: 0.65;
  line-height: 1;
  pointer-events: none;
  letter-spacing: -0.01em;
}
.cal-cell-inv-badge.is-zero {
  color: #EF4444;
  opacity: 0.9;
}

.calendar-price-button:hover {
  background: var(--surface);
  border-color: var(--line-strong);
  color: var(--green);
  box-shadow: var(--shadow-1);
}

.calendar-price-button.is-readonly {
  cursor: default;
  pointer-events: none;
  display: flex;
  align-items: center;
  justify-content: center;
}

.calendar-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  width: 100%;
}

.calendar-title {
  font-size: 22px;
  font-weight: 800;
  color: var(--t1);
  line-height: 1;
  letter-spacing: -0.3px;
}

.calendar-subtoolbar {
  display: flex;
  align-items: center;
  min-height: 34px;
  margin-bottom: 10px;
}

.calendar-mode-actions {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

.calendar-icon-button {
  width: 38px;
  min-width: 38px;
  padding: 0;
  justify-content: center;
  border-radius: 8px;
}

.calendar-jump-picker .date-picker-panel {
  left: auto;
  right: 0;
}

/* Calendar page chrome (card, nav arrows, view tabs) */
.calendar-page-header {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  margin-bottom: 16px;
}

.calendar-page-title {
  display: none;
  font-size: 26px;
  font-weight: 700;
  color: var(--t1);
  letter-spacing: -0.025em;
  margin-bottom: 0;
}

.calendar-card {
  background: var(--surface);
  border-radius: 16px;
  border: 1px solid var(--line);
  box-shadow: var(--shadow-2);
  overflow: visible;
}

.calendar-card-inner {
  padding: 14px 20px 20px;
}

.calendar-card-toolbar {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 12px;
}

.calendar-card-month {
  font-size: 26px;
  font-weight: 700;
  color: var(--t1);
  letter-spacing: -0.025em;
  min-width: 110px;
  margin-right: 4px;
}

.calendar-arrow-btn {
  width: 32px;
  height: 32px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface);
  color: var(--t2);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  transition: background 0.14s ease, border-color 0.14s ease, color 0.14s ease;
}

.calendar-arrow-btn:hover {
  background: var(--surface-3);
  border-color: var(--line-strong);
  color: var(--t1);
}

.calendar-datepicker-btn {
  width: 32px;
  height: 32px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface);
  color: var(--t2);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  transition: background 0.14s ease, border-color 0.14s ease, color 0.14s ease;
}

.calendar-datepicker-btn:hover {
  background: var(--accent-soft);
  border-color: var(--accent-ring);
  color: var(--accent-2);
}

.calendar-sort-btn {
  min-height: 32px;
  padding: 0 13px;
  border: 1px solid var(--line);
  border-radius: 9px;
  background: var(--surface);
  font: inherit;
  font-size: 12.5px;
  font-weight: 600;
  color: var(--t2);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  box-shadow: var(--shadow-1);
  transition: background 0.14s ease, border-color 0.14s ease, color 0.14s ease;
}

.calendar-sort-btn small {
  color: var(--ms-text-2);
  font-size: 11px;
  font-weight: 600;
  margin-left: 2px;
}

.calendar-sort-btn:hover {
  background: var(--surface-3);
  border-color: var(--line-strong);
  color: var(--t1);
}

.calendar-sort-btn.active {
  background: var(--accent-soft);
  border-color: var(--accent-ring);
  color: var(--accent-2);
}

.calendar-sort-btn i {
  font-size: 11px;
  color: var(--t3);
}

.calendar-view-tabs {
  display: flex;
  align-items: center;
  gap: 2px;
  background: var(--surface-3);
  border-radius: 10px;
  padding: 3px;
}

.calendar-view-tab {
  height: 32px;
  padding: 0 16px;
  border: 0;
  border-radius: 8px;
  background: transparent;
  font: inherit;
  font-size: 12.5px;
  font-weight: 600;
  color: var(--t3);
  cursor: pointer;
  transition: background 0.15s ease, color 0.15s ease, box-shadow 0.15s ease;
}

.calendar-view-tab:hover {
  color: var(--t1);
}

.calendar-view-tab.active {
  background: var(--t1);
  color: var(--surface);
}

.calendar-booking {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 3;
  height: 36px;
  border-radius: 999px;
  color: #ffffff;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 10px 0 6px;
  font-family: inherit;
  font-weight: 600;
  font-size: 12px;
  letter-spacing: -0.01em;
  min-width: 0;
  overflow: hidden;
  white-space: nowrap;
  user-select: none;
  cursor: pointer;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.22), inset 0 -1px 0 rgba(0,0,0,0.12), 0 1px 2px rgba(12,12,16,0.10), 0 4px 10px -4px rgba(12,12,16,0.18);
  transition: filter 0.14s, transform 0.12s, box-shadow 0.12s;
}

.calendar-booking.clip-left  { border-top-left-radius: 0; border-bottom-left-radius: 0; }
.calendar-booking.clip-right { border-top-right-radius: 0; border-bottom-right-radius: 0; }

.calendar-today-line {
  position: absolute;
  top: 52px;
  bottom: 0;
  width: 1.5px;
  background: linear-gradient(180deg, var(--accent), rgba(var(--accent-rgb),0));
  pointer-events: none;
  z-index: 6;
}

.calendar-booking:hover {
  filter: brightness(1.05);
  transform: translateY(calc(-50% - 1px));
  z-index: 4;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.28), inset 0 -1px 0 rgba(0,0,0,0.14), 0 2px 4px rgba(12,12,16,0.14), 0 8px 18px -6px rgba(12,12,16,0.30);
}

.calendar-booking .source-logo {
  width: 18px;
  height: 18px;
  flex: 0 0 18px;
  border-radius: 4px;
  object-fit: contain;
  background: rgba(255,255,255,0.15);
}

.calendar-booking .source-logo-fallback {
  width: 18px;
  height: 18px;
  flex: 0 0 18px;
  border-radius: 50%;
  background: rgba(255,255,255,0.25);
  font-size: 9px;
  font-weight: 800;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.calendar-booking-name {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  flex: 1;
  min-width: 0;
}

.calendar-booking-meta {
  white-space: nowrap;
  font-size: 11px;
  font-weight: 500;
  opacity: 0.88;
  flex-shrink: 0;
  margin-left: 4px;
}

.calendar-booking-airbnb  { background: linear-gradient(180deg, #FF7A7E, #FF5A5F); }
.calendar-booking-booking  { background: linear-gradient(180deg, #1E5BB8, #003580); }
.calendar-booking-google   { background: linear-gradient(180deg, #5C9BFF, #3478F6); }
.calendar-booking-expedia  { background: linear-gradient(180deg, #FFE45C, #FFD230); color: #172033; }
.calendar-booking-vrbo,
.calendar-booking-abritel  { background: linear-gradient(180deg, #4C76D5, #245ABC); }
.calendar-booking-direct   { background: linear-gradient(180deg, #2A2A30, #0C0C10); }
.calendar-booking-beds24   { background: linear-gradient(180deg, #7E8EA1, #5E6E82); }
.calendar-booking-past     { background: linear-gradient(180deg, #3A3A40, #222222) !important; color: #ffffff !important; }


.form-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 20px;
}

.btn {
  height: 36px;
  border: 0;
  border-radius: 4px;
  padding: 0 16px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font: inherit;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
}

.btn-primary {
  background: var(--accent);
  color: #ffffff;
}

.btn-primary:hover {
  background: var(--accent-2);
}

.btn-secondary {
  background: var(--surface);
  border: 1px solid var(--line-strong);
  color: var(--t2);
}

.btn-secondary:hover {
  background: var(--surface-3);
}

.btn-danger {
  background: #c14343;
  color: #ffffff;
}

.btn-danger:hover {
  background: #a93636;
}

/* ─── Variantes ghost / tailles — compatibles light & dark ─── */
.btn-ghost {
  background: transparent;
  border: 1px solid var(--line-strong);
  color: var(--t2);
  transition: background 0.13s, color 0.13s, border-color 0.13s;
}
.btn-ghost:hover {
  background: var(--surface-2);
  color: var(--t1);
  border-color: var(--t3);
}
.btn-xs {
  height: 26px;
  padding: 0 10px;
  font-size: 11px;
  border-radius: 6px;
}
.btn-sm {
  height: 30px;
  padding: 0 12px;
  font-size: 12px;
  border-radius: 6px;
}

/* ─── Panneau latéral de détail réservation (calendrier) ─── */
.dashboard-side-panel {
  position: fixed;
  top: 0;
  right: 0;
  width: min(480px, 100vw);
  height: 100dvh;
  background: var(--surface);
  border-left: 1px solid var(--line);
  box-shadow: -8px 0 28px rgba(20,28,36,0.14);
  transform: translateX(100%);
  transition: transform 0.24s cubic-bezier(0.25,0.46,0.45,0.94);
  z-index: 700;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.dashboard-side-panel.open {
  transform: translateX(0);
}
.dashboard-side-head {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 20px;
  border-bottom: 1px solid var(--line);
  flex-shrink: 0;
  background: var(--surface);
}
.dashboard-side-back {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  border: 0;
  background: var(--surface-2);
  color: var(--t2);
  cursor: pointer;
  display: grid;
  place-items: center;
  font-size: 13px;
  flex-shrink: 0;
  transition: background 0.15s, color 0.15s;
}
.dashboard-side-back:hover {
  background: var(--surface-3);
  color: var(--t1);
}
/* Bouton ✕ côté droit — visible sur mobile, caché sur desktop */
.dashboard-side-close-x {
  width: 32px; height: 32px; border-radius: 8px;
  border: 1px solid var(--line-strong); background: var(--surface);
  color: var(--t3); cursor: pointer;
  display: none;                /* desktop : caché */
  place-items: center; font-size: 14px; flex-shrink: 0;
  transition: background .15s, color .15s;
}
.dashboard-side-close-x:hover { background: var(--surface-2); color: var(--t1); }
@media (max-width: 768px) {
  .dashboard-side-close-x { display: grid; }  /* mobile : visible */
  .dashboard-side-back     { display: none;  } /* mobile : on garde seulement le ✕ */
  /* Panneau détail : plein écran absolu sur mobile */
  .dashboard-side-panel {
    inset: 0;            /* top/right/bottom/left = 0 */
    width: 100%;
    height: 100%;
    max-height: none;
    border: none;
    border-radius: 0;
  }
}
.dashboard-side-title {
  flex: 1;
  min-width: 0;
}
.dashboard-side-title strong {
  display: block;
  font-size: 15px;
  font-weight: 700;
  color: var(--t1);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.dashboard-side-title span {
  display: block;
  font-size: 12px;
  color: var(--t3);
  margin-top: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.dashboard-side-body {
  flex: 1;
  overflow-y: auto;
  padding: 20px;
}

.detail-panel {
  position: fixed;
  top: 0;
  right: 0;
  width: min(460px, 100vw);
  height: 100dvh;
  background: #ffffff;
  border-left: 1px solid #e8e8ea;
  box-shadow: -12px 0 28px rgba(20, 28, 36, 0.14);
  transform: translateX(100%);
  transition: transform 0.22s ease;
  z-index: 700;
  display: flex;
  flex-direction: column;
}

.detail-panel.open {
  transform: translateX(0);
}

.detail-panel-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  padding: 20px;
  border-bottom: 1px solid #f0f0f2;
}

.detail-eyebrow {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #8a8f97;
  font-weight: 700;
  margin-bottom: 4px;
}

.detail-panel h2 {
  font-size: 18px;
  color: #3a3a3a;
}

.detail-close {
  width: 34px;
  height: 34px;
  border: 0;
  border-radius: 4px;
  background: #f5f6f8;
  color: #5a6068;
  cursor: pointer;
}

.detail-panel-body {
  padding: 20px;
  overflow-y: auto;
}

.detail-section {
  margin-bottom: 22px;
}

.detail-section h3 {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--t4);
  margin-bottom: 10px;
}

.detail-row {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding: 9px 0;
  border-bottom: 1px solid var(--line);
}

.detail-row span:first-child {
  color: var(--t3);
}

.detail-row span:last-child {
  color: var(--t1);
  font-weight: 600;
  text-align: right;
}

.detail-note {
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface-2);
  color: var(--t2);
  line-height: 1.6;
  white-space: pre-wrap;
}

.form-message {
  margin-top: 14px;
  font-weight: 600;
}

.form-message.error {
  color: #c14343;
}

.form-message.success {
  color: #23836e;
}

.cleaning-save-feedback {
  align-items: center;
  background: #f0fdf4;
  border: 1px solid #bbf7d0;
  border-radius: 12px;
  color: #15803d;
  display: flex;
  gap: 8px;
  margin: 0;
  padding: 11px 13px;
}

.form-hint {
  color: #8a8f97;
  font-size: 11px;
  line-height: 1.4;
  margin-top: 5px;
}

/* ============ AUTOMATED MESSAGES ============ */
.automation-grid {
  display: grid;
  grid-template-columns: var(--ms-list-panel-width) minmax(420px, 1fr);
  gap: 18px;
  align-items: start;
}

.automation-list {
  display: grid;
  gap: 0;
  padding: 0;
}

.automation-header-actions {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.automation-item {
  align-items: center;
  background: #ffffff;
  border: 0;
  border-bottom: 1px solid #f0f2f5;
  border-left: 3px solid transparent;
  cursor: pointer;
  display: grid;
  gap: 10px;
  grid-template-columns: minmax(0, 1fr) auto;
  padding: 14px 12px 14px 16px;
  transition: background .14s, border-color .14s;
  width: 100%;
}

.automation-item:hover,
.automation-item.active {
  background: #f7faff;
  border-left-color: var(--ms-blue);
}

.automation-main {
  flex: 1;
  min-width: 0;
}

.automation-title-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 5px;
  min-width: 0;
}

.automation-title-row strong {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: #2a3140;
}

.automation-status {
  flex: 0 0 auto;
  min-height: 22px;
  padding: 3px 8px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 700;
}

.automation-status.active {
  color: #126b5b;
  background: #d7f8ef;
}

.automation-status.draft {
  color: #7a5a10;
  background: #fff0c2;
}

.automation-meta {
  display: flex;
  align-items: center;
  gap: 6px;
  color: #7a8290;
  font-size: 12px;
  margin-top: 3px;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.automation-actions {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  justify-self: end;
}

.automation-new-row {
  align-items: center;
  background: #ffffff;
  border: 0;
  border-bottom: 1px solid #f0f2f5;
  color: var(--ms-blue);
  cursor: pointer;
  display: flex;
  font-family: inherit;
  font-size: 13px;
  font-weight: 700;
  gap: 10px;
  min-height: 48px;
  padding: 0 16px;
  text-align: left;
  width: 100%;
}

.automation-new-row i {
  align-items: center;
  background: var(--ms-blue-bg);
  border-radius: 9px;
  display: flex;
  height: 30px;
  justify-content: center;
  width: 30px;
}

.automation-new-row:hover {
  background: #f7faff;
}

.icon-btn {
  width: 34px;
  height: 34px;
  border: 1px solid #d9dde2;
  border-radius: 8px;
  background: #ffffff;
  color: #5a6068;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.icon-btn:hover {
  background: #e8f4fc;
  border-color: #9dcbee;
  color: #1770a8;
}

.icon-btn.danger:hover {
  background: #fff0f0;
  border-color: #efb4b4;
  color: #c14343;
}

.automation-check-list {
  position: relative;
}

.automation-check {
  min-height: 34px;
  border: 1px solid #eef0f2;
  border-radius: 8px;
  padding: 8px 10px;
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 600;
  color: #4a4a4a;
  background: #ffffff;
}

.automation-check input {
  width: auto;
}

.automation-check.is-group-covered {
  background: #f7faff;
  border-color: #d8e8f8;
  color: var(--ms-blue);
}

.automation-multiselect {
  position: relative;
}

.automation-multiselect-toggle {
  align-items: center;
  background: #ffffff;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  min-height: 42px;
  text-align: left;
  width: 100%;
}

.automation-multiselect-menu {
  background: #ffffff;
  border: 1px solid #d9dde2;
  border-radius: 12px;
  box-shadow: 0 16px 34px rgba(20, 28, 36, .14);
  display: none;
  gap: 8px;
  left: 0;
  padding: 10px;
  position: absolute;
  right: 0;
  top: calc(100% + 6px);
  z-index: 720;
}

.automation-multiselect.open .automation-multiselect-menu {
  display: grid;
}

.automation-property-menu {
  max-height: 360px;
  overflow: auto;
}

.automation-property-section {
  display: grid;
  gap: 7px;
}

.automation-property-section + .automation-property-section {
  border-top: 1px solid #eef0f3;
  padding-top: 9px;
}

.automation-property-section-title {
  color: var(--ms-text-2);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .03em;
  padding: 0 2px;
  text-transform: uppercase;
}

.automation-variables {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.automation-variables button {
  height: 30px;
  border: 1px solid #d9dde2;
  border-radius: 999px;
  background: #f7f9fb;
  color: #4f5968;
  padding: 0 10px;
  font: inherit;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
}

.automation-variables button:hover {
  background: #e8f4fc;
  border-color: #9dcbee;
  color: #1770a8;
}

.automation-language-tabs {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  padding: 3px;
  border-radius: 10px;
  background: #f0f2f6;
}

.automation-language-tabs button {
  height: 32px;
  border: 0;
  border-radius: 8px;
  background: transparent;
  padding: 0 14px;
  color: #7a8290;
  font: inherit;
  font-weight: 700;
  cursor: pointer;
}

.automation-language-tabs button.active {
  background: #ffffff;
  color: #2a3140;
  box-shadow: 0 1px 4px rgba(20, 28, 36, 0.10), 0 0 0 1px rgba(20, 28, 36, 0.06);
}

.automation-html-editor {
  border: 1px solid #d9dde2;
  border-radius: 10px;
  background: #ffffff;
  overflow: hidden;
}

.automation-html-toolbar {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 4px;
  padding: 8px;
  border-bottom: 1px solid #e4e8ec;
  background: #f7f9fb;
}

.automation-html-toolbar button {
  width: 34px;
  height: 32px;
  border: 1px solid transparent;
  border-radius: 7px;
  background: #ffffff;
  color: #344052;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background 0.14s ease, border-color 0.14s ease, color 0.14s ease;
}

.automation-html-toolbar button:hover {
  background: #e8f4fc;
  border-color: #9dcbee;
  color: #1770a8;
}

.automation-html-canvas {
  height: 220px;
  min-height: 140px;
  max-height: 640px;
  padding: 14px;
  color: #2a3140;
  line-height: 1.55;
  outline: none;
  overflow: auto;
  resize: vertical;
}

.automation-html-canvas:empty::before {
  content: "Rédige ton email ici...";
  color: #9aa0ab;
}

.automation-html-canvas h2 {
  font-size: 20px;
  margin: 0 0 10px;
  color: #2a3140;
}

.automation-html-canvas p {
  margin: 0 0 10px;
}

.automation-html-canvas ul,
.automation-html-canvas ol,
.automation-preview-body ul,
.automation-preview-body ol {
  margin: 8px 0 10px;
  padding-left: 24px;
  list-style-position: outside;
}

.automation-html-canvas li,
.automation-preview-body li {
  margin: 4px 0;
  padding-left: 2px;
}

.automation-html-canvas a {
  color: #1770a8;
  font-weight: 700;
}

.automation-selection-preview {
  background: rgba(33, 150, 212, 0.22);
  box-shadow: 0 0 0 2px rgba(33, 150, 212, 0.12);
  border-radius: 3px;
}

.automation-html-source {
  display: none;
  border: 0;
  border-top: 1px solid #e4e8ec;
  border-radius: 0;
  height: 220px;
  min-height: 140px;
  max-height: 640px;
  font-family: Consolas, "Courier New", monospace;
  overflow: auto;
  resize: vertical;
}

.automation-html-editor.source-open .automation-html-canvas {
  display: none;
}

.automation-html-editor.source-open .automation-html-source {
  display: block;
}

.automation-back-btn {
  align-items: center;
  background: #ffffff;
  border: 1px solid #d9dde2;
  border-radius: 8px;
  color: #5a6068;
  cursor: pointer;
  display: none;
  flex-shrink: 0;
  height: 30px;
  justify-content: center;
  padding: 0;
  width: 30px;
}

.automation-preview {
  margin-top: 16px;
  border: 1px solid #e4e8ec;
  border-radius: 12px;
  overflow: hidden;
  background: #fbfcfd;
}

.automation-preview-title {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border-bottom: 1px solid #e4e8ec;
  color: #344052;
  font-weight: 700;
}

.automation-preview-title span {
  margin-left: auto;
  padding: 3px 8px;
  border-radius: 999px;
  background: #eef6fb;
  color: #1770a8;
  font-size: 11px;
}

.automation-preview-body {
  min-height: 110px;
  padding: 14px;
  color: #3a3a3a;
  line-height: 1.55;
  white-space: normal;
}

.automation-preview-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.automation-preview-grid > div + div {
  border-left: 1px solid #e4e8ec;
}

.automation-preview-subtitle {
  padding: 9px 14px;
  border-bottom: 1px solid #e4e8ec;
  color: #7a8290;
  font-size: 12px;
  font-weight: 700;
}

.automation-preview-body p {
  margin: 0 0 10px;
}

.html-tool-modal {
  width: min(460px, calc(100vw - 32px));
}

.html-tool-body {
  display: grid;
  gap: 12px;
  margin-bottom: 18px;
}

.html-tool-field {
  display: grid;
  gap: 6px;
}

.html-tool-field label {
  font-weight: 700;
  color: #344052;
}

.html-tool-field input[type="text"],
.html-tool-field input[type="url"] {
  width: 100%;
  height: 40px;
  border: 1px solid #d9dde2;
  border-radius: 8px;
  padding: 0 12px;
  font: inherit;
  outline: none;
}

.html-tool-field input:focus {
  border-color: #2196d4;
  box-shadow: 0 0 0 3px rgba(33, 150, 212, 0.12);
}

.html-color-grid {
  display: grid;
  gap: 8px;
}

.html-color-auto-row,
.html-color-swatches {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
}

.html-color-option {
  width: 30px;
  height: 30px;
  border: 1px solid #d9dde2;
  border-radius: 999px;
  background: var(--color);
  cursor: pointer;
}

.html-color-option.active {
  box-shadow: 0 0 0 3px rgba(33, 150, 212, 0.18);
  border-color: #2196d4;
}

.html-color-auto {
  width: auto;
  min-width: 92px;
  padding: 0 14px;
  border-radius: 999px;
  background: #ffffff;
  color: #344052;
  font-size: 12px;
  font-weight: 700;
}

.empty-state {
  padding: 18px;
  border: 1px dashed #d9dde2;
  border-radius: 10px;
  color: #8a8f97;
  text-align: center;
}

/* ============ CLEANING ============ */


.cleaning-board {
  display: flex;
  flex: 1;
  flex-direction: column;
  min-height: 0;
  overflow: hidden;
}

/* Planning tab — scroll internally, with the same content padding as before */
[data-cleaning-panel-tab="planning"]:not([hidden]) {
  flex: 1;
  overflow-y: auto;
  padding: 20px 28px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}

/* Settings tab — fill full height, no padding (split panel handles its own layout) */
[data-cleaning-panel-tab="settings"]:not([hidden]) {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
  overflow: hidden;
}

[data-cleaning-settings] {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
  overflow: hidden;
}

/* Users tab — same pattern as settings */
[data-cleaning-panel-tab="users"]:not([hidden]) {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
  overflow: hidden;
}

[data-cleaning-users] {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
  overflow: hidden;
}

.cleaning-hero {
  align-items: center;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 16px;
  box-shadow: var(--shadow-2);
  display: flex;
  flex-shrink: 0;
  justify-content: space-between;
  margin: 20px 28px 0;
  padding: 22px 24px;
}

.cleaning-hero h1 {
  color: var(--t1);
  font-size: 28px;
  margin: 0 0 6px;
}

.cleaning-hero p {
  color: var(--t3);
  margin: 0;
}

.cleaning-summary {
  display: grid;
  grid-template-columns: repeat(4, minmax(76px, 1fr));
  gap: 10px;
}

.cleaning-summary div {
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 10px 12px;
  text-align: center;
}

.cleaning-summary strong {
  color: var(--t1);
  display: block;
  font-size: 22px;
}

.cleaning-summary span {
  color: var(--t3);
  font-size: 12px;
  font-weight: 700;
}

.cleaning-toolbar {
  align-items: end;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 14px;
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(3, minmax(0, 1fr)) auto;
  padding: 16px;
}

.cleaning-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.cleaning-tabs button {
  align-items: center;
  background: var(--surface);
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  color: var(--t2);
  cursor: pointer;
  display: inline-flex;
  font-weight: 800;
  gap: 8px;
  padding: 10px 14px;
}

.cleaning-tabs button.active {
  background: var(--t1);
  border-color: var(--t1);
  color: var(--surface);
}

.cleaning-tab-panel {
  /* overflow is handled per-tab via data-cleaning-panel-tab rules */
}

.menage-settings-ui {
  --ms-bg: var(--bg);
  --ms-surface: var(--surface);
  --ms-surface-2: var(--surface-2);
  --ms-border: var(--line-strong);
  --ms-border-light: var(--line);
  --ms-text-1: var(--t1);
  --ms-text-2: var(--t2);
  --ms-text-3: var(--t3);
  --ms-blue: var(--accent);
  --ms-blue-bg: var(--accent-soft);
  --ms-green: var(--green);
  --ms-orange: var(--accent);
  --ms-red: #ff3b30;
  color: var(--ms-text-1);
  display: grid;
  font-family: 'Inter Tight', -apple-system, BlinkMacSystemFont, sans-serif;
  gap: 14px;
  margin: 0 auto;
  max-width: 820px;
  padding-bottom: 78px;
}

.ms-prop-card,
.ms-card {
  background: var(--ms-surface);
  border: 1px solid var(--ms-border-light);
  border-radius: 16px;
  box-shadow: 0 2px 8px rgba(0,0,0,.07), 0 1px 2px rgba(0,0,0,.04);
  overflow: hidden;
}

.ms-prop-card {
  align-items: center;
  display: flex;
  gap: 14px;
  padding: 14px 18px;
}

.ms-prop-avatar {
  align-items: center;
  background: linear-gradient(135deg, #667eea, #764ba2);
  border-radius: 50%;
  color: #fff;
  display: flex;
  flex-shrink: 0;
  font-size: 16px;
  font-weight: 700;
  height: 40px;
  justify-content: center;
  overflow: hidden;
  width: 40px;
}

.ms-prop-avatar img {
  display: block;
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.ms-prop-name {
  font-size: 15px;
  font-weight: 600;
}

.ms-prop-meta {
  color: var(--ms-text-2);
  font-size: 12px;
  margin-top: 2px;
}

.ms-card-head {
  align-items: center;
  border-bottom: 1px solid var(--ms-border-light);
  display: flex;
  gap: 12px;
  padding: 14px 18px;
}

.ms-card-icon {
  align-items: center;
  background: var(--ms-blue-bg);
  border-radius: 8px;
  color: var(--ms-blue);
  display: flex;
  flex-shrink: 0;
  font-size: 13px;
  height: 30px;
  justify-content: center;
  width: 30px;
}

.ms-card-icon.orange { background: #fff3ec; color: var(--ms-orange); }
.ms-card-icon.green { background: #eafaf0; color: var(--ms-green); }
.ms-card-icon.blue { background: #e8f0fe; color: #1a73e8; }

.ms-card-title {
  flex: 1;
  font-size: 14px;
  font-weight: 600;
}

.ms-card-body {
  padding: 18px;
}

.topbar-profile-link,
.topbar-help,
.topbar-language {
  align-items: center;
  border-radius: 9px;
  color: #3a3a3a;
  display: inline-flex;
  gap: 8px;
  min-height: 34px;
  padding: 0 10px;
  text-decoration: none;
}

.topbar-profile-link:hover,
.topbar-help:hover,
.topbar-language:hover {
  background: #f4f6f8;
}

.topbar-profile-photo,
.topbar-profile-initials {
  border-radius: 50%;
  flex-shrink: 0;
  height: 28px;
  width: 28px;
}

.topbar-profile-photo {
  object-fit: cover;
}

.topbar-profile-initials {
  align-items: center;
  background: #e8f0fb;
  color: #0071e3;
  display: inline-flex;
  font-size: 11px;
  font-weight: 800;
  justify-content: center;
}

.topbar-language {
  padding: 0 7px;
}

.topbar-language img {
  border-radius: 50%;
  height: 22px;
  object-fit: cover;
  width: 22px;
}

.profile-photo-editor {
  align-items: start;
  display: grid;
  gap: 18px;
  grid-template-columns: 180px minmax(0, 1fr);
}

.profile-photo-preview {
  align-items: center;
  background: #eef2f7;
  border-radius: 50%;
  color: #0071e3;
  display: flex;
  font-size: 42px;
  font-weight: 800;
  height: 160px;
  justify-content: center;
  overflow: hidden;
  width: 160px;
}

.profile-photo-preview img {
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.profile-crop-box {
  display: grid;
  gap: 12px;
}

.profile-crop-stage {
  align-items: center;
  background: #f7f9fb;
  border: 1px solid var(--ms-border-light);
  border-radius: 14px;
  display: flex;
  justify-content: center;
  min-height: 240px;
  overflow: hidden;
}

.profile-crop-stage canvas {
  background: #ffffff;
  border-radius: 14px;
  max-width: 100%;
}

.profile-language-options {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.profile-language-option {
  align-items: center;
  border: 1px solid var(--ms-border-light);
  border-radius: 12px;
  cursor: pointer;
  display: flex;
  gap: 10px;
  padding: 12px;
}

.profile-language-option:has(input:checked) {
  background: var(--ms-blue-bg);
  border-color: var(--ms-blue);
}

.profile-language-option input {
  display: none;
}

.profile-language-option img {
  border-radius: 50%;
  height: 28px;
  object-fit: cover;
  width: 28px;
}

.profile-password-grid {
  align-items: start;
  display: grid;
  gap: 14px 16px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.profile-password-current {
  grid-row: span 2;
}

.account-badge-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 6px;
}

.account-badge {
  background: #eef2f7;
  border-radius: 999px;
  color: #536173;
  font-size: 11px;
  font-weight: 800;
  padding: 4px 8px;
}

.account-badge-admin { background: #e8f0fb; color: #0071e3; }
.account-badge-support { background: #fff3ec; color: #c05621; }
.account-badge-staff { background: #eafaf0; color: #15803d; }

@media (max-width: 720px) {
  .topbar-help span,
  .topbar-profile-link span,
  .topbar-actions .tag {
    display: none;
  }

  .profile-photo-editor,
  .profile-language-options,
  .profile-password-grid {
    grid-template-columns: 1fr;
  }

  .profile-password-current {
    grid-row: auto;
  }
}

.ms-label {
  color: var(--ms-text-3);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .4px;
  margin-bottom: 8px;
  text-transform: uppercase;
}

.ms-pill-group {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}

.ms-pill {
  align-items: center;
  background: var(--ms-surface-2);
  border: 1.5px solid var(--ms-border);
  border-radius: 999px;
  color: var(--ms-text-2);
  cursor: pointer;
  display: inline-flex;
  font-size: 13px;
  font-weight: 500;
  gap: 5px;
  padding: 7px 15px;
  transition: all .13s;
  user-select: none;
}

.ms-pill input {
  display: none;
}

.ms-pill:hover {
  border-color: var(--ms-blue);
  color: var(--ms-blue);
}

.ms-pill.on {
  background: var(--ms-blue);
  border-color: var(--ms-blue);
  color: #fff;
  font-weight: 600;
}

.ms-pill:has(input:checked) {
  background: var(--ms-blue);
  border-color: var(--ms-blue);
  color: #fff;
  font-weight: 600;
}

.ms-surface-field {
  margin-top: 16px;
  max-width: 220px;
}

.ms-field-input {
  border: 1px solid var(--ms-border);
  border-radius: 8px;
  color: var(--ms-text-1);
  font-family: inherit;
  font-size: 13px;
  outline: none;
  padding: 9px 12px;
  transition: border-color .13s, box-shadow .13s;
  width: 100%;
}

.ms-field-input:focus,
.ms-task-text:focus,
.ms-task-group-input:focus {
  border-color: var(--ms-blue);
  box-shadow: 0 0 0 3px var(--ms-blue-bg);
}

.ms-textarea {
  line-height: 1.5;
  min-height: 150px;
  resize: vertical;
}

.ms-stepper {
  align-items: center;
  border: 1px solid var(--ms-border);
  border-radius: 999px;
  display: inline-flex;
  overflow: hidden;
}

.ms-step-btn {
  align-items: center;
  background: transparent;
  border: none;
  color: var(--ms-blue);
  cursor: pointer;
  display: flex;
  font-size: 17px;
  font-weight: 300;
  height: 30px;
  justify-content: center;
  transition: background .12s;
  width: 30px;
}

.ms-step-btn:hover {
  background: var(--ms-blue-bg);
}

.ms-step-val {
  color: var(--ms-text-1);
  font-size: 13px;
  font-weight: 600;
  min-width: 26px;
  text-align: center;
}

.ms-room-grid {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
}

.ms-room-card {
  background: var(--ms-surface-2);
  border: 1px solid var(--ms-border-light);
  border-radius: 12px;
  padding: 14px;
}

.ms-room-card-head {
  align-items: center;
  display: flex;
  gap: 10px;
  justify-content: space-between;
  margin-bottom: 14px;
}

.ms-room-num {
  color: var(--ms-text-2);
  flex-shrink: 0;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .4px;
  text-transform: uppercase;
}

.ms-room-label-input {
  background: transparent;
  border: none;
  border-bottom: 1px dashed var(--ms-border-light);
  color: var(--ms-text-1);
  flex: 1;
  font-size: 13px;
  font-weight: 600;
  min-width: 0;
  outline: none;
  padding: 2px 4px;
}
.ms-room-label-input:focus {
  border-bottom-color: var(--ms-blue);
  background: var(--ms-blue-bg);
  border-radius: 4px 4px 0 0;
}
.ms-room-label-input::placeholder {
  color: var(--ms-text-3);
  font-weight: 400;
}

.ms-room-field {
  margin-bottom: 12px;
}

.ms-room-field:last-child {
  margin-bottom: 0;
}

.ms-name-input-wrap {
  align-items: center;
  display: flex;
  gap: 6px;
}

.ms-name-input-wrap .ms-field-input {
  flex: 1;
  min-width: 0;
}

.ms-save-name-btn {
  align-items: center;
  background: transparent;
  border: 1px solid var(--ms-border);
  border-radius: 8px;
  cursor: pointer;
  display: flex;
  flex-shrink: 0;
  font-size: 16px;
  height: 38px;
  justify-content: center;
  line-height: 1;
  padding: 0;
  transition: background .12s, border-color .12s;
  width: 38px;
}

.ms-save-name-btn:hover {
  background: var(--ms-blue-bg);
  border-color: var(--ms-blue);
}

.ms-row-between {
  align-items: center;
  display: flex;
  justify-content: space-between;
}

.ms-main-title {
  margin-bottom: 12px;
}

.ms-main-title strong,
.ms-main-bottom strong {
  display: block;
  font-size: 14px;
  font-weight: 600;
  margin-bottom: 6px;
}

.ms-main-title span {
  color: var(--ms-text-2);
  display: block;
  font-size: 12px;
}

.ms-toggle-row {
  align-items: center;
  border-bottom: 1px solid var(--ms-border-light);
  display: flex;
  justify-content: space-between;
  padding: 12px 0;
}

.ms-toggle-row:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.ms-toggle-label {
  color: var(--ms-text-1);
  font-size: 13px;
}

.ms-ios-sw {
  appearance: none;
  background: #c7c7cc;
  border-radius: 999px;
  cursor: pointer;
  flex-shrink: 0;
  height: 22px;
  outline: none;
  position: relative;
  transition: background .18s;
  width: 40px;
}

.ms-ios-sw::after {
  background: #fff;
  border-radius: 50%;
  box-shadow: 0 1px 4px rgba(0,0,0,.22);
  content: '';
  height: 18px;
  left: 2px;
  position: absolute;
  top: 2px;
  transition: transform .18s;
  width: 18px;
}

.ms-ios-sw:checked {
  background: var(--accent);
}

.ms-ios-sw:checked::after {
  transform: translateX(18px);
}

.ms-hr {
  border-top: 1px solid var(--ms-border-light);
  margin: 16px 0;
}

.ms-main-bottom {
  align-items: flex-start;
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
}

.ms-main-bottom > div:first-child {
  flex: 0 0 auto;
}

.ms-main-bottom > div:last-child {
  flex: 1;
  min-width: 180px;
}

.ms-annex-grid {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
}

.ms-annex-tile {
  align-items: center;
  background: var(--ms-surface-2);
  border: 1.5px solid var(--ms-border);
  border-radius: 12px;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  gap: 7px;
  padding: 14px 10px;
  text-align: center;
  transition: all .13s;
  user-select: none;
}

.ms-annex-tile:hover {
  border-color: var(--ms-blue);
}

.ms-annex-tile.on {
  background: var(--ms-blue-bg);
  border-color: var(--ms-blue);
}

.ms-annex-emoji {
  font-size: 22px;
}

.ms-annex-name {
  color: var(--ms-text-1);
  font-size: 12px;
  font-weight: 500;
  line-height: 1.3;
}

.ms-annex-counter {
  align-items: center;
  background: var(--ms-surface);
  border: 1px solid var(--ms-border);
  border-radius: 999px;
  display: none;
  overflow: hidden;
}

.ms-annex-tile.on .ms-annex-counter {
  display: flex;
}

/* Ancienne étiquette statique — conservée pour compatibilité */
.ms-task-group-label {
  align-items: center;
  color: var(--ms-text-2);
  display: flex;
  font-size: 11px;
  font-weight: 700;
  gap: 8px;
  letter-spacing: .5px;
  margin: 14px 0 7px;
  text-transform: uppercase;
}

.ms-task-group-label::before,
.ms-task-group-label::after {
  background: var(--ms-border-light);
  content: '';
  flex: 1;
  height: 1px;
}

/* ── Groupe de tâches éditable ─────────────────────────────── */
.ms-task-group-wrap {
  background: var(--surface);
  border: 1px solid var(--ms-border-light);
  border-radius: 16px;
  box-shadow: 0 2px 10px rgba(15, 23, 42, .04);
  margin-bottom: 14px;
  overflow: hidden;
  padding: 12px;
}

.ms-task-group-wrap + .ms-task-group-wrap {
  margin-top: 10px;
}

.ms-task-group-wrap.dragging {
  border-color: var(--ms-blue);
  box-shadow: 0 0 0 3px var(--ms-blue-bg), 0 10px 24px rgba(37, 99, 235, .12);
  opacity: .72;
  transform: scale(.995);
}

.ms-task-group-head {
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 12px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 10px;
  padding: 9px 10px;
}

.ms-task-group-title-row {
  align-items: center;
  display: flex;
  gap: 8px;
  min-width: 0;
  width: 100%;
}

.ms-task-group-selected-icon {
  align-items: center;
  background: #fff;
  border: 1px solid #dbeafe;
  border-radius: 9px;
  color: var(--ms-blue);
  display: inline-flex;
  flex: 0 0 30px;
  height: 30px;
  justify-content: center;
  width: 30px;
}

.ms-category-grip {
  color: var(--ms-text-3);
  display: none;
  font-size: 13px;
}

.cleaning-icon-picker {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  justify-content: flex-start;
  max-width: none;
  width: 100%;
}

.cleaning-icon-option {
  align-items: center;
  background: #fff;
  border: 1px solid var(--ms-border-light);
  border-radius: 9px;
  color: var(--ms-text-3);
  cursor: pointer;
  display: inline-flex;
  height: 30px;
  justify-content: center;
  padding: 0;
  width: 30px;
}

.cleaning-icon-option:hover,
.cleaning-icon-option.active {
  background: var(--ms-blue-bg);
  border-color: var(--ms-blue);
  color: var(--ms-blue);
}

.ms-task-group-label-input {
  background: transparent;
  border: none;
  border-bottom: 1.5px solid transparent;
  border-radius: 0;
  color: var(--ms-text-2);
  display: block;
  font-family: inherit;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .5px;
  margin-bottom: 0;
  outline: none;
  padding: 2px 4px;
  text-transform: uppercase;
  transition: border-color 0.15s;
  width: 100%;
}

.ms-task-group-label-input:focus {
  border-bottom-color: var(--ms-blue);
  color: var(--ms-text-1);
}

.ms-task-group-label-input::placeholder {
  color: var(--ms-text-3);
  font-weight: 400;
  text-transform: none;
}

/* ── Bouton photo par tâche ────────────────────────────────── */
.ms-task-photo-btn {
  align-items: center;
  border-radius: 4px;
  color: var(--ms-text-3);
  cursor: pointer;
  display: flex;
  flex-shrink: 0;
  font-size: 12px;
  padding: 4px 5px;
  transition: color 0.12s, background 0.12s;
}

.ms-task-photo-btn:hover {
  background: var(--ms-blue-bg);
  color: var(--ms-blue);
}

.ms-task-photo-btn.has-photo {
  color: var(--ms-blue);
}

/* ── Photo inline dans le flex row ─────────────────────────── */
/* Pas de div wrapper — img et bouton sont des flex items directs */
.ms-task-photo-img {
  border-radius: 6px;
  flex-shrink: 0;
  height: 40px;
  object-fit: cover;
  width: 60px;
}
.ms-task-photo-img[hidden] { display: none !important; }

.ms-task-photo-del {
  background: transparent;
  border: none;
  border-radius: 3px;
  color: var(--ms-text-3);
  cursor: pointer;
  flex-shrink: 0;
  font-size: 11px;
  padding: 3px 5px;
  transition: color 0.12s, background 0.12s;
}
.ms-task-photo-del[hidden] { display: none !important; }

.ms-task-photo-del:hover {
  background: #fff0f0;
  color: var(--ms-red);
}

/* Enveloppe : rectangle + bouton ✕ extérieur côte à côte */
.ms-task-item-wrap {
  align-items: center;
  display: flex;
  gap: 6px;
  margin-bottom: 5px;
}

.ms-task-item-wrap.dragging {
  opacity: .4;
}

.cleaning-generated-tasks.is-reordering .cleaning-generated-note,
.cleaning-generated-tasks.is-reordering .ms-task-item-wrap,
.cleaning-generated-tasks.is-reordering .ms-task-group-add,
.cleaning-generated-tasks.is-reordering .cleaning-photo-rule,
.cleaning-generated-tasks.is-reordering .cleaning-icon-picker {
  display: none;
}

.cleaning-generated-tasks.is-reordering .ms-task-group-wrap {
  cursor: grab;
  padding: 10px;
  transition: border-color .12s, box-shadow .12s, opacity .12s, transform .12s;
}

.cleaning-generated-tasks.is-reordering .ms-task-group-head {
  align-items: center;
  border-color: transparent;
  flex-direction: row;
  margin-bottom: 0;
}

.cleaning-generated-tasks.is-reordering .ms-category-grip {
  display: inline-flex;
}

.cleaning-generated-tasks.is-reordering .ms-task-group-label-input {
  pointer-events: none;
}

/* Rectangle de la tâche */
.ms-task-row {
  align-items: center;
  background: var(--ms-surface);
  border: 1px solid var(--ms-border-light);
  border-radius: 8px;
  cursor: grab;
  display: flex;
  flex: 1;
  flex-wrap: nowrap;   /* empêche tout retour à la ligne */
  gap: 8px;
  min-width: 0;
  padding: 6px 12px;   /* padding réduit — la photo de 40px donne la hauteur */
  transition: border-color .12s, box-shadow .12s;
}

.ms-task-row:hover {
  border-color: var(--ms-blue);
  box-shadow: 0 0 0 3px var(--ms-blue-bg);
}

/* Bouton ✕ de suppression de tâche — à l'extérieur du rectangle */
.ms-task-del-outer {
  background: transparent;
  border: none;
  border-radius: 50%;
  color: var(--ms-text-3);
  cursor: pointer;
  flex-shrink: 0;
  font-size: 12px;
  height: 24px;
  line-height: 1;
  padding: 0;
  transition: color .12s, background .12s;
  width: 24px;
}

.ms-task-del-outer:hover {
  background: #fff0f0;
  color: var(--ms-red);
}

.ms-task-grip {
  color: var(--ms-text-3);
  font-size: 11px;
}

.ms-task-text,
.ms-task-group-input {
  background: transparent;
  border: 1px solid transparent;
  border-radius: 6px;
  color: var(--ms-text-1);
  flex: 1 1 0;   /* rétrécit si besoin pour laisser la place à la photo */
  font-family: inherit;
  font-size: 13px;
  min-width: 60px;
  outline: none;
  overflow: hidden;
  padding: 7px 8px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ms-task-del {
  background: transparent;
  border: none;
  border-radius: 4px;
  color: var(--ms-text-3);
  cursor: pointer;
  font-size: 11px;
  padding: 3px 5px;
  transition: color .12s, background .12s;
}

.ms-task-del:hover {
  background: #fff0f0;
  color: var(--ms-red);
}

.ms-task-add {
  align-items: center;
  background: transparent;
  border: 1.5px dashed var(--ms-border);
  border-radius: 8px;
  color: var(--ms-text-3);
  cursor: pointer;
  display: flex;
  font-size: 12px;
  font-weight: 500;
  gap: 6px;
  justify-content: center;
  margin-bottom: 5px;
  padding: 7px;
  transition: all .12s;
  width: 100%;
}

.ms-task-add:hover {
  border-color: var(--ms-blue);
  color: var(--ms-blue);
}

.ms-btn-primary,
.ms-btn-ghost {
  align-items: center;
  border-radius: 980px;
  cursor: pointer;
  display: inline-flex;
  font-family: inherit;
  font-size: 13px;
  font-weight: 600;
  gap: 7px;
  padding: 9px 20px;
}

.ms-btn-primary {
  background: var(--accent);
  border: none;
  color: #fff;
}

.ms-btn-primary:hover {
  background: var(--accent-2);
}

.ms-btn-ghost {
  background: transparent;
  border: 1.5px solid var(--ms-border);
  color: var(--ms-text-2);
}

.ms-btn-ghost:hover {
  border-color: var(--ms-blue);
  color: var(--ms-blue);
}

.ms-btn-ghost.active {
  background: var(--ms-blue-bg);
  border-color: var(--ms-blue);
  color: var(--ms-blue);
}

/* Variante danger (supprimer) — dark mode friendly */
.ms-btn-ghost--danger {
  color: #dc2626;
  border-color: rgba(220, 38, 38, 0.35);
}

.ms-btn-ghost--danger:hover {
  background: rgba(220, 38, 38, 0.07);
  border-color: #dc2626;
  color: #dc2626;
}

[data-theme="dark"] .ms-btn-ghost--danger {
  color: #f87171;
  border-color: rgba(248, 113, 113, 0.3);
}

[data-theme="dark"] .ms-btn-ghost--danger:hover {
  background: rgba(248, 113, 113, 0.1);
  border-color: #f87171;
  color: #f87171;
}

/* Wrapper centré pour les panneaux détail (Logements, Planning, Utilisateurs) */
.ms-detail-content {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin: 0 auto;
  max-width: 820px;
  padding-bottom: 78px;
  width: 100%;
}

.ms-detail-content > form {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.ms-action-bar {
  align-items: center;
  background: rgba(255,255,255,.88);
  backdrop-filter: blur(14px);
  border: 1px solid var(--ms-border-light);
  border-radius: 999px;
  bottom: 18px;
  box-shadow: 0 10px 36px rgba(0,0,0,.08);
  display: flex;
  gap: 10px;
  justify-content: flex-end;
  margin-left: auto;
  padding: 8px;
  position: sticky;
  z-index: 20;
}
[data-theme="dark"] .ms-action-bar {
  background: rgba(22,22,26,.9);
  box-shadow: 0 10px 36px rgba(0,0,0,.4);
}

.ms-action-danger {
  border-color: #fca5a5;
  color: #dc2626;
  margin-right: auto;
}

.ms-action-danger:hover {
  border-color: #ef4444;
  color: #b91c1c;
}

.cleaning-layout {
  display: grid;
  gap: 18px;
  grid-template-columns: minmax(0, 1.35fr) minmax(340px, 0.65fr);
}

.cleaning-table-wrap {
  overflow-x: auto;
}

.cleaning-table {
  border-collapse: separate;
  border-spacing: 0;
  min-width: 920px;
  width: 100%;
}

.cleaning-table th,
.cleaning-table td {
  border-bottom: 1px solid var(--line);
  color: var(--t1);
  padding: 13px 14px;
  text-align: left;
  vertical-align: middle;
}

.cleaning-table th {
  background: var(--surface-2);
  color: var(--t3);
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.cleaning-row {
  cursor: pointer;
  transition: background 0.14s ease;
}

.cleaning-row:hover {
  background: var(--surface-2);
}

.cleaning-status,
.cleaning-urgency {
  border-radius: 999px;
  display: inline-flex;
  font-size: 12px;
  font-weight: 700;
  padding: 6px 10px;
}

.cleaning-status-todo { background: var(--surface-3); color: var(--t3); }
.cleaning-status-progress { background: var(--blue-soft); color: var(--blue); }
.cleaning-status-done { background: var(--green-soft); color: var(--green); }
.cleaning-status-review { background: var(--accent-soft); color: var(--accent-2); }
.cleaning-urgency { background: var(--surface-3); color: var(--t3); }

.cleaning-mobile-list {
  display: none;
}

.cleaning-task-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 14px;
  cursor: pointer;
  display: grid;
  gap: 8px;
  padding: 14px;
  transition: background 0.14s;
}

.cleaning-task-card:hover {
  background: var(--surface-2);
}

.cleaning-task-card > div {
  align-items: center;
  display: flex;
  gap: 10px;
  justify-content: space-between;
}

.cleaning-task-card p {
  color: var(--t3);
  margin: 0;
}

.cleaning-detail-grid {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-bottom: 18px;
}

.cleaning-detail-grid div {
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 12px;
}

.cleaning-detail-grid span {
  color: var(--t3);
  display: block;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: 5px;
}

.cleaning-detail-grid strong {
  color: var(--t1);
}

.cleaning-checklist {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.cleaning-room-list,
.cleaning-generated-tasks,
.cleaning-photo-inputs {
  display: grid;
  gap: 10px;
}

.cleaning-room-row {
  align-items: end;
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 12px;
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  padding: 12px;
}

.cleaning-annex-grid {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

/* .cleaning-generated-task est maintenant géré par .ms-task-row (display:flex)
   — on ne redéfinit ici que ce qui ne conflicte pas avec le layout flex */
.cleaning-generated-task {
  /* display et grid-template-columns supprimés : .ms-task-row prend le relais */
}

.cleaning-photo-row {
  display: grid;
  gap: 8px;
}

.cleaning-add-photo {
  margin-top: 8px;
  width: 42px;
}

.cleaning-consumables {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.cleaning-intro-block {
  background: #f7f9fb;
  border: 1px solid #e8edf2;
  border-radius: 12px;
  color: #536173;
  line-height: 1.55;
  margin-bottom: 16px;
  padding: 14px;
}

.cleaning-intro-block strong {
  color: #172033;
  display: block;
  margin-bottom: 8px;
}

.cleaning-intro-block p {
  margin: 0;
}

.cleaning-settings-form,
.cleaning-user-form {
  border-bottom: 1px solid #edf0f3;
  display: grid;
  gap: 14px;
  padding: 18px 0;
}

.cleaning-settings-form:first-child,
.cleaning-user-form:first-child {
  padding-top: 0;
}

.cleaning-settings-form:last-child,
.cleaning-user-form:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}

.cleaning-settings-head {
  align-items: center;
  display: flex;
  gap: 12px;
}

.cleaning-report-item {
  align-items: flex-start;
  gap: 14px;
}

.cleaning-reports-panel {
  display: flex;
  flex-direction: column;
  flex: 1;
  height: 100%;
  min-height: 0;
}

.cleaning-reports-panel[hidden] {
  display: none !important;
}

.cleaning-reports-panel > [data-cleaning-reports] {
  flex: 1;
  height: 100%;
  min-height: 0;
}

.cleaning-reports-layout {
  height: 100%;
  min-height: 0;
}

.cleaning-reports-list {
  background: #fff;
  height: 100%;
  min-width: var(--ms-list-panel-width);
}

.cleaning-reports-list .ms-settings-list-body {
  min-height: 0;
}

.cleaning-report-filter-head .automation-back-btn {
  display: inline-flex;
}


.cleaning-report-home-choices {
  display: grid;
  gap: 8px;
  padding: 12px 14px;
}

.cleaning-report-home-choice {
  align-items: center;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 9px;
  color: var(--t2);
  cursor: pointer;
  display: flex;
  font-family: inherit;
  font-size: 12.5px;
  font-weight: 500;
  gap: 9px;
  min-height: 46px;
  padding: 0 12px;
  text-align: left;
  transition: background 0.15s, color 0.15s;
  width: 100%;
}

.cleaning-report-home-choice:hover {
  background: var(--surface-2);
  color: var(--t1);
}

.cleaning-report-home-choice i {
  color: var(--t1);
  font-size: 12px;
  flex-shrink: 0;
}

.cleaning-report-home-choice:first-child i {
  color: var(--accent);
}

.cleaning-report-home-choice span {
  flex: 1;
  font-size: 12.5px;
  font-weight: 500;
}

.cleaning-report-home-choice strong {
  background: var(--surface-3);
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--t2);
  font-size: 11.5px;
  font-weight: 700;
  padding: 2px 8px;
}

.cleaning-report-filter-head {
  align-items: center;
  display: flex;
  gap: 10px;
  padding: 14px 14px 10px;
}

.cleaning-report-filter-head > div {
  display: grid;
  gap: 2px;
}

.cleaning-report-filter-head strong {
  color: #111827;
  font-size: 15px;
}

.cleaning-report-filter-head span {
  color: #64748b;
  font-size: 12px;
}

.cleaning-report-segments {
  display: grid;
  gap: 8px;
  padding: 14px;
}

.cleaning-report-segments button {
  align-items: center;
  background: #f7f8fa;
  border: 1px solid #e8ecf0;
  border-radius: 14px;
  color: #344054;
  cursor: pointer;
  display: flex;
  font: inherit;
  font-size: 13px;
  justify-content: space-between;
  min-height: 40px;
  padding: 0 12px;
  text-align: left;
}

.cleaning-report-segments button.active {
  background: #eef6ff;
  border-color: #b9ddff;
  color: #0f5fb8;
  font-weight: 700;
}

.cleaning-report-segments span {
  background: #fff;
  border-radius: 999px;
  color: inherit;
  font-size: 12px;
  font-weight: 700;
  min-width: 24px;
  padding: 3px 8px;
  text-align: center;
}

.cleaning-report-filters {
  border-bottom: 1px solid #f0f2f5;
  display: grid;
  gap: 9px;
  padding: 0 14px 14px;
}

.cleaning-report-search-wrap {
  position: relative;
}

.cleaning-report-search-wrap i {
  color: #aab0bb;
  font-size: 13px;
  left: 12px;
  pointer-events: none;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}

.cleaning-report-search-wrap input,
.cleaning-report-filters select,
.cleaning-report-date-grid input {
  background: #f7f8fa;
  border: 1px solid #e8ecf0;
  border-radius: 12px;
  box-sizing: border-box;
  color: #111827;
  font: inherit;
  font-size: 13px;
  height: 38px;
  outline: none;
  width: 100%;
}

.cleaning-report-date-row {
  gap: 8px;
}

.cleaning-report-date-row .date-picker {
  flex: 1 1 0;
}

.cleaning-report-search-wrap input {
  padding: 0 12px 0 34px;
}

.cleaning-report-filters select,
.cleaning-report-date-grid input {
  padding: 0 10px;
}

.cleaning-report-search-wrap input:focus,
.cleaning-report-filters select:focus,
.cleaning-report-date-grid input:focus {
  background: #fff;
  border-color: #9dcbee;
  box-shadow: 0 0 0 3px rgba(37, 99, 235, .10);
}

.cleaning-report-date-grid {
  display: grid;
  gap: 8px;
  grid-template-columns: 1fr 1fr;
}

.cleaning-report-date-grid label {
  color: #64748b;
  display: grid;
  font-size: 11px;
  font-weight: 700;
  gap: 4px;
}

.cleaning-report-list-item {
  background: transparent;
  border-left: 0;
  border-right: 0;
  border-top: 0;
  cursor: pointer;
  text-align: left;
  width: 100%;
}

.cleaning-report-list-item.is-selected {
  background: var(--accent-soft);
  border-left-color: var(--accent);
}

.cleaning-report-check-wrap {
  margin-right: -4px;
}

.cleaning-report-list-icon {
  align-items: center;
  background: #fff7ed;
  border-radius: 12px;
  color: #ea580c;
  display: inline-flex;
  flex: 0 0 38px;
  height: 38px;
  justify-content: center;
  width: 38px;
}

.cleaning-report-list-icon.has-photo {
  background: #eff6ff;
  color: #2563eb;
}

.cleaning-report-list-meta {
  color: #94a3b8;
  font-size: 11px;
  line-height: 1.35;
  margin-top: 2px;
}

.cleaning-report-list-empty {
  margin: 16px;
}

.cleaning-report-main {
  display: flex;
  flex: 1 1 auto;
  flex-direction: column;
  min-width: 0;
}

.cleaning-report-photos {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}

.cleaning-report-photos img {
  border-radius: 8px;
  height: 72px;
  object-fit: cover;
  width: 72px;
}

.cleaning-report-photo-btn {
  background: transparent;
  border: 0;
  cursor: pointer;
  padding: 0;
}

.cleaning-report-detail .ms-prop-card {
  margin-bottom: 16px;
}

.cleaning-report-description,
.cleaning-report-alert-text {
  color: #111827;
  line-height: 1.5;
  margin: 0;
}

.cleaning-report-alert {
  background: #fff8ed;
  border: 1px solid #fed7aa;
  border-radius: 14px;
  display: grid;
  gap: 6px;
  padding: 14px;
}

.cleaning-report-alert-title {
  color: #9a3412;
  font-size: 13px;
  font-weight: 800;
}

.cleaning-report-alert-text {
  font-size: 14px;
}

.cleaning-report-empty-photo {
  margin-top: 12px;
}

.cleaning-report-followup {
  background: #f8fafc;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 12px;
  padding: 10px;
}

.cleaning-report-followup label {
  color: #64748b;
  font-size: 12px;
  font-weight: 600;
}

.cleaning-report-followup textarea {
  background: #fff;
  border: 1px solid #dbe3ef;
  border-radius: 10px;
  color: #111827;
  font: inherit;
  min-height: 74px;
  padding: 10px 12px;
  resize: vertical;
  width: 100%;
}

.cleaning-report-followup textarea:focus {
  border-color: #2563eb;
  box-shadow: 0 0 0 3px rgba(37, 99, 235, .12);
  outline: none;
}

.cleaning-report-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-end;
}

.cleaning-report-actions .ms-btn-primary,
.cleaning-report-actions .ms-btn-ghost {
  min-height: 38px;
}

.cleaning-report-actions .ms-btn-primary.is-muted {
  background: #eef2f7;
  color: #334155;
}

@media (max-width: 640px) {
  .cleaning-report-item {
    flex-direction: column;
  }

  .cleaning-report-item .cleaning-status {
    align-self: flex-start;
  }

  .cleaning-report-actions {
    justify-content: flex-end;
  }

  .cleaning-report-actions .ms-btn-primary,
  .cleaning-report-actions .ms-btn-ghost {
    flex: 0 1 auto;
    justify-content: center;
    min-width: 0;
    padding-left: 14px;
    padding-right: 14px;
    white-space: nowrap;
  }
}

@media (max-width: 768px) {
  .cleaning-reports-panel {
    height: auto;
  }

  .ms-settings-layout.cleaning-reports-layout {
    height: auto;
    min-height: 0;
    overflow: visible;
  }

  .cleaning-reports-layout .cleaning-reports-list {
    height: auto;
    max-height: none;
    min-width: 0;
    overflow: visible;
  }

  .cleaning-reports-list .ms-settings-list-body {
    overflow: visible;
  }
}

/* ============ CALENDAR MONTHLY VIEW ============ */
.cal-monthly-view {
  display: flex;
  gap: 0;
  min-width: 0;
}

.cal-month-prop-selector {
  display: flex;
  flex-direction: column;
  gap: 6px;
  flex: 0 0 58px;
  border-right: 1px solid var(--line);
  padding: 0 10px 0 0;
  margin-right: 14px;
}

.cal-month-prop-btn {
  border: 0;
  background: transparent;
  padding: 5px 0;
  cursor: pointer;
  border-radius: 10px;
  opacity: 0.4;
  transition: opacity 0.15s ease;
  display: flex;
  align-items: center;
  justify-content: center;
}

.cal-month-prop-btn:hover {
  opacity: 0.7;
}

.cal-month-prop-btn.active {
  opacity: 1;
}

.cal-month-photo {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  object-fit: cover;
  display: block;
}

.cal-month-photo.property-photo-fallback {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  background: var(--surface-3);
  font-size: 15px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--t2);
}

.cal-monthly-right {
  flex: 1;
  min-width: 0;
  overflow: hidden;
}

.cal-month-main {
  min-width: 0;
}

/* Hidden on desktop — toolbar already shows month, no property label needed */
.cal-monthly-prop-label,
.cal-monthly-month-header {
  display: none;
}

/* Monthly month name is always "current" (blue) */
.cal-monthly-month-name {
  color: var(--blue);
}

.cal-month-day-header {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 5px;
  padding-bottom: 6px;
  background: transparent;
  border: none;
}

.cal-month-head-cell {
  text-align: center;
  padding: 4px 0;
  font-size: 12px;
  font-weight: 500;
  color: var(--t3);
  letter-spacing: 0;
}

.cal-month-week {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 5px;
  position: relative;
  margin-bottom: 5px;
}

.cal-month-day {
  border: 1.5px solid var(--line);
  border-radius: 12px;
  padding: 10px 12px 8px;
  min-height: 96px;
  background: var(--surface);
  cursor: pointer;
  transition: border-color 0.12s ease, box-shadow 0.12s ease;
  position: relative;
}

.cal-month-day:hover {
  border-color: var(--line-strong);
  box-shadow: 0 2px 8px rgba(20, 28, 36, 0.07);
}

.cal-month-day.is-other-month {
  background: var(--surface-2);
  border-color: var(--line);
  cursor: default;
  pointer-events: none;
  box-shadow: none;
  opacity: 0.35;
}

.cal-month-booking.is-other-month-bar {
  opacity: 0.2;
}

/* Reorder list in monthly view */
.cal-month-prop-selector.is-reordering {
  flex: 0 0 180px;
  gap: 4px;
}

.cal-month-reorder-item {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 8px;
  border-radius: 8px;
  background: var(--surface-2);
  border: 1px solid var(--line);
}

.cal-month-reorder-item.dragging {
  opacity: 0.4;
  background: var(--blue-soft);
}

.cal-month-reorder-item.is-reorder-hidden {
  opacity: 0.4;
}

.cal-month-reorder-grip {
  cursor: grab;
  color: var(--t3);
  margin-left: auto;
  font-size: 13px;
  padding: 2px 4px;
}

.cal-month-reorder-eye {
  border: 0;
  background: none;
  cursor: pointer;
  color: var(--t3);
  padding: 2px;
  border-radius: 4px;
  font-size: 12px;
  flex-shrink: 0;
}

.cal-month-reorder-eye:hover {
  color: var(--t1);
}

.cal-month-reorder-name {
  font-size: 11px;
  font-weight: 600;
  color: var(--t1);
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
}

.cal-month-day.is-weekend {
  background: var(--surface-2);
}

.cal-month-day.is-weekend:hover {
  background: var(--surface-3);
}

.cal-month-day.is-booked {
  cursor: default;
}
.cal-month-day.is-blocked {
  background: repeating-linear-gradient(
    45deg,
    rgba(180,60,40,0.07),
    rgba(180,60,40,0.07) 3px,
    transparent 3px,
    transparent 7px
  );
  border: 1px solid rgba(180,60,40,0.18) !important;
  cursor: pointer;
}
.cal-month-day-blocked {
  display: block; font-size: 9.5px; font-weight: 600;
  color: rgba(180,60,40,0.75); margin-top: 3px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}

.cal-month-day-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  font-size: 15px;
  font-weight: 700;
  color: var(--t1);
  border-radius: 50%;
}

.cal-month-day.is-today .cal-month-day-num {
  background: var(--blue);
  color: #ffffff;
}

.cal-month-day.is-other-month .cal-month-day-num {
  color: transparent;
}

.cal-month-day-price {
  display: block;
  font-size: 12px;
  font-weight: 500;
  color: var(--t3);
  margin-top: 5px;
}

/* gap constant used in JS: MONTH_GAP = 5 (must match gap: 5px above) */
.cal-month-booking {
  position: absolute;
  top: 44px;
  height: 34px;
  border-radius: 34px;
  color: #ffffff;
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 0 10px 0 5px;
  font-size: 13px;
  font-weight: 600;
  overflow: hidden;
  cursor: pointer;
  z-index: 2;
  transition: filter 0.15s ease;
}

.cal-month-booking:hover {
  filter: brightness(1.1);
}

.cal-month-booking .source-logo {
  width: 18px;
  height: 18px;
  flex: 0 0 18px;
  border-radius: 4px;
  object-fit: contain;
  background: rgba(255,255,255,0.15);
}

.cal-month-booking .source-logo-fallback {
  width: 18px;
  height: 18px;
  flex: 0 0 18px;
  border-radius: 50%;
  background: rgba(255,255,255,0.25);
  font-size: 9px;
  font-weight: 800;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.cal-month-booking-name {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  flex: 1;
  min-width: 0;
}

.cal-month-booking-meta {
  white-space: nowrap;
  font-size: 11px;
  font-weight: 500;
  opacity: 0.88;
  flex-shrink: 0;
  margin-left: 4px;
}

/* Expedia yellow = dark text */
.cal-month-booking.calendar-booking-expedia {
  color: #172033;
}

/* ============ CALENDAR ANNUAL VIEW ============ */
.cal-annual-outer {
  display: flex;
  gap: 0;
  min-width: 0;
}

.cal-annual-right {
  flex: 1;
  min-width: 0;
}

.cal-annual-prop-label {
  font-size: 13px;
  font-weight: 700;
  color: var(--t1);
  padding: 0 0 10px 2px;
}

.cal-annual-view {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  padding: 0 0 8px;
  min-width: 0;
}

.cal-annual-month {
  background: var(--surface);
  border: 1.5px solid var(--line);
  border-radius: 14px;
  padding: 12px 10px 10px;
  box-shadow: 0 2px 6px rgba(20, 28, 36, 0.04);
  transition: box-shadow 0.15s ease;
  min-width: 0;
  overflow: hidden;
}

.cal-annual-month:hover {
  box-shadow: 0 6px 18px rgba(20, 28, 36, 0.08);
}

.cal-annual-month.is-current {
  border-color: var(--blue);
  background: var(--blue-soft);
}

.cal-annual-month-header {
  margin-bottom: 6px;
}

.cal-annual-month-name {
  font-size: 12px;
  font-weight: 800;
  color: var(--t1);
  letter-spacing: -0.1px;
}

.cal-annual-month.is-current .cal-annual-month-name {
  color: var(--blue);
}

/* ── Mini overrides: scale down monthly cells inside annual cards ── */
.cal-annual-month .cal-month-day-header {
  gap: 2px;
  padding-bottom: 4px;
}

.cal-annual-month .cal-month-head-cell {
  font-size: 9px;
  padding: 2px 0;
}

.cal-annual-month .cal-month-week {
  gap: 2px;
  margin-bottom: 2px;
}

.cal-annual-month .cal-month-day {
  min-height: 46px;
  padding: 3px 4px 2px;
  border-radius: 6px;
  border-width: 1px;
}

.cal-annual-month .cal-month-day-num {
  width: 18px;
  height: 18px;
  font-size: 9px;
  font-weight: 700;
}

.cal-annual-month .cal-month-day-price {
  font-size: 8px;
  margin-top: 1px;
}

.cal-annual-month .cal-month-booking {
  top: 22px;
  height: 16px;
  font-size: 8px;
  padding: 0 4px 0 2px;
  gap: 2px;
  border-radius: 16px;
}

.cal-annual-month .cal-month-booking .source-logo,
.cal-annual-month .cal-month-booking .source-logo-fallback {
  width: 11px;
  height: 11px;
  flex: 0 0 11px;
}

.cal-annual-month .cal-month-booking-meta {
  display: none;
}

/* ============ CALENDAR MODAL ============ */
.cal-modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(20, 28, 36, 0.36);
  z-index: 900;
  display: flex;
  align-items: center;
  justify-content: center;
}

.cal-modal-backdrop[hidden] {
  display: none;
}

.cal-modal {
  background: var(--surface);
  border-radius: 14px;
  box-shadow: 0 8px 16px rgba(0,0,0,0.12), 0 24px 56px rgba(0,0,0,0.18);
  border: 1px solid var(--line);
  padding: 24px;
  width: min(400px, calc(100vw - 32px));
  animation: cal-modal-in 0.16s ease;
}

@keyframes cal-modal-in {
  from { opacity: 0; transform: scale(0.96) translateY(6px); }
  to   { opacity: 1; transform: scale(1) translateY(0); }
}

.cal-modal-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--t1);
  margin-bottom: 14px;
  line-height: 1.4;
}

.cal-modal-message {
  font-size: 14px;
  color: var(--t2);
  margin-bottom: 20px;
  line-height: 1.5;
}

.cal-modal-input {
  width: 100%;
  height: 40px;
  border: 1px solid var(--line-strong);
  border-radius: 8px;
  padding: 0 12px;
  font: inherit;
  font-size: 14px;
  color: var(--t1);
  background: var(--surface-2);
  outline: none;
  margin-bottom: 18px;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.cal-modal-input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-ring);
}

.cleaning-confirm-modal .cal-modal-title {
  margin-bottom: 8px;
}

.cleaning-confirm-textarea {
  min-height: 110px;
  resize: vertical;
}

.cal-modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}

/* ============ NOTE TOOLTIP ============ */
.calendar-note-tooltip {
  position: absolute;
  z-index: 600;
  background: var(--t1);
  color: var(--surface);
  font-size: 12px;
  font-weight: 500;
  line-height: 1.5;
  padding: 7px 12px;
  border-radius: 8px;
  box-shadow: 0 4px 14px rgba(20, 28, 36, 0.22);
  pointer-events: none;
  white-space: pre-wrap;
  max-width: 260px;
  transform: translateX(-50%);
}

.calendar-note-tooltip[hidden] {
  display: none;
}

body.sidebar-collapsed .sidebar {
  width: 0;
  min-width: 0;
  padding: 0;
  border-right: 0;
  overflow: hidden;
}

.mobile-overlay {
  display: none;
}

@media (max-width: 860px) {
  body.sidebar-open {
    overflow: hidden;
  }

  .sidebar {
    position: fixed;
    left: 0;
    top: 0;
    height: 100dvh;
    width: 236px;
    transform: translateX(-100%);
    box-shadow: 4px 0 18px rgba(0,0,0,0.12);
    overflow-y: auto;
  }

  body.sidebar-open .sidebar {
    transform: translateX(0);
  }

  body.sidebar-open .mobile-overlay {
    display: block;
    position: fixed;
    inset: 0;
    background: rgba(20, 28, 36, 0.36);
    z-index: 250;
  }

  .topbar {
    flex-wrap: wrap;
    height: auto;
    min-height: 56px;
    padding: 10px 14px;
  }

  .content {
    padding: 10px 8px;
  }

  .grid,
  .form-grid {
    grid-template-columns: 1fr;
  }

  .automation-time-row {
    grid-template-columns: 1fr;
  }

  .cleaning-checklist,
  .cleaning-detail-grid,
  .cleaning-consumables,
  .cleaning-room-row,
  .cleaning-annex-grid {
    grid-template-columns: 1fr;
  }

  .menage-settings-ui {
    max-width: none;
  }

  .ms-room-grid,
  .ms-annex-grid {
    grid-template-columns: 1fr;
  }

  .ms-card-head {
    align-items: flex-start;
    flex-wrap: wrap;
  }

  .ms-main-bottom {
    display: grid;
  }

  .ms-action-bar {
    border-radius: 14px;
    bottom: 12px;
    flex-wrap: wrap;
    justify-content: stretch;
    position: sticky;
  }

  .ms-action-bar > * {
    flex: 1 1 auto;
    text-align: center;
  }

  .cleaning-hero {
    align-items: stretch;
    flex-direction: column;
    gap: 14px;
    padding: 18px;
  }

  .cleaning-summary {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .cleaning-toolbar {
    grid-template-columns: 1fr;
  }

  .cleaning-layout {
    display: block;
  }

  .cleaning-table-wrap {
    display: none;
  }

  .cleaning-mobile-list {
    display: grid;
    gap: 10px;
  }

  .cleaning-detail-card {
    display: none;
  }

  .cleaning-layout[data-cleaning-panel="detail"] .cleaning-list-card {
    display: none;
  }

  .cleaning-layout[data-cleaning-panel="detail"] .cleaning-detail-card {
    display: block;
  }

  .filters-row {
    align-items: stretch;
    flex-direction: column;
  }

  .filters-row .form-field,
  .filter-dropdown,
  .filter-dropdown .btn,
  .filter-clear {
    width: 100%;
  }

  .filter-menu,
  .date-picker-panel {
    width: min(292px, calc(100vw - 48px));
  }

  .reservations-table-wrap {
    display: none;
  }

  .reservations-mobile-list {
    display: grid;
    gap: 10px;
    margin-top: 12px;
  }

  .calendar-card-inner {
    padding: 10px 12px 16px;
  }

  .calendar-planner {
    overflow: hidden;
  }

  .calendar-header-row,
  .calendar-row {
    /* 160px = même valeur que calendar-property-group à ≤860px → colonnes alignées */
    grid-template-columns: 160px repeat(var(--calendar-days), minmax(26px, 1fr));
  }

  .calendar-row-track {
    grid-template-columns: repeat(var(--calendar-days), minmax(26px, 1fr));
  }

  .calendar-property-head,
  .calendar-property-cell {
    padding: 7px;
  }

  .calendar-property-photo {
    width: 44px;
    /* height gérée par align-self: stretch dans .cal-prop-full-id */
  }

  .calendar-property-name {
    font-size: 14px;
    max-width: 100%;
  }

  .calendar-property-row.is-reordering .calendar-property-photo {
    display: none;
  }

  .calendar-row-grip {
    height: 24px;
    width: 24px;
  }

  .calendar-property-meta {
    display: none;
  }

  .calendar-day-head {
    padding: 4px 2px;
    min-height: 38px;
  }

  .calendar-day-head .cal-day-abbr {
    font-size: 9px;
  }

  .calendar-day-head .cal-day-num {
    width: 24px;
    height: 24px;
    font-size: 13px;
  }

  .calendar-booking {
    height: 26px;
    padding: 0 6px 0 4px;
    gap: 4px;
    border-radius: 6px;
    justify-content: flex-start;
    min-width: 0;
  }

  .calendar-booking-name {
    display: block;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 10px;
    font-weight: 700;
  }

  .calendar-booking .source-logo,
  .calendar-booking .source-logo-fallback {
    width: 16px;
    height: 16px;
    flex: 0 0 16px;
  }

  .calendar-booking-meta {
    display: none;
  }

  .calendar-toolbar {
    align-items: flex-start;
  }

  .calendar-title {
    font-size: 20px;
  }

  .calendar-mode-actions {
    justify-content: flex-end;
    flex-wrap: nowrap;
  }

  .calendar-mode-actions .btn {
    width: 36px;
    min-width: 36px;
    padding: 0;
  }

  .property-list-item {
    align-items: flex-start;
    flex-wrap: wrap;
  }

  .property-list-item .btn {
    width: 100%;
    justify-content: center;
  }

  .property-sort-menu {
    left: 12px;
    right: 12px;
    width: auto;
  }

  /* Monthly view mobile — card style matching annual */
  .cal-monthly-view {
    flex-direction: column;
  }

  .cal-monthly-view .cal-month-prop-selector {
    flex-direction: row;
    flex-wrap: wrap;
    border-right: none;
    border-bottom: none;
    flex: 0 0 auto;
    margin-right: 0;
    margin-bottom: 8px;
    padding: 0;
    width: 100%;
  }

  .cal-monthly-prop-label {
    display: block;
  }

  .cal-monthly-month-header {
    display: block;
  }

  .cal-monthly-view .cal-month-main {
    background: #f7fbff;
    border: 1.5px solid #b8d8f0;
    border-radius: 14px;
    padding: 12px 10px 10px;
    box-shadow: 0 2px 6px rgba(20, 28, 36, 0.04);
    overflow: hidden;
  }

  .cal-month-day {
    min-height: 60px;
    padding: 5px 5px 3px;
    border-radius: 8px;
  }

  .cal-month-day-num {
    width: 22px;
    height: 22px;
    font-size: 11px;
  }

  .cal-month-day-price {
    font-size: 10px;
  }

  .cal-month-booking {
    top: 30px;
    height: 24px;
    font-size: 11px;
  }

  .cal-month-booking-meta {
    display: none;
  }

  /* Annual view tablet — 2 cols */
  .cal-annual-view {
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
  }

  .cal-annual-outer {
    flex-direction: column;
  }

  .cal-month-prop-selector {
    flex-direction: row;
    flex-wrap: wrap;
    width: 100%;
    padding: 0 0 8px;
  }

  .property-sort-row {
    grid-template-columns: 28px 28px 38px minmax(0, 1fr) 34px;
  }

  .property-sort-drag {
    display: none;
  }

  .property-sort-mobile-move {
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  .calendar-property-menu-button {
    width: 22px;
    height: 28px;
  }

  .calendar-day-cell {
    padding-top: 5px;
  }

  .calendar-price-button {
    width: calc(100% - 4px);
    height: 22px;
    font-size: 9px;
    padding: 0 2px;
  }

  .calendar-setting-label {
    padding-left: 8px;
  }
}

@media (max-width: 560px) {
  /* Annual — 1 col, cells scale back up to full monthly size */
  .cal-annual-view {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .cal-annual-month .cal-month-day {
    min-height: 72px;
    padding: 6px 7px 5px;
    border-radius: 10px;
    border-width: 1.5px;
  }

  .cal-annual-month .cal-month-day-num {
    width: 26px;
    height: 26px;
    font-size: 13px;
  }

  .cal-annual-month .cal-month-day-price {
    font-size: 11px;
    margin-top: 3px;
  }

  .cal-annual-month .cal-month-day-header {
    gap: 5px;
  }

  .cal-annual-month .cal-month-head-cell {
    font-size: 11px;
    padding: 4px 0;
  }

  .cal-annual-month .cal-month-week {
    gap: 5px;
    margin-bottom: 5px;
  }

  .cal-annual-month .cal-month-booking {
    top: 38px;
    height: 28px;
    font-size: 12px;
    padding: 0 8px 0 3px;
    gap: 5px;
    border-radius: 28px;
  }

  .cal-annual-month .cal-month-booking .source-logo,
  .cal-annual-month .cal-month-booking .source-logo-fallback {
    width: 16px;
    height: 16px;
    flex: 0 0 16px;
  }

  /* Monthly — match annual cell sizing on small phones */
  .cal-monthly-view .cal-month-day {
    min-height: 72px;
    padding: 6px 7px 5px;
    border-radius: 10px;
    border-width: 1.5px;
  }

  .cal-monthly-view .cal-month-day-num {
    width: 26px;
    height: 26px;
    font-size: 13px;
  }

  .cal-monthly-view .cal-month-day-price {
    font-size: 11px;
    margin-top: 3px;
  }

  .cal-monthly-view .cal-month-week {
    gap: 5px;
    margin-bottom: 5px;
  }

  .cal-monthly-view .cal-month-day-header {
    gap: 5px;
  }

  .cal-monthly-view .cal-month-head-cell {
    font-size: 11px;
    padding: 4px 0;
  }

  .cal-monthly-view .cal-month-booking {
    top: 38px;
    height: 28px;
    font-size: 12px;
    padding: 0 8px 0 3px;
    gap: 5px;
    border-radius: 28px;
  }

  .cal-monthly-view .cal-month-booking .source-logo,
  .cal-monthly-view .cal-month-booking .source-logo-fallback {
    width: 16px;
    height: 16px;
    flex: 0 0 16px;
  }

  .cal-month-booking {
    top: 26px;
    height: 20px;
    font-size: 10px;
    padding: 0 5px 0 2px;
  }

  .content {
    padding: 12px;
  }

  .page-header {
    padding: 15px 16px;
  }

  .topbar-actions {
    gap: 8px;
  }
}

/* ══════════════════════════════════════════════════════════════
   INBOX
   ══════════════════════════════════════════════════════════════ */

/* Inbox page : viewport height locked so internal lists scroll, not the page */
body:has(.inbox-main) {
  height: 100vh;
  overflow: hidden;
}
body:has(.inbox-main) .app {
  height: 100vh;
  overflow: hidden;
}
.inbox-main {
  overflow: hidden;
  min-height: 0;   /* prevent flex overflow */
}

.inbox-layout {
  flex: 1;
  display: flex;
  min-height: 0;
  overflow: hidden;
  background: var(--bg);
}

/* ── Left: conversation list ── */
.inbox-sidebar {
  width: var(--ms-list-panel-width);
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  background: var(--surface);
  border-right: 1px solid var(--line);
  overflow: hidden;
}



.inbox-filter-bar {
  display: flex;
  gap: 6px;
  padding: 10px 14px;
  border-bottom: 1px solid var(--line);
  flex-shrink: 0;
}
.inbox-filter-tab {
  flex: 1;
  padding: 5px 10px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: transparent;
  color: var(--t3);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  font-family: inherit;
  white-space: nowrap;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.inbox-filter-tab:hover {
  background: var(--surface-2);
  color: var(--t1);
}
.inbox-filter-tab.active {
  background: var(--accent-soft);
  border-color: var(--accent-ring);
  color: var(--accent);
}

.inbox-search-wrap {
  position: relative;
  padding: 12px 14px;
  border-bottom: 1px solid var(--line);
  flex-shrink: 0;
}

.inbox-search-icon {
  position: absolute;
  left: 26px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--t4);
  font-size: 12px;
  pointer-events: none;
}

.inbox-search-input {
  width: 100%;
  height: 34px;
  padding: 0 12px 0 32px;
  border: 1px solid var(--line-strong);
  border-radius: 8px;
  background: var(--surface-2);
  font: inherit;
  font-size: 13px;
  color: var(--t1);
  outline: none;
  transition: border-color 0.14s, background 0.14s;
  box-sizing: border-box;
}

.inbox-search-input:focus {
  border-color: var(--accent);
  background: var(--surface);
}

.inbox-search-input::placeholder { color: var(--t4); }

.inbox-list {
  flex: 1;
  overflow-y: auto;
  padding: 4px 0;
}

.inbox-no-results {
  padding: 28px 16px;
  font-size: 13px;
  color: var(--t4);
  text-align: center;
}

.inbox-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 11px 14px;
  cursor: pointer;
  transition: background 0.12s;
  border-left: 3px solid transparent;
  color: inherit;
}

.inbox-item:hover  { background: var(--surface-2); }
.inbox-item.active { background: color-mix(in srgb, var(--accent) 8%, transparent); border-left-color: var(--accent); }

.inbox-item.unread .inbox-item-name    { font-weight: 700; color: var(--t1); }
.inbox-item.unread .inbox-item-preview { color: var(--t2); }

.inbox-avatar {
  border-radius: 50%;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  color: #ffffff;
  letter-spacing: -0.5px;
}

.inbox-item-body { flex: 1; min-width: 0; }

.inbox-item-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 1px;
}

.inbox-item-meta {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 3px;
  flex-shrink: 0;
  margin-left: 8px;
}

.inbox-item-meta .inbox-channel-logo {
  width: 16px;
  height: 16px;
}

.inbox-item-name {
  font-size: 13px;
  font-weight: 500;
  color: var(--t1);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.inbox-item-time {
  font-size: 11px;
  color: var(--t4);
  flex-shrink: 0;
  margin-left: 6px;
}

.inbox-item-meta .inbox-item-time { margin-left: 0; }

.inbox-channel-logo {
  border-radius: 4px;
  object-fit: contain;
  background: #ffffff;
  flex-shrink: 0;
  display: inline-block;
  vertical-align: middle;
}

.inbox-item-property {
  font-size: 11px;
  color: var(--accent);
  font-weight: 600;
  margin-bottom: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.inbox-item-preview {
  font-size: 12px;
  color: var(--t3);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.inbox-unread-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--accent);
  flex-shrink: 0;
  margin-left: 2px;
}

/* ── Center: thread ── */
.inbox-thread {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  background: var(--bg);
}

.inbox-thread-empty {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 14px;
  color: var(--t4);
}

.inbox-thread-empty i { font-size: 52px; opacity: 0.3; }
.inbox-thread-empty p { font-size: 14px; }

.inbox-thread-hd {
  padding: 14px 20px;
  background: var(--surface);
  border-bottom: 1px solid var(--line);
  display: flex;
  align-items: center;
  gap: 12px;
  flex-shrink: 0;
  box-shadow: var(--shadow-1);
}

.inbox-thread-info { flex: 1; min-width: 0; }

.inbox-thread-name {
  font-size: 15px;
  font-weight: 600;
  color: var(--t1);
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.inbox-thread-sub {
  font-size: 12px;
  color: var(--t3);
  margin-top: 3px;
}

.inbox-channel-badge {
  display: inline-flex;
  align-items: center;
  font-size: 10px;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: 20px;
  color: #ffffff;
  letter-spacing: 0.2px;
}

.inbox-channel-badge.channel-airbnb   { background: #ff385c; }
.inbox-channel-badge.channel-booking  { background: #003e98; }
.inbox-channel-badge.channel-expedia  { background: #ffdc30; color: #172033; }
.inbox-channel-badge.channel-google   { background: #4388f3; }
.inbox-channel-badge.channel-vrbo,
.inbox-channel-badge.channel-abritel  { background: #3592f3; }
.inbox-channel-badge.channel-direct   { background: #3caa61; }
.inbox-channel-badge.channel-narbana  { background: #6c5ce7; }
.inbox-channel-badge.channel-beds24   { background: #5a6068; }

.inbox-msgs {
  flex: 1;
  overflow-y: auto;
  padding: 20px 24px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.inbox-date-sep {
  text-align: center;
  margin: 14px 0 8px;
}

.inbox-date-sep span {
  font-size: 11px;
  color: var(--t3);
  background: var(--surface-2);
  padding: 3px 12px;
  border-radius: 20px;
}

.inbox-msg {
  display: flex;
  flex-direction: column;
  max-width: 66%;
  margin-bottom: 4px;
}

.inbox-msg.guest { align-self: flex-start; }
.inbox-msg.host  { align-self: flex-end; }

.inbox-bubble {
  padding: 10px 14px;
  border-radius: 18px;
  font-size: 13px;
  line-height: 1.55;
  word-break: break-word;
}

.inbox-msg.guest .inbox-bubble {
  background: var(--surface);
  border: 1px solid var(--line);
  border-bottom-left-radius: 4px;
  color: var(--t1);
  box-shadow: var(--shadow-1);
}

.inbox-msg.host .inbox-bubble {
  background: var(--accent);
  color: #ffffff;
  border-bottom-right-radius: 4px;
}

.inbox-msg-time {
  font-size: 10px;
  color: var(--t4);
  margin-top: 4px;
  padding: 0 4px;
}

.inbox-msg.host .inbox-msg-time { text-align: right; }

.inbox-compose {
  padding: 10px 16px 12px;
  background: var(--surface);
  border-top: 1px solid var(--line);
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

.inbox-compose-input {
  flex: 1;
  min-height: 40px;
  max-height: 120px;
  padding: 10px 14px;
  border: 1.5px solid var(--line-strong);
  border-radius: 20px;
  font: inherit;
  font-size: 13px;
  color: var(--t1);
  background: var(--surface-2);
  resize: none;
  outline: none;
  line-height: 1.45;
  transition: border-color 0.14s, background 0.14s;
  overflow-y: auto;
}

.inbox-compose-input:focus     { border-color: var(--accent); background: var(--surface); }
.inbox-compose-input::placeholder { color: var(--t4); }

.inbox-send-btn {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 0;
  background: var(--accent);
  color: #ffffff;
  font-size: 14px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: opacity 0.14s, transform 0.1s;
}

.inbox-send-btn:hover  { opacity: 0.82; }
.inbox-send-btn:active { transform: scale(0.93); }

/* ── Right: detail panel ── */
.inbox-detail {
  width: 300px;
  flex-shrink: 0;
  background: var(--surface);
  border-left: 1px solid var(--line);
  overflow-y: auto;
  display: flex;
  flex-direction: column;
}

.inbox-dh {
  padding: 18px 18px 14px;
  border-bottom: 1px solid var(--line);
}

.inbox-dh-name {
  font-size: 14px;
  font-weight: 600;
  color: var(--t1);
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 6px;
}

.inbox-dh-prop {
  font-size: 12px;
  color: var(--t3);
  font-weight: 500;
  display: flex;
  align-items: center;
  gap: 5px;
}

.inbox-dh-prop i { color: var(--t4); font-size: 11px; }

.inbox-ds {
  padding: 14px 18px;
  border-bottom: 1px solid var(--line);
}

.inbox-ds:last-child { border-bottom: none; }

.inbox-dst {
  font-size: 10px;
  font-weight: 700;
  color: var(--t3);
  letter-spacing: 0.7px;
  text-transform: uppercase;
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  gap: 6px;
}

.inbox-dst i { color: var(--accent); }

.inbox-dr {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 7px;
  font-size: 12px;
}

.inbox-dr:last-of-type { margin-bottom: 0; }

.inbox-dr-sep {
  border-top: 1px solid var(--line);
  padding-top: 7px;
  margin-top: 4px;
}

.inbox-dl { color: var(--t3); }
.inbox-dl-strong { color: var(--t1); font-weight: 600; }
.inbox-dv { color: var(--t1); font-weight: 600; text-align: right; }
.inbox-dv-positive { color: #3caa61; font-weight: 600; text-align: right; }
.inbox-dv-negative { color: #ef4444; }

.inbox-fin-boxes {
  display: flex;
  gap: 8px;
  margin-bottom: 12px;
}

.inbox-fin-box {
  flex: 1;
  background: var(--surface-2);
  border-radius: 10px;
  padding: 10px 12px;
}

.inbox-fin-lbl {
  font-size: 10px;
  font-weight: 600;
  color: var(--t3);
  text-transform: uppercase;
  letter-spacing: 0.4px;
  margin-bottom: 4px;
}

.inbox-fin-val {
  font-size: 16px;
  font-weight: 700;
  color: var(--t1);
}

.inbox-fin-val.positive { color: #3caa61; }
.inbox-fin-val.negative { color: #ef4444; }

.inbox-note-ta {
  width: 100%;
  min-height: 80px;
  border: 1.5px solid var(--line-strong);
  border-radius: 8px;
  padding: 8px 10px;
  font: inherit;
  font-size: 12px;
  color: var(--t1);
  background: var(--surface-2);
  resize: vertical;
  outline: none;
  line-height: 1.5;
  transition: border-color 0.14s;
  box-sizing: border-box;
}

.inbox-note-ta:focus     { border-color: var(--accent); }
.inbox-note-ta::placeholder { color: var(--t4); }

.inbox-contact-row {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  color: var(--t1);
  margin-bottom: 7px;
}

.inbox-contact-row:last-child { margin-bottom: 0; }
.inbox-contact-row i { width: 14px; color: var(--t3); flex-shrink: 0; }

/* Mobile nav controls (hidden on desktop) */
.inbox-back-btn {
  display: none;
  width: 30px;
  height: 30px;
  border: 1px solid var(--line-strong);
  border-radius: 8px;
  background: var(--surface);
  color: var(--t2);
  cursor: pointer;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  padding: 0;
  transition: background 0.12s, border-color 0.12s;
}

.inbox-back-btn:hover { background: var(--surface-2); border-color: var(--accent); }

.inbox-info-btn {
  display: none;
  width: 30px;
  height: 30px;
  border: 1.5px solid var(--line-strong);
  border-radius: 50%;
  background: var(--surface);
  color: var(--t2);
  font-size: 15px;
  cursor: pointer;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-left: auto;
  transition: background 0.14s, color 0.14s, border-color 0.14s;
}

.inbox-info-btn:hover { background: var(--surface-2); color: var(--accent); border-color: var(--accent); }

.inbox-detail-back {
  display: none;
  padding: 12px 16px 10px;
  border-bottom: 1px solid var(--line);
  flex-shrink: 0;
}

/* ── Inbox responsive ── */
@media (max-width: 1100px) {
  .inbox-detail { width: 260px; }
}

@media (max-width: 860px) {
  .automation-grid {
    grid-template-columns: 1fr;
  }

  .automation-item {
    align-items: flex-start;
    flex-direction: column;
  }

  .automation-actions {
    width: 100%;
    justify-content: flex-end;
  }

  .automation-check-list {
    grid-template-columns: 1fr;
  }

  .automation-preview-grid {
    grid-template-columns: 1fr;
  }

  .automation-preview-grid > div + div {
    border-left: 0;
    border-top: 1px solid #e4e8ec;
  }

  .inbox-sidebar { width: var(--ms-list-panel-width); }
  .inbox-detail  { display: none; }
}

@media (max-width: 640px) {
  .automation-back-btn {
    display: inline-flex;
  }

  .automation-grid[data-automation-panel="list"] .automation-form-card {
    display: none;
  }

  .automation-grid[data-automation-panel="detail"] .automation-list-card {
    display: none;
  }

  .automation-grid[data-automation-panel="detail"] .automation-form-card {
    display: block;
  }

  .automation-language-tabs {
    width: 100%;
  }

  .automation-language-tabs button {
    flex: 1;
    padding: 0 8px;
  }

  .calendar-jump-picker .date-picker-panel {
    position: fixed;
    top: 218px;
    left: 16px !important;
    right: 16px !important;
    width: auto;
    max-width: calc(100vw - 32px);
    max-height: calc(100dvh - 234px);
    overflow-y: auto;
    z-index: 800;
  }

  .inbox-sidebar { width: 100%; border-right: none; }
  .inbox-detail  { border-left: none; width: 100%; }

  .inbox-back-btn    { display: flex; }
  .inbox-info-btn    { display: flex; }
  .inbox-detail-back { display: flex; }

  /* Show only the active panel */
  .inbox-layout[data-inbox-panel="list"] .inbox-thread,
  .inbox-layout[data-inbox-panel="list"] .inbox-detail   { display: none; }

  .inbox-layout[data-inbox-panel="thread"] .inbox-sidebar,
  .inbox-layout[data-inbox-panel="thread"] .inbox-detail  { display: none; }

  .inbox-layout[data-inbox-panel="detail"] .inbox-sidebar,
  .inbox-layout[data-inbox-panel="detail"] .inbox-thread  { display: none; }

  .inbox-layout[data-inbox-panel="detail"] .inbox-detail  { display: flex; }
}

/* ============ MÉNAGE — NOUVEAUX COMPOSANTS ============ */

/* --- Type de logement : pills --- */
.property-type-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.property-type-pill {
  align-items: center;
  border: 2px solid #dfe5eb;
  border-radius: 999px;
  color: #536173;
  cursor: pointer;
  display: inline-flex;
  font-size: 13px;
  font-weight: 700;
  padding: 7px 16px;
  transition: border-color 0.14s, background 0.14s, color 0.14s;
  user-select: none;
}

.property-type-pill input[type="radio"] {
  display: none;
}

.property-type-pill:hover {
  border-color: #2196d4;
  color: #2196d4;
}

.property-type-pill.active,
.property-type-pill:has(input:checked) {
  background: #e8f4fc;
  border-color: #2196d4;
  color: #2196d4;
}

/* --- Oui / Non toggle --- */
.yes-no-toggle {
  border: 1px solid #dfe5eb;
  border-radius: 8px;
  display: flex;
  overflow: hidden;
}

.yes-no-option {
  background: #ffffff;
  color: #536173;
  cursor: pointer;
  flex: 1;
  font-size: 12px;
  font-weight: 700;
  padding: 7px 10px;
  text-align: center;
  transition: background 0.14s, color 0.14s;
  user-select: none;
}

.yes-no-option + .yes-no-option {
  border-left: 1px solid #dfe5eb;
}

.yes-no-option input[type="radio"] {
  display: none;
}

.yes-no-option:has(input:checked) {
  background: #172033;
  color: #ffffff;
}

/* --- Pièce row (flex au lieu de grid pour que hidden fonctionne proprement) --- */
.cleaning-room-row {
  align-items: flex-end;
  background: #f8fafc;
  border: 1px solid #e8edf2;
  border-radius: 12px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  padding: 12px;
}

.cleaning-room-row .form-field {
  flex: 1 1 140px;
  min-width: 0;
}

/* --- Input photo stylisé --- */
.cleaning-file-label {
  align-items: center;
  background: #f8fafc;
  border: 1px solid #dfe5eb;
  border-radius: 8px;
  cursor: pointer;
  display: inline-flex;
  gap: 10px;
  min-height: 38px;
  padding: 6px 12px;
  width: 100%;
}

.cleaning-file-label:hover {
  border-color: #2196d4;
}

.cleaning-file-label input[type="file"] {
  display: none;
}

.cleaning-file-btn {
  background: #eef2f7;
  border: 1px solid #dfe5eb;
  border-radius: 6px;
  color: #536173;
  flex-shrink: 0;
  font-size: 12px;
  font-weight: 700;
  padding: 4px 10px;
  white-space: nowrap;
}

.cleaning-file-name {
  color: #9aa3af;
  font-size: 12px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* --- Feedback rapport --- */
.cleaning-report-feedback {
  align-items: center;
  background: #e9f8f2;
  border-radius: 6px;
  color: #12805c;
  display: inline-flex;
  font-size: 12px;
  font-weight: 700;
  padding: 6px 12px;
}

.cleaning-report-feedback[hidden] {
  display: none;
}

/* ── Settings split layout ─────────────────────────────────── */
.ms-settings-layout {
  display: flex;
  flex: 1;
  min-height: 0;
  overflow: hidden;
}

/* Left column — identical rhythm to .inbox-sidebar */
.ms-settings-list {
  background: var(--surface);
  border-right: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
  overflow: hidden;
  width: var(--ms-list-panel-width);
}

/* Search bar — mirrors .inbox-search-wrap */
.ms-settings-search-wrap {
  border-bottom: 1px solid #f0f2f5;
  flex-shrink: 0;
  padding: 14px 14px 10px;
  position: relative;
}

.ms-settings-search-icon {
  color: #aab0bb;
  font-size: 13px;
  left: 26px;
  margin-top: 2px;
  pointer-events: none;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}

.ms-settings-search-input {
  background: #f5f6f8;
  border: 1px solid #e8ecf0;
  border-radius: 20px;
  box-sizing: border-box;
  font-size: 13px;
  height: 34px;
  outline: none;
  padding: 0 12px 0 32px;
  transition: border-color 0.15s, background 0.15s;
  width: 100%;
}

.ms-settings-search-input:focus {
  background: #ffffff;
  border-color: #9dcbee;
}

.ms-settings-search-input::placeholder { color: #aab0bb; }

/* Scrollable items area */
.ms-settings-list-body {
  flex: 1;
  overflow-y: auto;
  padding: 4px 0;
}

/* Right detail pane */
.ms-settings-detail {
  flex: 1;
  min-width: 0;
  overflow-y: auto;
  padding: 24px 28px;
}

.ms-prop-list-item {
  align-items: center;
  border-bottom: 1px solid var(--ms-border-light);
  cursor: pointer;
  display: flex;
  gap: 10px;
  padding: 12px 16px 12px 0;
  transition: background 0.15s;
}

.ms-settings-list .ms-prop-list-item {
  padding-left: 16px;
}

.users-mode .ms-prop-list-item {
  padding-left: 16px;
}

/* Users left panel — flex column so search bar stays fixed and list scrolls */
.users-mode [data-users-list] {
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.cleaning-generated-note {
  background: var(--ms-blue-bg);
  border: 1px solid rgba(0, 122, 255, .16);
  border-radius: 12px;
  color: var(--ms-text-2);
  font-size: 13px;
  line-height: 1.45;
  margin: 0 0 14px;
  padding: 12px 14px;
}

.cleaning-generated-note a {
  color: var(--ms-blue);
  font-weight: 700;
  text-decoration: none;
}

.cleaning-generated-note a:hover {
  text-decoration: underline;
}

.cleaning-photo-requirements {
  display: grid;
  gap: 12px;
}

.cleaning-photo-rule {
  background: #f8fafc;
  border: 1px solid #dbe3ef;
  border-radius: 14px;
  margin-top: 16px;
  overflow: hidden;
}

.cleaning-photo-rule-head {
  align-items: center;
  background: #f8fafc;
  border-bottom: 1px solid #eef2f7;
  display: flex;
  gap: 10px;
  justify-content: space-between;
  padding: 12px 14px;
}

.cleaning-photo-rule-head > div {
  align-items: center;
  display: flex;
  gap: 9px;
  min-width: 0;
}

.cleaning-photo-rule-head i {
  color: #2563eb;
}

.cleaning-photo-rule-head strong {
  color: #111827;
  font-size: 13px;
}

.cleaning-photo-rule-body {
  display: grid;
  gap: 12px;
  padding: 14px;
}

.cleaning-photo-rule-body::before {
  color: #64748b;
  content: "Validations et photos attendues";
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.cleaning-photo-count-field {
  align-items: center;
  display: flex;
  gap: 10px;
}

.cleaning-photo-count-field span {
  color: #64748b;
  font-size: 12px;
  font-weight: 700;
}

.cleaning-photo-count-field select {
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 10px;
  font: inherit;
  height: 36px;
  padding: 0 10px;
}

.cleaning-photo-labels,
.cleaning-reference-settings {
  display: grid;
  gap: 8px;
}

.cleaning-photo-label-input[hidden] {
  display: none;
}

.cleaning-reference-settings {
  border-top: 1px dashed #e2e8f0;
  padding-top: 10px;
}

.cleaning-reference-strip,
.hk-reference-grid,
.hk-proof-grid,
.admin-proof-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.cleaning-reference-thumb,
.cleaning-reference-add,
.hk-reference-photo,
.hk-proof-empty,
.hk-proof-filled,
.admin-proof-photo {
  border-radius: 12px;
  height: 76px;
  overflow: hidden;
  width: 96px;
}

.cleaning-reference-thumb,
.hk-proof-filled {
  position: relative;
}

.cleaning-reference-thumb img,
.hk-reference-photo img,
.hk-proof-filled img,
.admin-proof-photo img {
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.cleaning-reference-thumb button,
.hk-proof-filled button {
  align-items: center;
  background: rgba(12, 12, 16, .72);
  border: 0;
  border-radius: 999px;
  color: #fff;
  cursor: pointer;
  display: inline-flex;
  height: 22px;
  justify-content: center;
  position: absolute;
  right: 5px;
  top: 5px;
  width: 22px;
}

.cleaning-reference-add,
.hk-proof-empty {
  align-items: center;
  background: var(--surface-2);
  border: 1.5px dashed var(--line-strong);
  color: var(--t3);
  cursor: pointer;
  display: flex;
  flex-direction: column;
  font-size: 12px;
  gap: 6px;
  justify-content: center;
}

.hk-reference-photo,
.admin-proof-photo {
  background: transparent;
  border: 0;
  cursor: pointer;
  padding: 0;
}

.ms-prop-list-item.dragging { opacity: .45; background: #eef2f8; }

.ms-prop-grip {
  align-items: center;
  color: #c8cdd8;
  cursor: grab;
  display: flex;
  flex-shrink: 0;
  font-size: 13px;
  justify-content: center;
  padding: 0 6px 0 10px;
  self-align: stretch;
  transition: color 0.1s;
}

.ms-prop-grip:hover { color: #5a6478; }

.ms-prop-list-item:hover {
  background: #f5f6f8;
}

.ms-prop-list-item.active {
  background: #eaf2fb;
}

.ms-prop-list-info {
  flex: 1;
  min-width: 0;
}

.ms-prop-list-name {
  font-size: 14px;
  font-weight: 600;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ms-prop-list-meta {
  color: var(--ms-text-2);
  font-size: 12px;
  margin-top: 2px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ms-prop-list-arrow {
  display: none;
}

.ms-prop-img {
  border-radius: 50%;
  flex-shrink: 0;
  height: 40px;
  object-fit: cover;
  width: 40px;
}

.ms-back-btn {
  align-items: center;
  background: #ffffff;
  border: 1px solid #d9dde2;
  border-radius: 8px;
  color: #5a6068;
  cursor: pointer;
  display: none;
  flex-shrink: 0;
  height: 30px;
  justify-content: center;
  padding: 0;
  width: 30px;
}

/* ── Multi-furniture counts ────────────────────────────────── */
.ms-equip-counts {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 10px;
}

.ms-equip-count-row {
  align-items: center;
  display: flex;
  gap: 10px;
  justify-content: space-between;
}

.ms-equip-count-row[hidden] {
  display: none;
}

/* ──────────────────────────────────────────────────────────
   HERO BAR — force-hide when hidden attribute is set
   (needed because display:flex overrides the browser default)
   ────────────────────────────────────────────────────────── */
.cleaning-hero[hidden] { display: none !important; }

/* ══════════════════════════════════════════════════════════
   PAGE SPLIT — universal inbox-style layout for all pages
   Mirrors the inbox pattern: left list panel + right detail
   ══════════════════════════════════════════════════════════ */

/* Add page-main class to <main> to opt into full-height mode */
.page-main {
  flex: 1;
  min-height: 0;
  overflow: hidden;
}

/* The top-level split container */
.page-split {
  flex: 1;
  display: flex;
  min-height: 0;
  overflow: hidden;
  background: var(--bg);
}

/* ── Left: narrow list panel ── */
.page-split-list {
  width: var(--ms-list-panel-width);
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  background: var(--surface);
  border-right: 1px solid var(--line);
  overflow-y: auto;
}

.page-split-list-hd {
  height: 60px;
  padding: 0 20px;
  border-bottom: 1px solid var(--line);
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-shrink: 0;
}


.page-split-list-body {
  flex: 1;
  overflow-y: auto;
}

/* ── Right: scrollable detail/form area ── */
.page-split-detail {
  flex: 1;
  overflow-y: auto;
  padding: 24px 28px;
}

.page-split-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 100%;
  gap: 14px;
  color: var(--t4);
  font-size: 14px;
}

.page-split-empty i { font-size: 48px; opacity: 0.35; }

/* ── messages.html: automation-grid fills full height ── */
.page-main > .automation-grid {
  flex: 1;
  min-height: 0;
  align-items: stretch;
  gap: 0;
  overflow: hidden;
  border-top: 1px solid #e8ecf0;
  grid-template-columns: var(--ms-list-panel-width) minmax(0, 1fr);
}

.page-main > .automation-grid .automation-list-card {
  border-radius: 0;
  box-shadow: none;
  border-right: 1px solid #e8ecf0;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.page-main > .automation-grid .automation-form-card {
  border-radius: 0;
  box-shadow: none;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.page-main > .automation-grid .automation-form-card .card-body {
  flex: 1;
  overflow-y: auto;
}

@media (min-width: 861px) {
  .page-main > .automation-grid .automation-form-card {
    background: #f5f6f8;
    border: 0;
    padding: 24px;
  }

  .page-main > .automation-grid .automation-form-card > .card-header,
  .page-main > .automation-grid .automation-form-card > .automation-form {
    background: #ffffff;
    border: 1px solid #e8ecf0;
    box-shadow: 0 10px 28px rgba(28, 37, 48, 0.06);
    margin-left: auto;
    margin-right: auto;
    max-width: 980px;
    width: 100%;
  }

  .page-main > .automation-grid .automation-form-card > .card-header {
    border-radius: 16px 16px 0 0;
    border-bottom: 0;
  }

  .page-main > .automation-grid .automation-form-card > .automation-form {
    border-radius: 0 0 16px 16px;
    margin-bottom: 80px;
  }
}

/* ── Responsive: stack on mobile ── */
@media (max-width: 860px) {
  .page-split { flex-direction: column; }

  .page-split-list {
    width: 100%;
    border-right: none;
    border-bottom: 1px solid var(--line);
    flex-shrink: 0;
    max-height: 40vh;
  }

  .page-split-detail { padding: 16px; }

  .page-main > .automation-grid {
    grid-template-columns: 1fr;
    overflow-y: auto;
    align-items: start;
  }

  .page-main > .automation-grid .automation-list-card,
  .page-main > .automation-grid .automation-form-card {
    overflow-y: visible;
  }

  .automation-item {
    align-items: center;
    flex-direction: row;
  }

  .automation-actions {
    justify-content: flex-end;
    width: auto;
  }

  .automation-back-btn {
    display: inline-flex;
  }

  .automation-grid[data-automation-panel="list"] .automation-form-card {
    display: none;
  }

  .automation-grid[data-automation-panel="detail"] .automation-list-card {
    display: none;
  }

  .automation-grid[data-automation-panel="detail"] .automation-form-card {
    display: flex;
  }
}

.ms-equip-count-row > span {
  color: var(--ms-text-1);
  font-size: 13px;
  font-weight: 500;
}

/* ── Per-group task add button ─────────────────────────────── */
.ms-task-group-add {
  align-items: center;
  background: transparent;
  border: 1px dashed var(--ms-border);
  border-radius: 6px;
  color: var(--ms-text-3);
  cursor: pointer;
  display: flex;
  font-family: inherit;
  font-size: 11px;
  font-weight: 500;
  gap: 5px;
  margin: 10px 0 2px;
  padding: 5px 10px;
  transition: all 0.12s;
}

.ms-task-group-add:hover {
  border-color: var(--ms-blue);
  color: var(--ms-blue);
}

.ms-task-category-add {
  justify-content: center;
  margin: 14px 0 0;
  min-height: 38px;
  width: 100%;
}

/* ── Mobile settings layout ────────────────────────────────── */
@media (max-width: 768px) {
  .ms-settings-layout {
    flex-direction: column;
    overflow-y: auto;
  }

  .ms-settings-list {
    border-right: none;
    flex-shrink: 0;
    height: auto;
    max-height: 40vh;
    overflow: hidden;
    width: 100%;
  }

  .ms-settings-detail {
    overflow-y: visible;
    padding: 16px;
  }

  .ms-settings-layout[data-ms-mobile-panel="detail"] .ms-settings-list {
    display: none;
  }

  .ms-settings-layout:not([data-ms-mobile-panel="detail"]) .ms-settings-detail {
    display: none;
  }

  .ms-back-btn {
    display: inline-flex;
  }
}

/* ═══════════════════════════════════════════════════════════════
   SETTINGS — Nav items & panel layout
═══════════════════════════════════════════════════════════════ */

/* Nav item row */
.stg-nav-item {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 11px 16px;
  border: none;
  border-bottom: 1px solid var(--line);
  background: transparent;
  color: var(--t2);
  font-size: 13px;
  font-weight: 500;
  font-family: inherit;
  line-height: 1;
  cursor: pointer;
  text-align: left;
  transition: background 0.15s, color 0.15s;
}
.stg-nav-item:last-child { border-bottom: none; }
.stg-nav-item:hover:not(:disabled) {
  background: var(--surface-2);
  color: var(--t1);
}
.stg-nav-item.active {
  background: var(--accent-soft);
  color: var(--accent-2);
}
.stg-nav-item:disabled,
.stg-nav-item.stg-nav-soon {
  cursor: default;
  opacity: 0.5;
}

/* Icon capsule */
.stg-nav-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  border-radius: 8px;
  background: var(--surface-2);
  border: 1px solid var(--line);
  font-size: 12px;
  color: var(--t3);
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.stg-nav-item.active .stg-nav-icon {
  background: var(--accent-soft);
  border-color: var(--accent-ring);
  color: var(--accent);
}

/* Label stretches to fill available space */
.stg-nav-label { flex: 1; }

/* Chevron — hidden on desktop, visible on mobile */
.stg-nav-chevron {
  font-size: 10px;
  color: var(--t4);
  display: none;
}

/* Panel wrapper — largeur max centrée + flex column */
[data-settings-panel] {
  max-width: 820px;
  margin: 0 auto;
}
[data-settings-panel] > form {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

/* On mobile, show chevron and hide on desktop */
@media (max-width: 860px) {
  .stg-nav-chevron { display: block; }
}

/* ═══════════════════════════════════════════════════════════════
   ADMIN PLANNING — Layout Apple-style deux colonnes
═══════════════════════════════════════════════════════════════ */

.cleaning-layout.adm-planning-mode {
  display: flex !important;
  flex-direction: row;
  gap: 0;
  overflow: hidden;
  flex: 1;
  grid-template-columns: none;
  min-height: 0;
  background: var(--bg);
}

.cleaning-layout.adm-planning-mode .cleaning-list-card {
  border-radius: 0;
  border-right: 1px solid var(--line);
  box-shadow: none;
  width: var(--ms-list-panel-width);
  flex-shrink: 0;
  min-height: 0;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

/* Hide legacy table and mobile list in admin planning mode */
.cleaning-layout.adm-planning-mode .cleaning-table-wrap,
.cleaning-layout.adm-planning-mode .cleaning-mobile-list,
.cleaning-layout.adm-planning-mode .cleaning-list-card .card-header {
  display: none;
}

.cleaning-layout.adm-planning-mode .cleaning-detail-card {
  background: var(--bg);
  border-radius: 0;
  border: 0;
  box-shadow: none;
  flex: 1;
  overflow-y: auto;
  display: flex !important;
  flex-direction: column;
}

/* Date filter bar — two pickers below the title */
.cleaning-date-filter-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  border-bottom: 1px solid var(--line);
  flex-shrink: 0;
}
.cleaning-date-filter-bar .adm-date-picker {
  flex: 1 1 0;
  min-width: 0;
}

/* Planning tab override in admin mode */
[data-cleaning-panel-tab="planning"].adm-planning-panel:not([hidden]) {
  min-height: 0;
  overflow: hidden;
  padding: 0;
}

/* Date range picker — compact single row */
.adm-date-range {
  display: flex;
  align-items: center;
  gap: 5px;
  flex-wrap: nowrap;
}

.adm-date-picker {
  flex: 1 1 0;
  min-width: 0;
}

.adm-dr-label {
  font-size: 10px;
  font-weight: 700;
  color: #8896a5;
  text-transform: uppercase;
  letter-spacing: .04em;
  white-space: nowrap;
  flex-shrink: 0;
}

.adm-date-input {
  padding: 5px 6px;
  border-radius: 8px;
  border: 1px solid var(--line-strong);
  background: var(--surface-2);
  font-size: 11px;
  font-family: inherit;
  color: var(--t1);
  box-sizing: border-box;
  cursor: pointer;
  width: 100%;
}

.adm-date-input:focus { outline: none; border-color: var(--accent-ring); background: var(--surface); }

.adm-date-sep {
  font-size: 12px;
  color: var(--t4);
  flex-shrink: 0;
}

/* Task list body */
.adm-task-body {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
}

/* Task items */
.adm-task-item {
  align-items: flex-start;
  background: var(--surface);
  border-bottom: 1px solid var(--line);
  border-left: 3px solid transparent;
  cursor: pointer;
  display: flex;
  gap: 11px;
  padding: 12px 14px;
  transition: background .12s;
}

.adm-task-item:hover { background: var(--surface-2); }
.adm-task-item.active { background: var(--accent-soft); border-left-color: var(--accent); }

/* Property photo avatar */
.adm-avatar {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: var(--accent-soft);
  color: var(--accent);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 14px;
  flex-shrink: 0;
  overflow: hidden;
}

.adm-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
  display: block;
}

/* Letter fallback keeps the accent bg */
.adm-avatar.adm-avatar-letter {
  background: var(--accent-soft);
  color: var(--accent);
}

.adm-item-info { flex: 1; min-width: 0; }
.adm-item-name { font-weight: 600; font-size: 13px; color: var(--t1); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.adm-item-meta { font-size: 11px; color: var(--t3); margin-top: 3px; }
.adm-item-guest { font-size: 11px; color: var(--t2); margin-top: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.adm-item-badges { display: flex; gap: 5px; margin-top: 5px; flex-wrap: wrap; align-items: center; }

/* Status tags */
.adm-tag-todo     { background: var(--surface-3); color: var(--t3); }
.adm-tag-progress { background: var(--blue-soft); color: var(--blue); }
.adm-tag-done     { background: var(--green-soft); color: var(--green); }
.adm-tag-review   { background: var(--accent-soft); color: var(--accent-2); }

/* Assigned & urgency micro-badges */
.adm-badge-assigned {
  font-size: 10px;
  color: var(--green);
  background: var(--green-soft);
  border-radius: 4px;
  padding: 2px 6px;
  white-space: nowrap;
}

.adm-badge-urgency {
  font-size: 10px;
  border-radius: 4px;
  padding: 2px 6px;
  white-space: nowrap;
  font-weight: 700;
}

.adm-badge-urgency.late { background: var(--rose-soft); color: var(--rose); }
.adm-badge-urgency.prio { background: var(--accent-soft); color: var(--accent-2); }

/* ═══════════════════════════════════════════════════════════════
   TÂCHES PONCTUELLES — Settings
═══════════════════════════════════════════════════════════════ */

.ms-periodic-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.ms-periodic-row {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 10px 12px;
  background: var(--ms-surface-2);
  border: 1px solid var(--ms-border-light);
  border-radius: 10px;
  flex-wrap: wrap;
}

.ms-periodic-freq,
.ms-periodic-group {
  flex: 0 0 auto;
  width: 130px;
}

.ms-periodic-text {
  flex: 1;
  min-width: 160px;
}

.ms-periodic-date-col {
  flex: 0 0 auto;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.ms-periodic-date-col input {
  width: 150px;
}

.ms-periodic-empty {
  padding: 16px 0;
  font-size: 13px;
  color: var(--ms-text-2);
  text-align: center;
}

/* ═══════════════════════════════════════════════════════════════
   PANEL ATTRIBUTION ADMIN
═══════════════════════════════════════════════════════════════ */

.assign-section {
  margin-top: 16px;
  border: 1px solid #e8ecf0;
  border-radius: 12px;
  overflow: hidden;
}

.assign-section-hd {
  background: #f7f9fc;
  border-bottom: 1px solid #e8ecf0;
  padding: 10px 16px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .5px;
  text-transform: uppercase;
  color: #5a6a7a;
  display: flex;
  align-items: center;
  gap: 8px;
}

.assign-legend {
  display: flex;
  gap: 12px;
  margin-left: auto;
  text-transform: none;
  letter-spacing: 0;
  font-size: 11px;
  font-weight: 400;
  color: #5a6a7a;
}

.assign-legend-item {
  display: flex;
  align-items: center;
  gap: 5px;
}

.assign-legend-dot {
  width: 10px;
  height: 10px;
  border-radius: 2px;
  flex-shrink: 0;
}

/* Housekeepers */
.assign-hk-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 12px 14px;
}

.assign-hk-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border: 1.5px solid #e0e4e8;
  border-radius: 10px;
  cursor: pointer;
  transition: border-color .12s, background .12s;
}

.assign-hk-row:hover { border-color: var(--accent-ring); background: var(--accent-soft); }
.assign-hk-row.selected { border-color: var(--accent); background: var(--accent-soft); }

.assign-hk-avatar {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: #dbeafe;
  color: #1d4ed8;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 700;
  flex-shrink: 0;
}

.assign-hk-info { flex: 1; min-width: 0; }
.assign-hk-name { font-size: 13px; font-weight: 600; color: var(--t1); }
.assign-hk-email { font-size: 11px; color: var(--t3); }

.assign-hk-icon { font-size: 18px; color: var(--t4); }
.assign-hk-icon.selected { color: var(--accent); }

/* Task list */
.assign-task-list { padding: 10px 14px; display: flex; flex-direction: column; gap: 10px; }

.assign-group {
  border: 1px solid #e8ecf0;
  border-radius: 10px;
  overflow: hidden;
}

.assign-group-hd {
  background: #f7f9fc;
  border-bottom: 1px solid #e8ecf0;
  padding: 7px 14px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .4px;
  color: #5a6a7a;
}

.assign-task-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 14px;
  border-bottom: 1px solid #f0f2f5;
  font-size: 13px;
  color: #2d3a47;
}

.assign-task-row:last-child { border-bottom: none; }

.assign-grip { color: #c8d0da; font-size: 11px; flex-shrink: 0; }
.assign-task-text { flex: 1; }

/* Periodic due (amber) */
.assign-periodic-due {
  background: #fffbeb;
  border-left: 3px solid #f59e0b;
}

/* Periodic optional (grey) */
.assign-periodic-opt {
  background: #fafafa;
  border-left: 3px solid #d1d5db;
  opacity: .85;
}

.assign-periodic-info { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.assign-periodic-meta { font-size: 10px; color: #92400e; }
.assign-periodic-opt .assign-periodic-meta { color: #9ca3af; }

.assign-badge-due {
  font-size: 10px;
  color: #92400e;
  background: #fef3c7;
  border: 1px solid #fcd34d;
  border-radius: 5px;
  padding: 2px 7px;
  white-space: nowrap;
  flex-shrink: 0;
}

.assign-badge-opt {
  font-size: 10px;
  color: #9ca3af;
  background: #f3f4f6;
  border: 1px solid #e5e7eb;
  border-radius: 5px;
  padding: 2px 7px;
  white-space: nowrap;
  flex-shrink: 0;
}

.assign-remove-btn,
.assign-add-btn {
  width: 26px;
  height: 26px;
  border-radius: 7px;
  border: none;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  cursor: pointer;
  flex-shrink: 0;
  transition: background .12s;
}

.assign-remove-btn { background: #fee2e2; color: #dc2626; }
.assign-remove-btn:hover { background: #fecaca; }
.assign-add-btn { background: var(--accent-soft); color: var(--accent); border: 1px solid var(--accent-ring); }
.assign-add-btn:hover { background: var(--accent-ring); }

/* Manual task badge */
.assign-badge-manual {
  font-size: 10px;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 999px;
  background: #f0fdf4;
  color: #16a34a;
  border: 1px solid #bbf7d0;
  white-space: nowrap;
  flex-shrink: 0;
}

/* Manual task addition bar */
.assign-add-task-bar {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 10px 14px 12px;
  border-top: 1px dashed #e0e4e8;
  flex-wrap: wrap;
}

.assign-add-group-select {
  flex: 0 0 auto;
  min-width: 120px;
  max-width: 150px;
  padding: 7px 10px;
  border-radius: 8px;
  border: 1px solid #e0e4e8;
  background: #f7f9fc;
  font-size: 12px;
  font-family: inherit;
  color: #1a2332;
}

.assign-add-group-custom {
  flex: 0 0 auto;
}

.assign-add-group-input {
  padding: 7px 10px;
  border-radius: 8px;
  border: 1px solid #93c5fd;
  background: #eff6ff;
  font-size: 12px;
  font-family: inherit;
  color: #1a2332;
  width: 130px;
}

.assign-add-task-input {
  flex: 1;
  min-width: 140px;
  padding: 7px 10px;
  border-radius: 8px;
  border: 1px solid #e0e4e8;
  background: #fff;
  font-size: 12px;
  font-family: inherit;
  color: #1a2332;
}

.assign-add-task-input:focus,
.assign-add-group-input:focus {
  outline: none;
  border-color: #3b82f6;
}

.assign-add-task-btn {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 7px 14px;
  border-radius: 8px;
  border: none;
  background: var(--accent);
  color: #fff;
  font-size: 12px;
  font-weight: 600;
  font-family: inherit;
  cursor: pointer;
  white-space: nowrap;
  transition: background .12s;
  flex-shrink: 0;
}

.assign-add-task-btn:hover { background: var(--accent-2); }

/* ═══════════════════════════════════════════════════════════════
   VUE HOUSEKEEPER
═══════════════════════════════════════════════════════════════ */

.cleaning-review-admin-note,
.hk-finish-feedback {
  align-items: flex-start;
  border-radius: 14px;
  display: flex;
  gap: 10px;
  line-height: 1.4;
}

.cleaning-review-admin-note {
  background: var(--accent-soft);
  border: 1px solid var(--accent-ring);
  border-radius: 10px;
  color: var(--accent-2);
  margin-top: 14px;
  padding: 13px 14px;
}

.cleaning-review-admin-note strong,
.cleaning-review-admin-note span {
  display: block;
}

.cleaning-review-admin-note span {
  color: var(--accent);
  font-size: 12px;
  margin-top: 2px;
}

.hk-finish-feedback {
  background: var(--green-soft);
  border: 1px solid var(--green);
  border-radius: 10px;
  color: var(--green);
  font-size: 13px;
  font-weight: 700;
  margin: 14px 0;
  padding: 12px 14px;
}

.hk-finish-feedback .fa-flag {
  color: var(--accent-2);
}

.hk-finish-feedback:has(.fa-flag) {
  background: var(--accent-soft);
  border-color: var(--accent-ring);
  color: var(--accent-2);
}

/* Housekeeper mode: two-column always visible */
.cleaning-layout.hk-mode {
  display: flex;
  flex-direction: row;
  gap: 0;
  overflow: hidden;
  flex: 1;
}

.cleaning-layout.hk-mode .cleaning-list-card {
  width: var(--ms-list-panel-width);
  flex-shrink: 0;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  border-right: 1px solid var(--line);
  border-radius: 0;
  background: var(--surface);
  box-shadow: none;
}

/* Detail card header (back btn + title) */
.cleaning-layout.hk-mode .cleaning-detail-card .card-header {
  background: var(--surface);
  border-bottom: 1px solid var(--line);
  padding: 0 20px;
  height: 60px;
  flex-shrink: 0;
}
.cleaning-layout.hk-mode .cleaning-detail-card .card-title {
  color: var(--t1);
  font-size: 14px;
  font-weight: 600;
}

/* Detail card body scrolls, uses page background */
.cleaning-layout.hk-mode .cleaning-detail-card .card-body {
  flex: 1;
  overflow-y: auto;
  background: var(--bg);
  padding: 0;
}

.cleaning-layout.hk-mode .cleaning-detail-card {
  flex: 1;
  overflow: hidden;
  display: flex !important;
  flex-direction: column;
  background: var(--bg);
  box-shadow: none;
  border-radius: 0;
  border: none;
}

.cleaning-layout.hk-mode[data-cleaning-panel="list"] .cleaning-detail-card { display: flex !important; }

.hk-mission-content {
  padding-top: 8px;
}

/* Mission list items */
.hk-missions-list {
  flex: 1;
  overflow-y: auto;
}

.hk-mission-item {
  display: flex;
  align-items: flex-start;
  gap: 11px;
  padding: 13px 16px;
  border-bottom: 1px solid var(--line);
  cursor: pointer;
  transition: background .12s;
  border-left: 3px solid transparent;
}

.hk-mission-item:hover { background: var(--surface-2); }
.hk-mission-item.active { background: var(--accent-soft); border-left-color: var(--accent); }

.hk-avatar {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: var(--accent-soft);
  color: var(--accent-2);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 14px;
  flex-shrink: 0;
}

.hk-mission-info { flex: 1; min-width: 0; }
.hk-mission-name { font-weight: 600; font-size: 14px; color: var(--t1); }
.hk-mission-meta { font-size: 11px; color: var(--t3); margin-top: 3px; }

/* Status tags for housekeeper */
.hk-tag-todo { background: var(--surface-3); color: var(--t3); }
.hk-tag-progress { background: var(--blue-soft); color: var(--blue); }
.hk-tag-done { background: var(--green-soft); color: var(--green); }
.hk-tag-review { background: var(--accent-soft); color: var(--accent-2); }

/* Info chips row */
.hk-info-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  padding: 0 0 4px;
}

.hk-chip {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 12px;
  box-shadow: var(--shadow-1);
  color: var(--t1);
  font-size: 12px;
  padding: 9px 13px;
}

.hk-chip strong {
  display: block;
  font-size: 10px;
  color: var(--t3);
  text-transform: uppercase;
  letter-spacing: .4px;
  margin-bottom: 2px;
}

/* Task groups */
.hk-group {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 16px;
  box-shadow: var(--shadow-1);
  margin-top: 18px;
  overflow: hidden;
}

.hk-group-hd {
  align-items: center;
  background: var(--surface-2);
  border-bottom: 1px solid var(--line);
  color: var(--t1);
  display: flex;
  font-size: 12px;
  font-weight: 700;
  justify-content: space-between;
  letter-spacing: .05em;
  padding: 13px 16px;
  text-transform: uppercase;
}

.hk-group-hd > div {
  align-items: center;
  display: flex;
  gap: 9px;
  min-width: 0;
}

.hk-group-hd i {
  color: var(--accent);
  font-size: 14px;
}

.hk-group-hd span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.hk-group-hd strong {
  background: var(--accent-soft);
  border: 1px solid var(--accent-ring);
  border-radius: 999px;
  color: var(--accent-2);
  flex-shrink: 0;
  font-size: 11px;
  padding: 3px 8px;
}

.hk-task-list {
  display: grid;
}

/* Task rows */
.hk-task {
  align-items: center;
  border-bottom: 1px solid var(--line);
  display: flex;
  gap: 11px;
  padding: 11px 16px;
  transition: background .1s;
}

.hk-task:last-of-type { border-bottom: none; }

.hk-task-check {
  width: 17px;
  height: 17px;
  --cb-accent: var(--accent);
  flex-shrink: 0;
  cursor: pointer;
}

.hk-task-label { flex: 1; font-size: 13px; color: var(--t1); line-height: 1.4; }
.hk-task.checked .hk-task-label { text-decoration: line-through; color: var(--t4); }

/* Periodic task highlight */
.hk-task.periodic-due {
  background: var(--accent-soft);
  border-left: 3px solid var(--accent);
}

.hk-periodic-badge {
  font-size: 10px;
  color: var(--accent-2);
  background: var(--accent-soft);
  border: 1px solid var(--accent-ring);
  border-radius: 5px;
  padding: 2px 7px;
  white-space: nowrap;
  flex-shrink: 0;
}

/* Reference photo thumbnail */
.hk-task-thumb-wrap {
  position: relative;
  cursor: pointer;
  flex-shrink: 0;
}

.hk-ref-thumb {
  width: 48px;
  height: 36px;
  border-radius: 6px;
  object-fit: cover;
  border: 1px solid var(--line);
  display: block;
}

.hk-task-thumb-wrap:hover::after {
  content: '🔍';
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.35);
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
}

/* ── End-of-block report ── */
.hk-report {
  background: var(--surface-2);
  border-top: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 14px 16px;
}

.hk-proof-section {
  background: var(--surface-2);
  border-top: 1px solid var(--line);
  display: grid;
  gap: 12px;
  padding: 14px 16px;
}

.hk-reference-block,
.hk-proof-block {
  display: grid;
  gap: 9px;
}

.hk-proof-title,
.admin-proof-title {
  align-items: center;
  color: var(--t2);
  display: flex;
  font-size: 12px;
  font-weight: 700;
  gap: 7px;
}

.hk-proof-title span {
  background: var(--accent-soft);
  border-radius: 999px;
  color: var(--accent-2);
  font-size: 11px;
  margin-left: auto;
  padding: 3px 8px;
}

.hk-proof-item {
  display: grid;
  gap: 6px;
}

.hk-proof-label {
  color: var(--t1);
  font-size: 12px;
  font-weight: 700;
}

.hk-progress-warning {
  align-items: center;
  color: var(--accent-2);
  display: flex;
  font-size: 12px;
  font-weight: 700;
  gap: 7px;
  margin-top: 6px;
}

.admin-proof-group {
  display: grid;
  gap: 10px;
}

.admin-proof-group + .admin-proof-group {
  border-top: 1px dashed var(--line-strong);
  margin-top: 14px;
  padding-top: 14px;
}

.hk-report-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--t3);
  display: flex;
  align-items: center;
  gap: 6px;
}

.hk-report-pills { display: flex; gap: 8px; flex-wrap: wrap; }

.hk-rpill {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  border-radius: 999px;
  border: 1.5px solid var(--line-strong);
  background: var(--surface);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  color: var(--t2);
  transition: all .12s;
  font-family: inherit;
}

.hk-rpill:hover { border-color: var(--accent-ring); background: var(--accent-soft); color: var(--accent-2); }
.hk-rpill.is-done { background: var(--green); border-color: var(--green); color: #fff; }
.hk-rpill.is-problem { background: var(--rose); border-color: var(--rose); color: #fff; }

.hk-report-textarea {
  width: 100%;
  box-sizing: border-box;
  border: 1px solid var(--line-strong);
  border-radius: 9px;
  padding: 8px 12px;
  font-size: 13px;
  font-family: inherit;
  resize: none;
  min-height: 58px;
  color: var(--t1);
  outline: none;
  background: var(--surface);
}

.hk-report-textarea:focus { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-ring); }

/* Photo strip */
.hk-photo-strip {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}

.hk-photo-slot {
  width: 56px;
  height: 56px;
  border-radius: 9px;
  border: 1.5px dashed var(--line-strong);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  color: var(--t3);
  cursor: pointer;
  background: var(--surface);
  transition: border-color .12s, background .12s, color .12s;
}

.hk-photo-slot:hover { border-color: var(--accent); background: var(--accent-soft); color: var(--accent); }

.hk-photo-filled {
  width: 56px;
  height: 56px;
  border-radius: 9px;
  background: var(--surface-2);
  border: 1px solid var(--line);
  position: relative;
  overflow: hidden;
}

.hk-photo-del {
  position: absolute;
  top: -3px;
  right: -3px;
  width: 18px;
  height: 18px;
  background: var(--rose);
  border-radius: 50%;
  color: #fff;
  font-size: 9px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 1;
}

/* ── Global mission footer ── */
.hk-mission-footer {
  align-items: center;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 16px;
  box-shadow: var(--shadow-2);
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 14px;
  padding: 14px;
}

.hk-progress-wrap { flex: 1; min-width: 180px; }
.hk-progress-text { font-size: 12px; color: var(--t3); margin-bottom: 5px; }
.hk-progress-bar-bg { background: var(--surface-3); border-radius: 999px; height: 6px; }
.hk-progress-bar-fill { background: var(--accent); border-radius: 999px; height: 6px; transition: width .3s; }

/* ── Lightbox ── */
#hk-lightbox {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
}

#hk-lightbox[hidden] { display: none !important; }

.hk-lb-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.7);
}

.hk-lb-box {
  position: relative;
  z-index: 1;
  max-width: 90vw;
  max-height: 90vh;
}

.hk-lb-img {
  max-width: 90vw;
  max-height: 85vh;
  border-radius: 12px;
  display: block;
}

.hk-lb-close {
  position: absolute;
  top: -14px;
  right: -14px;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: #fff;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  box-shadow: 0 2px 8px rgba(0,0,0,.3);
}

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE MOBILE — Ménage planning & housekeeper
═══════════════════════════════════════════════════════════════ */

@media (max-width: 640px) {
  /* Admin planning: stack vertically; show only active panel */
  .cleaning-layout.adm-planning-mode {
    display: block !important;
    overflow: visible;
    height: auto;
  }

  .cleaning-layout.adm-planning-mode .cleaning-list-card {
    width: 100%;
    border-radius: 12px;
    border-right: none;
    max-height: none;
    overflow: visible;
    display: flex;
    flex-direction: column;
  }

  /* When detail is open, hide list and show detail full-height */
  .cleaning-layout.adm-planning-mode[data-cleaning-panel="detail"] .cleaning-list-card {
    display: none !important;
  }

  .cleaning-layout.adm-planning-mode .cleaning-detail-card {
    display: none !important;
  }

  .cleaning-layout.adm-planning-mode[data-cleaning-panel="detail"] .cleaning-detail-card {
    display: flex !important;
    width: 100%;
    border-radius: 12px;
  }

  /* Housekeeper: same pattern */
  .cleaning-layout.hk-mode {
    display: block !important;
    overflow: visible;
    height: auto;
  }

  .cleaning-layout.hk-mode .cleaning-list-card {
    width: 100%;
    border-radius: 12px;
    border-right: none;
  }

  .cleaning-layout.hk-mode[data-cleaning-panel="detail"] .cleaning-list-card {
    display: none !important;
  }

  .cleaning-layout.hk-mode .cleaning-detail-card {
    display: none !important;
  }

  .cleaning-layout.hk-mode[data-cleaning-panel="detail"] .cleaning-detail-card {
    display: flex !important;
    width: 100%;
    border-radius: 12px;
  }

  /* Date range: stays as a single row, just smaller inputs */
  .adm-date-input {
    font-size: 10px;
    padding: 4px 4px;
  }

  /* Manual task bar: stack on mobile */
  .assign-add-task-bar {
    flex-direction: column;
    align-items: stretch;
  }

  .assign-add-group-select,
  .assign-add-task-input,
  .assign-add-task-btn {
    max-width: 100%;
    width: 100%;
  }
}

/* ═══════════════════════════════════════════════════════════════
   MÉNAGE / UTILISATEURS — Layout deux colonnes
═══════════════════════════════════════════════════════════════ */

.cln-users-layout {
  display: flex;
  flex: 1;
  min-height: 0;
  overflow: hidden;
}

/* ── Colonne gauche ─────────────────────────────────────────── */
.cln-users-list {
  background: #ffffff;
  border-right: 1px solid #e8ecf0;
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
  overflow: hidden;
  width: var(--ms-list-panel-width);
}


.cln-users-list-body {
  flex: 1;
  overflow-y: auto;
  padding: 4px 0;
}

/* ── Items de la liste ──────────────────────────────────────── */
.cln-user-item {
  align-items: center;
  background: #ffffff;
  border-bottom: 1px solid #f0f2f5;
  cursor: pointer;
  display: flex;
  gap: 12px;
  padding: 14px 16px;
  transition: background 0.15s;
}

.cln-user-item:hover {
  background: #f5f6f8;
}

.cln-user-item.active {
  background: #eaf2fb;
}

.cln-user-avatar {
  align-items: center;
  background: #e0eef8;
  border-radius: 50%;
  color: #1770a8;
  display: flex;
  flex-shrink: 0;
  font-size: 15px;
  font-weight: 700;
  height: 40px;
  justify-content: center;
  width: 40px;
}

.cln-user-info {
  flex: 1;
  min-width: 0;
}

.cln-user-name {
  font-size: 14px;
  font-weight: 600;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.cln-user-meta {
  color: #7b8492;
  font-size: 12px;
  margin-top: 2px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.cln-user-status {
  border-radius: 999px;
  flex-shrink: 0;
  font-size: 11px;
  font-weight: 700;
  padding: 4px 9px;
}

.cln-user-status-active {
  background: #e9f8f2;
  color: #12805c;
}

.cln-user-status-inactive {
  background: #eef2f7;
  color: #7b8492;
}

/* ── Colonne droite ─────────────────────────────────────────── */
.cln-users-detail {
  flex: 1;
  min-width: 0;
  overflow-y: auto;
  padding: 24px;
}

.cln-users-detail > .ms-detail-content {
  margin: 0 auto;
  max-width: 820px;
}

.cln-users-detail > .cleaning-user-detail-form {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding-bottom: 0;
}

.cln-users-detail .cleaning-users-action-bar.ms-action-bar {
  -webkit-backdrop-filter: none;
  align-items: center;
  backdrop-filter: none;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 14px;
  bottom: auto;
  box-shadow: var(--shadow-1);
  justify-content: flex-end;
  margin: 0;
  padding: 14px 18px;
  position: static;
  width: 100%;
}

[data-theme="dark"] .cln-users-detail .cleaning-users-action-bar.ms-action-bar {
  background: var(--surface);
  box-shadow: none;
}

.cln-users-detail .cleaning-users-action-bar .ms-btn-primary {
  border-radius: 999px;
  font-size: 14px;
  font-weight: 700;
  min-height: 42px;
  padding: 0 18px;
}

/* En-tête du formulaire utilisateur */
.cln-users-form-head {
  align-items: center;
  display: flex;
  gap: 14px;
  margin-bottom: 24px;
}

.cln-users-form-avatar {
  align-items: center;
  background: #e0eef8;
  border-radius: 50%;
  color: #1770a8;
  display: flex;
  flex-shrink: 0;
  font-size: 22px;
  font-weight: 700;
  height: 56px;
  justify-content: center;
  width: 56px;
}

.cln-users-form-name {
  color: #172033;
  font-size: 17px;
  font-weight: 700;
  line-height: 1.3;
}

.cln-users-form-email {
  color: #7b8492;
  font-size: 13px;
  margin-top: 2px;
}

/* Grille d'assignation des logements */
.cln-prop-assign-grid {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(auto-fill, minmax(210px, 1fr));
  margin-top: 10px;
}

.cln-prop-assign-item {
  align-items: center;
  background: #f7f9fb;
  border: 1.5px solid #e8ecf0;
  border-radius: 12px;
  cursor: pointer;
  display: flex;
  gap: 10px;
  padding: 12px 14px;
  transition: border-color 0.15s, background 0.15s;
  user-select: none;
}

.cln-prop-assign-item:has(input:checked) {
  background: #eaf2fb;
  border-color: #9dcbee;
}

.cln-prop-assign-thumb {
  border-radius: 8px;
  flex-shrink: 0;
  height: 36px;
  object-fit: cover;
  width: 36px;
}

.cln-prop-assign-fallback {
  align-items: center;
  background: #d6eaf7;
  border-radius: 8px;
  color: #1770a8;
  display: flex;
  flex-shrink: 0;
  font-size: 14px;
  font-weight: 700;
  height: 36px;
  justify-content: center;
  width: 36px;
}

.cln-prop-assign-name {
  flex: 1;
  font-size: 13px;
  font-weight: 600;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.cln-prop-assign-item input[type="checkbox"] {
  --cb-accent: #1770a8;
  flex-shrink: 0;
  height: 16px;
  width: 16px;
}

/* Bouton retour mobile — même style que inbox-back-btn */
.cln-users-back-btn {
  align-items: center;
  background: #ffffff;
  border: 1px solid #d9dde2;
  border-radius: 8px;
  color: #5a6068;
  cursor: pointer;
  display: none;
  flex-shrink: 0;
  height: 30px;
  justify-content: center;
  margin-bottom: 20px;
  padding: 0;
  width: 30px;
}

/* ── Responsive mobile ──────────────────────────────────────── */
@media (max-width: 640px) {
  .ms-task-group-head {
    grid-template-columns: 1fr;
  }

  .cleaning-icon-picker {
    justify-content: flex-start;
    max-width: none;
  }

  .cln-users-layout {
    flex-direction: column;
    overflow-y: auto;
  }

  .cln-users-list {
    border-right: none;
    flex-shrink: 0;
    overflow: visible;
    width: 100%;
  }

  .cln-users-detail {
    overflow-y: visible;
    padding: 16px;
  }

  .cln-users-layout[data-cln-users-panel="detail"] .cln-users-list {
    display: none;
  }

  .cln-users-layout:not([data-cln-users-panel="detail"]) .cln-users-detail {
    display: none;
  }

  .cln-users-back-btn {
    display: inline-flex;
  }

  .cln-prop-assign-grid {
    grid-template-columns: 1fr;
  }
}

/* ═══════════════════════════════════════════════════════════════
   LOGEMENTS — Layout deux colonnes
═══════════════════════════════════════════════════════════════ */

/* Bouton retour mobile — même style que inbox-back-btn */
.prop-back-btn {
  align-items: center;
  background: var(--surface);
  border: 1px solid var(--line-strong);
  border-radius: 8px;
  color: var(--t3);
  cursor: pointer;
  display: none;
  flex-shrink: 0;
  height: 30px;
  justify-content: center;
  margin-bottom: 16px;
  padding: 0;
  width: 30px;
}

/* Petit bouton "Nouveau" dans le header gauche */
.prop-add-btn {
  font-size: 12px;
  height: 30px;
  padding: 0 10px;
}

.prop-sort-row {
  display: grid;
  gap: 10px;
  padding: 12px 16px;
}

.prop-list-head-actions {
  align-items: center;
  display: flex;
  gap: 8px;
}

.prop-list-tools {
  display: grid;
  gap: 10px;
  padding: 12px 14px;
}

.prop-list-sort {
  position: relative;
}

.adm-task-item.is-selected {
  background: var(--accent-soft);
  border-left-color: var(--accent);
}

.adm-task-check-wrap {
  align-items: center;
  cursor: pointer;
  display: inline-flex;
  flex: 0 0 auto;
  height: 38px;
  justify-content: center;
  margin-right: -2px;
  width: 22px;
}

.adm-task-check-wrap input {
  --cb-accent: var(--accent);
  margin: 0;
}

.cleaning-bulk-bar {
  align-items: center;
  border-bottom: 1px solid var(--line);
  display: flex;
  flex-shrink: 0;
  gap: 8px;
  justify-content: space-between;
  padding: 10px 16px;
}

.cleaning-bulk-bar .ms-btn-ghost,
.cleaning-bulk-bar .ms-btn-primary {
  min-height: 36px;
  padding: 0 14px;
}

.cleaning-bulk-assign[hidden] {
  display: none;
}

.cleaning-report-bulk-resolve[hidden] {
  display: none;
}

.prop-sort-control {
  align-items: center;
  background: #ffffff;
  border: 1px solid #e2e6ea;
  border-radius: 12px;
  color: var(--ms-text-1);
  cursor: pointer;
  display: grid;
  font-family: inherit;
  gap: 2px 9px;
  grid-template-columns: auto minmax(0, 1fr);
  min-height: 46px;
  padding: 7px 10px;
  text-align: left;
  width: 100%;
}

.prop-sort-control i {
  color: var(--ms-blue);
  grid-row: 1 / span 2;
}

.prop-sort-control span {
  font-size: 13px;
  font-weight: 800;
  line-height: 1.1;
}

.prop-sort-control small {
  color: var(--ms-text-2);
  font-size: 11px;
  font-weight: 600;
  line-height: 1.25;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.prop-list-sort-menu {
  left: 0;
  right: 0;
  top: calc(100% + 7px);
  width: auto;
}

.prop-group-manage-btn {
  align-items: center;
  background: #ffffff;
  border: 1px solid #e2e6ea;
  border-radius: 10px;
  color: var(--ms-text-1);
  cursor: pointer;
  display: flex;
  font-family: inherit;
  font-size: 13px;
  font-weight: 800;
  gap: 9px;
  min-height: 38px;
  padding: 0 11px;
  width: 100%;
}

.prop-group-manage-btn i {
  color: var(--ms-blue);
}

.prop-group-manager {
  background: #ffffff;
  border: 1px solid #e2e6ea;
  border-radius: 12px;
  display: grid;
  gap: 8px;
  padding: 10px;
}

.prop-group-manager[hidden] {
  display: none;
}

.prop-group-manager-create {
  align-items: center;
  border-bottom: 1px solid #eef0f3;
  display: grid;
  gap: 8px;
  grid-template-columns: minmax(0, 1fr) 32px;
  padding-bottom: 8px;
}

.prop-group-manager-add {
  align-items: center;
  background: var(--ms-blue);
  border: 1px solid var(--ms-blue);
  border-radius: 8px;
  color: #ffffff;
  cursor: pointer;
  display: inline-flex;
  height: 32px;
  justify-content: center;
  width: 32px;
}

.prop-group-manager-row {
  align-items: center;
  display: grid;
  gap: 8px;
  grid-template-columns: minmax(0, 1fr) auto 32px;
}

.prop-group-manager-count {
  align-items: center;
  background: var(--ms-blue-bg);
  border-radius: 999px;
  color: var(--ms-blue);
  display: inline-flex;
  font-size: 11px;
  font-weight: 800;
  height: 24px;
  justify-content: center;
  min-width: 24px;
  padding: 0 7px;
}

.prop-group-manager-delete {
  align-items: center;
  background: #fff7f7;
  border: 1px solid #ffd4d4;
  border-radius: 8px;
  color: #dc2626;
  cursor: pointer;
  display: inline-flex;
  height: 32px;
  justify-content: center;
  width: 32px;
}

.prop-group-filter {
  position: relative;
}

.prop-group-filter-toggle {
  align-items: center;
  background: #ffffff;
  border: 1px solid #e2e6ea;
  border-radius: 10px;
  color: var(--ms-text-1);
  cursor: pointer;
  display: grid;
  font-family: inherit;
  gap: 2px 9px;
  grid-template-columns: auto 1fr;
  min-height: 42px;
  padding: 8px 11px;
  text-align: left;
  width: 100%;
}

.prop-group-filter-toggle i {
  color: var(--ms-blue);
  grid-row: 1 / span 2;
}

.prop-group-filter-toggle span {
  font-size: 13px;
  font-weight: 800;
}

.prop-group-filter-toggle small {
  color: var(--ms-text-2);
  font-size: 11px;
  font-weight: 600;
}

.prop-group-filter-popover {
  background: #ffffff;
  border: 1px solid #d9dde2;
  border-radius: 14px;
  box-shadow: 0 18px 38px rgba(20, 28, 36, .16);
  display: none;
  gap: 10px;
  grid-template-columns: minmax(86px, .65fr) minmax(0, 1.35fr);
  left: 0;
  padding: 10px;
  position: absolute;
  right: 0;
  top: calc(100% + 7px);
  z-index: 760;
}

.prop-group-filter.open .prop-group-filter-popover {
  display: grid;
}

.prop-group-filter-col {
  display: grid;
  gap: 6px;
}

.prop-group-filter-col-left {
  border-right: 1px solid #eef0f3;
  padding-right: 10px;
}

.prop-group-filter-option {
  align-items: center;
  border-radius: 9px;
  color: var(--ms-text-2);
  cursor: pointer;
  display: flex;
  font-size: 12px;
  font-weight: 700;
  gap: 8px;
  min-height: 34px;
  padding: 0 8px;
}

.prop-group-filter-option:hover,
.prop-group-filter-option:has(input:checked) {
  background: var(--ms-blue-bg);
  color: var(--ms-blue);
}

.prop-group-filter-option input {
  --cb-accent: var(--ms-blue);
}

.prop-group-section {
  border-bottom: 1px solid #edf0f4;
  padding: 10px 0 12px;
}

.prop-group-section-title {
  color: var(--ms-text-2);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .03em;
  padding: 2px 16px 8px;
  text-transform: uppercase;
}

.prop-group-section-list {
  display: grid;
  gap: 6px;
  padding: 0 8px;
}

.page-split-tabs {
  display: none;
}

.property-tabs {
  align-items: center;
  background: rgba(255, 255, 255, 0.94);
  border: 1px solid #e4e8ee;
  border-radius: 12px;
  box-shadow: 0 8px 22px rgba(28, 37, 48, 0.06);
  display: flex;
  gap: 4px;
  margin-bottom: 14px;
  overflow-x: auto;
  padding: 4px;
  position: sticky;
  scrollbar-width: none;
  top: 0;
  z-index: 35;
}

.property-detail-form > [data-property-panel] {
  display: grid;
  gap: 14px;
}

.property-detail-form > [data-property-panel][hidden] {
  display: none !important;
}

.property-detail-form .ms-field-input:is(select) {
  appearance: none;
  background-image:
    linear-gradient(45deg, transparent 50%, var(--ms-text-2) 50%),
    linear-gradient(135deg, var(--ms-text-2) 50%, transparent 50%);
  background-position:
    calc(100% - 15px) 50%,
    calc(100% - 10px) 50%;
  background-repeat: no-repeat;
  background-size: 5px 5px, 5px 5px;
  padding-right: 30px;
}

.property-detail-form .ms-field-input:is(select):disabled {
  background-color: #f3f5f8;
  color: var(--ms-text-3);
  cursor: not-allowed;
}

.property-plan-label {
  margin-top: 12px;
}

.property-photo-count {
  color: var(--ms-text-2);
  font-weight: 400;
}

.form-field-wide {
  grid-column: 1 / -1;
}

.property-stay-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.property-layout-stack {
  display: grid;
  gap: 14px;
  margin-top: 16px;
}

.property-layout-stack[hidden] {
  display: none !important;
}

.property-sub-card {
  background: #ffffff;
  border: 1px solid var(--ms-border-light);
  border-radius: 14px;
  overflow: hidden;
}

.property-access-choice {
  margin-bottom: 12px;
}

.property-toilet-list {
  display: grid;
  gap: 10px;
}

.property-toilet-row {
  align-items: center;
  background: var(--ms-surface-2);
  border: 1px solid var(--ms-border-light);
  border-radius: 12px;
  display: flex;
  gap: 14px;
  justify-content: space-between;
  padding: 10px 12px;
}

.property-toilet-row .property-access-choice {
  margin-bottom: 0;
}

.property-map-preview {
  background: var(--ms-surface-2);
  border: 1px solid var(--ms-border-light);
  border-radius: 14px;
  min-height: 220px;
  overflow: hidden;
  position: relative;
}

.property-map-canvas {
  height: 260px;
  width: 100%;
}

.property-map-empty {
  align-items: center;
  color: var(--ms-text-2);
  display: flex;
  flex-direction: column;
  font-size: 13px;
  gap: 8px;
  inset: 0;
  justify-content: center;
  padding: 18px;
  position: absolute;
  text-align: center;
}

.property-map-empty i {
  color: var(--ms-blue);
  font-size: 24px;
}

.property-map-preview.has-map .property-map-empty {
  display: none;
}

.property-map-actions {
  display: flex;
  justify-content: flex-end;
  margin-top: 10px;
}

.property-map-actions .disabled {
  opacity: .45;
  pointer-events: none;
}

.property-action-bar {
  align-self: flex-end;
}

.map-info {
  position: relative;
}

.map-help-tooltip {
  background: #ffffff;
  border: 1px solid #d9dde2;
  border-radius: 14px;
  box-shadow: 0 18px 44px rgba(20, 28, 36, 0.18);
  color: var(--ms-text-1);
  display: none;
  font-size: 12px;
  font-weight: 600;
  left: -10px;
  line-height: 1.35;
  padding: 10px;
  position: absolute;
  text-transform: none;
  top: calc(100% + 9px);
  width: min(320px, calc(100vw - 48px));
  z-index: 5000;
}

.map-help-tooltip img {
  border-radius: 10px;
  display: block;
  height: auto;
  margin-top: 8px;
  max-height: 190px;
  object-fit: contain;
  width: 100%;
}

.map-info:hover .map-help-tooltip,
.map-info:focus .map-help-tooltip,
.map-info:focus-within .map-help-tooltip {
  display: block;
}

.ms-card:has(.map-info:hover),
.ms-card:has(.map-info:focus),
.ms-card:has(.map-info:focus-within) {
  overflow: visible;
  position: relative;
  z-index: 300;
}

.property-gallery-drop + .property-gallery {
  margin-top: 12px;
}

.ttlock-access-window {
  margin-bottom: 10px;
}

.property-tabs::-webkit-scrollbar {
  display: none;
}

.property-tab {
  background: transparent;
  border: 0;
  border-radius: 9px;
  color: var(--ms-text-2);
  cursor: pointer;
  flex: 0 0 auto;
  font-family: inherit;
  font-size: 13px;
  font-weight: 700;
  line-height: 1;
  min-height: 34px;
  padding: 0 12px;
  transition: background 0.14s ease, color 0.14s ease, box-shadow 0.14s ease;
  white-space: nowrap;
}

.property-tab:hover {
  background: #f1f4f8;
  color: var(--ms-text-1);
}

.property-tab.active {
  background: #ffffff;
  box-shadow: 0 2px 9px rgba(28, 37, 48, 0.12);
  color: var(--ms-blue);
}

.property-placeholder-card .empty-state {
  min-height: 120px;
}

.property-capacity-grid {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin-top: 16px;
}

.property-capacity-hint {
  line-height: 1.45;
  margin-top: 8px;
}

.property-surface-field {
  margin-top: 14px;
}

.property-settings-block {
  border-top: 1px solid var(--ms-border-light);
  margin-top: 16px;
  padding-top: 16px;
}

.property-group-create {
  align-items: center;
  display: grid;
  gap: 10px;
  grid-template-columns: minmax(0, 1fr) auto;
}

.property-group-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

.property-group-check {
  align-items: center;
  background: var(--ms-surface-2);
  border: 1.5px solid var(--ms-border);
  border-radius: 999px;
  color: var(--ms-text-2);
  cursor: pointer;
  display: inline-flex;
  font-size: 13px;
  font-weight: 700;
  gap: 7px;
  min-height: 34px;
  padding: 0 12px;
}

.property-group-check:has(input:checked) {
  background: var(--ms-blue-bg);
  border-color: var(--ms-blue);
  color: var(--ms-blue);
}

.property-group-check input {
  --cb-accent: var(--ms-blue);
}

.property-settings-label {
  color: var(--ms-text-2);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .03em;
  margin-bottom: 10px;
  text-transform: uppercase;
}

.property-context-panel {
  background: #f7f9fb;
  border: 1px solid var(--ms-border-light);
  border-radius: 12px;
  margin-top: 14px;
  padding: 14px;
}

.property-context-title,
.property-time-title {
  align-items: center;
  color: var(--ms-text-1);
  display: flex;
  font-size: 13px;
  font-weight: 800;
  gap: 8px;
  margin-bottom: 10px;
}

.property-context-title i,
.property-time-title i {
  color: var(--ms-text-2);
}

.property-mini-grid,
.property-time-grid {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.property-time-card {
  background: #ffffff;
  border: 1px solid var(--ms-border-light);
  border-radius: 12px;
  padding: 14px;
}

.property-time-selects {
  align-items: center;
  display: grid;
  gap: 6px;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
}

.property-time-selects select {
  min-width: 0;
}

.property-time-arrow {
  color: var(--ms-text-2);
  font-weight: 800;
  text-align: center;
}

.field-info {
  align-items: center;
  background: #eef2f7;
  border-radius: 999px;
  color: var(--ms-text-2);
  cursor: help;
  display: inline-flex;
  font-size: 10px;
  font-style: normal;
  height: 16px;
  justify-content: center;
  margin-left: 4px;
  text-transform: none;
  width: 16px;
}

.property-mobile-menu {
  background: #ffffff;
  border: 1px solid #e4e8ee;
  border-radius: 16px;
  box-shadow: 0 8px 24px rgba(28, 37, 48, 0.08);
  overflow: hidden;
}

.property-mobile-menu-item {
  align-items: center;
  background: #ffffff;
  border: 0;
  border-bottom: 1px solid #edf0f4;
  color: var(--ms-text-1);
  cursor: pointer;
  display: flex;
  font-family: inherit;
  font-size: 15px;
  font-weight: 500;
  justify-content: space-between;
  min-height: 54px;
  padding: 0 16px;
  text-align: left;
  width: 100%;
}

.property-mobile-menu-item:last-child {
  border-bottom: 0;
}

.property-mobile-menu-item span {
  align-items: center;
  display: flex;
  gap: 12px;
  min-width: 0;
}

.property-mobile-menu-item span i {
  align-items: center;
  background: var(--ms-blue-bg);
  border-radius: 9px;
  color: var(--ms-blue);
  display: flex;
  flex-shrink: 0;
  height: 30px;
  justify-content: center;
  width: 30px;
}

.property-mobile-menu-item > i {
  color: var(--ms-text-3);
  font-size: 12px;
}

.city-autocomplete {
  position: relative;
}

.city-autocomplete-menu {
  background: #ffffff;
  border: 1px solid var(--ms-border);
  border-radius: 12px;
  box-shadow: 0 16px 36px rgba(20, 28, 36, 0.14);
  left: 0;
  max-height: 280px;
  overflow-y: auto;
  padding: 6px;
  position: absolute;
  right: 0;
  top: calc(100% + 6px);
  z-index: 620;
}

.ms-card:has(.city-autocomplete-menu:not([hidden])) {
  overflow: visible;
  position: relative;
  z-index: 80;
}

.city-result {
  background: transparent;
  border: 0;
  border-radius: 9px;
  color: var(--ms-text-1);
  cursor: pointer;
  display: block;
  font-family: inherit;
  padding: 10px 11px;
  text-align: left;
  width: 100%;
}

.city-result:hover {
  background: var(--ms-blue-bg);
}

.city-result-name {
  display: block;
  font-size: 13px;
  font-weight: 700;
}

.city-result-meta {
  color: var(--ms-text-2);
  display: block;
  font-size: 12px;
  margin-top: 2px;
}

/* ====================================================================== */
/*  LOGEMENTS — refonte colonne unique (style experience picker)         */
/* ====================================================================== */
.page-split.prop-mode {
  display: block;
  overflow-y: auto;
  background: var(--surface-2);
}
.page-split.prop-mode .page-split-list {
  width: 100%;
  max-width: 1140px;
  margin: 0 auto;
  border-right: 0;
  border-bottom: 0;
  max-height: none;
  overflow: visible;
  padding: 26px 24px 56px;
  box-sizing: border-box;
  background: transparent;
}
.page-split.prop-mode .page-split-detail {
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
}
/* Le panneau intermédiaire "tabs" n'est utilisé qu'en vrai mobile */
.page-split.prop-mode .page-split-tabs { display: none; }

/* Bascule liste / détail à TOUTES les largeurs (la sélection pose data-prop-panel) */
.page-split.prop-mode[data-prop-panel="detail"] .page-split-list,
.page-split.prop-mode[data-prop-panel="tabs"] .page-split-list { display: none; }
.page-split.prop-mode:not([data-prop-panel="detail"]) .page-split-detail { display: none; }

/* En-tête de la liste */
.prop-mode .page-split-list-hd { padding: 0 2px 4px; }
.prop-mode .panel-list-title { font-size: 24px; font-weight: 800; letter-spacing: -0.02em; }
.prop-mode .prop-add-btn { font-size: 13.5px; font-weight: 700; padding: 9px 16px; }
.prop-mode .pg-search { margin: 14px 0; max-width: 480px; }
/* Outils Trier / Groupes : compacts et en ligne */
.prop-mode .pg-list-tools { margin-bottom: 18px; display: flex; flex-wrap: wrap; gap: 10px; align-items: flex-start; }
.prop-mode .pg-list-tools .prop-list-sort,
.prop-mode .pg-list-tools .prop-list-group { position: relative; }
.prop-mode .pg-list-tools .prop-sort-control { width: auto; }

/* Bouton retour visible à toutes les largeurs dans le détail, aligné à gauche */
.page-split.prop-mode .page-split-detail .prop-back-btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 40px; height: 40px; border-radius: 10px;
  border: 1px solid var(--line-strong); background: var(--surface);
  color: var(--t1); cursor: pointer; margin: 0 0 16px; font-size: 15px;
  align-self: flex-start; position: static;
}
.page-split.prop-mode .page-split-detail .prop-back-btn:hover { border-color: var(--accent); color: var(--accent); }

/* Grille de cartes par groupe */
.prop-mode .prop-group-section { margin-bottom: 26px; }
.prop-mode .prop-group-section-title { font-size: 13px; font-weight: 800; letter-spacing: .04em; text-transform: uppercase; color: var(--t3); margin: 0 0 12px; padding: 0 2px; }
.prop-mode .pg-prop-list .prop-group-section-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(248px, 1fr));
  gap: 16px;
  padding: 0;
}

/* Carte logement (verticale) */
.prop-mode .pg-prop-list .pg-prop-row {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0;
  border: 1px solid var(--line);
  border-radius: 16px;
  overflow: hidden;
  background: var(--surface);
  cursor: pointer;
  padding: 0;
  text-align: left;
  transition: border-color .18s ease, box-shadow .18s ease, transform .15s ease;
}
.prop-mode .pg-prop-row:hover { border-color: var(--accent-ring, var(--line-strong)); box-shadow: 0 12px 30px -14px rgba(0,0,0,.22); transform: translateY(-2px); }
.prop-mode .pg-prop-row.is-active { border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent); }
.prop-mode .pg-prop-row .pg-photo {
  width: 100%;
  height: 138px;
  border-radius: 0;
  flex-shrink: 0;
  display: grid;
  place-items: center;
  font-size: 30px;
  font-weight: 800;
  color: #fff;
  background: linear-gradient(135deg, var(--accent), var(--accent-2, var(--accent)));
  overflow: hidden;
}
.prop-mode .pg-prop-row .pg-photo img { width: 100%; height: 100%; object-fit: cover; }
.prop-mode .pg-prop-main { padding: 13px 15px 15px; display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.prop-mode .pg-prop-name { font-size: 15.5px; font-weight: 750; color: var(--t1); white-space: normal; line-height: 1.25; }
.prop-mode .pg-prop-city { font-size: 12.5px; color: var(--t3); }
.prop-mode .pg-prop-city i { color: var(--accent); margin-right: 5px; }
.prop-mode .pg-prop-meta { display: flex; align-items: center; gap: 8px; font-size: 12px; color: var(--t2); margin-top: 2px; }
.prop-mode .pg-meta-sep { width: 3px; height: 3px; border-radius: 50%; background: var(--line-strong); }
.prop-mode .pg-prop-meta i { margin-right: 3px; color: var(--t3); }
/* Poignée de réordonnancement : discrète, sur la photo */
.prop-mode .pg-prop-row .ms-prop-grip {
  position: absolute; top: 8px; left: 8px; z-index: 2;
  width: 26px; height: 26px; border-radius: 7px;
  background: rgba(0,0,0,.4); color: #fff;
  display: grid; place-items: center; cursor: grab; opacity: 0;
  transition: opacity .15s ease;
}
.prop-mode .pg-prop-row:hover .ms-prop-grip { opacity: 1; }

/* ═══════════════════ Réservations : menu central unique ═══════════════════ */
/* Même logique que la page Logements : plus de colonne à gauche, tout est */
/* centré dans le menu principal ; la sélection bascule liste ↔ détail.      */
.page-split.reservations-mode {
  display: block;
  overflow-y: auto;
  background: var(--surface-2);
}
/* Le corps de liste ne doit pas créer sa propre boîte de scroll, sinon il
   rogne le menu déroulant « Logements ». Le scroll est porté par le split. */
.reservations-mode .page-split-list-body {
  overflow: visible;
}
.page-split.reservations-mode .page-split-list {
  width: 100%;
  max-width: 1180px;
  margin: 0 auto;
  border-right: 0;
  border-bottom: 0;
  max-height: none;
  overflow: visible;
  padding: 26px 24px 56px;
  box-sizing: border-box;
  background: transparent;
}
.page-split.reservations-mode .page-split-detail {
  width: 100%;
  max-width: 1120px;
  margin: 0 auto;
  border: 0;
  overflow: visible;
  background: transparent;
}
/* Bascule liste / détail à toutes les largeurs */
.page-split.reservations-mode[data-res-panel="detail"] .page-split-list { display: none; }
.page-split.reservations-mode:not([data-res-panel="detail"]) .page-split-detail { display: none; }

/* En-tête type "picker" (réutilise les classes de la page Logements) */
.reservations-mode .reservation-picker-head { border-bottom: 0; }

/* Barre d'outils centrée : recherche + dates + filtre logement, sans cadre */
.reservations-mode .reservation-toolbar {
  border-bottom: 0;
  padding: 0 0 6px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
}
.reservations-mode .reservation-toolbar .res-search-wrap {
  flex: 1 1 320px;
  max-width: 520px;
}
.reservations-mode .reservation-toolbar .reservation-filter-row { margin: 0; }
.reservations-mode .reservation-toolbar .date-picker { min-width: 130px; }

/* Liste des réservations en grille de cartes */
.reservations-mode .reservation-choice-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 14px;
  margin-top: 18px;
}

/* Le contenu du détail remplit le panneau central (la limite 820px globale
   bridait la table de facturation). */
.reservations-mode .ms-detail-content { max-width: none; }

/* Bouton « Rechercher » : compact, pas pleine largeur */
.reservations-mode .reservation-toolbar .reservation-search-btn {
  flex: 0 0 auto;
  width: auto;
}

/* Bouton retour dans le détail, aligné à gauche, visible partout */
.page-split.reservations-mode .page-split-detail .prop-back-btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 40px; height: 40px; border-radius: 10px;
  border: 1px solid var(--line-strong); background: var(--surface);
  color: var(--t1); cursor: pointer; margin: 0 0 16px; font-size: 15px;
  position: static;
}
.page-split.reservations-mode .page-split-detail .prop-back-btn:hover {
  border-color: var(--accent); color: var(--accent);
}

/* Mobile toggle — uniquement pour la page Logements */
@media (max-width: 640px) {
  .page-split.prop-mode {
    flex-direction: column;
    overflow-y: auto;
  }

  .page-split.prop-mode .page-split-list {
    border-bottom: none;
    border-right: none;
    flex-shrink: 0;
    max-height: none;
    overflow: visible;
    width: 100%;
  }

  .page-split.prop-mode .page-split-detail {
    overflow-y: visible;
    padding: 16px;
  }

  .page-split.prop-mode .page-split-tabs {
    display: none;
    overflow-y: visible;
    padding: 16px;
    width: 100%;
  }

  .property-tabs {
    display: none;
  }

  .property-capacity-grid,
  .property-mini-grid,
  .property-time-grid {
    grid-template-columns: 1fr;
  }

  .property-group-create {
    grid-template-columns: 1fr;
  }

  .property-time-selects {
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  }

  .page-split.prop-mode[data-prop-panel="tabs"] .page-split-list,
  .page-split.prop-mode[data-prop-panel="detail"] .page-split-list {
    display: none;
  }

  .page-split.prop-mode[data-prop-panel="tabs"] .page-split-tabs {
    display: block;
  }

  .page-split.prop-mode:not([data-prop-panel="detail"]) .page-split-detail {
    display: none;
  }

  .page-split.prop-mode[data-prop-panel="detail"] .page-split-tabs,
  .page-split.prop-mode:not([data-prop-panel]) .page-split-tabs {
    display: none;
  }

  .prop-back-btn {
    display: inline-flex;
  }

  /* Mobile toggle — page Utilisateurs */
  .page-split.users-mode {
    flex-direction: column;
    overflow-y: auto;
  }

  .page-split.users-mode .page-split-list {
    border-bottom: none;
    border-right: none;
    flex-shrink: 0;
    max-height: none;
    overflow: visible;
    width: 100%;
  }

  .page-split.users-mode .page-split-detail {
    overflow-y: visible;
    padding: 16px;
  }

  .page-split.users-mode[data-users-panel="detail"] .page-split-list {
    display: none;
  }

  .page-split.users-mode:not([data-users-panel="detail"]) .page-split-detail {
    display: none;
  }
}

/* ═══════════════════════════════════════════════════════
   Page Cautions (deposit.html)
   ═══════════════════════════════════════════════════════ */

/* ── Groupes accordéon ── */
[data-deposit-groups] {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 12px 14px;
}

.deposit-group {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 9px;
  overflow: hidden;
}

.deposit-group-hd {
  align-items: center;
  background: transparent;
  border: none;
  color: var(--t2);
  cursor: pointer;
  display: flex;
  font-family: inherit;
  font-size: 12.5px;
  font-weight: 500;
  gap: 9px;
  min-height: 46px;
  padding: 0 12px;
  text-align: left;
  transition: background .15s, color .15s;
  width: 100%;
}

.deposit-group-hd:hover { background: var(--surface-2); color: var(--t1); }

.deposit-group-icon { font-size: 12px; flex-shrink: 0; }
.dep-gicon-pending  { color: var(--t3); }
.dep-gicon-active   { color: var(--accent); }
.dep-gicon-checkout { color: var(--accent-2); }
.dep-gicon-expired  { color: var(--rose); }
.dep-gicon-closed   { color: var(--green); }

.deposit-group-label { flex: 1; }

.deposit-group-count {
  background: var(--surface-3);
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--t2);
  flex-shrink: 0;
  font-size: 11.5px;
  font-weight: 700;
  padding: 2px 8px;
}

.deposit-group-chevron {
  color: var(--t4);
  font-size: 11px;
  transition: transform .2s;
}

.deposit-group.open > .deposit-group-hd {
  background: var(--accent-soft);
  color: var(--accent-2);
}
.deposit-group.open > .deposit-group-hd .deposit-group-icon  { color: var(--accent); }
.deposit-group.open > .deposit-group-hd .deposit-group-count { background: var(--accent-ring); border-color: transparent; color: var(--accent-2); }
.deposit-group.open > .deposit-group-hd .deposit-group-chevron { color: var(--accent-2); transform: rotate(180deg); }

.deposit-group-body { display: none; }
.deposit-group.open .deposit-group-body { border-top: 1px solid var(--line); display: block; }

/* ── Items de liste ── */
.deposit-item {
  align-items: center;
  border-bottom: 1px solid var(--line);
  cursor: pointer;
  display: flex;
  gap: 10px;
  justify-content: space-between;
  padding: 10px 16px;
  transition: background .1s;
}

.deposit-item:hover  { background: var(--surface-2); }
.deposit-item.active { background: var(--accent-soft); border-left: 3px solid var(--accent); padding-left: 13px; }
.deposit-item.active .deposit-item-name { color: var(--accent-2); }
.deposit-item.active .deposit-item-sub  { color: var(--accent); opacity: .7; }

.deposit-item-main { flex: 1; min-width: 0; }

.deposit-item-name {
  color: var(--t1);
  font-size: 13px;
  font-weight: 700;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.deposit-item-sub {
  color: var(--t3);
  font-size: 11px;
  margin-top: 2px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.deposit-item-right {
  align-items: flex-end;
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
  gap: 4px;
}

.deposit-item-amount { color: var(--t2); font-size: 11.5px; font-weight: 700; }

.deposit-empty-row { color: var(--t4); font-size: 12px; padding: 12px 16px; }

/* ── Pills statut ── */
.dep-pill {
  border-radius: 4px;
  flex-shrink: 0;
  font-size: 10.5px;
  font-weight: 700;
  padding: 2px 7px;
  white-space: nowrap;
}

.dep-st-not-sent   { background: var(--surface-3);   border: 1px solid var(--line); color: var(--t3); }
.dep-st-link-sent  { background: var(--accent-soft);  color: var(--accent-2); }
.dep-st-authorized { background: var(--green-soft);   color: var(--green); }
.dep-st-expired    { background: var(--rose-soft);    color: var(--rose); }
.dep-st-captured   { background: var(--surface-3);   border: 1px solid var(--line); color: var(--t2); }
.dep-st-released   { background: var(--green-soft);   color: var(--green); }

/* ── Badges expiration ── */
.dep-expiry-badge {
  border-radius: 4px;
  font-size: 10px;
  font-weight: 700;
  padding: 2px 6px;
  white-space: nowrap;
}

.dep-expiry-warn   { background: var(--accent-soft);  color: var(--accent-2); }
.dep-expiry-urgent { background: var(--rose-soft);    color: var(--rose); }

/* ── Bannière statut (panneau détail) ── */
.dep-status-banner {
  align-items: center;
  border-radius: 10px;
  display: flex;
  gap: 12px;
  margin-bottom: 14px;
  padding: 12px 14px;
}

.dep-banner-not-sent   { background: var(--surface-2);  border: 1px solid var(--line); }
.dep-banner-link-sent  { background: var(--accent-soft); border: 1px solid var(--accent-ring); }
.dep-banner-authorized { background: var(--green-soft);  border: 1px solid var(--green-soft); }
.dep-banner-expired    { background: var(--rose-soft);   border: 1px solid var(--rose-soft); }
.dep-banner-captured   { background: var(--surface-2);   border: 1px solid var(--line); }
.dep-banner-released   { background: var(--green-soft);  border: 1px solid var(--green-soft); }

.dep-status-icon {
  align-items: center;
  border-radius: 50%;
  display: flex;
  flex-shrink: 0;
  font-size: 15px;
  height: 36px;
  justify-content: center;
  width: 36px;
}

.dep-banner-not-sent   .dep-status-icon { background: var(--surface-3); color: var(--t3); }
.dep-banner-link-sent  .dep-status-icon { background: var(--accent-ring); color: var(--accent); }
.dep-banner-authorized .dep-status-icon { background: var(--green-soft); color: var(--green); }
.dep-banner-expired    .dep-status-icon { background: var(--rose-soft);  color: var(--rose); }
.dep-banner-captured   .dep-status-icon { background: var(--surface-3);  color: var(--t2); }
.dep-banner-released   .dep-status-icon { background: var(--green-soft); color: var(--green); }

.dep-status-info { min-width: 0; }

.dep-status-label { color: var(--t1); font-size: 13px; font-weight: 700; }
.dep-status-sub   { color: var(--t3); font-size: 11.5px; margin-top: 2px; }

/* ── Grille infos clés ── */
.dep-key-grid {
  display: grid;
  gap: 8px;
  grid-template-columns: 1fr 1fr;
  margin-bottom: 14px;
}

.dep-key-item {
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 9px 11px;
}

.dep-key-label {
  color: var(--t3);
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: .3px;
  margin-bottom: 3px;
  text-transform: uppercase;
}

.dep-key-value  { color: var(--t1); font-size: 13px; font-weight: 600; }
.dep-key-warn   { color: var(--accent-2); }
.dep-key-urgent { color: var(--rose); }

/* ── Boutons d'action ── */
.dep-actions {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 14px;
}

.dep-action-btn {
  align-items: center;
  border: none;
  border-radius: 9px;
  cursor: pointer;
  display: flex;
  font-family: inherit;
  font-size: 13px;
  font-weight: 600;
  gap: 8px;
  justify-content: center;
  padding: 11px 16px;
  transition: opacity .15s, filter .15s;
  width: 100%;
}

.dep-action-btn:hover    { filter: brightness(.93); }
.dep-action-primary      { background: var(--accent);    color: #fff; }
.dep-action-success      { background: var(--green);     color: #fff; }
.dep-action-danger       { background: var(--rose);      color: #fff; }
.dep-action-secondary    { background: var(--surface-2); border: 1px solid var(--line); color: var(--t1); }
.dep-action-secondary:hover { background: var(--surface-3); filter: none; }

/* ── Actions formulaire ── */
.ms-detail-actions {
  display: flex;
  gap: 10px;
  justify-content: flex-end;
  margin-top: 14px;
}

/* ── Filtres rapides ── */
.dep-filter-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 10px 14px;
  border-bottom: 1px solid var(--line);
}

.dep-filter-pill {
  align-items: center;
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--t3);
  cursor: pointer;
  display: inline-flex;
  font-family: inherit;
  font-size: 11.5px;
  font-weight: 600;
  gap: 5px;
  padding: 4px 12px;
  transition: background .13s, color .13s, border-color .13s;
  white-space: nowrap;
}
.dep-filter-pill:hover    { background: var(--surface-3); color: var(--t1); }
.dep-filter-pill.active   { background: var(--accent-soft); border-color: var(--accent-ring); color: var(--accent-2); }
.dep-filter-count {
  background: var(--accent);
  border-radius: 999px;
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  line-height: 1.4;
  min-width: 16px;
  padding: 0 5px;
  text-align: center;
}

/* ── Point coloré sur les items de liste ── */
.dep-item-dot {
  border-radius: 50%;
  flex-shrink: 0;
  height: 8px;
  width: 8px;
}
.dep-dot-not-sent   { background: var(--t4); }
.dep-dot-link-sent  { background: var(--accent); }
.dep-dot-authorized { background: var(--green); }
.dep-dot-refused    { background: var(--rose); }
.dep-dot-expired    { background: var(--rose); }
.dep-dot-captured   { background: var(--t3); }
.dep-dot-released   { background: var(--green); }

/* ── Nouveaux statuts pill ── */
.dep-st-refused  { background: var(--rose-soft); color: var(--rose); }

/* ── Nouveaux statuts bannière ── */
.dep-banner-refused { background: var(--rose-soft); border: 1px solid var(--rose-soft); }
.dep-banner-refused .dep-status-icon { background: var(--rose-soft); color: var(--rose); }

/* ── Nouveaux icônes groupes ── */
.dep-gicon-link-sent { color: var(--accent); }
.dep-gicon-refused   { color: var(--rose); }

/* ── ID Stripe monospace ── */
.dep-key-mono { font-family: 'Menlo', 'Consolas', monospace; font-size: 11px; letter-spacing: .02em; }

/* ── Bloc code boîte à clés ── */
.dep-keycode-block {
  align-items: center;
  border-radius: 10px;
  display: flex;
  gap: 12px;
  margin-bottom: 14px;
  padding: 12px 14px;
}
.dep-keycode-locked { background: var(--surface-2);  border: 1px solid var(--line); }
.dep-keycode-ready  { background: var(--accent-soft); border: 1px solid var(--accent-ring); }
.dep-keycode-sent   { background: var(--green-soft);  border: 1px solid rgba(30,158,95,.2); }

.dep-keycode-icon {
  align-items: center;
  border-radius: 8px;
  display: flex;
  flex-shrink: 0;
  font-size: 14px;
  height: 32px;
  justify-content: center;
  width: 32px;
}
.dep-keycode-locked .dep-keycode-icon { background: var(--surface-3); color: var(--t4); }
.dep-keycode-ready  .dep-keycode-icon { background: var(--accent-ring); color: var(--accent); }
.dep-keycode-sent   .dep-keycode-icon { background: rgba(30,158,95,.12); color: var(--green); }

.dep-keycode-info    { flex: 1; min-width: 0; }
.dep-keycode-label   { color: var(--t1); font-size: 12.5px; font-weight: 700; }
.dep-keycode-sub     { color: var(--t3); font-size: 11px; margin-top: 1px; }

.dep-keycode-action {
  align-items: center;
  border-radius: 8px;
  border: 1px solid transparent;
  cursor: pointer;
  display: flex;
  flex-shrink: 0;
  font-family: inherit;
  font-size: 11.5px;
  font-weight: 600;
  gap: 5px;
  padding: 6px 12px;
  transition: opacity .15s;
  white-space: nowrap;
}
.dep-keycode-action:hover { opacity: .8; }
.dep-keycode-send   { background: var(--accent); color: #fff; }
.dep-keycode-cancel { background: var(--surface-3); border-color: var(--line); color: var(--t2); }

/* ── Historique ── */
.dep-history-block {
  border-top: 1px solid var(--line);
  margin-top: 14px;
  padding-top: 12px;
}
.dep-history-summary {
  align-items: center;
  color: var(--t3);
  cursor: pointer;
  display: flex;
  font-size: 12px;
  font-weight: 600;
  gap: 7px;
  list-style: none;
  padding: 4px 0;
  user-select: none;
}
.dep-history-summary::-webkit-details-marker { display: none; }
.dep-history-summary:hover { color: var(--t1); }
.dep-history-list {
  border-left: 2px solid var(--line);
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-left: 6px;
  margin-top: 10px;
  padding-left: 14px;
}
.dep-history-entry {
  align-items: baseline;
  display: flex;
  gap: 10px;
  padding: 5px 0;
  position: relative;
}
.dep-history-dot {
  background: var(--line-strong);
  border-radius: 50%;
  flex-shrink: 0;
  height: 7px;
  left: -18px;
  position: absolute;
  top: 9px;
  width: 7px;
}
.dep-history-ts    { color: var(--t4); font-size: 11px; flex-shrink: 0; }
.dep-history-event { color: var(--t2); font-size: 12px; }

/* ── Paramètres caution ── */
.dep-settings-help {
  color: var(--t3);
  font-size: 12px;
  margin-bottom: 14px;
  margin-top: 2px;
}
.dep-ota-grid {
  display: flex;
  flex-direction: column;
  gap: 0;
  border: 1px solid var(--line);
  border-radius: 10px;
  overflow: hidden;
}
.dep-ota-row {
  align-items: center;
  border-bottom: 1px solid var(--line);
  display: flex;
  gap: 12px;
  justify-content: space-between;
  padding: 11px 14px;
}
.dep-ota-row:last-child { border-bottom: none; }
.dep-ota-row.dep-ota-disabled { opacity: .55; }
.dep-ota-left  { display: flex; flex-direction: column; gap: 1px; }
.dep-ota-label { color: var(--t1); font-size: 13px; font-weight: 600; }
.dep-ota-note  { color: var(--t4); font-size: 11px; }
.dep-ota-toggle { flex-shrink: 0; }

/* Connexion Stripe */
.dep-stripe-status {
  align-items: flex-start;
  border-radius: 10px;
  display: flex;
  gap: 12px;
  padding: 12px 14px;
}
.dep-stripe-off {
  background: var(--surface-2);
  border: 1px solid var(--line);
  color: var(--t3);
}
.dep-stripe-off > i { font-size: 18px; flex-shrink: 0; margin-top: 2px; }
.dep-stripe-label { color: var(--t2); font-size: 13px; font-weight: 600; }
.dep-stripe-sub   { color: var(--t4); font-size: 11.5px; margin-top: 3px; line-height: 1.5; }

/* ── Mobile ── */
@media (max-width: 860px) {
  [data-deposit-split] {
    flex-direction: column;
    overflow-y: auto;
  }

  [data-deposit-split] .page-split-list {
    border-right: none;
    flex-shrink: 0;
    max-height: none;
    overflow: visible;
    width: 100%;
  }

  [data-deposit-split] .page-split-detail {
    flex-shrink: 0;
    overflow-y: visible;
    padding: 16px;
    width: 100%;
  }

  [data-deposit-split]:has([data-deposit-detail][hidden]) .page-split-detail { display: none; }
  [data-deposit-split]:has([data-deposit-detail]:not([hidden])) .page-split-list { display: none; }
}

/* ══════════════════════════════════════════════════════════════════════════════
   REDESIGN 2026 — Mockup classes
   ══════════════════════════════════════════════════════════════════════════════ */

/* ─── Sidebar new (.sb-*) ─── */
.sidebar {
  width: 236px;
  flex-shrink: 0;
  background: var(--surface);
  border-right: 1px solid var(--line);
  padding: 14px 12px 12px;
  display: flex;
  flex-direction: column;
  gap: 18px;
  transition: width 0.25s ease, transform 0.25s ease, padding 0.25s ease;
  z-index: 300;
  height: 100vh;
  position: sticky;
  top: 0;
  overflow-y: auto;
}
.sb-profile-wrap,
.sb-foot {
  margin-top: auto;
}
.sb-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 8px 4px;
  text-decoration: none;
}
.sb-mark {
  width: 30px; height: 30px;
  border-radius: 9px;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  color: #fff;
  display: grid; place-items: center;
  font-family: 'Instrument Serif', Georgia, serif;
  font-style: italic;
  font-size: 22px;
  line-height: 1;
  box-shadow: 0 4px 10px -3px var(--accent-ring), inset 0 1px 0 rgba(255,255,255,0.3);
  flex-shrink: 0;
}
.sb-brand-name {
  font-weight: 700;
  font-size: 16px;
  letter-spacing: -0.02em;
  color: var(--t1);
}
.sb-section {
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.sb-item {
  display: flex;
  align-items: center;
  gap: 11px;
  padding: 8px 10px;
  border-radius: 8px;
  color: var(--t2);
  font-size: 13.5px;
  font-weight: 500;
  transition: background 0.15s, color 0.15s;
  text-decoration: none;
  position: relative;
  cursor: pointer;
}
.sb-item:hover { background: var(--surface-3); color: var(--t1); }
.sb-item.is-active { background: var(--t1); color: #fff; font-weight: 600; }
.sb-item.is-active .sb-ico { color: #fff; }
.sb-ico {
  width: 18px; height: 18px;
  display: grid; place-items: center;
  color: var(--t3);
  flex-shrink: 0;
}
.sb-item:hover .sb-ico { color: var(--t1); }
.sb-label { flex: 1; }
.sb-badge {
  background: var(--accent);
  color: #fff;
  font-size: 10.5px;
  font-weight: 700;
  border-radius: 999px;
  min-width: 18px;
  height: 18px;
  padding: 0 6px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.sb-item.is-active .sb-badge { background: #fff; color: var(--t1); }
.sb-chevron {
  font-size: 11px;
  color: var(--t4);
  flex-shrink: 0;
  transition: transform 0.2s;
}
.sb-item.submenu-open .sb-chevron { transform: rotate(180deg); }
.sb-item.has-submenu { cursor: pointer; }
.sb-submenu {
  display: none;
  flex-direction: column;
  gap: 1px;
  padding: 2px 0 2px 30px;
}
.sb-submenu.is-open { display: flex; }
.sb-subitem {
  border-radius: 6px;
  color: var(--t3);
  cursor: pointer;
  font-size: 12.5px;
  font-weight: 500;
  padding: 6px 10px;
  text-decoration: none;
  transition: background 0.15s, color 0.15s;
  display: flex;
  align-items: center;
  gap: 6px;
}
.sb-subitem:hover { background: var(--surface-3); color: var(--t1); }
.sb-subitem.is-active { color: var(--accent); font-weight: 600; }
.sb-divider { height: 1px; background: var(--line); margin: 0 8px; }
.sb-foot {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px;
  border-radius: 10px;
  background: var(--surface-3);
}
.sb-foot-avatar {
  width: 32px; height: 32px;
  border-radius: 50%;
  background: linear-gradient(135deg, #2A2A30, #0C0C10);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  display: grid; place-items: center;
  letter-spacing: 0.02em;
  flex-shrink: 0;
}
.sb-foot-meta { flex: 1; min-width: 0; }
.sb-foot-name {
  font-size: 12.5px;
  font-weight: 600;
  color: var(--t1);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.sb-foot-org {
  font-size: 11.5px;
  color: var(--t3);
  margin-top: 1px;
}

/* Dark sidebar */
[data-theme="dark"] .sb-item.is-active { background: var(--accent) !important; color: #fff !important; }
[data-theme="dark"] .sb-item.is-active .sb-ico { color: #fff !important; }
[data-theme="dark"] .sb-item.is-active .sb-badge { background: rgba(0,0,0,0.25); color: #fff; }
[data-theme="dark"] .sb-mark {
  box-shadow: 0 4px 10px -3px var(--accent-ring), inset 0 1px 0 rgba(255,255,255,0.25), 0 0 0 0.5px rgba(255,255,255,0.1);
}

/* ─── Topbar new (.tb-*) ─── */
.topbar {
  gap: 16px;
  padding: 0 22px;
}
.tb-left { min-width: 0; }
.tb-crumbs {
  display: flex; align-items: center; gap: 7px;
  font-size: 13.5px;
  font-weight: 600;
  color: var(--t1);
}
.tb-crumb-muted { color: var(--t3); font-weight: 500; }
.tb-search {
  flex: 1;
  max-width: 480px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 9px;
  height: 34px;
  padding: 0 12px;
  background: var(--surface-3);
  border: 1px solid var(--line);
  border-radius: 10px;
  color: var(--t3);
}
.tb-search:focus-within {
  background: var(--surface);
  border-color: var(--line-strong);
  box-shadow: 0 0 0 4px rgba(12,12,16,0.04);
}
.tb-search input {
  flex: 1; border: 0; outline: 0; background: transparent;
  font-size: 13px; color: var(--t1); font-family: inherit;
}
.tb-search input::placeholder { color: var(--t3); }
.tb-kbd {
  font-size: 10.5px;
  font-weight: 600;
  background: var(--surface);
  border: 1px solid var(--line);
  color: var(--t3);
  padding: 1px 6px;
  border-radius: 5px;
  white-space: nowrap;
}
.tb-actions { display: flex; align-items: center; gap: 8px; }
.tb-iconbtn {
  width: 34px; height: 34px;
  border-radius: 9px;
  border: none;
  background: transparent;
  color: var(--t2);
  display: grid; place-items: center;
  transition: background 0.15s, color 0.15s;
  font-size: 14px;
}
.tb-iconbtn:hover { background: var(--surface-3); color: var(--t1); }
.tb-dot {
  position: absolute;
  top: 7px; right: 8px;
  width: 7px; height: 7px;
  background: var(--accent);
  border: 2px solid rgba(255,255,255,0.95);
  border-radius: 50%;
}
.tb-cta {
  display: inline-flex; align-items: center; gap: 7px;
  height: 34px; padding: 0 14px;
  background: var(--t1);
  color: #fff;
  font-size: 13px;
  font-weight: 600;
  border-radius: 9px;
  box-shadow: 0 1px 0 rgba(255,255,255,0.08) inset, 0 6px 14px -6px rgba(12,12,16,0.5);
  text-decoration: none;
  white-space: nowrap;
}
.tb-cta:hover { background: #1c1c22; }

[data-theme="dark"] .tb-cta {
  background: var(--surface-3);
  color: var(--t1);
  box-shadow: 0 1px 0 rgba(255,255,255,0.06) inset, 0 4px 10px -4px rgba(0,0,0,0.5);
}
[data-theme="dark"] .tb-cta:hover { background: #2c2c33; }
[data-theme="dark"] .tb-kbd { background: var(--surface); border-color: var(--line-strong); }

/* ─── Dashboard hero ─── */
.hero {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 24px;
  margin-bottom: 22px;
}
.hero-eyebrow {
  display: flex; align-items: center; gap: 10px;
  font-size: 12.5px; color: var(--t3); font-weight: 500; margin-bottom: 6px;
}
.hero-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 0 4px var(--green-soft);
}
.hero-eyebrow-sep { width: 3px; height: 3px; border-radius: 50%; background: var(--t4); }
.hero-title {
  font-size: 32px; line-height: 1.18; font-weight: 700;
  letter-spacing: -0.025em; color: var(--t1);
}
.hero-title-soft { color: var(--t3); font-weight: 500; }
.hero-right { display: flex; align-items: center; gap: 8px; }
.chip-btn {
  display: inline-flex; align-items: center; gap: 8px;
  height: 34px; padding: 0 13px;
  background: var(--surface); border: 1px solid var(--line);
  border-radius: 10px; font-size: 12.5px; font-weight: 600; color: var(--t1);
  box-shadow: var(--shadow-1); transition: background 0.15s, transform 0.15s;
  cursor: pointer; text-decoration: none;
}
.chip-btn:hover { background: var(--surface-2); transform: translateY(-1px); }
.chip-btn svg { color: var(--accent); }

/* ─── KPI row ─── */
.kpi-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin-bottom: 18px;
}
.kpi {
  background: var(--surface); border: 1px solid var(--line);
  border-radius: 16px; padding: 16px 18px 14px;
  display: flex; flex-direction: column; gap: 14px;
  box-shadow: var(--shadow-1); position: relative; overflow: hidden;
}
.kpi::before {
  content: ""; position: absolute; inset: 0; border-radius: 16px;
  background: linear-gradient(180deg, rgba(255,255,255,0) 60%, rgba(12,12,16,0.015));
  pointer-events: none;
}
.kpi-top { display: flex; align-items: center; justify-content: space-between; }
.kpi-label { font-size: 12.5px; color: var(--t3); font-weight: 500; }
.kpi-trend {
  display: inline-flex; align-items: center; gap: 3px;
  font-size: 11px; font-weight: 700; padding: 2px 7px 2px 5px;
  border-radius: 999px; background: var(--green-soft); color: var(--green);
}
.kpi-trend.is-down { background: var(--rose-soft); color: var(--rose); }
.kpi-value {
  font-size: 32px; font-weight: 700; color: var(--t1);
  letter-spacing: -0.03em; line-height: 1; font-feature-settings: "tnum";
}
.kpi-foot { display: flex; align-items: flex-end; justify-content: space-between; gap: 10px; }
.kpi-sub { font-size: 11.5px; color: var(--t3); line-height: 1.4; }
[data-theme="dark"] .kpi::before {
  background: linear-gradient(180deg, rgba(255,255,255,0.025) 0%, rgba(255,255,255,0) 60%);
}

/* ─── Dashboard grid ─── */
.grid-2 {
  display: grid;
  grid-template-columns: minmax(0, 1.65fr) minmax(0, 1fr);
  gap: 14px;
}
.right-col { display: flex; flex-direction: column; gap: 14px; }
.card {
  background: var(--surface); border: 1px solid var(--line);
  border-radius: 16px; box-shadow: var(--shadow-1); overflow: hidden;
}
.card-head {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 16px; padding: 16px 18px 12px;
}
.card-head h3 {
  font-size: 14.5px; font-weight: 600; color: var(--t1); letter-spacing: -0.01em;
}
.card-head p { font-size: 12px; color: var(--t3); margin-top: 2px; }
.link-btn {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 12px; font-weight: 600; color: var(--t2); padding: 4px 0; text-decoration: none;
}
.link-btn:hover { color: var(--t1); }
.seg {
  display: inline-flex; padding: 3px; background: var(--surface-3);
  border-radius: 9px; border: 1px solid var(--line);
}
.seg-btn {
  padding: 4px 11px; font-size: 12px; font-weight: 600;
  color: var(--t3); border-radius: 6px; transition: all 0.15s; cursor: pointer;
}
.seg-btn:hover { color: var(--t1); }
.seg-btn.is-on {
  background: var(--surface); color: var(--t1);
  box-shadow: 0 1px 2px rgba(12,12,16,0.06), 0 0 0 0.5px rgba(12,12,16,0.05);
}
[data-theme="dark"] .seg-btn.is-on {
  box-shadow: 0 1px 2px rgba(0,0,0,0.5), 0 0 0 0.5px rgba(255,255,255,0.06);
}

/* ─── Activity tabs ─── */
.act-tabs {
  display: flex; align-items: center; gap: 2px;
  background: var(--surface-2); border-radius: 10px; padding: 3px;
}
.act-tab {
  height: 28px; padding: 0 11px;
  border: none; background: transparent;
  border-radius: 8px; font-size: 12px; font-weight: 600;
  color: var(--t3); cursor: pointer; font-family: inherit;
  transition: background 0.15s, color 0.15s;
}
.act-tab:hover { color: var(--t1); }
.act-tab.is-on { background: var(--surface); color: var(--t1); box-shadow: 0 1px 3px rgba(12,12,16,0.08); }
[data-theme="dark"] .act-tab.is-on { box-shadow: 0 1px 3px rgba(0,0,0,0.3); }

/* ─── Activity list ─── */
.act-list { padding: 4px 6px 8px; }
.act-row {
  display: grid;
  grid-template-columns: 28px minmax(0,1.4fr) minmax(0,1.6fr) 110px 70px 54px;
  align-items: center; gap: 14px; padding: 11px 12px;
  border-radius: 11px; transition: background 0.15s;
}
.act-row + .act-row { border-top: 1px solid var(--line); border-radius: 0; }
.act-row:first-child { border-top: 0; }
.act-row:hover { background: var(--surface-2); }
.ota-badge {
  border-radius: 7px; display: grid; place-items: center;
  font-weight: 800; flex-shrink: 0;
  box-shadow: inset 0 0 0 0.5px rgba(0,0,0,0.1), 0 1px 1px rgba(12,12,16,0.06);
  font-family: 'Inter Tight', sans-serif;
}
.act-guest { min-width: 0; }
.act-name {
  font-size: 13.5px; font-weight: 600; color: var(--t1);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.act-meta { font-size: 11.5px; color: var(--t3); margin-top: 2px; }
.act-prop { display: flex; align-items: center; gap: 10px; min-width: 0; }
.prop-chip {
  width: 32px; height: 32px; border-radius: 9px;
  display: grid; place-items: center; color: #fff;
  font-size: 11px; font-weight: 700; letter-spacing: 0.01em; flex-shrink: 0;
  box-shadow: inset 0 0 0 0.5px rgba(255,255,255,0.2), 0 1px 1px rgba(12,12,16,0.06);
}
.act-prop-name {
  font-size: 13px; font-weight: 600; color: var(--t1);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.act-prop-city { font-size: 11.5px; color: var(--t3); margin-top: 1px; }
.act-status {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 11.5px; font-weight: 600; padding: 4px 10px;
  border-radius: 999px; width: fit-content;
}
.act-status-dot { width: 6px; height: 6px; border-radius: 50%; }
.status-arrival { background: var(--blue-soft); color: var(--blue); }
.status-arrival .act-status-dot { background: var(--blue); }
.status-departure { background: var(--accent-soft); color: var(--accent-2); }
.status-departure .act-status-dot { background: var(--accent); }
.status-stay { background: var(--green-soft); color: var(--green); }
.status-stay .act-status-dot { background: var(--green); }
.act-time {
  font-size: 12px; color: var(--t2); font-weight: 600;
  display: inline-flex; align-items: center; gap: 4px; font-feature-settings: "tnum";
}
.act-more {
  display: flex; align-items: center; gap: 4px;
  justify-self: center; align-self: center;
}
.act-icon-btn {
  width: 25px; height: 25px; border-radius: 7px; border: 0;
  background: transparent; cursor: pointer; color: var(--t3);
  display: grid; place-items: center; font-size: 13px;
  transition: background 0.15s, color 0.15s;
  text-decoration: none; flex-shrink: 0;
}
.act-row:hover .act-icon-btn { color: var(--t2); }
/* Utiliser var(--accent) et non var(--t1) : en dark mode --t1 est blanc → bouton blanc invisible */
.act-icon-btn:hover { background: var(--accent) !important; color: #fff !important; }

/* ─── Occupancy bars ─── */
.occ {
  display: flex; align-items: flex-end; gap: 5px;
  padding: 4px 18px 18px; height: 132px;
}
.occ-col {
  flex: 1; display: flex; flex-direction: column;
  align-items: center; gap: 6px; height: 100%; justify-content: flex-end;
}
.occ-bar {
  width: 100%; min-height: 8px; border-radius: 5px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.15);
}
.occ-day { font-size: 10.5px; color: var(--t3); font-weight: 600; text-transform: uppercase; }

/* ─── Tasks ─── */
.tasks { padding: 4px 8px 12px; }
.task-row {
  display: flex; align-items: center; gap: 12px;
  padding: 11px 10px; border-radius: 10px;
}
.task-row + .task-row { border-top: 1px solid var(--line); border-radius: 0; }
.task-row:hover { background: var(--surface-2); }
.task-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.task-main { flex: 1; min-width: 0; }
.task-what { font-size: 13px; font-weight: 600; color: var(--t1); }
.task-what span { color: var(--t3); font-weight: 500; }
.task-who { font-size: 11.5px; color: var(--t3); margin-top: 2px; }
.task-cta {
  height: 28px; padding: 0 12px; border-radius: 7px;
  background: var(--surface-3); border: 1px solid var(--line);
  font-size: 12px; font-weight: 600; color: var(--t1); cursor: pointer;
  font-family: inherit;
}
.task-cta:hover { background: var(--t1); color: #fff; border-color: var(--t1); }
[data-theme="dark"] .task-cta:hover { background: var(--accent); color: #fff; border-color: var(--accent); }

/* ─── Reservation detail — full link ─── */
.detail-full-link-wrap { padding: 14px 18px 18px; }
.detail-full-link {
  display: flex; align-items: center; justify-content: center; gap: 7px;
  width: 100%; font-size: 13px; font-weight: 600;
}

/* ─── Boutons œil / crayon du dashboard (tableau réservations) ─── */
.dashboard-row-actions {
  display: flex; align-items: center; gap: 4px;
}
.dashboard-detail-btn {
  width: 28px; height: 28px; border-radius: 8px; border: 0;
  background: var(--surface-2); color: var(--t2);
  cursor: pointer; display: grid; place-items: center;
  font-size: 13px; transition: background 0.15s, color 0.15s;
  text-decoration: none; flex-shrink: 0;
}
.dashboard-detail-btn:hover { background: var(--accent); color: #fff; }

/* ─── Panneau de détail réservation — carte (dashboard + calendrier) ─── */
.dashboard-detail-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 14px;
  overflow: hidden;
  margin-bottom: 4px;
}
.dashboard-detail-card-head {
  display: flex; align-items: center; gap: 10px;
  padding: 14px 18px; border-bottom: 1px solid var(--line);
  background: var(--surface);
}
.dashboard-detail-card-title {
  flex: 1; font-size: 14px; font-weight: 700; color: var(--t1);
  display: flex; align-items: center; gap: 7px;
}
.dashboard-detail-card-body { padding: 18px; background: var(--surface-2); }

/* Photo pleine largeur du logement dans le panneau (3/2 = format photo classique) */
.detail-panel-property-banner { margin-bottom: 12px; }
.detail-panel-property-photo {
  width: 100%; aspect-ratio: 3/2;
  object-fit: cover; border-radius: 10px; display: block;
  background: var(--surface-3);
}
.detail-panel-property-photo.property-photo-fallback {
  display: flex; align-items: center; justify-content: center;
  font-size: 28px; font-weight: 700; color: var(--t3);
}

/* Ligne provenance : logo OTA + nom */
.detail-row-source {
  display: flex; align-items: center; gap: 6px; justify-content: flex-end;
}
.detail-row-source .source-logo,
.detail-row-source .source-logo-fallback {
  width: 20px; height: 20px; border-radius: 4px; flex-shrink: 0;
}

/* ─── Assign task modal ─── */
.assign-modal-prop { padding: 2px 20px 14px; font-size: 12px; color: var(--t3); }
.assign-staff-list { padding: 8px 20px 16px; display: flex; flex-direction: column; gap: 4px; }
.assign-staff-opt {
  display: flex; align-items: center; gap: 10px;
  font-size: 13px; font-weight: 500; color: var(--t1);
  cursor: pointer; padding: 8px 0; border-bottom: 1px solid var(--line);
}
.assign-staff-opt:last-child { border-bottom: 0; }
.assign-staff-opt input[type=radio] {
  appearance: none;
  background: var(--surface);
  border: 2px solid var(--line-strong);
  border-radius: 50%;
  flex-shrink: 0;
  height: 16px;
  margin: 0;
  position: relative;
  width: 16px;
}
.assign-staff-opt input[type=radio]:checked {
  border-color: var(--accent);
}
.assign-staff-opt input[type=radio]:checked::after {
  background: var(--accent);
  border-radius: 50%;
  content: "";
  height: 8px;
  left: 50%;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 8px;
}

/* ─── Calendar blocked bars ─── */
.calendar-blocked-bar {
  position: absolute; top: 3px; bottom: 3px;
  border-radius: 6px;
  background: repeating-linear-gradient(
    45deg,
    rgba(180,60,40,0.1),
    rgba(180,60,40,0.1) 4px,
    rgba(180,60,40,0.035) 4px,
    rgba(180,60,40,0.035) 8px
  );
  border: 1.5px solid rgba(180,60,40,0.28);
  display: flex; align-items: center; gap: 5px; padding: 0 8px;
  overflow: hidden; cursor: pointer; z-index: 1;
  transition: background 0.15s;
}
.calendar-blocked-bar:hover {
  background: repeating-linear-gradient(
    45deg,
    rgba(180,60,40,0.2),
    rgba(180,60,40,0.2) 4px,
    rgba(180,60,40,0.08) 4px,
    rgba(180,60,40,0.08) 8px
  );
}
.calendar-blocked-bar.clip-left  { border-top-left-radius: 0; border-bottom-left-radius: 0; }
.calendar-blocked-bar.clip-right { border-top-right-radius: 0; border-bottom-right-radius: 0; }
.calendar-blocked-dates { font-size: 10px; font-weight: 600; color: var(--t2); white-space: nowrap; }
.calendar-blocked-reason { font-size: 10px; color: var(--t3); white-space: nowrap; }

/* ─── Gérer les dates — cell editor panel ─── */
.cal-cell-editor-backdrop { align-items: center; justify-content: center; }
@media (max-width: 600px) { .cal-cell-editor-backdrop { align-items: flex-end; justify-content: center; } }

.cal-cell-editor-panel {
  background: var(--surface); border: 1px solid var(--line);
  border-radius: 16px; width: min(400px, calc(100vw - 32px));
  max-height: calc(100vh - 80px);
  display: flex; flex-direction: column;
  box-shadow: 0 8px 24px rgba(0,0,0,0.14), 0 32px 64px rgba(0,0,0,0.18);
  animation: cal-modal-in 0.16s ease;
  /* overflow: visible permet aux panels de date-picker de s'afficher sans être écrêtés */
  overflow: visible;
  /* Le scroll interne est géré par cal-cell-editor-scroll */
}
@media (max-width: 600px) {
  .cal-cell-editor-panel { border-radius: 20px 20px 0 0; width: 100%; max-height: 92vh; }
}

.cal-cell-editor-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 18px 14px; flex-shrink: 0;
}
.cal-cell-editor-title { font-size: 16px; font-weight: 700; color: var(--t1); }
.cal-cell-editor-close {
  width: 28px; height: 28px; border-radius: 8px; border: 0;
  background: var(--surface-3); cursor: pointer; color: var(--t2);
  display: grid; place-items: center; font-size: 14px;
  transition: background 0.15s;
}
.cal-cell-editor-close:hover { background: var(--line-strong); }

.cal-cell-date-range {
  display: grid; grid-template-columns: 1fr 1fr; gap: 10px;
  padding: 0 18px 14px; flex-shrink: 0;
  position: relative; z-index: 10;
}
.cal-cell-date-label { font-size: 11px; font-weight: 600; color: var(--t3); display: block; margin-bottom: 4px; text-transform: uppercase; letter-spacing: 0.04em; }
/* Le date picker à l'intérieur de l'éditeur prend toute la largeur de sa colonne */
.cal-cell-date-picker { position: relative; }
.cal-cell-date-input {
  width: 100%; border: 1px solid var(--line-strong); border-radius: 9px;
  padding: 8px 10px; font-size: 13px; color: var(--t1);
  background: var(--surface-2); font-family: inherit;
  transition: border-color 0.15s; cursor: pointer; box-sizing: border-box;
}
.cal-cell-date-input:focus { outline: none; border-color: var(--accent); }
/* Panel du sélecteur positionné en fixed par JS — on lui donne les bases */
.cal-cell-picker-panel {
  width: 292px;
  z-index: 1100;
}
/* Fallback CSS (avant que JS fixe la position) : le picker de droite
   s'aligne sur le bord droit de son input pour ne pas déborder. */
.cal-cell-date-col:last-child .cal-cell-picker-panel {
  left: auto;
  right: 0;
}

.cal-cell-editor-scroll { flex: 1; overflow-y: auto; min-height: 0; overflow-x: hidden; }

/* Sections */
.cal-cell-section { border-top: 1px solid var(--line); }
.cal-cell-section-head {
  width: 100%; display: flex; align-items: center; justify-content: space-between;
  padding: 13px 18px; background: none; border: 0; cursor: pointer;
  font-size: 14px; font-weight: 700; color: var(--t1); font-family: inherit;
  transition: background 0.12s;
}
.cal-cell-section-head:hover { background: var(--surface-2); }
.cal-cell-section-chevron { font-size: 11px; color: var(--t3); transition: transform 0.18s; }
.cal-cell-section-body { /* open by default */ }
.cal-cell-section-inner { padding: 2px 18px 16px; }

/* Base rate + canal */
.cal-cell-base-rate-label { font-size: 12px; color: var(--t2); margin-bottom: 8px; font-weight: 500; }
.cal-cell-rate-top { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.cal-cell-rate-input {
  flex: 1; border: 1px solid var(--line-strong); border-radius: 9px;
  padding: 8px 12px; font-size: 14px; color: var(--t1);
  background: var(--surface-2); font-family: inherit;
  transition: border-color 0.15s;
}
.cal-cell-rate-input:focus { outline: none; border-color: var(--accent); }
.cal-cell-canal-btn {
  font-size: 12px; font-weight: 600; color: var(--accent); background: none; border: 0;
  cursor: pointer; white-space: nowrap; padding: 0; font-family: inherit;
}
.cal-cell-canal-btn:hover { text-decoration: underline; }
.cal-cell-channels { display: flex; flex-direction: column; gap: 2px; }
.cal-cell-channel-row { display: flex; align-items: center; gap: 9px; padding: 5px 0; border-bottom: 1px solid var(--line); }
.cal-cell-channel-row:last-child { border-bottom: 0; }
.cal-cell-channel-logo { width: 22px; height: 22px; border-radius: 6px; object-fit: contain; flex-shrink: 0; background: var(--surface-2); }
.cal-cell-channel-icon { width: 22px; height: 22px; flex-shrink: 0; display: grid; place-items: center; font-size: 14px; color: var(--t3); }
.cal-cell-channel-dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }
.cal-cell-channel-name { flex: 1; font-size: 13px; color: var(--t1); font-weight: 500; }
.cal-cell-channel-price { font-size: 13px; color: var(--t2); font-weight: 600; }

/* Day-of-week filter */
.cal-cell-dow-filter {
  padding: 12px 18px 14px;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: var(--surface);
}
.cal-cell-dow-header { display: flex; align-items: baseline; gap: 8px; margin-bottom: 9px; }
.cal-cell-dow-label { font-size: 11px; font-weight: 700; color: var(--t2); text-transform: uppercase; letter-spacing: 0.05em; }
.cal-cell-dow-hint { font-size: 11px; color: var(--t4); font-style: italic; }
.cal-cell-dow-days { display: flex; gap: 5px; margin-bottom: 8px; }
.cal-cell-dow-item { display: flex; flex-direction: column; align-items: center; cursor: pointer; user-select: none; }
.cal-cell-dow-item input[type="checkbox"] { display: none; }
.cal-cell-dow-item span {
  width: 34px; height: 34px; border-radius: 8px;
  border: 1.5px solid var(--line-strong);
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 600; color: var(--t3);
  background: var(--surface-2); cursor: pointer;
  transition: background 0.12s, border-color 0.12s, color 0.12s;
}
.cal-cell-dow-item span:hover { border-color: var(--accent); color: var(--accent); }
.cal-cell-dow-item input[type="checkbox"]:checked + span { background: var(--accent); border-color: var(--accent); color: #fff; }
.cal-cell-dow-item input[type="checkbox"]:checked + span:hover { filter: brightness(1.1); }
.cal-cell-dow-shortcuts { display: flex; gap: 7px; }
.cal-cell-dow-shortcut {
  flex: 1; padding: 7px 10px; border-radius: 8px;
  border: 1.5px solid var(--line-strong);
  font-size: 12px; font-weight: 600; color: var(--t2);
  background: var(--surface-2); cursor: pointer; font-family: inherit;
  transition: background 0.12s, border-color 0.12s, color 0.12s;
}
.cal-cell-dow-shortcut:hover { border-color: var(--accent); color: var(--accent); }
.cal-cell-dow-shortcut.is-on { background: var(--accent); border-color: var(--accent); color: #fff; }
.cal-cell-dow-shortcut.is-on:hover { filter: brightness(1.1); }

/* Min/max nights */
.cal-cell-minmax-row { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 12px; }
.cal-cell-minmax-label { font-size: 11px; font-weight: 600; color: var(--t3); display: block; margin-bottom: 5px; text-transform: uppercase; letter-spacing: 0.04em; }
.cal-cell-minmax-input {
  width: 100%; border: 1px solid var(--line-strong); border-radius: 9px;
  padding: 8px 10px; font-size: 13.5px; color: var(--t1);
  background: var(--surface-2); font-family: inherit;
  transition: border-color 0.15s;
}
.cal-cell-minmax-input:focus { outline: none; border-color: var(--accent); }

/* Dispo toggles */
.cal-cell-toggle-row {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 9px 0; border-bottom: 1px solid var(--line); cursor: pointer;
}
.cal-cell-toggle-row:last-child { border-bottom: 0; }
.cal-cell-toggle-label { font-size: 13px; color: var(--t1); font-weight: 500; flex: 1; }

/* Unavailability reason */
.cal-cell-unavail-reason {
  background: var(--surface-2); border-radius: 10px;
  padding: 12px 14px; margin: 6px 0 10px; border: 1px solid var(--line);
}
/* Related blocked dates indicator */
.cal-cell-related-block {
  margin-bottom: 12px; padding: 10px 12px;
  background: var(--surface-3); border-radius: 10px;
  border: 1px solid var(--line);
}
.cal-cell-related-title {
  font-size: 11px; font-weight: 600; color: var(--t3);
  text-transform: uppercase; letter-spacing: 0.04em;
  margin-bottom: 7px;
}
.cal-cell-related-list { display: flex; flex-wrap: wrap; gap: 5px; align-items: center; }
.cal-cell-related-date {
  font-size: 11.5px; font-weight: 600; color: var(--t1);
  background: var(--surface-2); border: 1px solid var(--line-strong);
  border-radius: 6px; padding: 3px 8px; white-space: nowrap;
}
.cal-cell-related-more { font-size: 11.5px; color: var(--t3); font-style: italic; }

.cal-cell-reason-label { font-size: 11.5px; font-weight: 600; color: var(--t2); margin-bottom: 8px; text-transform: uppercase; letter-spacing: 0.04em; }
.cal-cell-reason-options { display: flex; flex-direction: column; gap: 0; }
.cal-cell-reason-opt {
  display: flex; align-items: center; gap: 9px;
  font-size: 13px; font-weight: 500; color: var(--t1); cursor: pointer;
  padding: 6px 0; border-bottom: 1px solid var(--line);
}
.cal-cell-reason-opt:last-child { border-bottom: 0; }
.cal-cell-reason-opt input[type=radio] { accent-color: var(--accent); width: 14px; height: 14px; flex-shrink: 0; }
.cal-cell-text-input {
  width: 100%; border: 1px solid var(--line-strong); border-radius: 8px;
  padding: 7px 10px; font-size: 13px; color: var(--t1);
  background: var(--surface); font-family: inherit;
}
.cal-cell-text-input:focus { outline: none; border-color: var(--accent); }

/* Footer */
.cal-cell-editor-footer {
  display: flex; gap: 8px; justify-content: flex-end;
  padding: 14px 18px; border-top: 1px solid var(--line); flex-shrink: 0;
  background: var(--surface);
}

/* ─── Calendar new header/toolbar ─── */
.cal-head {
  display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px;
}
.cal-head-left { display: flex; align-items: center; gap: 18px; }
.cal-title {
  font-size: 26px; font-weight: 700;
  letter-spacing: -0.025em; color: var(--t1);
}
.cal-nav {
  display: flex; align-items: center; gap: 4px;
}
.cal-nav-btn {
  width: 32px; height: 32px; border-radius: 9px;
  background: var(--surface); border: 1px solid var(--line);
  box-shadow: var(--shadow-1); color: var(--t2);
  display: grid; place-items: center; cursor: pointer; transition: background 0.15s, color 0.15s;
}
.cal-nav-btn:hover { background: var(--surface-2); color: var(--t1); }
.cal-today-btn {
  padding: 0 12px; height: 32px; border-radius: 9px;
  background: var(--surface); border: 1px solid var(--line);
  box-shadow: var(--shadow-1); color: var(--t2);
  font-size: 12.5px; font-weight: 600; cursor: pointer; font-family: inherit;
  display: inline-flex; align-items: center; transition: background 0.15s, color 0.15s;
}
.cal-today-btn:hover { background: var(--surface-2); color: var(--t1); }
.cal-head-right { display: flex; align-items: center; gap: 10px; }
.cal-views {
  display: inline-flex; gap: 4px;
}
.cal-view {
  padding: 0 14px; height: 32px;
  background: var(--surface); border: 1px solid var(--line);
  box-shadow: var(--shadow-1); color: var(--t2);
  font-size: 12.5px; font-weight: 600; border-radius: 9px;
  display: inline-flex; align-items: center;
  transition: all 0.15s; cursor: pointer; font-family: inherit;
}
.cal-view:hover { background: var(--surface-2); color: var(--t1); }
.cal-view.is-on { background: var(--t1); color: #fff; border-color: var(--t1); box-shadow: none; }
[data-theme="dark"] .cal-view.is-on { background: var(--accent) !important; border-color: var(--accent); color: #fff; }

/* Toolbar */
.cal-toolbar {
  display: flex; align-items: center; gap: 8px; margin-bottom: 14px;
}
.tool-btn {
  display: inline-flex; align-items: center; gap: 7px;
  height: 32px; padding: 0 12px;
  background: var(--surface); border: 1px solid var(--line);
  border-radius: 9px; font-size: 12.5px; font-weight: 600;
  color: var(--t2); box-shadow: var(--shadow-1); cursor: pointer; font-family: inherit;
}
.tool-btn:hover { background: var(--surface-2); color: var(--t1); }
.tool-em { color: var(--t1); }
.tool-count {
  background: var(--accent); color: #fff;
  font-size: 10.5px; font-weight: 700; padding: 1px 5px;
  border-radius: 4px; margin-left: 1px;
}
.tool-spacer { flex: 1; }
.legend { display: inline-flex; align-items: center; gap: 14px; }
.leg { display: inline-flex; align-items: center; gap: 6px; font-size: 11.5px; color: var(--t2); font-weight: 500; }
.leg-dot { width: 8px; height: 8px; border-radius: 3px; }

/* Calendar grid (new) */
.cal-grid {
  background: var(--surface); border: 1px solid var(--line);
  border-radius: 16px; box-shadow: var(--shadow-1);
  overflow: hidden; flex: 1; display: flex; flex-direction: column; min-height: 0;
}
.cal-row {
  display: grid; grid-template-columns: 220px 1fr;
  align-items: stretch; min-height: 60px;
  border-bottom: 1px solid var(--line); position: relative;
}
.cal-row:last-child { border-bottom: 0; }
.cal-row-head { background: var(--surface-2); min-height: 48px; position: sticky; top: 0; z-index: 5; }
.cal-prop-col-head,
.cal-prop-col {
  display: flex; align-items: center; gap: 12px;
  padding: 0 16px; border-right: 1px solid var(--line);
  background: var(--surface);
}
.cal-prop-col-head {
  background: var(--surface-2); font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.05em; color: var(--t3);
}
.cal-prop-meta { min-width: 0; }
.cal-prop-name {
  font-size: 13px; font-weight: 600; color: var(--t1);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.cal-prop-city { font-size: 11px; color: var(--t3); margin-top: 1px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cal-days, .cal-track { display: grid; position: relative; }
.cal-day-head {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 2px; padding: 6px 0; border-right: 1px solid var(--line); position: relative;
}
.cal-day-head:last-child { border-right: 0; }
.cal-day-head.is-weekend { background: var(--surface-2); }
.cal-day-abbr { font-size: 10px; font-weight: 600; color: var(--t3); text-transform: uppercase; letter-spacing: 0.06em; }
.cal-day-num { font-size: 14px; font-weight: 600; color: var(--t1); line-height: 1; margin-top: 2px; font-feature-settings: "tnum"; }
.cal-day-head.is-today .cal-day-abbr { color: var(--accent); }
.cal-day-head.is-today .cal-day-num {
  background: var(--accent); color: #fff;
  width: 24px; height: 24px; border-radius: 7px;
  display: grid; place-items: center; margin-top: 1px;
  box-shadow: 0 4px 10px -4px var(--accent-ring), inset 0 1px 0 rgba(255,255,255,0.25);
}
.cal-cell { border-right: 1px solid var(--line); height: 100%; }
.cal-cell:last-child { border-right: 0; }
.cal-cell.is-weekend { background: rgba(244,244,246,0.4); }
.cal-cell.is-today { background: linear-gradient(180deg, rgba(var(--accent-rgb),0.04), rgba(var(--accent-rgb),0.02)); }
[data-theme="dark"] .cal-cell.is-today { background: linear-gradient(180deg, rgba(var(--accent-rgb),0.06), rgba(var(--accent-rgb),0.02)); }
[data-theme="dark"] .cal-cell.is-weekend { background: rgba(0,0,0,0.15); }
[data-theme="dark"] .cal-day-head.is-weekend { background: var(--surface-2); }
.cal-today-line {
  position: absolute; top: 0; bottom: 0; width: 1.5px;
  background: linear-gradient(180deg, var(--accent), rgba(var(--accent-rgb),0));
  z-index: 3; pointer-events: none;
}
.cal-pill {
  position: absolute; top: 50%; transform: translateY(-50%);
  height: 36px; border-radius: 999px; z-index: 2;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.22), inset 0 -1px 0 rgba(0,0,0,0.12),
    0 1px 2px rgba(12,12,16,0.10), 0 4px 10px -4px rgba(12,12,16,0.18);
  overflow: hidden; transition: transform 0.15s, box-shadow 0.15s; cursor: pointer;
}
.cal-pill:hover {
  transform: translateY(calc(-50% - 1px));
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.28), inset 0 -1px 0 rgba(0,0,0,0.15),
    0 6px 18px -4px rgba(12,12,16,0.30); z-index: 4;
}
.cal-pill.clip-l { border-top-left-radius: 0; border-bottom-left-radius: 0; }
.cal-pill.clip-r { border-top-right-radius: 0; border-bottom-right-radius: 0; }
.cal-pill-inner {
  display: flex; align-items: center; gap: 8px; padding: 0 10px 0 6px;
  height: 100%; font-size: 12px; font-weight: 600; color: #fff;
}
.cal-pill-name { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; letter-spacing: -0.005em; }
.cal-pill-meta { opacity: 0.75; font-weight: 500; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* Group header */
.cal-group {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 18px 6px; background: var(--surface-2); border-bottom: 1px solid var(--line);
}
.cal-group-label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--t3); }
.cal-group-line { flex: 1; height: 1px; background: var(--line); }

/* Calendar footer stats */
.cal-foot {
  display: flex; align-items: center; gap: 28px; padding: 14px 4px 6px;
}
.cal-foot-item { display: flex; flex-direction: column; gap: 2px; }
.cal-foot-label { font-size: 11px; color: var(--t3); font-weight: 500; text-transform: uppercase; letter-spacing: 0.05em; }
.cal-foot-value { font-size: 18px; font-weight: 700; color: var(--t1); letter-spacing: -0.02em; font-feature-settings: "tnum"; }
.cal-foot-spacer { flex: 1; }

/* ─── Content area for calendar ─── */
.content {
  overflow-y: auto;
}
.content-cal {
  padding: 22px 28px 0;
  display: flex;
  flex-direction: column;
  gap: 0;
  flex: 1;
  min-height: 0;
  overflow: hidden;
}

/* ─── Sidebar collapse (mobile) ─── */
@media (max-width: 860px) {
  .sidebar {
    position: fixed; left: -260px; top: 0; bottom: 0;
    transition: transform 0.25s ease; z-index: 500;
  }
  body.sidebar-open .sidebar { transform: translateX(260px); }
  .menu-toggle { display: inline-flex; }
}
@media (min-width: 861px) {
  body.sidebar-collapsed .sidebar { width: 60px; padding: 14px 8px; gap: 12px; }
  body.sidebar-collapsed .sb-brand-name,
  body.sidebar-collapsed .sb-label,
  body.sidebar-collapsed .sb-badge,
  body.sidebar-collapsed .sb-foot-meta { display: none; }
  body.sidebar-collapsed .sb-brand { justify-content: center; padding: 6px 4px 4px; }
  body.sidebar-collapsed .sb-item { justify-content: center; gap: 0; padding: 8px; }
  body.sidebar-collapsed .sb-foot { justify-content: center; }
  body.sidebar-collapsed .sb-divider { margin: 0 4px; }
}

/* ─── Sidebar profile menu ─── */
.sb-profile-wrap { position: relative; margin-top: auto; }
.sb-profile-menu {
  position: absolute;
  bottom: calc(100% + 8px); left: 0; right: 0;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 12px;
  box-shadow: var(--shadow-pop);
  padding: 6px;
  z-index: 600;
}
.sb-profile-item {
  display: flex; align-items: center; gap: 9px;
  width: 100%; padding: 8px 10px;
  font-size: 13px; font-weight: 500; color: var(--t1);
  border-radius: 8px; text-decoration: none; cursor: pointer;
  transition: background 0.12s;
  background: none; font-family: inherit; text-align: left;
}
.sb-profile-item:hover { background: var(--surface-3); }
.sb-profile-item i { color: var(--t3); width: 14px; text-align: center; }
.sb-profile-sep { height: 1px; background: var(--line); margin: 4px 0; }
.sb-profile-logout { color: var(--rose); }
.sb-profile-logout i { color: var(--rose); }

/* ─── Topbar theme toggle SVG ─── */
.tb-theme-btn { color: var(--t2); }
.tb-theme-btn svg { display: block; }
[data-theme="dark"] .tb-theme-btn { color: var(--t2); }

/* ─── Mobile: cache la recherche dans la topbar ─── */
@media (max-width: 860px) {
  .tb-search { display: none; }
  .topbar { padding: 0 14px; gap: 10px; }
  .tb-cta { display: none; }
}

/* ─── Property-sort-menu dark mode ─── */
.property-sort-menu {
  background: var(--surface);
  border-color: var(--line);
}
.cal-toolbar { position: relative; }

[data-theme="dark"] .property-sort-menu {
  background: var(--surface);
  border-color: var(--line-strong);
}
[data-theme="dark"] .calendar-filter-check {
  background: var(--surface-2);
  color: var(--t1);
}
[data-theme="dark"] .calendar-filter-check:hover,
[data-theme="dark"] .calendar-filter-check:has(input:checked) {
  background: var(--surface-3);
  border-color: var(--line-strong);
}
[data-theme="dark"] .calendar-filter-section + .calendar-filter-section,
[data-theme="dark"] .property-sort-options,
[data-theme="dark"] .property-sort-custom {
  border-top-color: var(--line);
}
[data-theme="dark"] .property-sort-option {
  background: var(--surface-2);
  color: var(--t2);
}
[data-theme="dark"] .property-sort-option:hover,
[data-theme="dark"] .property-sort-option.active {
  background: var(--surface-3);
  color: var(--t1);
}
[data-theme="dark"] .property-sort-row {
  background: var(--surface-2);
  border-color: var(--line);
}
[data-theme="dark"] .property-sort-row span {
  color: var(--t1);
}
[data-theme="dark"] .property-sort-menu.is-dragging .property-sort-row:not(.dragging) {
  background: var(--surface-3);
}
[data-theme="dark"] .property-sort-handle,
[data-theme="dark"] .property-sort-drag,
[data-theme="dark"] .property-sort-eye {
  background: var(--surface-3);
  color: var(--t3);
}
[data-theme="dark"] .property-sort-handle:hover,
[data-theme="dark"] .property-sort-drag:hover,
[data-theme="dark"] .property-sort-eye:hover {
  background: var(--surface-3);
  color: var(--t1);
}

/* ─── Date picker dark mode ─── */
.date-picker-panel {
  background: var(--surface) !important;
  border-color: var(--line) !important;
}
[data-theme="dark"] .date-picker-panel,
[data-theme="dark"] .date-picker-panel * {
  color: var(--t1);
}
[data-theme="dark"] .dp-day:hover,
[data-theme="dark"] .dp-day.is-today { background: var(--surface-3); }
[data-theme="dark"] .dp-day.is-selected { background: var(--accent); color: #fff; }
[data-theme="dark"] .dp-nav-btn { color: var(--t2); }

/* ─── Sidebar collapsed: hide profile menu & ellipsis ─── */
body.sidebar-collapsed .sb-profile-wrap .sb-foot i.fa-ellipsis,
body.sidebar-collapsed .sb-profile-wrap .sb-foot .sb-foot-meta { display: none; }

/* ─── Dashboard mobile ─── */
@media (max-width: 860px) {
  .hero { flex-direction: column; align-items: flex-start; gap: 12px; }
  .hero-right { width: 100%; flex-direction: row; justify-content: space-between; align-items: center; }
  .kpi-row { grid-template-columns: 1fr 1fr; gap: 10px; }
  .grid-2 { grid-template-columns: 1fr; }
  .act-row { grid-template-columns: 28px 1fr 54px; gap: 8px; }
  .act-prop, .act-status, .act-time { display: none; }
  .act-more { display: flex; align-items: center; justify-content: center; gap: 4px; }
}

/* ─── Calendar mobile ─── */
@media (max-width: 860px) {
  .cal-head { flex-direction: column; align-items: flex-start; gap: 10px; }
  .cal-toolbar { flex-wrap: wrap; gap: 6px; }
  .tool-spacer { display: none; }
  .content-cal { padding: 12px 14px 0; }
}

/* ══════════════════════════════════════════════════════════════════════════════
   PROPERTIES PAGE — pg-* design system (light + dark + responsive)
   ══════════════════════════════════════════════════════════════════════════════ */

/* ─── Shell layout ─── */
.pg-shell {
  display: grid;
  grid-template-columns: 360px 1fr;
  gap: 0;
  flex: 1;
  min-height: 0;
  overflow: hidden;
  background: var(--bg);
}

/* ─── Left list ─── */
.pg-list {
  display: flex;
  flex-direction: column;
  background: var(--surface);
  border-right: 1px solid var(--line);
  min-width: 0;
  overflow: hidden;
}
.pg-mini-cta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 30px;
  padding: 0 11px;
  border: none;
  border-radius: 9px;
  background: var(--t1);
  color: #fff;
  font-size: 12.5px;
  line-height: 1;
  font-weight: 700;
  cursor: pointer;
  font-family: inherit;
  white-space: nowrap;
  transition: background 0.15s, transform 0.1s;
}
.pg-mini-cta:hover { background: #1c1c22; }
.pg-mini-cta:active { transform: scale(0.97); }
[data-theme="dark"] .pg-mini-cta { background: var(--accent); }
[data-theme="dark"] .pg-mini-cta:hover { background: var(--accent-2); }

.pg-list-tools {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

/* ─── Chips (filter pills) ─── */
.pg-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
}
.pg-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  height: 28px;
  padding: 0 11px;
  border: 1px solid var(--line);
  background: var(--surface);
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
  color: var(--t2);
  cursor: pointer;
  font-family: inherit;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
  white-space: nowrap;
}
.pg-chip:hover { background: var(--surface-2); color: var(--t1); }
.pg-chip.is-on {
  background: var(--t1);
  color: #fff;
  border-color: var(--t1);
}
[data-theme="dark"] .pg-chip.is-on {
  background: var(--accent);
  border-color: var(--accent);
}
.pg-chip-ghost {
  background: transparent;
  border-style: dashed;
  color: var(--t3);
}
.pg-chip-ghost:hover { color: var(--t1); border-color: var(--line-strong); background: var(--surface-2); }

/* ─── Properties list ─── */
.pg-prop-list {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding-right: 2px;
  margin-right: -2px;
}
.pg-prop-row {
  display: grid;
  grid-template-columns: 42px minmax(0,1fr) auto;
  gap: 12px;
  align-items: center;
  padding: 10px;
  border-radius: 12px;
  background: transparent;
  border: 1px solid transparent;
  cursor: pointer;
  text-align: left;
  font-family: inherit;
  color: inherit;
  width: 100%;
  transition: background 0.15s, border-color 0.15s;
}
.pg-prop-row:hover { background: var(--surface-2); }
.pg-prop-row.is-active {
  background: var(--surface-2);
  border-color: var(--line-strong);
}
[data-theme="dark"] .pg-prop-row.is-active {
  background: var(--surface-3);
  border-color: var(--line-strong);
}
.pg-photo {
  width: 42px;
  height: 42px;
  border-radius: 10px;
  background: linear-gradient(135deg, var(--surface-3), var(--surface-2));
  overflow: hidden;
  flex-shrink: 0;
  display: grid;
  place-items: center;
  color: var(--t3);
  font-size: 14px;
  font-weight: 700;
}
.pg-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
.pg-prop-main { min-width: 0; }
.pg-prop-name-row {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}
.pg-prop-name {
  font-size: 13.5px;
  font-weight: 600;
  color: var(--t1);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pg-prop-city {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 11.5px;
  color: var(--t3);
  margin-top: 1px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pg-prop-city i, .pg-prop-city svg { font-size: 9px; opacity: 0.7; flex-shrink: 0; }
.pg-prop-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
  color: var(--t3);
  margin-top: 3px;
}
.pg-meta-sep {
  width: 2px;
  height: 2px;
  border-radius: 50%;
  background: var(--t4);
}
.pg-prop-connected {
  display: flex;
  align-items: center;
  gap: 3px;
  flex-shrink: 0;
}
.pg-ota {
  width: 20px;
  height: 20px;
  border-radius: 6px;
  background: var(--surface-3);
  color: var(--t2);
  font-size: 9.5px;
  font-weight: 800;
  display: grid;
  place-items: center;
}

.property-channel-grid {
  display: grid;
  gap: 12px;
}

.property-channel-card {
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 14px;
}

.property-channel-card.is-disabled {
  opacity: 0.72;
}

.property-channel-head {
  align-items: center;
  display: flex;
  gap: 12px;
  justify-content: space-between;
  margin-bottom: 12px;
}

.property-channel-title {
  align-items: center;
  display: flex;
  gap: 10px;
  min-width: 0;
}

.property-channel-title strong {
  color: var(--t1);
  display: block;
  font-size: 14px;
  font-weight: 750;
}

.property-channel-title span {
  color: var(--t3);
  display: block;
  font-size: 12px;
  margin-top: 2px;
}

.property-channel-logo {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 7px;
  flex: 0 0 auto;
  height: 28px;
  object-fit: contain;
  padding: 3px;
  width: 28px;
}

.property-channel-logo.is-fallback {
  align-items: center;
  color: var(--t3);
  display: inline-flex;
  font-size: 12px;
  font-weight: 850;
  justify-content: center;
}

.property-channel-status {
  border: 1px solid var(--line);
  border-radius: 999px;
  flex: 0 0 auto;
  font-size: 11.5px;
  font-weight: 750;
  padding: 5px 9px;
}

.property-channel-status.is-ready {
  background: var(--green-soft);
  border-color: transparent;
  color: var(--green);
}

.property-channel-status.is-warning {
  background: rgba(245, 158, 11, 0.12);
  border-color: rgba(245, 158, 11, 0.22);
  color: #b45309;
}

.property-channel-status.is-off {
  background: var(--surface-3);
  color: var(--t3);
}

.property-channel-toggle-row.perm-toggle-row {
  background: transparent;
  border: 0;
  border-radius: 0;
  padding: 0;
}

.property-channel-fields {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 12px;
}

@media (max-width: 640px) {
  .property-channel-head {
    align-items: flex-start;
    flex-direction: column;
  }

  .property-channel-fields {
    grid-template-columns: 1fr;
  }
}

/* ─── Right detail panel ─── */
.pg-detail {
  display: flex;
  flex-direction: column;
  min-width: 0;
  overflow-y: auto;
  background: var(--bg);
  padding: 20px 28px 24px;
  gap: 16px;
}
.pg-detail > form {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
}

/* ─── Property header card ─── */
.pg-prop-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 16px 18px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 16px;
  box-shadow: var(--shadow-1);
}
.pg-prop-header-left {
  display: flex;
  align-items: center;
  gap: 14px;
  min-width: 0;
}
.pg-prop-chip {
  width: 48px;
  height: 48px;
  border-radius: 12px;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  color: #fff;
  display: grid;
  place-items: center;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.02em;
  flex-shrink: 0;
  box-shadow: 0 4px 10px -3px var(--accent-ring);
  overflow: hidden;
}
.pg-prop-chip img { width: 100%; height: 100%; object-fit: cover; }
.pg-prop-header-eyebrow {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 4px;
  flex-wrap: wrap;
}
.pg-status-pill {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  height: 22px;
  padding: 0 9px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 700;
  background: var(--surface-3);
  color: var(--t2);
}
.pg-status-pill.ok { background: var(--green-soft); color: var(--green); }
.pg-status-pill.draft { background: var(--surface-3); color: var(--t3); }
.pg-status-pill.warn { background: var(--accent-soft); color: var(--accent-2); }
[data-theme="dark"] .pg-status-pill.draft { color: var(--t2); }
.pg-status-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
}
.pg-prop-header-id {
  font-size: 11px;
  color: var(--t3);
  font-weight: 600;
  letter-spacing: 0.02em;
}
.pg-prop-header-name {
  font-size: 19px;
  font-weight: 700;
  letter-spacing: -0.015em;
  color: var(--t1);
  margin: 0;
  line-height: 1.2;
}
.pg-prop-header-city {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12.5px;
  color: var(--t3);
  margin-top: 4px;
}
.pg-prop-header-city i, .pg-prop-header-city svg { font-size: 10px; opacity: 0.7; }
.pg-prop-header-right {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

/* ─── Chip button (used in headers + actions) ─── */
.chip-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 32px;
  padding: 0 13px;
  border: 1px solid var(--t1);
  background: var(--t1);
  color: #fff;
  border-radius: 9px;
  font-size: 12.5px;
  font-weight: 600;
  cursor: pointer;
  font-family: inherit;
  white-space: nowrap;
  text-decoration: none;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.chip-btn:hover { background: #1c1c22; border-color: #1c1c22; }
[data-theme="dark"] .chip-btn { background: var(--accent); border-color: var(--accent); }
[data-theme="dark"] .chip-btn:hover { background: var(--accent-2); border-color: var(--accent-2); }
.chip-btn.is-ghost {
  background: transparent;
  color: var(--t2);
  border-color: var(--line-strong);
}
.chip-btn.is-ghost:hover {
  background: var(--surface-2);
  color: var(--t1);
  border-color: var(--line-strong);
}
[data-theme="dark"] .chip-btn.is-ghost {
  background: transparent;
  color: var(--t2);
  border-color: var(--line-strong);
}
[data-theme="dark"] .chip-btn.is-ghost:hover {
  background: var(--surface-2);
  color: var(--t1);
}

/* ─── Tabs ─── */
.pg-tabs {
  display: flex;
  gap: 2px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 4px;
  overflow-x: auto;
  scrollbar-width: none;
  box-shadow: var(--shadow-1);
}
.pg-tabs::-webkit-scrollbar { display: none; }
.pg-tab {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  height: 34px;
  padding: 0 14px;
  border: none;
  background: transparent;
  border-radius: 8px;
  font-size: 12.5px;
  font-weight: 600;
  color: var(--t3);
  cursor: pointer;
  font-family: inherit;
  white-space: nowrap;
  transition: background 0.15s, color 0.15s;
}
.pg-tab i, .pg-tab svg { font-size: 11.5px; opacity: 0.85; }
.pg-tab:hover { color: var(--t1); }
.pg-tab.is-on, .pg-tab.active {
  background: var(--surface-3);
  color: var(--t1);
}
[data-theme="dark"] .pg-tab.is-on, [data-theme="dark"] .pg-tab.active {
  background: var(--surface-3);
}

/* ─── Tab content container ─── */
.pg-content {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.pg-content[hidden] { display: none; }

/* ─── KPI strip ─── */
.pg-kpi-strip {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 10px;
}

.pg-kpi-strip[hidden] {
  display: none !important;
}
.pg-kpi-tile {
  padding: 12px 14px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 12px;
  box-shadow: var(--shadow-1);
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.pg-kpi-tile-lab {
  font-size: 11px;
  color: var(--t3);
  font-weight: 600;
  letter-spacing: 0.01em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.pg-kpi-tile-val {
  font-size: 19px;
  font-weight: 700;
  color: var(--t1);
  letter-spacing: -0.02em;
  font-feature-settings: "tnum";
  line-height: 1.1;
}
.pg-kpi-tile-unit {
  font-size: 12px;
  font-weight: 500;
  color: var(--t3);
  margin-left: 2px;
}

/* ─── Form section card ─── */
.pg-form-section {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 16px;
  box-shadow: var(--shadow-1);
  padding: 0;
  overflow: hidden;
}
.pg-form-section-head {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 16px 18px 14px;
  border-bottom: 1px solid var(--line);
}
.pg-form-section-head h3 {
  font-size: 14.5px;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--t1);
  margin: 0;
}
.pg-form-section-head p {
  font-size: 12px;
  color: var(--t3);
  margin: 3px 0 0 0;
  line-height: 1.45;
}
/* When .pg-form-section also has .ms-card body */
.pg-form-section .ms-card-body {
  padding: 18px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

/* ─── Fields ─── */
.pg-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 0;
  flex: 1;
}
.pg-field > span:first-child {
  font-size: 11.5px;
  font-weight: 600;
  color: var(--t2);
  letter-spacing: 0.01em;
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
.pg-field > span:first-child i { font-size: 10.5px; color: var(--t3); }
.pg-fields {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.pg-fields-row {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
  align-items: end;
}
.pg-fields-row.cols-3 { grid-template-columns: repeat(3, 1fr); }
.pg-field-block {
  display: flex;
  flex-direction: column;
  gap: 9px;
}
.pg-field-block-label {
  font-size: 11.5px;
  font-weight: 600;
  color: var(--t2);
  letter-spacing: 0.01em;
}

/* ─── Inputs / textarea / select ─── */
.pg-input,
.pg-field input.ms-field-input,
.pg-field select.ms-field-input {
  height: 38px;
  padding: 0 12px;
  border: 1px solid var(--line-strong);
  border-radius: 10px;
  background: var(--surface);
  color: var(--t1);
  font-size: 13px;
  font-family: inherit;
  font-weight: 500;
  outline: none;
  transition: border-color 0.15s, box-shadow 0.15s, background 0.15s;
  width: 100%;
}
.pg-input:focus,
.pg-field input.ms-field-input:focus,
.pg-field select.ms-field-input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-ring);
}
.pg-input::placeholder { color: var(--t4); }
.pg-input:disabled { background: var(--surface-2); color: var(--t3); cursor: not-allowed; }
[data-theme="dark"] .pg-input { background: var(--surface-2); }
[data-theme="dark"] .pg-input:focus { background: var(--surface); }

.pg-textarea {
  width: 100%;
  min-height: 110px;
  padding: 12px;
  border: 1px solid var(--line-strong);
  border-radius: 10px;
  background: var(--surface);
  color: var(--t1);
  font-size: 13px;
  font-family: inherit;
  font-weight: 500;
  outline: none;
  resize: vertical;
  line-height: 1.55;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.pg-textarea:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-ring);
}
[data-theme="dark"] .pg-textarea { background: var(--surface-2); }
[data-theme="dark"] .pg-textarea:focus { background: var(--surface); }

/* ─── Hint text ─── */
.pg-hint {
  font-size: 11.5px;
  color: var(--t3);
  margin: 8px 0 0;
  line-height: 1.5;
}

/* ─── Localisation grid (fields + map) ─── */
.pg-loc-grid,
.pg-form-section .ms-card-body.pg-loc-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 14px;
  align-items: stretch;
  flex-direction: initial;
}
.pg-loc-grid .pg-fields {
  display: contents;
}
.pg-loc-grid .pg-fields-row {
  display: grid;
  gap: 12px;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
}
.pg-loc-grid .pg-fields > .pg-fields-row:nth-of-type(1) {
  order: 1;
}
.pg-loc-grid .pg-fields > .pg-fields-row:nth-of-type(2) {
  order: 2;
}
.pg-loc-grid .pg-fields > .pg-fields-row:nth-of-type(3) {
  order: 3;
}
.pg-loc-grid .pg-fields > label:nth-of-type(1) {
  order: 5;
}
.pg-loc-grid .pg-fields > label:nth-of-type(2) {
  order: 6;
}
.pg-loc-grid .pg-field {
  min-width: 0;
}
.pg-loc-grid .pg-field[style] {
  flex: initial !important;
}
.pg-loc-grid .pg-input,
.pg-loc-grid .ms-field-input {
  min-width: 0;
  width: 100%;
}
.pg-loc-gmaps-btn { align-self: flex-start; margin-top: 4px; }
.pg-map-preview {
  position: relative;
  min-height: 320px;
  background: linear-gradient(135deg, var(--surface-2), var(--surface-3));
  border: 1px solid var(--line);
  border-radius: 12px;
  overflow: hidden;
  display: grid;
  place-items: center;
  order: 4;
  width: 100%;
}
.pg-map-grid { width: 100%; height: 100%; }

/* ─── Type pills ─── */
.pg-type-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.pg-type-pill {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  height: 32px;
  padding: 0 13px;
  border: 1px solid var(--line-strong);
  background: var(--surface);
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
  color: var(--t2);
  cursor: pointer;
  font-family: inherit;
  white-space: nowrap;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
  position: relative;
}
.pg-type-pill input { position: absolute; opacity: 0; pointer-events: none; }
.pg-type-pill:hover { background: var(--surface-2); color: var(--t1); }
.pg-type-pill:has(input:checked),
.pg-type-pill.is-on {
  background: var(--t1);
  color: #fff;
  border-color: var(--t1);
}
[data-theme="dark"] .pg-type-pill:has(input:checked),
[data-theme="dark"] .pg-type-pill.is-on {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}
.pg-type-pill-ghost {
  background: transparent;
  border-style: dashed;
  color: var(--t3);
}

/* ─── Rooms stack (sub-cards in pg-* style) ─── */
.pg-rooms-stack {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 4px;
}
.pg-room-card {
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--surface);
  overflow: hidden;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.pg-room-card:hover { border-color: var(--line-strong); }
.pg-room-card.is-blue .pg-room-card-icon { background: var(--blue-soft); color: var(--blue); }
.pg-room-card.is-annex .pg-room-card-icon { background: var(--accent-soft); color: var(--accent-2); }
.pg-room-card.is-muted .pg-room-card-icon { background: var(--surface-3); color: var(--t3); }
.pg-room-card-head {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  border-bottom: 1px solid transparent;
  background: var(--surface-2);
}
.pg-room-card:has(.pg-room-card-body:not(:empty)) .pg-room-card-head,
.pg-room-card-body:not(:empty) ~ .pg-room-card-head {
  border-bottom-color: var(--line);
}
.pg-room-card-icon {
  width: 32px;
  height: 32px;
  border-radius: 9px;
  background: var(--surface-3);
  color: var(--t2);
  display: grid;
  place-items: center;
  font-size: 14px;
  flex-shrink: 0;
}
.pg-room-card-title {
  flex: 1;
  font-size: 13.5px;
  font-weight: 600;
  color: var(--t1);
}
.pg-room-card-hint {
  padding: 10px 14px 14px;
  font-size: 11.5px;
  color: var(--t3);
}
.pg-room-card-body {
  padding: 14px;
}
.pg-room-card-body:empty { display: none; }

/* ─── Stepper ─── */
.pg-stepper {
  display: inline-flex;
  align-items: center;
  gap: 0;
  border: 1px solid var(--line-strong);
  border-radius: 9px;
  background: var(--surface);
  overflow: hidden;
}
.pg-step-btn {
  width: 28px;
  height: 28px;
  border: none;
  background: transparent;
  color: var(--t2);
  cursor: pointer;
  font-size: 14px;
  font-weight: 600;
  font-family: inherit;
  display: grid;
  place-items: center;
  transition: background 0.15s, color 0.15s;
}
.pg-step-btn:hover { background: var(--surface-2); color: var(--t1); }
.pg-step-val {
  min-width: 28px;
  text-align: center;
  font-size: 13px;
  font-weight: 700;
  color: var(--t1);
  font-feature-settings: "tnum";
  padding: 0 4px;
}

/* ─── Sub-section (Paramètres de réservation) ─── */
.pg-sub-section {
  padding: 14px 0;
  border-top: 1px solid var(--line);
}
.pg-sub-section:first-child { padding-top: 0; border-top: 0; }
.pg-sub-section:last-child { padding-bottom: 0; }
.pg-sub-title {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 12.5px;
  font-weight: 700;
  color: var(--t1);
  margin-bottom: 10px;
  letter-spacing: -0.005em;
}
.pg-sub-title i {
  font-size: 11px;
  color: var(--t3);
}

/* ─── Time range selector ─── */
.pg-time-range {
  display: flex;
  align-items: center;
  gap: 6px;
}
.pg-time-range select.ms-field-input { flex: 1; min-width: 0; }
.pg-time-sep {
  color: var(--t4);
  font-size: 13px;
  font-weight: 600;
  user-select: none;
}

/* ─── Toggle ─── */
.pg-toggle {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  user-select: none;
}
.pg-toggle input { position: absolute; opacity: 0; pointer-events: none; }
.pg-toggle-track {
  width: 40px;
  height: 22px;
  border-radius: 999px;
  background: var(--surface-3);
  border: 1px solid var(--line-strong);
  position: relative;
  transition: background 0.18s, border-color 0.18s;
  flex-shrink: 0;
}
.pg-toggle-thumb {
  position: absolute;
  top: 2px; left: 2px;
  width: 16px; height: 16px;
  border-radius: 50%;
  background: var(--surface);
  box-shadow: 0 1px 2px rgba(12,12,16,0.18);
  transition: transform 0.18s ease;
}
.pg-toggle input:checked + .pg-toggle-track {
  background: var(--accent);
  border-color: var(--accent);
}
.pg-toggle input:checked + .pg-toggle-track .pg-toggle-thumb {
  transform: translateX(18px);
  background: #fff;
}
.pg-toggle-label {
  font-size: 13px;
  font-weight: 500;
  color: var(--t1);
}

/* ─── Action bar (bottom) ─── */
.pg-action-bar,
.pg-action-bar.ms-action-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 14px 18px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 14px;
  box-shadow: var(--shadow-2);
  position: sticky;
  bottom: 12px;
  z-index: 20;
  width: 100%;
  margin-left: 0;
  justify-content: flex-end;
  backdrop-filter: none;
}
[data-theme="dark"] .pg-action-bar { background: var(--surface); }
.pg-action-spacer { flex: 1; }
.pg-action-primary {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  height: 36px;
  padding: 0 16px;
  border: none;
  border-radius: 10px;
  background: var(--accent);
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  font-family: inherit;
  white-space: nowrap;
  transition: background 0.15s, transform 0.1s, box-shadow 0.15s;
  box-shadow: 0 4px 10px -3px var(--accent-ring);
}
.pg-action-primary:hover { background: var(--accent-2); }
.pg-action-primary:active { transform: scale(0.98); }
.pg-action-danger {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 36px;
  margin-right: auto;
  padding: 0 13px;
  border: 1px solid var(--line-strong);
  background: transparent;
  color: var(--rose);
  border-radius: 10px;
  font-size: 12.5px;
  font-weight: 600;
  cursor: pointer;
  font-family: inherit;
  transition: background 0.15s, border-color 0.15s;
}
.pg-action-danger:hover { background: var(--rose-soft); border-color: var(--rose); }

/* ─── Form section that also keeps ms-card-head behaviour (icon) ─── */
.pg-form-section .ms-card-head .ms-card-icon {
  flex-shrink: 0;
}

/* ─── Responsive: tablet and mobile ─── */
@media (max-width: 1280px) {
  .pg-kpi-strip { grid-template-columns: repeat(3, 1fr); }
  .pg-loc-grid { grid-template-columns: 1fr; }
  .pg-map-preview { min-height: 220px; }
}

@media (max-width: 960px) {
  .pg-shell { grid-template-columns: 320px 1fr; }
  .pg-detail { padding: 16px 18px 20px; }
}

@media (max-width: 860px) {
  .pg-shell { display: block; }
  .pg-list { border-right: none; padding: 14px; }
  .pg-detail { padding: 14px; }
  .pg-prop-header { flex-direction: column; align-items: flex-start; padding: 14px; }
  .pg-prop-header-right { width: 100%; }
  .pg-prop-header-right .chip-btn { flex: 1; justify-content: center; }
  .pg-kpi-strip { grid-template-columns: repeat(2, 1fr); }
  .pg-fields-row, .pg-fields-row.cols-3 { grid-template-columns: 1fr; }
  .pg-prop-header-name { font-size: 17px; }
  .pg-tabs { padding: 3px; }
  .pg-tab { padding: 0 10px; height: 32px; font-size: 12px; }
  .pg-tab i { display: none; }
  .pg-action-bar { padding: 12px; border-radius: 12px; justify-content: flex-end; }
  .pg-action-bar.ms-action-bar > * { flex: 0 0 auto; text-align: unset; }
  .pg-action-primary span, .pg-action-danger span { display: inline; }
}

@media (max-width: 480px) {
  .pg-kpi-strip { grid-template-columns: 1fr 1fr; }
  .pg-kpi-tile { padding: 10px 12px; }
  .pg-kpi-tile-val { font-size: 17px; }
  .pg-room-card-head { gap: 10px; padding: 10px 12px; }
  .pg-room-card-icon { width: 28px; height: 28px; font-size: 12px; }
}

/* ══════════════════════════════════════════════════════════════════════════════
   PROPERTIES PAGE — FIX BATCH (corrections after first review)
   ══════════════════════════════════════════════════════════════════════════════ */

/* ─── Font weights : softer, more "2027" ─── */
.pg-prop-header-name,
.pg-form-section-head h3,
.pg-kpi-tile-val,
.pg-prop-name,
.pg-sub-title,
.pg-room-card-title { font-weight: 600; }
.pg-tab,
.pg-chip,
.pg-type-pill,
.pg-mini-cta,
.pg-action-primary,
.pg-prop-meta,
.pg-field > span:first-child,
.pg-field-block-label { font-weight: 500; }
.pg-status-pill { font-weight: 600; }

/* ─── Avatar: remove orange "halo" around photo ─── */
.pg-prop-chip { padding: 0; overflow: hidden; }
.pg-prop-chip img,
.pg-prop-chip .ms-prop-avatar img,
.pg-prop-header [data-prop-header-avatar] img,
[data-prop-menu-avatar] img {
  width: 100% !important;
  height: 100% !important;
  border-radius: 12px !important;
  object-fit: cover !important;
  display: block;
}
.pg-prop-chip .ms-prop-avatar {
  width: 100%; height: 100%;
  border-radius: 12px;
  background: transparent;
}

/* ─── Photo thumb in list rows ─── */
.pg-prop-row .pg-photo {
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  color: #fff;
  font-weight: 700;
  font-size: 13px;
}
.pg-prop-row .pg-photo img { width: 100%; height: 100%; object-fit: cover; }
.pg-prop-row.ms-prop-list-item .ms-prop-grip {
  display: none; /* hide old grip for new list rows on desktop */
}

/* ─── Tab active fix: only one tab active at a time ─── */
/* Override old .property-tab.active rules — use only .active for active state */
.pg-tab.is-on:not(.active) {
  background: transparent;
  color: var(--t3);
}
.pg-tabs .pg-tab.property-tab { color: var(--t3); background: transparent; }
.pg-tabs .pg-tab.property-tab.active,
.pg-tabs .pg-tab.property-tab.is-on { color: var(--t1); background: var(--surface-3); }
[data-theme="dark"] .pg-tabs .pg-tab.property-tab.active,
[data-theme="dark"] .pg-tabs .pg-tab.property-tab.is-on { background: var(--surface-3); }

/* ─── Sub-sections : add internal padding so border doesn't hug content ─── */
.pg-sub-section.property-context-panel {
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 14px 16px;
  margin-top: 14px;
}
.pg-sub-section.property-context-panel:first-child { margin-top: 0; }
.pg-sub-section.property-context-panel + .pg-sub-section.property-context-panel { border-top: 1px solid var(--line); }
.pg-sub-section .pg-sub-title { margin-bottom: 12px; }
[data-theme="dark"] .pg-sub-section.property-context-panel {
  background: var(--surface-2);
  border-color: var(--line);
}

/* TTLock access window same fix */
.ttlock-access-window.pg-sub-section,
.ttlock-access-window { padding: 14px 16px; }

/* ─── ms-pill / property-type-pill : active color #0C0C10 ─── */
.ms-pill:has(input:checked),
.ms-pill.is-on,
.property-type-pill:has(input:checked),
.property-type-pill.is-on,
.pg-type-pill:has(input:checked),
.pg-type-pill.is-on {
  background: var(--t1) !important;
  border-color: var(--t1) !important;
  color: #fff !important;
}
[data-theme="dark"] .ms-pill:has(input:checked),
[data-theme="dark"] .ms-pill.is-on,
[data-theme="dark"] .property-type-pill:has(input:checked),
[data-theme="dark"] .property-type-pill.is-on,
[data-theme="dark"] .pg-type-pill:has(input:checked),
[data-theme="dark"] .pg-type-pill.is-on {
  background: var(--accent) !important;
  border-color: var(--accent) !important;
  color: #fff !important;
}

/* ─── Icons: uniform style (black icon + very light orange bg + thin black border) ─── */
.pg-form-section .ms-card-icon,
.pg-form-section .ms-card-icon.blue,
.pg-form-section .ms-card-icon.green,
.pg-form-section .ms-card-icon.orange,
.pg-room-card .ms-card-icon,
.pg-room-card .pg-room-card-icon,
.pg-room-card.is-blue .pg-room-card-icon,
.pg-room-card.is-annex .pg-room-card-icon,
.pg-room-card.is-muted .pg-room-card-icon,
.property-mobile-menu-item span i {
  background: rgba(var(--accent-rgb), 0.08) !important;
  color: var(--t1) !important;
  border: 1px solid rgba(12, 12, 16, 0.08) !important;
}
[data-theme="dark"] .pg-form-section .ms-card-icon,
[data-theme="dark"] .pg-room-card .pg-room-card-icon,
[data-theme="dark"] .property-mobile-menu-item span i {
  background: rgba(var(--accent-rgb), 0.12) !important;
  color: var(--t1) !important;
  border-color: rgba(255, 255, 255, 0.08) !important;
}

/* ─── Search input (left sidebar) ─── */
.pg-search {
  position: relative;
  display: flex;
  align-items: center;
}
.pg-search i {
  position: absolute;
  left: 11px;
  color: var(--t3);
  font-size: 12px;
  pointer-events: none;
}
.pg-search input {
  width: 100%;
  height: 34px;
  padding: 0 12px 0 32px;
  border: 1px solid var(--line-strong);
  border-radius: 10px;
  background: var(--surface);
  color: var(--t1);
  font-size: 13px;
  font-family: inherit;
  font-weight: 400;
  outline: none;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.pg-search input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-ring);
}
.pg-search input::placeholder { color: var(--t4); }
[data-theme="dark"] .pg-search input { background: var(--surface-2); }

/* ─── Sort button : lighter, black icon ─── */
.prop-sort-control {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  height: 32px;
  padding: 0 12px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 9px;
  font-size: 12.5px;
  font-weight: 500;
  color: var(--t2);
  cursor: pointer;
  font-family: inherit;
  transition: background 0.15s;
}
.prop-sort-control:hover { background: var(--surface-2); color: var(--t1); }
.prop-sort-control i { color: var(--t1); font-size: 11px; }
.prop-sort-control small { color: var(--t3); font-size: 11.5px; font-weight: 500; margin-left: 3px; }

/* ─── Group filter popover (Trier-like button) ─── */
.prop-list-group { position: relative; }
.prop-group-control {
  /* inherits .prop-sort-control look */
}
/* Override inherited .property-sort-menu width so popover fits the sidebar */
.prop-list-group-menu.property-sort-menu {
  position: absolute;
  top: calc(100% + 7px);
  left: 0;
  right: 0;
  z-index: 540;
  padding: 8px;
  border-radius: 14px;
  background: var(--surface);
  border: 1px solid var(--line-strong);
  box-shadow: var(--shadow-pop);
  display: flex;
  flex-direction: column;
  gap: 6px;
  width: auto;
  min-width: 0;
  max-width: none;
  max-height: none;
  overflow: visible;
}
/* Allow the popover to escape the sidebar's overflow:hidden by hoisting clip */
.pg-list { overflow: visible; }
.pg-prop-list { overflow-y: auto; overflow-x: hidden; }

/* ─── Sort menu items: use new design system (black/orange, not blue) ─── */
.prop-list-sort-menu.property-sort-menu {
  background: var(--surface);
  border: 1px solid var(--line-strong);
  box-shadow: var(--shadow-pop);
  border-radius: 14px;
  padding: 10px;
  width: auto;
  min-width: 0;
  max-width: none;
  max-height: none;
  overflow: visible;
}
.prop-list-sort-menu .calendar-filter-panel-head {
  padding: 2px 4px 8px;
  border: 0;
}
.prop-list-sort-menu .calendar-filter-panel-head strong {
  color: var(--t1);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: -0.005em;
}
.prop-list-sort-menu .calendar-filter-panel-head span {
  color: var(--t3);
  font-size: 11.5px;
  font-weight: 500;
  margin-top: 2px;
  display: block;
}
.prop-list-sort-menu .property-sort-options {
  padding-top: 6px;
  border-top: 1px solid var(--line);
  gap: 2px;
}
.prop-list-sort-menu .property-sort-option {
  background: transparent !important;
  color: var(--t2) !important;
  font-weight: 500 !important;
  min-height: 32px;
  border-radius: 8px;
  font-size: 12.5px;
}
.prop-list-sort-menu .property-sort-option i {
  color: var(--t3) !important;
  font-size: 12px;
  width: 14px;
}
.prop-list-sort-menu .property-sort-option:hover {
  background: var(--surface-2) !important;
  color: var(--t1) !important;
}
.prop-list-sort-menu .property-sort-option:hover i {
  color: var(--t1) !important;
}
.prop-list-sort-menu .property-sort-option.active {
  background: var(--surface-3) !important;
  color: var(--t1) !important;
  font-weight: 600 !important;
}
.prop-list-sort-menu .property-sort-option.active i {
  color: var(--accent) !important;
}
[data-theme="dark"] .prop-list-sort-menu .property-sort-option.active {
  background: var(--surface-3) !important;
}

/* footer "Add group" row inside popover */
.pg-grpfilter-addrow {
  display: flex;
  align-items: center;
  gap: 8px;
  height: 32px;
  padding: 0 11px;
  border: 1px dashed var(--line-strong);
  background: transparent;
  border-radius: 9px;
  font-family: inherit;
  font-size: 12.5px;
  font-weight: 500;
  color: var(--t2);
  cursor: pointer;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.pg-grpfilter-addrow:hover {
  background: var(--surface-2);
  color: var(--t1);
  border-color: var(--t3);
}
.pg-grpfilter-addrow i { font-size: 10px; color: var(--t3); }
.pg-grpfilter-addrow:hover i { color: var(--t1); }

.prop-group-filter {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 0;
}

.pg-grpfilter-segs {
  display: flex;
  flex-direction: column;
  gap: 1px;
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 3px;
}
.pg-grpfilter-seg-wrap {
  position: relative;
  display: flex;
  align-items: center;
}
.pg-grpfilter-seg {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 8px;
  height: 30px;
  padding: 0 10px;
  border: none;
  background: transparent;
  border-radius: 7px;
  font-family: inherit;
  font-size: 12.5px;
  font-weight: 500;
  color: var(--t2);
  cursor: pointer;
  text-align: left;
  transition: background 0.15s, color 0.15s;
}
.pg-grpfilter-seg:hover { background: var(--surface); color: var(--t1); }
.pg-grpfilter-seg.is-on {
  background: var(--surface);
  color: var(--t1);
  font-weight: 600;
  box-shadow: 0 1px 2px rgba(12, 12, 16, 0.06), 0 0 0 0.5px rgba(12, 12, 16, 0.04);
}
[data-theme="dark"] .pg-grpfilter-seg.is-on {
  background: var(--surface);
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.5), 0 0 0 0.5px rgba(255, 255, 255, 0.06);
}
.pg-grpfilter-name {
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pg-grpfilter-num {
  font-size: 11px;
  color: var(--t3);
  font-weight: 500;
  font-feature-settings: "tnum";
}
.pg-grpfilter-seg.is-on .pg-grpfilter-num { color: var(--t2); }
.pg-grpfilter-seg-muted .pg-grpfilter-name { color: var(--t3); font-style: italic; }
.pg-grpfilter-seg-muted.is-on .pg-grpfilter-name { color: var(--t1); font-style: normal; }

.pg-grpfilter-seg-x {
  position: absolute;
  right: 4px;
  width: 20px;
  height: 20px;
  border: none;
  border-radius: 5px;
  background: transparent;
  color: var(--t4);
  cursor: pointer;
  display: grid;
  place-items: center;
  font-size: 10px;
  opacity: 0;
  transition: opacity 0.12s ease, background 0.12s, color 0.12s;
  font-family: inherit;
}
.pg-grpfilter-seg-wrap:hover .pg-grpfilter-seg-x,
.pg-grpfilter-seg-x:focus-visible { opacity: 1; }
.pg-grpfilter-seg-x:hover { background: var(--rose-soft); color: var(--rose); }
.pg-grpfilter-seg-wrap:hover .pg-grpfilter-seg { padding-right: 30px; }

/* ─── Custom app modals (replace native prompt/confirm/alert) ─── */
.app-modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(12, 12, 16, 0.45);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  display: grid;
  place-items: center;
  z-index: 9999;
  padding: 20px;
  animation: app-modal-fade 0.15s ease-out;
}
.app-modal-backdrop[hidden] { display: none; }
.app-modal {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 22px;
  max-width: 420px;
  width: 100%;
  box-shadow: 0 24px 60px -10px rgba(0, 0, 0, 0.3), 0 8px 16px -8px rgba(0, 0, 0, 0.15);
  animation: app-modal-pop 0.18s cubic-bezier(0.22, 1.2, 0.36, 1);
}
.app-modal-title {
  font-size: 16px;
  font-weight: 700;
  color: var(--t1);
  margin-bottom: 6px;
  letter-spacing: -0.01em;
}
.app-modal-title[hidden] { display: none; }
.app-modal-message {
  font-size: 13px;
  color: var(--t2);
  line-height: 1.5;
  margin-bottom: 16px;
}
.app-modal-message[hidden] { display: none; }
.app-modal-input {
  width: 100%;
  height: 38px;
  padding: 0 12px;
  border: 1px solid var(--line-strong);
  border-radius: 9px;
  background: var(--surface);
  color: var(--t1);
  font-size: 13px;
  font-family: inherit;
  outline: none;
  margin-bottom: 18px;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.app-modal-input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-ring);
}
[data-theme="dark"] .app-modal-input { background: var(--surface-2); }
.app-modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}
.app-modal-btn {
  height: 34px;
  padding: 0 16px;
  border-radius: 9px;
  border: 1px solid transparent;
  font-family: inherit;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.app-modal-btn-ghost {
  background: transparent;
  color: var(--t2);
  border-color: var(--line-strong);
}
.app-modal-btn-ghost:hover { background: var(--surface-2); color: var(--t1); }
.app-modal-btn-primary {
  background: var(--t1);
  color: #fff;
}
.app-modal-btn-primary:hover { background: #1c1c22; }
[data-theme="dark"] .app-modal-btn-primary { background: var(--accent); }
[data-theme="dark"] .app-modal-btn-primary:hover { background: var(--accent-2); }

@keyframes app-modal-fade {
  from { opacity: 0; }
  to { opacity: 1; }
}
@keyframes app-modal-pop {
  from { opacity: 0; transform: scale(0.96) translateY(4px); }
  to { opacity: 1; transform: scale(1) translateY(0); }
}

/* ─── Confirm/Input modal: orange "Valider" button (override blue .btn-primary) ─── */
[data-app-confirm] .cal-modal-actions .btn.btn-primary,
[data-app-confirm] .cal-modal-actions .btn-primary {
  background: var(--accent) !important;
  color: #fff !important;
  border: 0 !important;
}
[data-app-confirm] .cal-modal-actions .btn.btn-primary:hover,
[data-app-confirm] .cal-modal-actions .btn-primary:hover {
  background: var(--accent-2) !important;
}
[data-app-confirm] .cal-modal-actions .btn.btn-secondary,
[data-app-confirm] .cal-modal-actions .btn-secondary {
  background: transparent !important;
  color: var(--t2) !important;
  border: 1px solid var(--line-strong) !important;
}
[data-app-confirm] .cal-modal-actions .btn.btn-secondary:hover,
[data-app-confirm] .cal-modal-actions .btn-secondary:hover {
  background: var(--surface-2) !important;
  color: var(--t1) !important;
}
/* Modernize the confirm modal card itself to match the new app-modal style */
[data-app-confirm].cal-modal-backdrop {
  background: rgba(12, 12, 16, 0.45);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
[data-app-confirm] .cal-modal {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 22px;
  box-shadow: 0 24px 60px -10px rgba(0, 0, 0, 0.3), 0 8px 16px -8px rgba(0, 0, 0, 0.15);
}
[data-app-confirm] .cal-modal-message {
  font-size: 13.5px;
  color: var(--t1);
  line-height: 1.55;
  margin-bottom: 18px;
}

/* ─── Mobile menu (page-split-tabs) modernized to pg-* ─── */
@media (max-width: 860px) {
  .property-detail-form > .property-quality-card {
    display: none;
  }
  .property-quality-mobile {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 14px;
    box-shadow: var(--shadow-1);
    display: grid;
    gap: 10px;
    margin: 10px 0 0;
    padding: 14px 16px;
  }
  .property-quality-mobile[hidden] {
    display: none;
  }
  .property-quality-mobile .property-quality-list {
    grid-template-columns: 1fr;
  }
  .property-quality-mobile .property-quality-item {
    grid-template-columns: 26px minmax(0, 1fr);
  }
  .property-quality-mobile .property-quality-item em {
    display: none;
  }
  .property-mobile-menu {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 14px;
    box-shadow: var(--shadow-1);
    overflow: hidden;
  }
  .property-mobile-menu-item {
    background: var(--surface);
    border-bottom: 1px solid var(--line);
    color: var(--t1);
    font-family: inherit;
    font-size: 13.5px;
    font-weight: 500;
    transition: background 0.15s;
  }
  .property-mobile-menu-item:hover { background: var(--surface-2); }
  .property-mobile-menu-item:last-child { border-bottom: 0; }
  .property-mobile-menu-item > i { color: var(--t3); }
}

/* ─── Mobile: location grid (map below fields) ─── */
@media (max-width: 860px) {
  .pg-loc-grid .pg-map-preview {
    min-height: 220px;
  }
  .pg-fields > .pg-loc-gmaps-btn {
    display: none;
  }
}

/* ─── Mobile: smaller "Ajouter" button ─── */
@media (max-width: 860px) {
  .page-split-list-hd .pg-mini-cta {
    height: 30px;
    padding: 0 10px;
    font-size: 12px;
  }
  .page-split-list-hd .pg-mini-cta i { font-size: 10px; }
  .page-split-list-hd .pg-mini-cta.prop-add-btn { width: auto; }
}

/* ─── Mobile: annexes 2 per row ─── */
@media (max-width: 860px) {
  .ms-annex-grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
  }
  .ms-annex-tile {
    padding: 10px 8px !important;
    font-size: 11.5px !important;
  }
}

/* ─── Mobile: tighter pg-prop-row ─── */
@media (max-width: 860px) {
  .pg-prop-row { grid-template-columns: 38px minmax(0,1fr) auto; gap: 10px; padding: 9px; }
  .pg-prop-row .pg-photo { width: 38px; height: 38px; }
}

/* ══════════════════════════════════════════════════════════════════════════════
   PROPERTIES — FIX BATCH 2 (group menu, icons, photo drag, group choice)
   ══════════════════════════════════════════════════════════════════════════════ */

/* ─── Modernized group sections in left list ─── */
.pg-prop-list .prop-group-section {
  border-bottom: 1px solid var(--line);
  padding: 6px 0 8px;
  margin-bottom: 4px;
}
.pg-prop-list .prop-group-section:last-child {
  border-bottom: 0;
  margin-bottom: 0;
}
.pg-prop-list .prop-group-section-title {
  color: var(--t3);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin-bottom: 4px;
  padding: 0 4px;
}
.pg-prop-list .prop-group-section-list {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 0;
}

/* ─── Property group choice (Groupe du logement) : selected = #0C0C10 not blue ─── */
.property-group-list {
  gap: 6px;
}
.property-group-check {
  align-items: center;
  background: var(--surface);
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  color: var(--t2);
  cursor: pointer;
  display: inline-flex;
  font-family: inherit;
  font-size: 12px;
  font-weight: 600;
  gap: 5px;
  height: 32px;
  padding: 0 13px;
  position: relative;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
  white-space: nowrap;
}
.property-group-check input {
  opacity: 0;
  pointer-events: none;
  position: absolute;
}
.property-group-check:hover {
  background: var(--surface-2);
  color: var(--t1);
}
.property-group-check:has(input:checked) {
  background: var(--t1) !important;
  border-color: var(--t1) !important;
  color: #fff !important;
}
.property-group-check:has(input:checked) span { color: #fff !important; }
[data-theme="dark"] .property-group-check:has(input:checked) {
  background: var(--accent) !important;
  border-color: var(--accent) !important;
}

/* ─── Solid orange #f5874d background behind icons + dark icon ─── */
.pg-form-section .ms-card-icon,
.pg-form-section .ms-card-icon.blue,
.pg-form-section .ms-card-icon.green,
.pg-form-section .ms-card-icon.orange,
.pg-room-card .ms-card-icon,
.pg-room-card .pg-room-card-icon,
.pg-room-card.is-blue .pg-room-card-icon,
.pg-room-card.is-annex .pg-room-card-icon,
.pg-room-card.is-muted .pg-room-card-icon,
.property-mobile-menu-item span i {
  background: var(--accent-soft) !important;
  color: var(--accent) !important;
  border: 1px solid var(--accent-ring) !important;
}

/* ─── Photo gallery : visible drop indicator before release ─── */
.property-gallery-item.dragging {
  opacity: 0.3 !important;
  cursor: grabbing;
}
.property-gallery-item.drag-over {
  border-color: var(--accent) !important;
  box-shadow:
    0 0 0 2px var(--accent),
    0 6px 14px -2px var(--accent-ring) !important;
  transform: scale(1.02);
  transition: transform 0.12s ease, box-shadow 0.12s ease;
}
.property-gallery-item.drag-over::before {
  content: '';
  position: absolute;
  inset: -4px;
  border: 2px dashed var(--accent);
  border-radius: 12px;
  pointer-events: none;
  z-index: 5;
}
.property-gallery-item { position: relative; }
[data-theme="dark"] .property-gallery-item.drag-over {
  box-shadow:
    0 0 0 2px var(--accent),
    0 6px 14px -2px var(--accent-ring) !important;
}

/* ─── Mobile tabs : proper horizontal scroll + readable ─── */
@media (max-width: 860px) {
  .pg-tabs {
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding: 3px;
    gap: 2px;
    max-width: 100%;
  }
  .pg-tabs::-webkit-scrollbar { display: none; }
  .pg-tab {
    flex: 0 0 auto;
    padding: 0 11px;
    height: 32px;
    font-size: 12px;
    gap: 5px;
  }
  .pg-tab i { display: none; }
}

/* Properties: hide desktop tab bar on mobile — mobile menu list handles navigation */
@media (max-width: 640px) {
  .page-split.prop-mode .pg-tabs { display: none !important; }
}

/* Hide the mobile menu when not in mobile mode */
@media (min-width: 861px) {
  .page-split-tabs { display: none !important; }
}

@keyframes ms-toast-fade {
  0% { opacity: 0; transform: translateY(-4px); }
  15% { opacity: 1; transform: translateY(0); }
  85% { opacity: 1; transform: translateY(0); }
  100% { opacity: 0; transform: translateY(-2px); }
}

.ms-save-toast {
  position: absolute;
  top: 100%;
  right: 0;
  margin-top: 6px;
  padding: 5px 10px;
  background: var(--green);
  color: #fff;
  font-size: 11.5px;
  font-weight: 600;
  border-radius: 6px;
  box-shadow: var(--shadow-1);
  z-index: 10;
  animation: ms-toast-fade 1.6s ease-out forwards;
  white-space: nowrap;
  pointer-events: none;
}

/* ══════════════════════════════════════════════════════════════════════════════
   PROPERTIES — FIX BATCH 3 (uniform black accents + new group display)
   ══════════════════════════════════════════════════════════════════════════════ */

/* ─── Uniform black color for tags/icons inside property form ─── */
.pg-form-section .tag,
.pg-prop-header .tag {
  color: var(--t1);
  background: rgba(12, 12, 16, 0.06);
  border: 1px solid rgba(12, 12, 16, 0.1);
}
[data-theme="dark"] .pg-form-section .tag,
[data-theme="dark"] .pg-prop-header .tag {
  color: var(--t1);
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.12);
}

/* Map empty-state icon */
.pg-map-preview .property-map-empty .fa-map-location-dot,
.property-map-empty .fa-map-location-dot {
  color: var(--t1) !important;
}

/* Photo gallery upload icon */
.property-gallery-drop .property-gallery-drop-icon,
.property-gallery-drop .fa-cloud-arrow-up {
  color: var(--t1) !important;
}

/* Stepper buttons (room/kitchen/bathroom counters) */
.pg-form-section .ms-step-btn,
.pg-room-card .ms-step-btn,
.ms-stepper .ms-step-btn {
  color: var(--t1) !important;
}
.pg-form-section .ms-step-btn:hover,
.pg-room-card .ms-step-btn:hover,
.ms-stepper .ms-step-btn:hover {
  background: var(--surface-3);
  color: var(--t1) !important;
}

[data-theme="dark"] .pg-map-preview .property-map-empty .fa-map-location-dot,
[data-theme="dark"] .property-gallery-drop .property-gallery-drop-icon,
[data-theme="dark"] .pg-form-section .ms-step-btn,
[data-theme="dark"] .pg-room-card .ms-step-btn,
[data-theme="dark"] .ms-stepper .ms-step-btn {
  color: var(--t1) !important;
}

/* ─── Groups in left list: simple section title (previous design) ─── */
.pg-prop-list .prop-group-section {
  border-bottom: 1px solid var(--line);
  padding: 6px 0 8px;
  margin-bottom: 4px;
}
.pg-prop-list .prop-group-section:last-child {
  border-bottom: 0;
  margin-bottom: 0;
}
.pg-prop-list .prop-group-section-title {
  display: block;
  color: var(--t3);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin-bottom: 4px;
  padding: 0 4px;
}
.pg-prop-list .prop-group-section-list {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 0;
}

/* ══════════════════════════════════════════════════════════════════════════════
   FIX BATCH — Dashboard / Inbox / Properties / Calendar
   ══════════════════════════════════════════════════════════════════════════════ */

/* ─── Dashboard: occupation bars with percentage ─── */
.occ-pct {
  font-size: 9px;
  font-weight: 700;
  color: var(--t4);
  text-align: center;
  line-height: 1;
}
.occ-col.is-today .occ-pct { color: var(--accent); }

/* ─── Dashboard: property name on mobile activity rows ─── */
.act-prop-mobile {
  display: none;
  font-size: 11px;
  color: var(--accent);
  font-weight: 600;
  margin-top: 2px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
@media (max-width: 960px) {
  .act-prop-mobile { display: block; }
}

/* ─── Inbox: detail back button as text link ─── */
.inbox-detail-back-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  background: none;
  border: none;
  color: var(--accent);
  font: inherit;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  padding: 4px 0;
  transition: color 0.12s;
}
.inbox-detail-back-btn:hover { color: var(--t1); }
.inbox-detail-back-btn i { font-size: 11px; }

/* ─── Properties: dark mode missing fixes ─── */
[data-theme="dark"] .ms-field-input,
[data-theme="dark"] .ms-textarea {
  background: var(--surface-2);
  color: var(--t1);
}
[data-theme="dark"] .field-info {
  background: var(--surface-3);
  color: var(--t3);
}
[data-theme="dark"] .map-help-tooltip {
  background: var(--surface-2);
  border-color: var(--line-strong);
  color: var(--t1);
}
[data-theme="dark"] .property-gallery-drop {
  background: var(--surface-2);
  border-color: var(--line-strong);
}
[data-theme="dark"] .property-gallery-drop:hover {
  background: var(--surface-3);
  border-color: var(--accent);
}
[data-theme="dark"] .property-gallery-item {
  background: var(--surface-2);
  border-color: var(--line-strong);
}
[data-theme="dark"] .property-gallery-image-wrap {
  background: var(--surface-3);
}
[data-theme="dark"] .property-gallery-empty {
  background: var(--surface-2);
}
[data-theme="dark"] .property-time-card {
  background: var(--surface-2);
  border-color: var(--line);
}
[data-theme="dark"] .prop-back-btn {
  background: var(--surface);
  border-color: var(--line-strong);
  color: var(--t2);
}
[data-theme="dark"] .prop-group-section-item.is-active {
  background: var(--surface-3);
}

/* ─── Properties: mobile gallery — 2 columns, smaller thumbnails ─── */
@media (max-width: 640px) {
  .property-gallery {
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
  }
}

/* ─── Calendar: toolbar active state + sort menu matches properties style ─── */
.tool-btn.active {
  background: var(--surface-3);
  color: var(--t1);
  border-color: var(--line-strong);
}
/* .tool-btn.is-grouped : classe technique JS uniquement — pas de style visuel différent */
[data-calendar-property-sort-menu] .property-sort-option {
  background: transparent !important;
  color: var(--t2) !important;
  font-weight: 500 !important;
  min-height: 32px;
  border-radius: 8px;
  font-size: 13px;
}
[data-calendar-property-sort-menu] .property-sort-option i {
  color: var(--t3) !important;
  font-size: 12px;
  width: 14px;
}
[data-calendar-property-sort-menu] .property-sort-option:hover {
  background: var(--surface-2) !important;
  color: var(--t1) !important;
}
[data-calendar-property-sort-menu] .property-sort-option:hover i {
  color: var(--t1) !important;
}
[data-calendar-property-sort-menu] .property-sort-option.active {
  background: var(--surface-3) !important;
  color: var(--t1) !important;
  font-weight: 600 !important;
}
[data-calendar-property-sort-menu] .property-sort-option.active i {
  color: var(--accent) !important;
}
[data-calendar-property-sort-menu] .calendar-filter-panel-head strong {
  color: var(--t1);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: -0.005em;
}
[data-calendar-property-sort-menu] .calendar-filter-panel-head span {
  color: var(--t3);
  font-size: 11.5px;
  font-weight: 500;
  margin-top: 2px;
  display: block;
}
[data-calendar-property-sort-menu] .property-sort-options {
  padding-top: 6px;
  border-top: 1px solid var(--line);
  gap: 2px;
}

/* ══════════════════════════════════════════════════════════════════════════════
   FIX BATCH 2 — Icons dark mode / Eye / Filtrer / Groups / Gallery
   ══════════════════════════════════════════════════════════════════════════════ */

/* ─── Icons: dark mode override (fixes specificity — all icon variants get accent style) ─── */
[data-theme="dark"] .pg-form-section .ms-card-icon,
[data-theme="dark"] .pg-form-section .ms-card-icon.blue,
[data-theme="dark"] .pg-form-section .ms-card-icon.green,
[data-theme="dark"] .pg-form-section .ms-card-icon.orange,
[data-theme="dark"] .pg-room-card .ms-card-icon,
[data-theme="dark"] .pg-room-card .pg-room-card-icon,
[data-theme="dark"] .pg-room-card.is-blue .pg-room-card-icon,
[data-theme="dark"] .pg-room-card.is-annex .pg-room-card-icon,
[data-theme="dark"] .pg-room-card.is-muted .pg-room-card-icon,
[data-theme="dark"] .property-mobile-menu-item span i {
  background: rgba(var(--accent-rgb), 0.18) !important;
  color: var(--accent) !important;
  border: 1px solid rgba(var(--accent-rgb), 0.4) !important;
}

/* ─── Calendar: "Filtrer" panel — replace hardcoded blue with theme colors ─── */
[data-calendar-property-sort-menu] .calendar-filter-check {
  background: transparent !important;
  border-color: transparent !important;
  border-radius: 8px;
  color: var(--t2);
  min-height: 32px;
  font-family: inherit;
  font-size: 13px;
  font-weight: 500;
}
[data-calendar-property-sort-menu] .calendar-filter-check:hover {
  background: var(--surface-2) !important;
  border-color: var(--line) !important;
  color: var(--t1);
}
[data-calendar-property-sort-menu] .calendar-filter-check:has(input:checked) {
  background: var(--surface-2) !important;
  border-color: var(--line) !important;
  color: var(--t1);
}
[data-calendar-property-sort-menu] .calendar-filter-check.is-group-covered {
  color: var(--t2);
}
[data-calendar-property-sort-menu] .calendar-filter-check input[type="checkbox"] {
  --cb-accent: var(--accent);
}
[data-calendar-property-sort-menu] .calendar-filter-section + .calendar-filter-section {
  border-top-color: var(--line) !important;
}
[data-calendar-property-sort-menu] .calendar-filter-section-title {
  color: var(--t3);
}
[data-calendar-property-sort-menu] .calendar-filter-reset {
  background: transparent;
  border: 1px solid var(--line-strong);
  border-radius: 8px;
  color: var(--t3);
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  padding: 3px 10px;
  transition: background 0.12s, color 0.12s;
  flex-shrink: 0;
}
[data-calendar-property-sort-menu] .calendar-filter-reset:hover {
  background: var(--surface-2);
  color: var(--t1);
}

.dashboard-property-sort-menu .property-sort-option {
  background: transparent !important;
  color: var(--t2) !important;
  font-weight: 500 !important;
  min-height: 32px;
  border-radius: 8px;
  font-size: 13px;
}
.dashboard-property-sort-menu .property-sort-option i {
  color: var(--t3) !important;
  font-size: 12px;
  width: 14px;
}
.dashboard-property-sort-menu .property-sort-option:hover {
  background: var(--surface-2) !important;
  color: var(--t1) !important;
}
.dashboard-property-sort-menu .property-sort-option:hover i {
  color: var(--t1) !important;
}
.dashboard-property-sort-menu .property-sort-option.active {
  background: var(--surface-3) !important;
  color: var(--t1) !important;
  font-weight: 600 !important;
}
.dashboard-property-sort-menu .property-sort-option.active i {
  color: var(--accent) !important;
}
.dashboard-property-sort-menu .calendar-filter-panel-head strong {
  color: var(--t1);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: -0.005em;
}
.dashboard-property-sort-menu .calendar-filter-panel-head span {
  color: var(--t3);
  display: block;
  font-size: 11.5px;
  font-weight: 500;
  margin-top: 2px;
}
.dashboard-property-sort-menu .property-sort-options {
  border-top: 1px solid var(--line);
  gap: 2px;
  padding-top: 6px;
}
.dashboard-property-sort-menu .calendar-filter-check {
  background: transparent !important;
  border-color: transparent !important;
  border-radius: 8px;
  color: var(--t2);
  font-family: inherit;
  font-size: 13px;
  font-weight: 500;
  min-height: 32px;
}
.dashboard-property-sort-menu .calendar-filter-check:hover,
.dashboard-property-sort-menu .calendar-filter-check:has(input:checked) {
  background: var(--surface-2) !important;
  border-color: var(--line) !important;
  color: var(--t1);
}
.dashboard-property-sort-menu .calendar-filter-check input[type="checkbox"] {
  --cb-accent: var(--accent);
}
.dashboard-property-sort-menu .calendar-filter-section + .calendar-filter-section {
  border-top-color: var(--line) !important;
}
.dashboard-property-sort-menu .calendar-filter-section-title {
  color: var(--t3);
}
.dashboard-property-sort-menu .calendar-filter-reset {
  background: transparent;
  border: 1px solid var(--line-strong);
  border-radius: 8px;
  color: var(--t3);
  cursor: pointer;
  flex-shrink: 0;
  font-size: 12px;
  font-weight: 500;
  padding: 3px 10px;
  transition: background 0.12s, color 0.12s;
}
.dashboard-property-sort-menu .calendar-filter-reset:hover {
  background: var(--surface-2);
  color: var(--t1);
}

/* ─── Properties: grouped list items in dark mode ─── */
[data-theme="dark"] .prop-group-section-list .ms-prop-list-item {
  color: var(--t1) !important;
  background: transparent !important;
}
[data-theme="dark"] .prop-group-section-list .ms-prop-list-item:hover {
  background: var(--surface-2) !important;
}
[data-theme="dark"] .prop-group-section-list .ms-prop-list-item.active,
[data-theme="dark"] .prop-group-section-list .ms-prop-list-item.is-active {
  background: var(--surface-3) !important;
  border-color: var(--line-strong) !important;
}
[data-theme="dark"] .prop-group-section-list .ms-prop-list-name {
  color: var(--t1);
}
[data-theme="dark"] .prop-group-section-list .ms-prop-list-meta {
  color: var(--t3);
}

/* ─── Properties: gallery actions bar in dark mode ─── */
[data-theme="dark"] .property-gallery-actions {
  background: var(--surface-2);
  border-top-color: var(--line-strong);
}
[data-theme="dark"] .property-gallery-actions button {
  color: var(--t2);
}
[data-theme="dark"] .property-gallery-actions button:hover {
  color: var(--t1);
  background: var(--surface-3);
}

/* ─── Gallery buttons: dark mode base state ─── */
[data-theme="dark"] .property-gallery-btn {
  background: var(--surface-3);
  border-color: var(--line);
  color: var(--t2);
}
[data-theme="dark"] .property-gallery-btn:hover {
  background: var(--accent-soft);
  border-color: var(--accent-ring);
  color: var(--accent);
}
[data-theme="dark"] .property-gallery-btn.danger:hover {
  background: rgba(239, 68, 68, 0.15);
  border-color: transparent;
  color: var(--ms-red);
}

/* ─── Properties: hide KPI strip when creating a new property ─── */
[data-prop-split]:not([data-active-prop-id]) .pg-kpi-strip { display: none; }

/* ─── Reservations: ms-card-icon — accent orange, no blue ─── */
.reservations-mode .ms-card-icon,
.reservations-mode .ms-card-icon.blue,
.reservations-mode .ms-card-icon.green,
.reservations-mode .ms-card-icon.orange {
  background: rgba(var(--accent-rgb), 0.08) !important;
  color: var(--accent) !important;
  border: 1px solid rgba(12, 12, 16, 0.08) !important;
}
[data-theme="dark"] .reservations-mode .ms-card-icon,
[data-theme="dark"] .reservations-mode .ms-card-icon.blue,
[data-theme="dark"] .reservations-mode .ms-card-icon.green,
[data-theme="dark"] .reservations-mode .ms-card-icon.orange {
  background: rgba(var(--accent-rgb), 0.12) !important;
  color: var(--accent) !important;
  border-color: rgba(255, 255, 255, 0.08) !important;
}

/* ─── Reservations: tag — neutral, no blue ─── */
.reservations-mode .tag {
  color: var(--t1);
  background: rgba(12, 12, 16, 0.06);
  border: 1px solid rgba(12, 12, 16, 0.1);
}
[data-theme="dark"] .reservations-mode .tag {
  color: var(--t1);
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.12);
}


/* ─── Reservations: action bar — right-aligned, no stretch on mobile ─── */
.reservations-mode .ms-action-bar {
  justify-content: flex-end;
}
.reservations-mode .ms-action-bar > * {
  flex: 0 0 auto;
}

.reservations-mode [data-reservation-workspace] {
  padding-bottom: 0;
}

.reservations-mode .res-action-bar.ms-action-bar {
  -webkit-backdrop-filter: none;
  align-items: center;
  backdrop-filter: none;
  background: transparent;
  border: 0;
  border-top: 1px solid var(--line);
  border-radius: 0;
  bottom: auto;
  box-shadow: none;
  margin: 0;
  padding: 14px 18px;
  position: static;
  width: 100%;
}

[data-theme="dark"] .reservations-mode .res-action-bar.ms-action-bar {
  background: transparent;
  box-shadow: none;
}

.reservation-message-modal .app-modal-title {
  margin-bottom: 8px;
}

.reservations-mode .res-action-bar .ms-btn-primary,
.reservations-mode .res-action-bar .ms-btn-ghost {
  border-radius: 999px;
  font-size: 14px;
  font-weight: 700;
  min-height: 42px;
  padding: 0 18px;
}

.reservations-mode .reservation-detail-empty {
  min-height: 360px;
  text-align: center;
}

.reservations-mode .reservation-detail-empty p {
  margin: 0;
}

/* ─────────────────────────────────────────
   LOGIN PAGE — centered card layout
   ───────────────────────────────────────── */

body.login-page {
  min-height: 100vh;
}

.log-centered {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  background: var(--bg);
  position: relative;
  overflow: hidden;
}

/* Decorative blobs */
.log-centered-bg {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  overflow: hidden;
}

.r-blob {
  position: absolute;
  border-radius: 50%;
  background: var(--accent);
  filter: blur(100px);
}

.r-blob-1 {
  width: 520px;
  height: 520px;
  top: -180px;
  right: -100px;
  opacity: 0.32;
}

.r-blob-2 {
  width: 360px;
  height: 360px;
  bottom: -120px;
  left: -80px;
  opacity: 0.22;
}

/* Top bar */
.r-centered-top {
  position: relative;
  z-index: 2;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 32px;
}

.r-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: var(--t1);
}

.r-mark {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: linear-gradient(135deg, #F5874D, #ED6B2D);
  display: grid;
  place-items: center;
  color: #fff;
  font-size: 22px;
  font-family: 'Instrument Serif', Georgia, serif;
  font-style: italic;
  line-height: 1;
  flex-shrink: 0;
  box-shadow: 0 6px 14px -4px rgba(var(--accent-rgb), 0.45),
              0 1px 0 0 rgba(255, 255, 255, 0.3) inset;
}

.r-brand-name {
  font-size: 17px;
  font-weight: 700;
  letter-spacing: -0.5px;
  color: var(--t1);
}

.r-top-cta {
  font-size: 13px;
  color: var(--t3);
}

.r-top-cta a {
  color: var(--t1);
  font-weight: 600;
  text-decoration: none;
}

.r-top-cta a:hover {
  text-decoration: underline;
}

/* Main centered area */
.log-centered-main {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  position: relative;
  z-index: 2;
}

/* Card */
.log-card {
  width: 100%;
  max-width: 420px;
  background: var(--surface);
  border-radius: 22px;
  padding: 36px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  box-shadow: rgba(12, 12, 16, 0.22) 0px 30px 80px -30px,
              rgba(12, 12, 16, 0.08) 0px 8px 24px -10px;
}

.log-card-head {
  font-family: 'Instrument Serif', Georgia, serif;
  font-style: italic;
  font-size: 30px;
  font-weight: 400;
  color: var(--t1);
  margin: 0;
  letter-spacing: -0.4px;
  line-height: 1.15;
}

/* Form */
.r-form {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.r-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.r-field-label {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--t3);
}

.log-pwd-label {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.log-forgot {
  font-size: 12px;
  font-weight: 600;
  color: var(--t3);
  text-decoration: none;
  transition: color 0.12s;
}

.log-forgot:hover {
  color: var(--t1);
}

/* Input wrapper */
.r-input-wrap {
  height: 44px;
  display: flex;
  align-items: center;
  background: var(--surface);
  border: 1px solid var(--line-strong);
  border-radius: 11px;
  padding: 0 12px;
  gap: 9px;
  transition: border-color 0.12s, box-shadow 0.12s;
}

.r-input-wrap:focus-within {
  border-color: var(--accent-ring);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

.r-input-wrap input {
  flex: 1;
  min-width: 0;
  border: none;
  background: transparent;
  font-size: 14px;
  font-family: 'Inter Tight', system-ui, sans-serif;
  color: var(--t1);
  outline: none;
}

.r-input-wrap input::placeholder {
  color: var(--t4);
}

.r-input-icon {
  color: var(--t4);
  font-size: 13px;
  flex-shrink: 0;
}

.r-input-action {
  background: none;
  border: none;
  color: var(--t3);
  cursor: pointer;
  padding: 0;
  display: flex;
  align-items: center;
  flex-shrink: 0;
  font-size: 13px;
  transition: color 0.12s;
}

.r-input-action:hover {
  color: var(--t1);
}

/* Remember me */
.log-remember {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  user-select: none;
}

.r-check-box {
  display: flex;
  align-items: center;
}

.r-check-box input[type="checkbox"] {
  width: 15px;
  height: 15px;
  --cb-accent: var(--accent);
  cursor: pointer;
  margin: 0;
}

.r-check-label {
  font-size: 13px;
  color: var(--t2);
}

/* Submit button */
.r-submit {
  height: 48px;
  border-radius: 12px;
  background: linear-gradient(180deg, #0C0C10 0%, #1C1C22 100%);
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  font-family: 'Inter Tight', system-ui, sans-serif;
  letter-spacing: -0.07px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  box-shadow: rgba(255, 255, 255, 0.1) 0px 1px 0px 0px inset,
              rgba(12, 12, 16, 0.4) 0px 8px 20px -6px;
  transition: opacity 0.15s;
}

.r-submit:hover {
  opacity: 0.85;
}

/* Divider */
.r-divider {
  display: flex;
  align-items: center;
  gap: 14px;
  font-size: 12px;
  font-weight: 500;
  color: var(--t3);
}

.r-divider-line {
  flex: 1;
  height: 1px;
  background: var(--line);
}

/* Social buttons */
.r-social {
  display: flex;
  gap: 10px;
}

.r-social-btn {
  flex: 1;
  height: 44px;
  border-radius: 11px;
  background: var(--surface);
  border: 1px solid var(--line-strong);
  color: var(--t1);
  font-size: 13.5px;
  font-weight: 600;
  font-family: 'Inter Tight', system-ui, sans-serif;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  transition: background 0.12s;
}

.r-social-btn:not([disabled]):hover {
  background: var(--surface-2);
}

.r-social-btn[disabled] {
  opacity: 0.45;
  cursor: not-allowed;
}

/* Security note */
.log-secure {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  font-size: 11.5px;
  font-weight: 500;
  color: var(--t4);
}

/* ─── Login: dark mode ─── */
[data-theme="dark"] .log-card {
  box-shadow: rgba(0, 0, 0, 0.5) 0px 30px 80px -30px,
              rgba(0, 0, 0, 0.2) 0px 8px 24px -10px;
}

[data-theme="dark"] .r-input-wrap {
  background: var(--surface-2);
}

[data-theme="dark"] .r-social-btn {
  background: var(--surface-2);
}

[data-theme="dark"] .r-social-btn:not([disabled]):hover {
  background: var(--surface-3);
}

[data-theme="dark"] .r-submit {
  background: var(--accent);
  box-shadow: rgba(255, 255, 255, 0.15) 0px 1px 0px 0px inset,
              rgba(var(--accent-rgb), 0.45) 0px 8px 20px -6px;
}

/* ─── Register: wider card + section layout ─── */
.log-card-wide {
  max-width: 460px;
}

.r-form-section {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.r-form-section-label {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--t4);
}

.r-field-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.r-field-sm {
  max-width: 120px;
}

/* ─── Login: mobile ─── */
@media (max-width: 520px) {
  .r-centered-top {
    padding: 16px 20px;
  }
  .r-top-cta {
    display: none;
  }
  .log-centered-main {
    padding: 12px 16px 32px;
    align-items: flex-start;
  }
  .log-card {
    border-radius: 18px;
    padding: 28px 22px;
  }
  .r-social {
    flex-direction: column;
  }
}

/* ─── Calendar filter: property thumbnail ─── */
.cal-filter-prop-thumb {
  border-radius: 5px;
  flex-shrink: 0;
  height: 26px;
  object-fit: cover;
  width: 36px;
}
.cal-filter-prop-thumb-fallback {
  align-items: center;
  background: var(--accent-soft);
  border-radius: 5px;
  color: var(--accent);
  display: inline-flex;
  flex-shrink: 0;
  font-size: 11px;
  font-weight: 700;
  height: 26px;
  justify-content: center;
  width: 36px;
}

/* ═══════════════════════════════════════════════════════════════
   CLEANING PLANNING — global fixes (calendar, items, detail card)
   ═══════════════════════════════════════════════════════════════ */

/* ─── 1. Calendar positioning: panels stay within the 320px column ─── */
.cleaning-date-filter-bar {
  position: relative;
  overflow: visible;
}
.cleaning-date-filter-bar .date-picker {
  position: static;
}
.cleaning-date-filter-bar .date-picker-panel {
  top: 100%;
  left: 0;
  right: auto;
}
.cleaning-date-filter-bar .adm-date-picker:last-child .date-picker-panel {
  left: auto;
  right: 0;
}
[data-cleaning-panel-tab="planning"].adm-planning-panel:not([hidden]) {
  min-height: 0;
  overflow: hidden;
}

/* ─── 2. Task items: CSS vars + proper spacing ─── */
.adm-item-name {
  color: var(--t1);
  font-size: 13px;
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.adm-item-meta {
  color: var(--t3);
  font-size: 11px;
  margin-top: 4px;
}
.adm-item-guest {
  color: var(--t2);
  font-size: 11px;
  margin-top: 3px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.adm-item-badges {
  display: flex;
  gap: 5px;
  margin-top: 7px;
  flex-wrap: wrap;
  align-items: center;
}

/* Active state matching pg-prop-row.is-active */
.adm-task-item.active {
  background: var(--surface-2);
  border-left-color: var(--accent);
}
[data-theme="dark"] .adm-task-item.active {
  background: var(--surface-3);
}

/* Status tag colours → CSS vars */
.adm-tag-todo     { background: var(--surface-3); color: var(--t3); }
.adm-tag-progress { background: var(--blue-soft);  color: var(--blue); }
.adm-tag-done     { background: var(--green-soft); color: var(--green); }

/* ─── 3. Detail card header + body — CSS vars / dark mode ─── */
.adm-planning-mode .cleaning-detail-card .card-header {
  background: var(--surface);
  border-bottom: 1px solid var(--line);
  padding: 14px 20px;
}
.adm-planning-mode .cleaning-detail-card .card-title {
  color: var(--t1);
  font-size: 14px;
  font-weight: 600;
}
.adm-planning-mode .cleaning-detail-card .card-body {
  background: var(--bg);
  padding: 20px 20px 24px;
  flex: 1;
  overflow-y: auto;
}

.adm-planning-mode .cleaning-detail-card .ms-detail-content {
  min-height: 100%;
  padding-bottom: 0;
}

.adm-planning-mode .cleaning-detail-card .cleaning-assign-action-bar.ms-action-bar {
  -webkit-backdrop-filter: none;
  align-items: center;
  backdrop-filter: none;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 14px;
  bottom: auto;
  box-shadow: var(--shadow-1);
  gap: 10px;
  justify-content: flex-end;
  margin: auto 0 0;
  padding: 14px 18px;
  position: static;
  width: 100%;
}

[data-theme="dark"] .adm-planning-mode .cleaning-detail-card .cleaning-assign-action-bar.ms-action-bar {
  background: var(--surface);
  box-shadow: none;
}

.adm-planning-mode .cleaning-detail-card .cleaning-assign-action-bar .ms-btn-primary,
.adm-planning-mode .cleaning-detail-card .cleaning-assign-action-bar .ms-btn-ghost {
  border-radius: 999px;
  font-size: 14px;
  font-weight: 700;
  min-height: 42px;
  padding: 0 18px;
}
/* Back button */
.adm-planning-mode .cleaning-detail-card .automation-back-btn {
  background: var(--surface-2);
  border-color: var(--line-strong);
  color: var(--t2);
}
.adm-planning-mode .cleaning-detail-card .automation-back-btn:hover {
  background: var(--surface-3);
  color: var(--t1);
}

/* ─── 4. Detail grid cells — CSS vars ─── */
.cleaning-detail-grid div {
  background: var(--surface-2);
  border: 1px solid var(--line);
}
.cleaning-detail-grid span {
  color: var(--t3);
}
.cleaning-detail-grid strong {
  color: var(--t1);
}

/* ─── 5. Review admin note — CSS vars ─── */
.cleaning-review-admin-note {
  background: var(--accent-soft);
  border-color: var(--accent-ring);
  color: var(--accent);
}
.cleaning-review-admin-note span {
  color: var(--accent-2);
}

/* ─── 6. Date inputs → identical to ms-field-input (reservations style) ─── */
.adm-date-input {
  background: var(--surface);
  border: 1px solid var(--ms-border);
  border-radius: 8px;
  color: var(--t1);
  font-family: inherit;
  font-size: 13px;
  padding: 9px 12px;
  width: 100%;
  cursor: pointer;
  outline: none;
  transition: border-color .13s, box-shadow .13s;
}
.adm-date-input:focus {
  border-color: var(--accent-ring);
  box-shadow: 0 0 0 3px var(--accent-soft);
}
/* Make "Du / Au" labels match the reservations filter style */
.adm-dr-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--t3);
  text-transform: uppercase;
  letter-spacing: .05em;
  white-space: nowrap;
  flex-shrink: 0;
}

/* ─── 7. Task items: badges repositioned top-right via grid ─── */
.adm-task-item {
  padding: 13px 14px 14px;
  gap: 12px;
}
.adm-item-info {
  display: grid;
  grid-template-columns: 1fr auto;
  column-gap: 8px;
  align-items: start;
  min-width: 0;
}
/* Text stack: column 1, auto rows */
.adm-item-name { grid-column: 1; grid-row: 1; }
.adm-item-meta { grid-column: 1; grid-row: 2; margin-top: 5px; }
.adm-item-guest { grid-column: 1; grid-row: 3; margin-top: 4px; }
/* Badges: column 2, span all rows, aligned top-right */
.adm-item-badges {
  grid-column: 2;
  grid-row: 1 / 4;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 4px;
  margin-top: 2px;
  flex-wrap: nowrap;
}

/* ─── 8. Detail card: all icons orange, all primary buttons orange ─── */
.adm-planning-mode .cleaning-detail-card .ms-card-icon,
.adm-planning-mode .cleaning-detail-card .ms-card-icon.blue,
.adm-planning-mode .cleaning-detail-card .ms-card-icon.green,
.adm-planning-mode .cleaning-detail-card .ms-card-icon.orange {
  background: rgba(var(--accent-rgb), 0.08) !important;
  color: var(--accent) !important;
  border: 1px solid rgba(12, 12, 16, 0.08) !important;
}
[data-theme="dark"] .adm-planning-mode .cleaning-detail-card .ms-card-icon,
[data-theme="dark"] .adm-planning-mode .cleaning-detail-card .ms-card-icon.blue,
[data-theme="dark"] .adm-planning-mode .cleaning-detail-card .ms-card-icon.green,
[data-theme="dark"] .adm-planning-mode .cleaning-detail-card .ms-card-icon.orange {
  background: rgba(var(--accent-rgb), 0.12) !important;
  color: var(--accent) !important;
  border-color: rgba(255, 255, 255, 0.08) !important;
}
.adm-planning-mode .cleaning-detail-card .ms-btn-primary:hover {
  background: var(--accent-2);
}
/* Property avatar → accent (replaces purple gradient) */
.adm-planning-mode .cleaning-detail-card .ms-prop-avatar {
  background: var(--accent-soft);
  color: var(--accent);
}
/* Assigned badge → CSS vars */
.adm-badge-assigned {
  background: var(--green-soft);
  color: var(--green);
}
/* Urgency badges → CSS vars */
.adm-badge-urgency.late { background: var(--rose-soft); color: var(--rose); }
.adm-badge-urgency.prio { background: rgba(245, 158, 11, 0.12); color: #d97706; }

/* ─── 9. assign-group / task list — full CSS vars (dark mode) ─── */
.assign-group {
  border-color: var(--line);
}
.assign-group-hd {
  background: var(--surface-2);
  border-bottom-color: var(--line);
  color: var(--t3);
}
.assign-task-row {
  border-bottom-color: var(--line);
  color: var(--t1);
}
.assign-grip { color: var(--line-strong); }

/* Periodic due row */
.assign-periodic-due {
  background: rgba(245, 158, 11, 0.06);
  border-left-color: #f59e0b;
}
.assign-periodic-meta { color: #d97706; }

/* Periodic optional row */
.assign-periodic-opt {
  background: var(--surface-2);
  border-left-color: var(--line-strong);
}
.assign-periodic-opt .assign-periodic-meta { color: var(--t4); }

/* Badges */
.assign-badge-due {
  background: rgba(245, 158, 11, 0.12);
  color: #d97706;
  border-color: rgba(245, 158, 11, 0.3);
}
.assign-badge-opt {
  background: var(--surface-3);
  color: var(--t3);
  border-color: var(--line);
}
.assign-badge-manual {
  background: var(--green-soft);
  color: var(--green);
  border-color: transparent;
}

/* Remove button */
.assign-remove-btn {
  background: var(--rose-soft);
  color: var(--rose);
}
.assign-remove-btn:hover {
  background: var(--rose);
  color: #fff;
}

/* Add task bar */
.assign-add-task-bar {
  border-top-color: var(--line);
}
.assign-add-group-select,
.assign-add-task-input,
.assign-add-group-input {
  background: var(--surface);
  border-color: var(--line-strong);
  color: var(--t1);
}
.assign-add-task-input:focus,
.assign-add-group-input:focus,
.assign-add-group-select:focus {
  outline: none;
  border-color: var(--accent-ring);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

/* ═══════════════════════════════════════════════════════════════
   CLEANING SETTINGS — full CSS vars + design system alignment
   ═══════════════════════════════════════════════════════════════ */

/* ── Left sidebar ── */
.ms-settings-list {
  background: var(--surface);
  border-right-color: var(--line);
}
.ms-settings-search-wrap {
  border-bottom-color: var(--line);
}
.ms-settings-search-icon {
  color: var(--t4);
}
.ms-settings-search-input {
  background: var(--surface-2);
  border-color: var(--line);
  color: var(--t1);
  font-family: 'Inter Tight', sans-serif;
}
.ms-settings-search-input:focus {
  background: var(--surface);
  border-color: var(--accent-ring);
}
.ms-settings-search-input::placeholder { color: var(--t4); }

/* ── Right detail pane ── */
.ms-settings-detail {
  background: var(--bg);
}

/* ── Back button ── */
.ms-back-btn {
  background: var(--surface-2);
  border-color: var(--line-strong);
  color: var(--t2);
}
.ms-back-btn:hover {
  background: var(--surface-3);
  color: var(--t1);
}

/* ── Property list items — hover / active ── */
.ms-prop-list-item:hover {
  background: var(--surface-2);
}
.ms-prop-list-item.active {
  background: var(--accent-soft);
}
[data-theme="dark"] .ms-prop-list-item.active {
  background: rgba(var(--accent-rgb), 0.12);
}

/* ── Property avatar — accent instead of purple ── */
.ms-prop-avatar {
  background: var(--accent-soft);
  color: var(--accent);
}

/* ── All ms-card-icon → orange accent (settings context) ── */
.menage-settings-ui .ms-card-icon,
.menage-settings-ui .ms-card-icon.blue,
.menage-settings-ui .ms-card-icon.green,
.menage-settings-ui .ms-card-icon.orange {
  background: rgba(var(--accent-rgb), 0.08) !important;
  color: var(--accent) !important;
  border: 1px solid rgba(12, 12, 16, 0.08) !important;
}
[data-theme="dark"] .menage-settings-ui .ms-card-icon,
[data-theme="dark"] .menage-settings-ui .ms-card-icon.blue,
[data-theme="dark"] .menage-settings-ui .ms-card-icon.green,
[data-theme="dark"] .menage-settings-ui .ms-card-icon.orange {
  background: rgba(var(--accent-rgb), 0.12) !important;
  color: var(--accent) !important;
  border-color: rgba(255, 255, 255, 0.08) !important;
}

/* ── ms-card-icon.orange / green base → CSS vars (no hardcoded bg) ── */
.ms-card-icon.orange {
  background: rgba(var(--accent-rgb), 0.08);
  color: var(--accent);
}
.ms-card-icon.green {
  background: var(--green-soft);
  color: var(--green);
}
[data-theme="dark"] .ms-card-icon.orange {
  background: rgba(var(--accent-rgb), 0.12);
}
[data-theme="dark"] .ms-card-icon.green {
  background: rgba(34, 197, 94, 0.12);
}

/* ── Primary button → accent orange ── */
.menage-settings-ui .ms-btn-primary {
  background: var(--accent);
  color: #fff;
}
.menage-settings-ui .ms-btn-primary:hover {
  background: var(--accent-2);
}

/* ── ms-field-input focus → accent (not blue) ── */
.menage-settings-ui .ms-field-input:focus {
  border-color: var(--accent-ring);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

/* ── Task group: selected icon → CSS vars ── */
.ms-task-group-selected-icon {
  background: var(--surface);
  border-color: var(--accent-ring);
  color: var(--accent);
}

/* ── Cleaning generated note → accent-themed ── */
.cleaning-generated-note {
  background: var(--accent-soft);
  border-color: var(--accent-ring);
  color: var(--t2);
}
.cleaning-generated-note a {
  color: var(--accent);
}

/* ── ms-card-head border ── */
.ms-card-head {
  border-bottom-color: var(--line);
}

/* ── ms-settings-layout background ── */
.ms-settings-layout {
  background: var(--bg);
}

/* ── Users page: keep search bar fixed, only list items scroll ── */
.ms-settings-list [data-users-list] {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  padding: 0;
}

/* ═══════════════════════════════════════════════════════════════
   CLEANING SETTINGS — icon picker + photo rules dark mode
   ═══════════════════════════════════════════════════════════════ */

/* ─── ms-task-group-selected-icon : icône choisie du groupe ───
   Rempli accent-soft + bordure accent → clairement "sélectionnée"
   Distinct de ms-card-icon (entête carte) et des option chips ─── */
.ms-task-group-selected-icon {
  background: var(--accent-soft);
  border-color: var(--accent-ring);
  color: var(--accent);
}
[data-theme="dark"] .ms-task-group-selected-icon {
  background: rgba(var(--accent-rgb), 0.15);
  border-color: rgba(var(--accent-rgb), 0.4);
  color: var(--accent);
}

.ms-task-group-delete {
  align-items: center;
  background: var(--rose-soft);
  border: 0;
  border-radius: 999px;
  color: var(--rose);
  cursor: pointer;
  display: inline-flex;
  flex: 0 0 auto;
  height: 32px;
  justify-content: center;
  width: 32px;
}

.ms-task-group-delete:hover {
  background: var(--rose);
  color: #fff;
}

.menage-settings-ui .cleaning-settings-action-bar.ms-action-bar {
  -webkit-backdrop-filter: none;
  align-items: center;
  backdrop-filter: none;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 14px;
  bottom: auto;
  box-shadow: var(--shadow-1);
  justify-content: flex-end;
  margin: auto 0 0;
  padding: 14px 18px;
  position: static;
  width: 100%;
}

.menage-settings-ui:has(.cleaning-settings-action-bar) {
  min-height: 100%;
  padding-bottom: 0;
}

[data-theme="dark"] .menage-settings-ui .cleaning-settings-action-bar.ms-action-bar {
  background: var(--surface);
  box-shadow: none;
}

.menage-settings-ui .cleaning-settings-action-bar .ms-btn-primary {
  border-radius: 999px;
  font-size: 14px;
  font-weight: 700;
  min-height: 42px;
  padding: 0 18px;
}

.cleaning-settings-header-card {
  align-items: center;
}

.cleaning-settings-header-main {
  flex: 1;
  min-width: 0;
}

.cleaning-reset-defaults-btn {
  flex: 0 0 auto;
  margin-left: auto;
  white-space: nowrap;
}

@media (max-width: 640px) {
  .cleaning-settings-header-card {
    align-items: flex-start;
    flex-wrap: wrap;
  }

  .cleaning-reset-defaults-btn {
    margin-left: 0;
    width: 100%;
    justify-content: center;
  }
}

/* ─── cleaning-icon-option : chips de sélection d'icône ───
   Neutres par défaut → accent uniquement au hover / actif ─── */
.cleaning-icon-option {
  background: var(--surface-2);
  border-color: var(--line);
  color: var(--t3);
}
.cleaning-icon-option:hover {
  background: var(--surface-3);
  border-color: var(--line-strong);
  color: var(--t1);
}
.cleaning-icon-option.active {
  background: var(--accent-soft);
  border-color: var(--accent);
  color: var(--accent);
}
[data-theme="dark"] .cleaning-icon-option.active {
  background: rgba(var(--accent-rgb), 0.15);
  border-color: rgba(var(--accent-rgb), 0.5);
}

/* ─── cleaning-photo-rule : blocs photo requis ─── */
.cleaning-photo-rule {
  background: var(--surface-2);
  border-color: var(--line);
}
.cleaning-photo-rule-head {
  background: var(--surface-2);
  border-bottom-color: var(--line);
}
.cleaning-photo-rule-head i {
  color: var(--accent);
}
.cleaning-photo-rule-head strong {
  color: var(--t1);
}
.cleaning-photo-rule-body {
  gap: 16px;
  padding-bottom: 20px;
}
.cleaning-photo-count-field {
  margin-bottom: 4px;
}
.cleaning-photo-rule-body::before {
  color: var(--t3);
}
/* count select + labels — CSS vars */
.cleaning-photo-count-field span {
  color: var(--t3);
}
.cleaning-photo-count-field select {
  background: var(--surface);
  border-color: var(--line-strong);
  color: var(--t1);
}
.cleaning-reference-settings {
  border-top-color: var(--line);
}

/* ══════════════════════════════════════════════════════════════
   CLEANING USERS — full CSS vars + dark mode
   ══════════════════════════════════════════════════════════════ */

/* Left list */
.cln-users-list {
  background: var(--surface);
  border-right-color: var(--line);
}
.panel-list-title i {
  color: var(--accent);
  margin-right: 7px;
}

/* User items */
.cln-user-item {
  background: var(--surface);
  border-bottom-color: var(--line);
}
.cln-user-item:hover {
  background: var(--surface-2);
}
.cln-user-item.active {
  background: var(--accent-soft);
}

/* Avatars */
.cln-user-avatar,
.cln-users-form-avatar {
  background: var(--accent);
  color: #fff;
}

/* Meta text */
.cln-user-meta,
.cln-users-form-email {
  color: var(--t3);
}
.cln-users-form-name {
  color: var(--t1);
}

/* Status badges */
.cln-user-status-active {
  background: var(--green-soft);
  color: var(--green);
}
.cln-user-status-inactive {
  background: var(--surface-3);
  color: var(--t3);
}

/* Inline status in detail panel */
.cln-status-active {
  color: var(--green);
  font-weight: 700;
}
.cln-status-inactive {
  color: var(--t3);
  font-weight: 700;
}

/* Property assign grid */
.cln-prop-assign-item {
  background: var(--surface-2);
  border-color: var(--line);
}
.cln-prop-assign-item:has(input:checked) {
  background: var(--accent-soft);
  border-color: var(--accent-ring);
}
.cln-prop-assign-fallback {
  background: var(--accent-soft);
  color: var(--accent);
}
.cln-prop-assign-item input[type="checkbox"] {
  --cb-accent: var(--accent);
}

/* Back button */
.cln-users-back-btn {
  background: var(--surface);
  border-color: var(--line-strong);
  color: var(--t2);
}
.cln-users-back-btn:hover {
  background: var(--surface-2);
  color: var(--t1);
}

/* Group label separators inside the assign grid */
.cln-prop-group-label {
  align-items: center;
  color: var(--t3);
  display: flex;
  font-size: 11px;
  font-weight: 700;
  gap: 7px;
  grid-column: 1 / -1;
  letter-spacing: 0.06em;
  margin-top: 8px;
  padding-bottom: 4px;
  text-transform: uppercase;
}
.cln-prop-group-label:first-child {
  margin-top: 2px;
}
.cln-prop-group-label::after {
  background: var(--line);
  content: '';
  flex: 1;
  height: 1px;
}
.cln-prop-group-label i {
  color: var(--accent);
  font-size: 10px;
}

/* ms-card-icon inside users tab → orange */
.cln-users-detail .ms-card-icon,
[data-cleaning-users] .ms-card-icon {
  background: rgba(var(--accent-rgb), 0.08) !important;
}
.cln-users-detail .ms-card-icon i,
[data-cleaning-users] .ms-card-icon i {
  color: var(--accent) !important;
}
[data-theme="dark"] .cln-users-detail .ms-card-icon,
[data-theme="dark"] [data-cleaning-users] .ms-card-icon {
  background: rgba(var(--accent-rgb), 0.12) !important;
}

/* ms-btn-primary inside users tab → orange */
.cln-users-detail .ms-btn-primary {
  background: var(--accent);
}
.cln-users-detail .ms-btn-primary:hover {
  background: var(--accent-2);
}

/* Group blocks with sub-grid */
.cln-prop-group-block {
  grid-column: 1 / -1;
}
.cln-prop-group-items {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(auto-fill, minmax(210px, 1fr));
  margin-top: 8px;
}

/* Select-all checkbox in group label */
.cln-group-check-all-label {
  align-items: center;
  cursor: pointer;
  display: flex;
  flex-shrink: 0;
}
.cln-group-check-all-input {
  --cb-accent: var(--accent);
  cursor: pointer;
  height: 14px;
  width: 14px;
}

/* ══════════════════════════════════════════════════════════════
   CLEANING REPORTS — full CSS vars + dark mode
   ══════════════════════════════════════════════════════════════ */

/* Reports header icon */
[data-cleaning-reports-layout] .page-split-list-hd i {
  color: var(--accent);
}


/* Filter header */
.cleaning-report-filter-head strong {
  color: var(--t1);
}
.cleaning-report-filter-head span {
  color: var(--t3);
}

/* Segment buttons */
.cleaning-report-segments button {
  background: var(--surface-2);
  border-color: var(--line);
  color: var(--t2);
}
.cleaning-report-segments button.active {
  background: var(--accent-soft);
  border-color: var(--accent-ring);
  color: var(--accent);
}
.cleaning-report-segments span {
  background: var(--surface);
}

/* Filters + search */
.cleaning-report-filters {
  border-bottom-color: var(--line);
}
.cleaning-report-search-wrap i {
  color: var(--t3);
}
.cleaning-report-search-wrap input,
.cleaning-report-filters select,
.cleaning-report-date-grid input {
  background: var(--surface-2);
  border-color: var(--line);
  color: var(--t1);
}
.cleaning-report-search-wrap input:focus,
.cleaning-report-filters select:focus,
.cleaning-report-date-grid input:focus {
  background: var(--surface);
  border-color: var(--accent-ring);
  box-shadow: 0 0 0 3px rgba(var(--accent-rgb), 0.12);
}
.cleaning-report-date-grid label {
  color: var(--t3);
}

/* List icons */
.cleaning-report-list-icon {
  background: var(--accent-soft);
  color: var(--accent);
}
.cleaning-report-list-icon.has-photo {
  background: var(--surface-3);
  color: var(--t2);
}

/* List meta */
.cleaning-report-list-meta {
  color: var(--t3);
}

/* Detail — text */
.cleaning-report-description,
.cleaning-report-alert-text {
  color: var(--t1);
}

/* Alert block */
.cleaning-report-alert {
  background: var(--accent-soft);
  border-color: var(--accent-ring);
}
.cleaning-report-alert-title {
  color: var(--accent);
}
[data-theme="dark"] .cleaning-report-alert {
  background: rgba(var(--accent-rgb), 0.1);
  border-color: rgba(var(--accent-rgb), 0.3);
}

/* Follow-up block */
.cleaning-report-followup {
  background: var(--surface-2);
  border-color: var(--line);
}
.cleaning-report-followup label {
  color: var(--t3);
}
.cleaning-report-followup textarea {
  background: var(--surface);
  border-color: var(--line-strong);
  color: var(--t1);
}
.cleaning-report-followup textarea:focus {
  border-color: var(--accent-ring);
  box-shadow: 0 0 0 3px rgba(var(--accent-rgb), 0.12);
  outline: none;
}

/* Action buttons */
.cleaning-report-actions .ms-btn-primary:hover {
  background: var(--accent-2);
}
.cleaning-report-actions .ms-btn-primary.is-muted {
  background: var(--surface-3);
  color: var(--t2);
}
.cleaning-report-actions .ms-btn-primary.is-muted:hover {
  background: var(--surface-2);
}

/* ms-card-icon in reports context → orange */
[data-cleaning-reports] .ms-card-icon {
  background: rgba(var(--accent-rgb), 0.08) !important;
  color: var(--accent) !important;
}
[data-theme="dark"] [data-cleaning-reports] .ms-card-icon {
  background: rgba(var(--accent-rgb), 0.12) !important;
}

/* ms-card-icon.blue — CSS vars (override hardcoded #e8f0fe) */
.ms-card-icon.blue {
  background: rgba(26, 115, 232, 0.08);
  color: #1a73e8;
}
[data-theme="dark"] .ms-card-icon.blue {
  background: rgba(26, 115, 232, 0.15);
  color: #60a5fa;
}

/* automation-back-btn — CSS vars (override hardcoded #ffffff) */
.automation-back-btn {
  background: var(--surface);
  border-color: var(--line-strong);
  color: var(--t2);
}
.automation-back-btn:hover {
  background: var(--surface-2);
  color: var(--t1);
}

/* ms-prop-list-name — explicit color to avoid inheriting hardcoded ancestor */
.ms-prop-list-name {
  color: var(--t1);
}
/* ms-prop-list-item hover/active — CSS vars */
.ms-prop-list-item:hover {
  background: var(--surface-2);
}
.ms-prop-list-item.active {
  background: var(--accent-soft);
}

/* ══════════════════════════════════════════════════════════════
   UNIFIED — Left panel title (single canonical class)
   ══════════════════════════════════════════════════════════════ */
.panel-list-title {
  color: var(--t1);
  font-size: 14px;
  font-weight: 600;
  letter-spacing: -0.1px;
}

/* ══════════════════════════════════════════════════════════════
   UNIFIED — Count tags (single canonical class: .tag)
   ══════════════════════════════════════════════════════════════ */
.tag {
  background: var(--surface-3);
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--t2);
  font-size: 11.5px;
  font-weight: 700;
  padding: 2px 8px;
  white-space: nowrap;
}

/* ══════════════════════════════════════════════════════════════
   TECHNIQUES PAGE — Gestion des dates bloquées
   ══════════════════════════════════════════════════════════════ */

/* Inputs filtre avec couleurs du site */
.tech-filter-input {
  border: 1.5px solid var(--line-strong);
  border-radius: 9px; color: var(--t1);
  font-family: inherit; font-size: 13px;
  outline: none; padding: 8px 12px;
  background: var(--surface-2);
  transition: border-color 0.15s;
  width: 100%; cursor: pointer; box-sizing: border-box;
}
.tech-filter-input:focus { border-color: var(--accent); box-shadow: 0 0 0 3px rgba(var(--accent-rgb), 0.12); }

/* Liste des groupes */
.techniques-list-item {
  display: flex; gap: 12px; align-items: center;
  padding: 12px 16px; border-bottom: 1px solid var(--line);
  cursor: pointer; transition: background 0.12s;
  border-left: 3px solid transparent;
}
.techniques-list-item:hover { background: var(--surface-2); }
.techniques-list-item.is-active {
  background: rgba(var(--accent-rgb), 0.07);
  border-left-color: var(--accent);
}
.techniques-list-thumb-wrap { flex-shrink: 0; }
.techniques-list-thumb {
  width: 44px; height: 44px; border-radius: 10px;
  object-fit: cover; display: block; background: var(--surface-3);
}
.techniques-list-thumb.property-photo-fallback {
  display: flex; align-items: center; justify-content: center;
  font-size: 16px; font-weight: 700; color: var(--t3);
}
.techniques-list-body { flex: 1; min-width: 0; }
.techniques-list-prop { font-size: 13px; font-weight: 700; color: var(--t1); margin-bottom: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.techniques-list-dates { font-size: 12px; color: var(--t2); margin-bottom: 6px; }
.techniques-list-foot { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.techniques-reason-tag { font-size: 11px !important; padding: 2px 7px !important; }
.techniques-list-count { font-size: 11.5px; color: var(--t3); }

/* Détail : avatar logement */
.techniques-detail-avatar { flex-shrink: 0; }
.techniques-detail-photo {
  width: 44px; height: 44px; border-radius: 10px;
  object-fit: cover; display: block; background: var(--surface-3);
}
.techniques-detail-photo.property-photo-fallback {
  display: flex; align-items: center; justify-content: center;
  font-size: 16px; font-weight: 700; color: var(--t3);
}

/* Sélectionner tout */
.techniques-select-all-row {
  display: flex; align-items: center; gap: 9px;
  padding: 8px 0 12px; border-bottom: 1px solid var(--line);
  margin-bottom: 6px;
  font-size: 13px; font-weight: 600; color: var(--t2); cursor: pointer;
}
.techniques-select-all-row input[type="checkbox"] {
  --cb-accent: var(--accent); width: 15px; height: 15px; cursor: pointer;
}

/* Liste des jours */
.techniques-days-list {
  display: flex; flex-direction: column; gap: 2px;
  max-height: 380px; overflow-y: auto;
}
.techniques-day-item {
  display: flex; align-items: center; gap: 10px;
  padding: 7px 8px; border-radius: 8px; cursor: pointer;
  transition: background 0.1s;
}
.techniques-day-item:hover { background: var(--surface-3); }
.techniques-day-check {
  --cb-accent: var(--accent); width: 15px; height: 15px;
  cursor: pointer; flex-shrink: 0;
}
.techniques-day-label { font-size: 13px; color: var(--t1); font-weight: 500; }

/* Bouton destructif rouge */
.ms-btn-danger {
  align-items: center; border-radius: 980px; cursor: pointer;
  display: inline-flex; font-family: inherit;
  font-size: 13px; font-weight: 600; gap: 7px; padding: 9px 20px;
  background: #EF4444; border: none; color: #fff;
}
.ms-btn-danger:hover { background: #DC2626; }
.techniques-delete-btn:disabled { opacity: 0.4; cursor: not-allowed; }

/* ─── Barre tri + groupe ─── */
.tech-list-tools {
  display: flex;
  gap: 8px;
  padding: 10px 14px 8px;
  border-bottom: 1px solid var(--line);
}
.tech-sort-wrap { flex: 1; min-width: 0; }
.tech-tool-btn {
  width: 100%;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 34px;
  padding: 0 10px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 9px;
  font-size: 12px;
  font-weight: 500;
  color: var(--t2);
  cursor: pointer;
  font-family: inherit;
  transition: background 0.15s;
  white-space: nowrap;
  overflow: hidden;
}
.tech-tool-btn:hover { background: var(--surface-2); color: var(--t1); }
.tech-tool-btn i { font-size: 11px; color: var(--accent); flex-shrink: 0; }
.tech-tool-btn span { font-size: 12px; font-weight: 600; color: var(--t1); }
.tech-tool-btn small { color: var(--t3); font-size: 11px; font-weight: 500; margin-left: auto; }
.tech-group-count {
  margin-left: auto;
  background: var(--surface-3);
  border-radius: 999px;
  font-size: 11px;
  font-weight: 600;
  padding: 1px 6px;
  color: var(--t2);
}

/* ─── Carte métadonnées (sélecteur d'icône, note, save) ─── */
.tech-meta-body { display: flex; flex-direction: column; gap: 16px; }
.tech-meta-field { display: flex; flex-direction: column; gap: 6px; }
.tech-meta-label {
  font-size: 12px;
  font-weight: 600;
  color: var(--t2);
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

/* Grille sélecteur d'icônes */
.tech-icon-picker {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 6px;
}
.tech-icon-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: 8px 4px;
  border: 1.5px solid var(--line);
  border-radius: 10px;
  background: var(--surface-2);
  cursor: pointer;
  font-family: inherit;
  transition: border-color 0.15s, background 0.15s;
  min-width: 0;
}
.tech-icon-btn i {
  font-size: 16px;
  color: var(--t1);
  transition: color 0.15s;
}
.tech-icon-btn span {
  font-size: 9.5px;
  font-weight: 600;
  color: var(--t3);
  text-align: center;
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}
.tech-icon-btn:hover { border-color: var(--accent); background: rgba(var(--accent-rgb), 0.06); }
.tech-icon-btn:hover i { color: var(--accent); }
.tech-icon-btn.is-selected {
  border-color: var(--accent);
  background: rgba(var(--accent-rgb), 0.1);
}
.tech-icon-btn.is-selected i { color: var(--accent); }
.tech-icon-btn.is-selected span { color: var(--accent); }

/* Zone de texte note technique */
.tech-note-textarea {
  width: 100%;
  min-height: 100px;
  padding: 10px 12px;
  border: 1.5px solid var(--line-strong);
  border-radius: 10px;
  background: var(--surface-2);
  color: var(--t1);
  font-family: inherit;
  font-size: 13px;
  line-height: 1.5;
  resize: vertical;
  box-sizing: border-box;
  outline: none;
  transition: border-color 0.15s;
}
.tech-note-textarea:focus { border-color: var(--accent); box-shadow: 0 0 0 3px rgba(var(--accent-rgb), 0.12); }
.tech-note-textarea::placeholder { color: var(--t3); }

/* Titre inline éditable dans ms-card-head (motif "autre") */
[data-techniques-card-title-wrap] {
  flex: 1;
  min-width: 0;
  display: flex;
  align-items: center;
}
.tech-title-input {
  flex: 1;
  border: none;
  border-bottom: 2px solid var(--accent);
  background: transparent;
  color: var(--t1);
  font-family: inherit;
  font-size: 14px;
  font-weight: 600;
  padding: 2px 4px;
  outline: none;
  min-width: 0;
  width: 100%;
}
.tech-title-input::placeholder { color: var(--t3); font-weight: 400; }

/* Sélecteur de catégorie */
.tech-reason-picker {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.tech-reason-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 11px;
  border: 1.5px solid var(--line);
  border-radius: 999px;
  background: var(--surface-2);
  cursor: pointer;
  font-family: inherit;
  font-size: 12px;
  font-weight: 600;
  color: var(--t2);
  transition: border-color 0.15s, background 0.15s, color 0.15s;
}
.tech-reason-btn i { font-size: 11px; transition: color 0.15s; }
.tech-reason-btn span { line-height: 1; }
.tech-reason-btn:hover {
  border-color: var(--rc, var(--accent));
  color: var(--t1);
}
.tech-reason-btn.is-selected {
  background: var(--rc, var(--accent));
  border-color: var(--rc, var(--accent));
  color: #fff;
}

/* Ligne bouton enregistrer */
.tech-meta-save-row { display: flex; justify-content: flex-end; padding-top: 4px; }
.tech-meta-save-row .btn { gap: 7px; }

/* Mobile responsive */
@media (max-width: 860px) {
  .page-split.techniques-mode { flex-direction: column; overflow-y: auto; }
  .page-split.techniques-mode .page-split-list {
    border-bottom: none; border-right: none;
    max-height: none; overflow: visible; width: 100%;
  }
  .page-split.techniques-mode .page-split-detail { overflow-y: visible; padding: 16px; }
  .page-split.techniques-mode[data-tech-panel="detail"] .page-split-list { display: none; }
  .page-split.techniques-mode:not([data-tech-panel="detail"]) .page-split-detail { display: none; }
  .tech-icon-picker { grid-template-columns: repeat(4, 1fr); }
}

/* ══════════════════════════════════════════════════════════════
   CALENDRIER — GROUPE LOGEMENT 3 RANGÉES (inventaire / + / réservations)
   ══════════════════════════════════════════════════════════════ */

.calendar-property-group {
  display: grid;
  grid-template-columns: 200px 1fr;
  /* grid-template-rows est volontairement absent : les rangées se dimensionnent
     automatiquement à partir de la hauteur des éléments (height: 20px sur les tracks).
     Cela permet à la grille de s'adapter lors du repli animé (height: 0). */
  background: var(--surface);
  position: relative;
}

/* La cellule logement — même rangée que la booking-track */
.calendar-property-group .calendar-property-cell {
  grid-column: 1;
  grid-row: 1;
  min-height: 0;
  flex-direction: column;
  align-items: stretch;
  padding: 0;
  gap: 0;
}

/* Booking-track dans le groupe — rangée 1 uniquement (plus de rangées fantômes) */
.calendar-property-group .calendar-row-track {
  grid-column: 2;
  grid-row: 1;
  height: auto;
  min-height: 54px;
}

/* ── Rangée inventaire ─────────────────────────────────────────── */
.calendar-inventory-track {
  grid-column: 2;
  grid-row: 1;
  height: 20px;
  overflow: hidden;                  /* nécessaire pour le repli animé */
  transition: height 0.22s ease;
  display: grid;
  grid-template-columns: repeat(var(--calendar-days), 1fr);
  position: relative;
  background: var(--surface-2);
  border-bottom: 1px solid var(--line);
}

.calendar-inventory-cell {
  display: flex;
  align-items: center;
  justify-content: center;
  border-right: 1px solid var(--line);
  cursor: pointer;
  transition: background 0.12s;
}
.calendar-inventory-cell:last-child { border-right: none; }

.calendar-inventory-cell:hover {
  background: var(--surface-3) !important;
}

.calendar-inventory-cell.is-weekend {
  background: var(--surface-3);
}

.calendar-inventory-cell.is-overbooking {
  background: rgba(239, 68, 68, 0.08);
}

.calendar-inventory-cell.is-blocked-inv {
  background: repeating-linear-gradient(
    135deg,
    transparent,
    transparent 3px,
    rgba(0,0,0,0.05) 3px,
    rgba(0,0,0,0.05) 6px
  );
}

.calendar-property-group.is-even .calendar-inventory-track {
  background: var(--surface-3);
}

.calendar-inv-num {
  font-size: 9px;
  font-weight: 700;
  color: var(--t3);
  line-height: 1;
}

.calendar-inv-num.is-red {
  color: #EF4444;
}

/* ── Rangée ajout ──────────────────────────────────────────────── */
.calendar-add-track {
  grid-column: 2;
  grid-row: 2;
  height: 20px;
  overflow: hidden;                  /* nécessaire pour le repli animé */
  transition: height 0.22s ease;
  display: grid;
  grid-template-columns: repeat(var(--calendar-days), 1fr);
  position: relative;
  border-bottom: 1px solid var(--line);
}

.calendar-add-cell {
  display: flex;
  align-items: center;
  justify-content: center;
  border-right: 1px solid var(--line);
}
.calendar-add-cell:last-child { border-right: none; }

.calendar-add-cell.is-weekend {
  background: var(--surface-2);
}

.calendar-property-group.is-even .calendar-add-track {
  background: var(--surface-2);
}
.calendar-property-group.is-even .calendar-add-cell.is-weekend {
  background: var(--surface-3);
}

.calendar-add-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 14px;
  height: 14px;
  border: 1px solid transparent;   /* invisible au repos, visible au hover */
  border-radius: 3px;
  background: transparent;
  color: var(--t3);                 /* même couleur que .cal-inv-num */
  font-size: 9px;                   /* même taille que .cal-inv-num */
  font-weight: 700;                 /* même graisse que .cal-inv-num */
  cursor: pointer;
  padding: 0;
  transition: border-color 0.12s, color 0.12s, background 0.12s;
}

.calendar-add-btn:hover {
  border-color: var(--accent);
  color: var(--accent);
  background: var(--accent-soft);
}

/* Centrage vertical du prix — aligné avec la photo à gauche */
.calendar-property-group .calendar-day-cell {
  align-items: center;
  padding-top: 0;
}

/* Compatibilité couleurs weekday/today dans le groupe */
.calendar-property-group .calendar-day-cell.is-weekend {
  background-color: var(--surface-2);
}
.calendar-property-group.is-even .calendar-day-cell.is-weekend {
  background-color: var(--surface-3);
}
.calendar-property-group .calendar-day-cell.is-today {
  background-color: rgba(var(--accent-rgb), 0.06);
}
.calendar-property-group:hover .calendar-inventory-cell,
.calendar-property-group:hover .calendar-add-cell {
  background: var(--surface-3) !important;
}
/* Rangées labels (colonne gauche) : même couleur de hover que les autres rangées */
.calendar-property-group:hover .cal-row-label-inv {
  background: var(--surface-3) !important;
}
.calendar-property-group:hover .cal-row-label-add {
  background: var(--surface-3) !important;
}
.calendar-property-group:hover .calendar-add-btn {
  border-color: var(--t4);
}

/* ══════════════════════════════════════════════════════════════
   CALENDRIER — TOGGLE INVENTAIRE + LÉGENDE
   ══════════════════════════════════════════════════════════════ */

/* Nom du logement : flex pour pousser le chevron à droite */
.calendar-property-cell { overflow: visible; }
.cal-prop-name-wrap { flex: 1; min-width: 0; }
.cal-prop-name-wrap .calendar-property-name { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* Bouton chevron toggle inventaire */
.cal-inv-toggle-btn {
  flex-shrink: 0;
  margin-left: auto;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--t4);
  padding: 4px 2px;
  border-radius: 4px;
  font-size: 9px;
  transition: color 0.15s;
}
.cal-inv-toggle-btn:hover { color: var(--accent); }
.cal-inv-toggle-btn i { transition: transform 0.22s ease; }

/* État collapsed : chevron pointe vers le bas, tracks masqués */
.calendar-property-group.is-inv-collapsed .cal-inv-toggle-btn i { transform: rotate(-180deg); }
.calendar-property-group.is-inv-collapsed .calendar-inventory-track,
.calendar-property-group.is-inv-collapsed .calendar-add-track {
  height: 0;
  border-bottom-width: 0;   /* supprime la bordure quand replié */
}

/* Bouton ⓘ dans l'en-tête propriétés — on garde le layout sticky existant, juste gap */
.calendar-property-head { gap: 6px; }
.cal-legend-btn {
  background: none;
  border: none;
  cursor: pointer;
  color: var(--t4);
  font-size: 12px;
  padding: 2px;
  line-height: 1;
  transition: color 0.15s;
  flex-shrink: 0;
}
.cal-legend-btn:hover { color: var(--accent); }

/* Panneau légende — positionné en fixed par JS pour éviter le clipping par overflow:auto */
.cal-legend-panel {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 10px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.14), 0 2px 8px rgba(0,0,0,0.08);
  padding: 12px 14px;
  min-width: 240px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.cal-legend-item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 12px;
  color: var(--t2);
}
.cal-legend-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 22px;
  height: 18px;
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 4px;
  font-size: 11px;
  font-weight: 600;
  color: var(--t2);
  flex-shrink: 0;
  padding: 0 4px;
}
.cal-legend-plus {
  /* Cohérent avec .cal-legend-badge : boîte solide, sans pointillés */
  min-width: 22px;
  height: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 4px;
  font-size: 11px;
  font-weight: 700;
  color: var(--t2);
  flex-shrink: 0;
  padding: 0 4px;
}

/* ══════════════════════════════════════════════════════════════
   CALENDRIER — LABELS DE RANGÉE + MINI-IDENTITÉ
   ══════════════════════════════════════════════════════════════ */

/* Labels de rangée (inventaire / +) — haut de la cellule, quand déplié */
.cal-row-labels {
  flex-shrink: 0;
  height: 40px;
  overflow: hidden;
  transition: height 0.22s ease, opacity 0.22s ease;
  display: flex;
  flex-direction: column;
}
.calendar-property-group.is-inv-collapsed .cal-row-labels {
  height: 0;
  opacity: 0;
}

.cal-row-label-inv,
.cal-row-label-add {
  height: 20px;
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 0 8px;
  font-size: 9px;
  font-weight: 600;
  color: var(--t3);
  white-space: nowrap;
  overflow: hidden;
  flex-shrink: 0;
}
.cal-row-label-inv {
  background: var(--surface-2);
  border-bottom: 1px solid var(--line);
}
.cal-row-label-add {
  border-bottom: 1px solid var(--line);
}
.calendar-property-group.is-even .cal-row-label-inv {
  background: var(--surface-3);
}

/* Mini-badge "1" et mini-icône "+" dans les labels */
.cal-rl-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 14px;
  height: 13px;
  background: var(--surface-3);
  border: 1px solid var(--line);
  border-radius: 3px;
  font-size: 8px;
  font-weight: 700;
  color: var(--t3);
  flex-shrink: 0;
  padding: 0 2px;
}
.cal-rl-plus {
  /* Même style que .cal-rl-badge : boîte solide, même couleur adaptative */
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 14px;
  height: 13px;
  background: var(--surface-3);
  border: 1px solid var(--line);
  border-radius: 3px;
  font-size: 8px;
  font-weight: 700;
  color: var(--t3);
  flex-shrink: 0;
  padding: 0 2px;
}

/* Zone d'identité — remplit la cellule et étire ses enfants */
.cal-prop-identity-zone {
  flex: 1;
  min-height: 0;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: stretch;
}

/* Identité pleine (photo + nom + ville) — visible quand replié */
.cal-prop-full-id {
  grid-column: 1;
  grid-row: 1;
  position: relative;        /* contexte de positionnement pour la photo absolue */
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 8px 0 80px;     /* 80px à gauche = 8 + 64 (photo) + 8, réservé à la photo absolue */
  min-width: 0;
  transition: opacity 0.22s ease;
  opacity: 1;
}

/* Mini-identité (petite photo + nom court) — visible quand déplié */
.cal-prop-mini-id {
  grid-column: 1;
  grid-row: 1;
  align-self: stretch;       /* s'étire sur toute la hauteur de la cellule */
  position: relative;        /* contexte de positionnement pour la photo absolue */
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 0 8px 0 80px;     /* 80px à gauche = 8 + 64 (photo) + 8, réservé à la photo absolue */
  min-width: 0;
  transition: opacity 0.22s ease;
  opacity: 0;
  pointer-events: none;
}

/* Quand déplié : bascule identité pleine → mini */
.calendar-property-group:not(.is-inv-collapsed) .cal-prop-full-id {
  opacity: 0;
  pointer-events: none;
}
.calendar-property-group:not(.is-inv-collapsed) .cal-prop-mini-id {
  opacity: 1;
  pointer-events: auto;
}

/* Photo en position absolue : hauteur dictée par top+bottom (= hauteur cellule - 16px),
   PAS par le ratio de l'image. La photo ne contribue donc plus à la hauteur de la rangée
   (c'est la booking-track qui la fixe), tout en remplissant ~70% de la cellule. */
.calendar-property-group .cal-prop-full-id .calendar-property-photo {
  position: absolute;
  left: 8px;
  top: 8px;
  width: 64px;
  /* sur un <img> en absolu, height:auto utilise la hauteur intrinsèque et ignore bottom.
     On force donc la hauteur = hauteur cellule - 16px (8px haut + 8px bas) ≈ 70%. */
  height: calc(100% - 16px);
  object-fit: cover;
}

/* Le chevron occupe la colonne 2 de la zone d'identité */
.cal-prop-identity-zone .cal-inv-toggle-btn {
  grid-column: 2;
  grid-row: 1;
  align-self: center;  /* centré verticalement, pas étiré */
  margin-left: 0;
}

/* Mini photo */
.cal-photo-mini {
  position: absolute;
  left: 8px;
  top: 8px;
  width: 64px !important;
  /* sur un <img> en absolu, height:auto utilise la hauteur intrinsèque et ignore bottom.
     On force donc la hauteur = hauteur cellule - 16px (8px haut + 8px bas) ≈ 70%. */
  height: calc(100% - 16px) !important;
  border-radius: 5px !important;
  object-fit: cover;
  flex-shrink: 0;
}

/* Mini nom */
.cal-prop-mini-name {
  font-size: 11px;
  font-weight: 600;
  color: var(--t2);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
}

/* ══════════════════════════════════════════════════════════════
   LOGEMENTS — GRILLE TARIFS PAR JOUR DE SEMAINE
   ══════════════════════════════════════════════════════════════ */

.prop-dow-rates {
  margin-top: 4px;
}

.prop-dow-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 6px;
}

.prop-dow-grid .pg-field span {
  font-size: 11px;
  font-weight: 600;
  color: var(--t3);
  text-align: center;
  display: block;
  margin-bottom: 3px;
}

.prop-dow-grid .pg-input {
  text-align: center;
  padding: 6px 4px;
  font-size: 12px;
}

@media (max-width: 860px) {
  .prop-dow-grid {
    grid-template-columns: repeat(4, 1fr);
  }
  /* Aligner le header et les rangées propriétés sur la même largeur de colonne */
  .calendar-header-row,
  .calendar-row {
    grid-template-columns: 160px repeat(var(--calendar-days), 1fr);
  }
  .calendar-property-group {
    grid-template-columns: 160px 1fr;
  }
  /* Photo mobile : même technique (absolu), plus compacte */
  .calendar-property-group .cal-prop-full-id {
    padding: 0 8px 0 66px;   /* 6 + 52 (photo) + 8 réservé à la photo absolue */
  }
  .calendar-property-group .cal-prop-full-id .calendar-property-photo {
    left: 6px;
    width: 52px;
    /* top: 8px et height: calc(100% - 16px) hérités de la règle desktop */
  }
}

/* ══════════════════════════════════════════════════════════════
   CALENDRIER — MODALES BLOCAGE / PRIX / NOUVELLE RÉSERVATION
   ══════════════════════════════════════════════════════════════ */

/* Backdrop partagé */
.cal-modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.45);
  display: flex;
  align-items: flex-start;   /* flex-start + margin:auto sur la modale = centrage quand il y a de la place, défilement quand trop haut */
  justify-content: center;
  z-index: 1100;
  padding: 20px 16px;
  opacity: 0;
  transition: opacity 0.18s;
  backdrop-filter: blur(2px);
  overflow-y: auto;           /* le backdrop défile quand le formulaire dépasse l'écran */
}
.cal-modal-backdrop.open { opacity: 1; }

/* Alerte calendrier — toujours au-dessus de toutes les autres modales */
[data-calendar-alert] { z-index: 2000; }
[data-calendar-alert] .cal-modal { padding: 24px; max-width: 380px; }
[data-calendar-alert] .cal-modal-message { white-space: pre-wrap; font-size: 14px; color: var(--t1); line-height: 1.55; margin-bottom: 20px; }
[data-calendar-alert] .cal-modal-actions { display: flex; justify-content: flex-end; }
[data-calendar-alert] .cal-modal-actions .btn-primary { background: var(--accent) !important; color: #fff !important; border: 0 !important; }
[data-calendar-alert] .cal-modal-actions .btn-primary:hover { background: var(--accent-2) !important; }

/* Carte modale */
.cal-modal {
  background: var(--surface);
  border-radius: 16px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.22), 0 4px 16px rgba(0,0,0,0.12);
  width: 100%;
  max-width: 480px;
  max-height: 90vh;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
}

/* Modals courts (blocage / prix) : overflow visible → les panneaux date-picker
   ne sont pas coupés sans avoir besoin de positionnement fixe JS. */
.cal-block-modal,
.cal-price-modal {
  overflow: visible;
}

/* Modal nouvelle réservation — reprend la structure de reservations.html */
.cal-newres-modal {
  max-width: 680px;
}
.cal-newres-modal .cal-modal-body {
  padding: 20px 20px 16px;
  overflow: visible; /* date-pickers ne doivent pas être coupés */
}
.cal-newres-modal .cal-modal-body .ms-card {
  border: none !important;
  box-shadow: none !important;
  background: transparent !important;
  overflow: visible !important;
  border-radius: 0 !important;
}
.cal-newres-modal .cal-modal-body .ms-card-body {
  padding: 0;
}
/* Footer dans la modale — override explicite du sticky de .ms-action-bar */
.cal-modal-footer,
.cal-modal-footer.ms-action-bar {
  position: static !important;
  bottom: auto !important;
  backdrop-filter: none !important;
  border: 0 !important;
  box-shadow: none !important;
  background: var(--surface) !important;
  border-top: 1px solid var(--line) !important;
  padding: 14px 20px !important;
  margin: 0 !important;
  border-radius: 0 0 16px 16px !important;
  z-index: auto !important;
}

/* Icône dans la modale nouvelle réservation → couleur accent (orange) */
.cal-newres-modal .ms-card-icon {
  background: rgba(var(--accent-rgb), 0.08);
  color: var(--accent);
  border: 1px solid rgba(12,12,16,0.08);
}
[data-theme="dark"] .cal-newres-modal .ms-card-icon {
  background: rgba(var(--accent-rgb), 0.12);
  border-color: rgba(255,255,255,0.08);
}

/* En-tête modale — pas de sticky, défile avec le contenu */
.cal-modal-head {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 18px 20px 16px;
  border-bottom: 1px solid var(--line);
  background: var(--surface);
}

.cal-modal-head-icon {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  background: var(--surface-2);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
  color: var(--t2);
  flex-shrink: 0;
}
.cal-modal-head-icon.is-red   { background: rgba(239,68,68,0.10); color: #EF4444; }
.cal-modal-head-icon.is-green { background: rgba(34,197,94,0.10); color: #22C55E; }
.cal-modal-head-icon.is-blue  { background: rgba(99,102,241,0.10); color: #6366F1; }

.cal-modal-head-text { flex: 1; min-width: 0; }
.cal-modal-title { font-size: 15px; font-weight: 700; color: var(--t1); margin: 0; }
.cal-modal-subtitle { font-size: 12px; color: var(--t3); margin: 2px 0 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

.cal-modal-close {
  width: 30px; height: 30px;
  border: 0; border-radius: 8px;
  background: var(--surface-2);
  color: var(--t3);
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px;
  flex-shrink: 0;
  transition: background 0.1s, color 0.1s;
}
.cal-modal-close:hover { background: var(--surface-3); color: var(--t1); }

/* Corps — overflow:visible pour que les panneaux date-picker ne soient pas coupés. */
.cal-modal-body {
  padding: 0;
  flex: 1;
  overflow: visible;
}

.cal-modal-section {
  padding: 16px 20px;
  border-bottom: 1px solid var(--line);
}
.cal-modal-section:last-child { border-bottom: none; }

.cal-modal-section-label {
  font-size: 11px;
  font-weight: 700;
  color: var(--t3);
  text-transform: uppercase;
  letter-spacing: 0.07em;
  margin-bottom: 10px;
}

.cal-modal-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.cal-modal-field {
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.cal-modal-field > span {
  font-size: 12px;
  font-weight: 600;
  color: var(--t2);
}

/* Jours de la semaine */
.cal-modal-dow-wrap { display: flex; flex-direction: column; gap: 8px; }
.cal-modal-dow { display: flex; gap: 5px; flex-wrap: wrap; }

.cal-dow-chip {
  cursor: pointer;
  user-select: none;
}
.cal-dow-chip input { display: none; }
.cal-dow-chip span {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px; height: 30px;
  border: 1px solid var(--line);
  border-radius: 8px;
  font-size: 11px;
  font-weight: 600;
  color: var(--t3);
  background: var(--surface-2);
  transition: border-color 0.1s, background 0.1s, color 0.1s;
}
.cal-dow-chip input:checked + span {
  border-color: var(--accent);
  background: var(--accent-soft);
  color: var(--accent);
}
.cal-dow-chip:hover span { border-color: var(--accent); }

.cal-modal-dow-shortcuts {
  display: flex;
  gap: 6px;
}
.cal-modal-dow-shortcuts .btn.is-on {
  background: var(--accent-soft);
  color: var(--accent);
  border-color: var(--accent);
}

/* Toggle disponibilité */
.cal-modal-toggle-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
}
.cal-modal-toggle-label-wrap { display: flex; flex-direction: column; gap: 2px; }
.cal-modal-toggle-hint {
  font-size: 11px;
  color: var(--t3);
}

/* Raisons */
.cal-modal-reason-wrap { margin-top: 4px; }
.cal-modal-reason-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 6px;
  margin-bottom: 8px;
}
.cal-modal-reason-opt {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  padding: 8px 4px;
  border: 1px solid var(--line);
  border-radius: 10px;
  cursor: pointer;
  background: var(--surface-2);
  font-size: 11px;
  font-weight: 600;
  color: var(--t2);
  transition: border-color 0.1s, background 0.1s;
  text-align: center;
  user-select: none;
}
.cal-modal-reason-opt input { display: none; }
.cal-modal-reason-opt i { font-size: 14px; color: var(--t3); }
.cal-modal-reason-opt.is-selected,
.cal-modal-reason-opt:has(input:checked) {
  border-color: var(--accent);
  background: var(--accent-soft);
  color: var(--accent);
}
.cal-modal-reason-opt.is-selected i,
.cal-modal-reason-opt:has(input:checked) i { color: var(--accent); }

.cal-autre-input { margin-top: 4px; }

/* Checkboxes arrivées/départs */
.cal-modal-section-checks { display: flex; flex-direction: column; gap: 10px; }
.cal-modal-check-row {
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  font-size: 13px;
  color: var(--t1);
}
.cal-modal-check-row input[type="checkbox"] {
  width: 16px; height: 16px;
  --cb-accent: var(--accent);
  cursor: pointer;
  flex-shrink: 0;
}

/* Canaux OTA */
.cal-cell-channels-list {
  margin-top: 10px;
  border: 1px solid var(--line);
  border-radius: 10px;
  overflow: hidden;
}
.cal-cell-channel-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 7px 12px;
  border-bottom: 1px solid var(--line);
  font-size: 12px;
}
.cal-cell-channel-row:last-child { border-bottom: none; }
.cal-cell-channel-source {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--t2);
  font-weight: 500;
}
.cal-cell-channel-logo { width: 20px; height: 20px; object-fit: contain; border-radius: 4px; }
.cal-cell-channel-fallback {
  width: 20px; height: 20px;
  border-radius: 4px;
  background: var(--surface-3);
  display: flex; align-items: center; justify-content: center;
  font-size: 10px; font-weight: 700; color: var(--t2);
}
.cal-cell-channel-price {
  font-weight: 700;
  color: var(--accent);
  font-size: 12px;
}

/* Tarifs nuitée (nouvelle réservation) */
.cal-res-nights-badge {
  font-size: 10px;
  font-weight: 600;
  color: var(--t3);
  background: var(--surface-2);
  padding: 1px 6px;
  border-radius: 20px;
  margin-left: 4px;
}
.cal-res-rates-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-top: 4px;
}
.cal-res-rate-row {
  display: grid;
  grid-template-columns: 1fr 90px 20px;
  align-items: center;
  gap: 8px;
}
.cal-res-rate-label { font-size: 12px; color: var(--t2); }
.cal-res-rate-input { text-align: right; }
.cal-res-rate-currency { font-size: 12px; color: var(--t3); }

/* Bouton toggle "Tarifs par nuit" */
.cal-rates-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 8px;
  cursor: pointer;
  padding: 8px 12px;
  font-size: 13px;
  font-weight: 600;
  color: var(--t2);
  transition: background 0.13s, color 0.13s;
  margin-bottom: 0;
}
.cal-rates-toggle:hover { background: var(--surface-3); color: var(--t1); }
.cal-rates-toggle i { transition: transform 0.2s; font-size: 11px; }
.cal-rates-toggle.is-open i { transform: rotate(90deg); }
.cal-rates-toggle.is-open { margin-bottom: 8px; }

/* Pied de modale — pas de sticky, défile avec le contenu */
.cal-modal-footer {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  padding: 14px 20px;
  border-top: 1px solid var(--line);
  background: var(--surface);
}
.cal-modal-footer .btn { gap: 6px; }

@media (max-width: 600px) {
  /* Plein écran sur mobile — rien n'est fixe/sticky */
  .cal-modal-backdrop { align-items: stretch; padding: 0; }
  .cal-modal {
    max-width: 100%;
    border-radius: 0;
    max-height: 100%;
    height: 100%;
    align-self: stretch;
  }
  /* Pas de border-radius sur mobile plein écran */
  .cal-modal-footer.ms-action-bar { border-radius: 0; }
  /* Grilles mobiles */
  .cal-modal-reason-grid { grid-template-columns: repeat(2, 1fr); }
  .cal-modal-row { grid-template-columns: 1fr; }

  /* Bug 1 : popup prix / blocage scrollable — header et footer restent visibles */
  .cal-price-modal,
  .cal-block-modal {
    overflow: hidden;
  }
  .cal-price-modal .cal-modal-body,
  .cal-block-modal .cal-modal-body {
    overflow-y: auto;
  }

  /* Bug 3c : boutons de la modal calendrier — ne pas étirer sur toute la largeur */
  .cal-modal-footer.ms-action-bar > * {
    flex: 0 0 auto;
  }
  /* Bug 3c : bouton "Créer une nouvelle réservation" dans reservations.html */
  .ms-action-bar [data-reservation-submit],
  .ms-action-bar [data-res-cancel-edit] {
    flex: 0 0 auto;
  }
}

/* ══════════════════════════════════════════════════════════════
   CALENDRIER — SURBOOKING
   ══════════════════════════════════════════════════════════════ */

/* Barre de réservation en conflit */
.calendar-booking.is-overbooking {
  box-shadow: inset 0 0 0 2px #ef4444, inset 0 0 0 4px rgba(239, 68, 68, 0.2);
}

/* Badge ⚠ : flex child (pas position:absolute — overflow:hidden clipperait) */
.cal-ob-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  background: #ef4444;
  border-radius: 50%;
  font-size: 10px;
  line-height: 1;
  color: #fff;
  font-style: normal;
}

/* Popup surbooking */
.cal-ob-popup {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 12px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.16), 0 2px 8px rgba(0,0,0,0.08);
  overflow: hidden;
  font-size: 13px;
}

.cal-ob-popup-head {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  border-bottom: 1px solid var(--line);
  font-size: 12px;
  font-weight: 600;
  color: #ef4444;
  background: rgba(239, 68, 68, 0.07);
}
.cal-ob-popup-head i {
  font-size: 13px;
  flex-shrink: 0;
}

.cal-ob-popup-list {
  display: flex;
  flex-direction: column;
}

.cal-ob-popup-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border: none;
  background: none;
  text-align: left;
  cursor: pointer;
  transition: background 0.12s;
  border-bottom: 1px solid var(--line);
  width: 100%;
}
.cal-ob-popup-item:last-child {
  border-bottom: none;
}
.cal-ob-popup-item:hover {
  background: var(--surface-2);
}

/* Mini logo OTA dans le popup surbooking */
.cal-ob-popup-logo {
  flex-shrink: 0;
  width: 22px;
  height: 22px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.cal-ob-popup-logo .source-logo {
  width: 22px;
  height: 22px;
  border-radius: 4px;
}
.cal-ob-popup-logo .source-logo-fallback {
  width: 22px;
  height: 22px;
  border-radius: 4px;
  font-size: 10px;
}

.cal-ob-popup-info {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.cal-ob-popup-name {
  font-size: 12px;
  font-weight: 600;
  color: var(--t1);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.cal-ob-popup-dates {
  font-size: 11px;
  color: var(--t3);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.cal-ob-popup-arrow {
  font-size: 10px;
  color: var(--t4);
  flex-shrink: 0;
}

/* ══════════════════════════════════════════════════════════════
   CALENDRIER — DIALOGUE CONFIRMATION OVERBOOKING
   ══════════════════════════════════════════════════════════════ */

.cal-ob-confirm-modal {
  max-width: 420px;
  padding: 0;
  overflow: hidden;
  border: 2px solid #ef4444;
}

.cal-ob-confirm-head {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 18px 20px 14px;
  background: rgba(239, 68, 68, 0.08);
  border-bottom: 1px solid rgba(239, 68, 68, 0.2);
}

.cal-ob-confirm-icon {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: #ef4444;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 18px;
  margin-top: 1px;
}

.cal-ob-confirm-title {
  font-size: 16px;
  font-weight: 700;
  color: #ef4444;
  line-height: 1.3;
}

.cal-ob-confirm-sub {
  font-size: 13px;
  color: var(--t2);
  margin-top: 2px;
}

.cal-ob-confirm-nights {
  margin: 0;
  padding: 12px 20px 12px 36px;
  border-bottom: 1px solid var(--line);
  background: var(--surface-2);
}
.cal-ob-confirm-nights li {
  font-size: 13px;
  font-weight: 600;
  color: var(--t1);
  padding: 2px 0;
}

.cal-ob-confirm-warn {
  margin: 0;
  padding: 14px 20px;
  font-size: 13px;
  color: var(--t2);
  line-height: 1.5;
  border-bottom: 1px solid var(--line);
}
.cal-ob-confirm-warn strong {
  color: #ef4444;
  font-weight: 700;
}

.cal-ob-confirm-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  padding: 14px 20px;
}

.cal-ob-confirm-btn-danger {
  background: #ef4444;
  color: #fff;
  border: none;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 0 18px;
  height: 38px;
  border-radius: 8px;
  cursor: pointer;
  transition: background 0.15s;
}
.cal-ob-confirm-btn-danger:hover { background: #dc2626; }
.cal-ob-confirm-btn-danger i { font-size: 12px; }

/* ── Bouton "Bloquer" désactivé pour rôles sans permission ─── */
.cal-add-popup-btn.is-disabled {
  opacity: 0.42;
  cursor: not-allowed;
  pointer-events: none;
  color: var(--t3);
}

/* ══════════════════════════════════════════════════════════════
   CALENDRIER — POPUP INVENTAIRE
   ══════════════════════════════════════════════════════════════ */

.cal-inv-popup {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 12px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.14), 0 2px 8px rgba(0,0,0,0.08);
  overflow: hidden;
}

.cal-inv-popup-head {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 11px 14px 10px;
  background: var(--surface-2);
  border-bottom: 1px solid var(--line);
  font-size: 12px;
  font-weight: 600;
  color: var(--t2);
}

.cal-inv-popup-head i {
  color: var(--accent);
  font-size: 11px;
}

.cal-inv-popup-body {
  padding: 12px 14px;
}

.cal-inv-popup-hint {
  font-size: 11px;
  color: var(--t3);
  margin: 0 0 10px;
  line-height: 1.4;
}

.cal-inv-stepper {
  display: flex;
  align-items: center;
  gap: 6px;
}

.cal-inv-step {
  width: 30px;
  height: 30px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface-2);
  color: var(--t1);
  font-size: 16px;
  font-weight: 700;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: background 0.12s, border-color 0.12s;
}
.cal-inv-step:hover {
  background: var(--surface-3);
  border-color: var(--accent);
}

.cal-inv-input {
  flex: 1;
  height: 30px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface);
  color: var(--t1);
  font: 600 16px/1 var(--font);
  text-align: center;
  padding: 0 4px;
  outline: none;
}
.cal-inv-input:focus { border-color: var(--accent); box-shadow: 0 0 0 2px var(--accent-soft); }

.cal-inv-default-hint {
  font-size: 10px;
  color: var(--t4);
  margin: 6px 0 0;
  text-align: center;
}

.cal-inv-popup-actions {
  display: flex;
  gap: 6px;
  justify-content: flex-end;
  padding: 8px 14px 12px;
  border-top: 1px solid var(--line);
}

/* ══════════════════════════════════════════════════════════════
   CALENDRIER — POPUP "+" (choix action)
   ══════════════════════════════════════════════════════════════ */

.cal-add-popup {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 12px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.14), 0 2px 8px rgba(0,0,0,0.08);
  overflow: hidden;
  padding: 6px;
}

.cal-add-popup-date {
  font-size: 11px;
  font-weight: 600;
  color: var(--t3);
  padding: 6px 8px 8px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 4px;
}

.cal-add-popup-date span {
  color: var(--t2);
}

.cal-add-popup-btn {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 10px 12px;
  border: 0;
  border-radius: 8px;
  background: transparent;
  color: var(--t1);
  font: 500 13px/1.2 var(--font);
  cursor: pointer;
  text-align: left;
  transition: background 0.1s;
}

.cal-add-popup-btn:hover {
  background: var(--surface-2);
}

.cal-add-popup-btn i {
  width: 24px;
  height: 24px;
  border-radius: 6px;
  background: var(--surface-2);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  color: var(--accent);
  flex-shrink: 0;
}

.cal-add-popup-btn[data-cal-add-block] i {
  color: #EF4444;
  background: rgba(239, 68, 68, 0.08);
}
/* Icônes spécifiques du menu cellule prix */
.cal-add-popup-btn[data-cal-menu-block] i {
  color: #EF4444;
  background: rgba(239, 68, 68, 0.08);
}
.cal-add-popup-btn[data-cal-menu-price] i {
  color: var(--green, #2EAB6E);
  background: rgba(46, 171, 110, 0.1);
}
.cal-add-popup-btn[data-cal-menu-inv] i {
  color: #7C6FF7;
  background: rgba(124, 111, 247, 0.1);
}

/* ══════════════════════════════════════════════════════════════════════════════
   CHANGELOG — Journal des modifications
   ══════════════════════════════════════════════════════════════════════════════ */

/* ── État vide (panneau droit ou liste vide) ── */
.cl-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 60px 24px;
  color: var(--t4);
  text-align: center;
}

.cl-empty i   { font-size: 36px; opacity: .4; }
.cl-empty p   { font-size: 14px; margin: 0; }

/* ── Filtre dropdown (extension du pattern existant) ── */
.cl-filter-dropdown .filter-menu.cl-filter-menu {
  width: 100%;
  max-height: 240px;
  border-radius: 10px;
}

.cl-filter-dropdown.open .reservation-filter-btn {
  border-color: var(--accent);
  color: var(--accent);
}

/* ── Ligne de liste (panneau gauche) ── */
.cl-row {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  padding: 12px 16px;
  border-bottom: 1px solid var(--line);
  cursor: pointer;
  transition: background .13s;
}

.cl-row:last-child { border-bottom: none; }

.cl-row:hover    { background: var(--surface-2); }
.cl-row.is-active { background: var(--accent-soft); }

.cl-row-avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: linear-gradient(135deg, #2A2A30, #0C0C10);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  letter-spacing: .5px;
}

.cl-row.is-active .cl-row-avatar {
  background: linear-gradient(135deg, var(--accent), var(--accent));
}

.cl-row-body   { flex: 1; min-width: 0; }

.cl-row-top {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 3px;
}

.cl-row-user {
  font-size: 13px;
  font-weight: 600;
  color: var(--t1);
}

.cl-row-label {
  font-size: 12px;
  color: var(--t2);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  margin-bottom: 2px;
}

.cl-row-time {
  font-size: 11px;
  color: var(--t4);
}

/* ── Badges d'action ── */
.cl-badge {
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .3px;
  white-space: nowrap;
  flex-shrink: 0;
}

.cl-badge-create  { background: rgba( 34, 197, 94, .12); color: #16a34a; }
.cl-badge-update  { background: rgba( 59, 130, 246, .12); color: #2563eb; }
.cl-badge-delete  { background: rgba(239,  68,  68, .12); color: #dc2626; }
.cl-badge-block   { background: rgba(239,  68,  68, .10); color: #dc2626; }
.cl-badge-unblock { background: rgba( 34, 197, 94, .10); color: #16a34a; }
.cl-badge-price   { background: rgba(245, 158,  11, .12); color: #b45309; }
.cl-badge-default { background: var(--surface-2);          color: var(--t3); }

/* ── Layout split Changelog (desktop) ── */
.page-split.changelog-mode .page-split-list {
  width: var(--ms-list-panel-width);
}

/* ── Layout split Changelog (mobile) ── */
@media (max-width: 860px) {
  .page-split.changelog-mode {
    flex-direction: column;
    overflow-y: auto;
  }

  .page-split.changelog-mode .page-split-list {
    border-right: none;
    border-bottom: 1px solid var(--line);
    max-height: none;
    overflow: visible;
    width: 100%;
  }

  .page-split.changelog-mode .page-split-detail {
    overflow-y: visible;
    padding: 16px;
  }

  .page-split.changelog-mode[data-cl-panel="detail"] .page-split-list {
    display: none;
  }

  .page-split.changelog-mode:not([data-cl-panel="detail"]) .page-split-detail {
    display: none;
  }
}

/* ══════════════════════════════════════════════════════════════════════════════
   NOTIFICATIONS — Bell badge + Dropdown panel + Settings table
══════════════════════════════════════════════════════════════════════════════ */

/* ── Cloche topbar ── */
.tb-notif-btn { position: relative; }
.tb-notif-badge {
  position: absolute;
  top: 1px; right: 0;
  background: var(--accent);
  color: #fff;
  font-size: 9px; font-weight: 700;
  border-radius: 999px;
  min-width: 16px; height: 16px;
  padding: 0 3px;
  display: flex; align-items: center; justify-content: center;
  line-height: 1; pointer-events: none;
  border: 2px solid var(--bg);
}

/* ── Panel flottant ── */
.notif-panel {
  position: fixed;
  top: 54px; right: 12px;
  width: 340px; max-height: 480px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 14px;
  box-shadow: 0 8px 32px rgba(0,0,0,.14);
  display: flex; flex-direction: column;
  z-index: 1200;
  overflow: hidden;
}
.notif-panel-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 13px 16px 11px;
  border-bottom: 1px solid var(--line);
  flex-shrink: 0;
}
.notif-panel-title {
  font-size: 13px; font-weight: 600; color: var(--t1);
  display: flex; align-items: center; gap: 6px;
}
.notif-count-pill {
  background: var(--accent);
  color: #fff; font-size: 10px; font-weight: 700;
  border-radius: 999px; padding: 1px 6px;
}
.notif-panel-actions { display: flex; gap: 6px; }
.notif-panel-action-btn {
  font-size: 11px; font-weight: 500;
  color: var(--accent-2);
  background: none; border: none;
  cursor: pointer; padding: 3px 6px;
  border-radius: 5px;
  transition: background .12s;
}
.notif-panel-action-btn:hover { background: var(--surface-2); }
.notif-clear-btn { color: var(--t3); }
.notif-clear-btn:hover { color: var(--t1) !important; }

/* ── Items ── */
.notif-panel-body { flex: 1; overflow-y: auto; }
.notif-item {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 11px 14px;
  border-bottom: 1px solid var(--line);
  cursor: pointer;
  transition: background .1s;
}
.notif-item:last-child { border-bottom: none; }
.notif-item:hover { background: var(--surface-2); }
.notif-item.is-unread { background: var(--accent-soft); }
.notif-icon {
  flex-shrink: 0;
  width: 30px; height: 30px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 12px; color: #fff;
  margin-top: 1px;
}
.notif-body { flex: 1; min-width: 0; }
.notif-title  { font-size: 12px; font-weight: 600; color: var(--t1); margin-bottom: 2px; }
.notif-message { font-size: 12px; color: var(--t2); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.notif-time   { font-size: 11px; color: var(--t4); margin-top: 3px; }
.notif-unread-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--accent);
  flex-shrink: 0; margin-top: 6px;
}
.notif-panel-empty {
  padding: 44px 20px;
  text-align: center; color: var(--t3); font-size: 13px;
}
.notif-panel-empty i { font-size: 32px; opacity: .3; display: block; margin: 0 auto 10px; }

/* ── Table paramètres ── */
.notif-settings-table { width: 100%; border-collapse: collapse; }
.notif-settings-table th {
  text-align: right;
  font-size: 11px; font-weight: 600; color: var(--t3);
  text-transform: uppercase; letter-spacing: .4px;
  padding: 8px 14px;
  border-bottom: 1px solid var(--line);
}
.notif-settings-table th:first-child { text-align: left; }
.notif-settings-table td {
  padding: 10px 14px;
  border-bottom: 1px solid var(--line);
  vertical-align: middle;
  color: var(--t3); font-size: 13px; text-align: center;
}
.notif-settings-table tr:last-child td { border-bottom: none; }
.notif-settings-event {
  display: flex; align-items: center; gap: 9px;
  font-size: 13px; font-weight: 500; color: var(--t1);
}
.notif-settings-icon {
  width: 26px; height: 26px;
  border-radius: 7px;
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; color: #fff; flex-shrink: 0;
}
.notif-settings-toggle-cell { text-align: center !important; width: 72px; }

@media (max-width: 860px) {
  .notif-panel { width: calc(100vw - 24px); right: 12px; max-height: 68vh; }
}

/* ══════════════════════════════════════════════════════════════
   Property — Messaging custom fields
══════════════════════════════════════════════════════════════ */

/* Carte de champ validé — même style que pg-sub-section */
.prop-msg-custom-list { display: flex; flex-direction: column; gap: 0; }
.prop-msg-custom-card {
  border-top: 1px solid var(--line);
  padding: 12px 0 4px;
  margin-top: 4px;
}
.prop-msg-card-head {
  display: flex !important;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
}
.prop-msg-card-head i { color: var(--accent); font-size: 13px; }
.prop-msg-card-head > span { flex: 1; font-weight: 600; font-size: 13px; color: var(--t1); }
.prop-msg-del-btn {
  margin-left: auto;
  width: 26px; height: 26px;
  border-radius: 6px;
  border: 1px solid var(--line);
  background: none;
  color: var(--t4);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; font-size: 11px;
  transition: background 0.15s, color 0.15s;
}
.prop-msg-del-btn:hover { background: var(--danger-soft, rgba(239,68,68,.1)); color: var(--danger, #EF4444); }
.prop-msg-custom-value {
  font-size: 13px; color: var(--t2);
  margin: 0 0 8px; padding-left: 22px;
  line-height: 1.5;
}

/* Formulaire d'ajout inline */
.prop-msg-add-form {
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 14px;
  margin-top: 10px;
  background: var(--surface-2);
  display: flex; flex-direction: column; gap: 12px;
}
.prop-msg-icon-label {
  font-size: 12px; font-weight: 600;
  color: var(--t2); text-transform: uppercase; letter-spacing: .04em;
}
.prop-msg-icon-picker {
  display: grid;
  grid-template-columns: repeat(10, 1fr);
  gap: 4px;
}
.prop-msg-icon-option {
  aspect-ratio: 1;
  border-radius: 8px;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--t2);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; font-size: 13px;
  transition: background 0.12s, color 0.12s, border-color 0.12s;
}
.prop-msg-icon-option:hover { background: var(--surface-3); color: var(--t1); }
.prop-msg-icon-option.selected {
  background: var(--accent-soft);
  border-color: var(--accent);
  color: var(--accent);
}
.prop-msg-add-fields { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.prop-msg-add-actions {
  display: flex; justify-content: flex-end; gap: 8px;
}
@media (max-width: 600px) {
  .prop-msg-icon-picker { grid-template-columns: repeat(6, 1fr); }
  .prop-msg-add-fields { grid-template-columns: 1fr; }
}

/* ══════════════════════════════════════════════════════════════
   Property — Guest guide builder
══════════════════════════════════════════════════════════════ */

.property-guide-card .ms-card-body {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.property-guide-workspace {
  display: grid;
  grid-template-columns: 250px minmax(0, 1fr);
  gap: 18px;
  align-items: start;
}
.property-guide-nav {
  position: sticky;
  top: 82px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 8px;
  border-right: 1px solid var(--line);
}
.property-guide-nav-item {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 40px;
  border: 0;
  border-radius: 10px;
  background: transparent;
  color: var(--t2);
  cursor: pointer;
  font: inherit;
  font-size: 13px;
  font-weight: 700;
  padding: 0 10px;
  text-align: left;
  transition: background .14s, color .14s;
}
.property-guide-nav-item i {
  width: 17px;
  color: var(--t3);
  text-align: center;
}
.property-guide-nav-item:hover {
  background: var(--surface-2);
  color: var(--t1);
}
.property-guide-nav-item.active {
  background: var(--surface-3);
  color: var(--t1);
}
.property-guide-nav-item.active i {
  color: var(--accent);
}
.property-guide-main {
  min-width: 0;
}
.property-guide-subpanel {
  display: none;
  flex-direction: column;
  gap: 14px;
}
.property-guide-subpanel.active {
  display: flex;
}
.property-guide-subpanel-head {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 14px 0 4px;
}
.property-guide-subpanel-head h4 {
  margin: 0;
  color: var(--t1);
  font-size: 18px;
  font-weight: 800;
  letter-spacing: 0;
}
.property-guide-subpanel-head p {
  margin: 0;
  color: var(--t2);
  font-size: 13px;
  line-height: 1.45;
}
.property-guide-intro {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--surface-2);
}
.property-guide-intro > div {
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 0;
}
.property-guide-intro strong {
  font-size: 14px;
  color: var(--t1);
}
.property-guide-intro span {
  font-size: 13px;
  color: var(--t2);
  line-height: 1.35;
}
.property-guide-intro-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.property-guide-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.property-guide-section {
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--surface);
  overflow: hidden;
}
.property-guide-section-head {
  display: grid;
  grid-template-columns: auto auto auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border-bottom: 1px solid var(--line);
}
.property-guide-grip {
  color: var(--t4);
  font-size: 14px;
  line-height: 1;
}
.property-guide-icon {
  width: 34px;
  height: 34px;
  border-radius: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--accent-soft);
  color: var(--accent);
  flex: 0 0 auto;
}
.property-guide-toggle {
  justify-content: center;
  padding: 0;
  min-height: auto;
}
.property-guide-title-input {
  min-width: 0;
  font-weight: 700;
}
.property-guide-actions {
  display: flex;
  align-items: center;
  gap: 6px;
}
.property-guide-icon-btn {
  width: 34px;
  height: 34px;
  padding: 0;
  justify-content: center;
  border-radius: 10px;
}
.property-guide-icon-btn:disabled {
  opacity: .38;
  pointer-events: none;
}
.property-guide-delete {
  color: var(--danger, #EF4444);
}
.property-guide-section-body {
  display: grid;
  grid-template-columns: minmax(180px, 240px) minmax(0, 1fr);
  gap: 12px;
  padding: 14px;
}
.property-guide-section-body textarea {
  min-height: 116px;
}
.property-guide-add {
  align-self: flex-start;
}
.property-guide-overview-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.property-guide-overview-card {
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-height: 136px;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--surface);
}
.property-guide-overview-card i {
  width: 36px;
  height: 36px;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--accent);
  background: var(--accent-soft);
}
.property-guide-overview-card strong {
  color: var(--t1);
  font-size: 14px;
}
.property-guide-overview-card span {
  color: var(--t2);
  font-size: 13px;
  line-height: 1.45;
}
.property-guide-channel-table {
  display: grid;
  gap: 10px;
}
.property-guide-step-card {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--surface);
}
.property-guide-step-head {
  display: flex;
  align-items: flex-start;
  gap: 12px;
}
.property-guide-step-head > span {
  width: 34px;
  height: 34px;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--accent);
  color: #fff;
  font-size: 14px;
  font-weight: 900;
  flex: 0 0 auto;
}
.property-guide-step-head strong,
.property-guide-step-head p {
  display: block;
}
.property-guide-step-head strong {
  color: var(--t1);
  font-size: 14px;
}
.property-guide-step-head p {
  margin: 3px 0 0;
  color: var(--t2);
  font-size: 13px;
  line-height: 1.4;
}
.property-guide-channel-table label {
  display: grid;
  grid-template-columns: minmax(150px, 240px) minmax(0, 1fr);
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--surface);
}
.property-guide-channel-table span {
  color: var(--t1);
  font-size: 13px;
  font-weight: 800;
}
.property-guide-check-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.property-guide-check-grid label {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 44px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--surface);
  color: var(--t1);
  cursor: pointer;
  font-size: 13px;
  font-weight: 700;
}
.property-guide-check-grid label:has(input:checked) {
  background: var(--accent-soft);
  border-color: var(--accent-ring);
}
.property-guide-preview-backdrop {
  align-items: center;
  justify-content: center;
  padding: 18px;
}
.property-guide-preview-modal {
  max-width: min(960px, calc(100vw - 28px));
  width: 100%;
  max-height: calc(100vh - 36px);
  overflow: hidden;
  padding: 0;
}
.property-guide-preview-shell {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) minmax(320px, 420px);
  min-height: min(760px, calc(100vh - 36px));
  background:
    linear-gradient(135deg, rgba(var(--accent-rgb), .11), transparent 38%),
    var(--surface);
}
.property-guide-preview-toolbar {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 24px;
  border-right: 1px solid var(--line);
}
.guest-guide-preview-phone {
  width: min(390px, calc(100vw - 54px));
  align-self: center;
  justify-self: center;
  max-height: calc(100vh - 74px);
  overflow-y: auto;
  border: 10px solid #17171d;
  border-radius: 38px;
  background: #f5f5f7;
  box-shadow: 0 22px 60px rgba(0,0,0,.24);
  padding: 12px;
}
.guest-guide-preview-status {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 8px 4px 12px;
  color: #17171d;
  font-size: 12px;
  font-weight: 800;
}
.guest-guide-preview-status i {
  color: var(--accent);
}
.guest-guide-preview-hero {
  height: 164px;
  border-radius: 24px;
  overflow: hidden;
  background: #e5e7eb;
}
.guest-guide-preview-hero img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.guest-guide-preview-hero-empty {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--accent);
  font-size: 38px;
  background: var(--accent-soft);
}
.guest-guide-preview-summary {
  padding: 16px 4px 8px;
}
.guest-guide-preview-kicker {
  display: block;
  color: var(--accent);
  font-size: 12px;
  font-weight: 800;
  margin-bottom: 4px;
}
.guest-guide-preview-summary h2 {
  margin: 0;
  color: #141418;
  font-size: 25px;
  line-height: 1.08;
  letter-spacing: 0;
}
.guest-guide-preview-summary p {
  margin: 7px 0 0;
  color: #70727b;
  font-size: 13px;
}
.guest-guide-preview-gate {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 8px 0 12px;
  padding: 12px;
  border-radius: 18px;
  background: #ffffff;
  border: 1px solid rgba(0,0,0,.06);
  box-shadow: 0 4px 16px rgba(0,0,0,.05);
}
.guest-guide-preview-gate i {
  width: 34px;
  height: 34px;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--accent-soft);
  color: var(--accent);
}
.guest-guide-preview-gate strong,
.guest-guide-preview-gate span {
  display: block;
}
.guest-guide-preview-gate strong {
  color: #17171d;
  font-size: 13px;
}
.guest-guide-preview-gate span {
  color: #777983;
  font-size: 12px;
  margin-top: 1px;
}
.guest-guide-preview-validation {
  display: grid;
  gap: 10px;
  margin: 8px 0 12px;
  padding: 12px;
  border-radius: 20px;
  background: #ffffff;
  border: 1px solid rgba(0,0,0,.06);
  box-shadow: 0 4px 16px rgba(0,0,0,.05);
}
.guest-guide-preview-validation-head,
.guest-guide-preview-info-title {
  display: flex;
  align-items: center;
  gap: 8px;
}
.guest-guide-preview-validation-head span,
.guest-guide-preview-info-title span {
  border-radius: 999px;
  background: var(--accent-soft);
  color: var(--accent);
  font-size: 11px;
  font-weight: 900;
  padding: 4px 8px;
}
.guest-guide-preview-validation-head strong,
.guest-guide-preview-info-title strong {
  color: #17171d;
  font-size: 14px;
  font-weight: 900;
}
.guest-guide-preview-validation-list {
  display: grid;
  gap: 7px;
}
.guest-guide-preview-validation-item {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
  min-height: 38px;
  padding: 8px;
  border-radius: 13px;
  background: #f7f7f8;
}
.guest-guide-preview-validation-item i {
  color: var(--accent);
  width: 18px;
  text-align: center;
}
.guest-guide-preview-validation-item span {
  color: #24252b;
  font-size: 13px;
  font-weight: 800;
}
.guest-guide-preview-validation-item small {
  color: #777983;
  font-size: 10px;
  font-weight: 800;
}
.guest-guide-preview-validation button {
  min-height: 44px;
  border: 0;
  border-radius: 14px;
  background: var(--accent);
  color: #fff;
  cursor: pointer;
  font: inherit;
  font-size: 14px;
  font-weight: 900;
}
.guest-guide-preview-info-title {
  margin: 16px 2px 10px;
}
.guest-guide-preview-grid {
  display: grid;
  gap: 10px;
}
.guest-guide-preview-card {
  border-radius: 18px;
  background: #ffffff;
  border: 1px solid rgba(0,0,0,.06);
  box-shadow: 0 4px 15px rgba(0,0,0,.045);
  overflow: hidden;
}
.guest-guide-preview-card-head {
  width: 100%;
  min-height: 62px;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 10px;
  border: 0;
  background: transparent;
  color: #17171d;
  cursor: pointer;
  font: inherit;
  padding: 12px;
  text-align: left;
}
.guest-guide-preview-card-icon {
  width: 38px;
  height: 38px;
  border-radius: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--accent-soft);
  color: var(--accent);
}
.guest-guide-preview-card-title {
  font-size: 14px;
  font-weight: 800;
  min-width: 0;
}
.guest-guide-preview-lock {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  border-radius: 999px;
  background: #f3f4f6;
  color: #747680;
  font-size: 10px;
  font-weight: 800;
  padding: 5px 8px;
  white-space: nowrap;
}
.guest-guide-preview-chevron {
  color: #8a8c95;
  font-size: 12px;
  transition: transform .16s;
}
.guest-guide-preview-card.is-open .guest-guide-preview-chevron {
  transform: rotate(180deg);
}
.guest-guide-preview-card-body {
  display: none;
  padding: 0 14px 14px 60px;
  color: #3f4148;
  font-size: 13px;
  line-height: 1.45;
}
.guest-guide-preview-card.is-open .guest-guide-preview-card-body {
  display: block;
}
.guest-guide-preview-card-body p {
  margin: 0 0 8px;
}
.guest-guide-preview-card-body p:last-child {
  margin-bottom: 0;
}
.guest-guide-preview-muted {
  color: #888b95;
}
.guest-guide-preview-list-row {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  margin: 7px 0;
}
.guest-guide-preview-list-row i {
  color: var(--accent);
  font-size: 11px;
  margin-top: 4px;
}
.guest-guide-preview-extras {
  display: grid;
  gap: 9px;
  margin-top: 12px;
}
.guest-guide-preview-extra {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  border-radius: 18px;
  background: #17171d;
  color: #ffffff;
  padding: 12px;
}
.guest-guide-preview-extra strong,
.guest-guide-preview-extra span {
  display: block;
}
.guest-guide-preview-extra strong {
  font-size: 13px;
}
.guest-guide-preview-extra span {
  color: rgba(255,255,255,.7);
  font-size: 12px;
  margin-top: 2px;
}
.guest-guide-preview-extra button {
  border: 0;
  border-radius: 999px;
  background: var(--accent);
  color: #ffffff;
  cursor: pointer;
  font: inherit;
  font-size: 12px;
  font-weight: 800;
  min-height: 34px;
  padding: 0 13px;
}

/* ══════════════════════════════════════════════════════════════
   Experience voyageur — Éditeur Guide (design 2026, handoff Claude Design)
══════════════════════════════════════════════════════════════ */

/* ============================================================================
   STUDIO — 3 zones
   ============================================================================ */
.experience-studio {
  flex: 1;
  display: grid;
  grid-template-columns: 330px minmax(0, 1fr);
  height: calc(100dvh - 65px);
  min-height: 0;
  overflow: hidden;
}
.experience-eyebrow {
  display: block; font-size: 11px; font-weight: 700; color: var(--t3);
  text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 3px;
}
.main:has(.experience-studio),
.page-main:has(.experience-studio) {
  min-height: 0;
  overflow: hidden;
}

/* ----- Left rail : logements -------------------------------------------- */
.experience-rail {
  border-right: 1px solid var(--line);
  background: var(--surface);
  display: flex; flex-direction: column; height: 100%; min-height: 0; overflow: hidden;
}
.experience-studio[data-has-selection="true"] .experience-rail-head,
.experience-studio[data-has-selection="true"] .experience-search-wrap,
.experience-studio[data-has-selection="true"] .experience-property-list {
  display: none;
}
.experience-rail-editor {
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: 16px;
  min-height: 0;
  overflow-y: auto;
  padding: 16px 16px 96px;
}
.experience-rail-editor[hidden] {
  display: none;
}
.experience-rail-editor-top {
  border-bottom: 1px solid var(--line);
  display: grid;
  gap: 7px;
  grid-template-columns: 1fr;
  padding-bottom: 14px;
}
.experience-rail-editor-top strong {
  color: var(--t1);
  display: block;
  font-size: 15px;
  font-weight: 800;
  line-height: 1.15;
}
.experience-rail-editor-top small {
  color: var(--t3);
  display: block;
  font-size: 12px;
  margin-top: 4px;
}
.experience-rail-editor .experience-inspector-close {
  display: none;
}
.experience-rail-back-btn {
  display: inline-flex;
  height: 30px;
  margin-bottom: 0;
  padding: 0;
  width: 30px;
}
.experience-rail-head { padding: 18px 18px 12px; }
.experience-rail-head strong { font-size: 18px; font-weight: 700; letter-spacing: -0.02em; }
.experience-search-wrap {
  position: relative; margin: 0 16px 12px;
}
.experience-search-wrap i {
  position: absolute; left: 12px; top: 50%; transform: translateY(-50%);
  color: var(--t3); font-size: 13px;
}
.experience-search-wrap input {
  width: 100%; height: 38px; padding: 0 12px 0 34px;
  background: var(--surface-3); border: 1px solid var(--line); border-radius: 10px;
  font-size: 13px; color: var(--t1); outline: none; transition: all 0.15s;
}
.experience-search-wrap input:focus { background: var(--surface); border-color: var(--line-strong); box-shadow: 0 0 0 4px rgba(12,12,16,0.04); }
.experience-property-list {
  flex: 1; overflow-y: auto; padding: 0 10px 16px;
  display: flex; flex-direction: column; gap: 2px;
}
.experience-property-card-mini {
  display: flex; align-items: center; gap: 12px;
  padding: 10px; border-radius: 12px; text-align: left;
  border: 0; background: transparent; color: inherit; cursor: pointer;
  transition: background 0.12s; width: 100%;
}
.experience-property-card-mini:hover { background: var(--surface-2); }
.experience-property-card-mini.active { background: var(--accent-soft); box-shadow: inset 0 0 0 1px var(--accent-ring); }
.experience-property-thumb, .experience-property-fallback {
  width: 46px; height: 46px; border-radius: 11px; object-fit: cover; flex-shrink: 0;
  box-shadow: inset 0 0 0 0.5px rgba(0,0,0,0.08);
}
.experience-property-fallback {
  display: grid; place-items: center; color: #fff; font-weight: 700; font-size: 16px;
  background: linear-gradient(135deg, oklch(0.78 0.10 30), oklch(0.62 0.13 30));
}
.experience-property-card-mini span { display: flex; flex-direction: column; min-width: 0; gap: 2px; }
.experience-property-card-mini strong { font-size: 13.5px; font-weight: 600; color: var(--t1); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.experience-property-card-mini small { font-size: 11.5px; color: var(--t3); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* ----- Center : canvas panel -------------------------------------------- */
.experience-canvas-panel {
  display: flex; flex-direction: column; min-height: 0; min-width: 0; overflow: hidden;
  background:
    radial-gradient(120% 70% at 50% -10%, rgba(245,135,77,0.06), transparent 55%),
    var(--bg);
}
.experience-studio-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  gap: 18px; padding: 18px 24px 12px;
}
.experience-studio-toolbar h1 { font-size: 20px; font-weight: 700; letter-spacing: -0.02em; }
.experience-toolbar-actions { display: flex; align-items: center; gap: 12px; flex-shrink: 0; }
.experience-mode-toggle {
  display: inline-flex; padding: 3px; gap: 2px;
  background: var(--surface); border: 1px solid var(--line); border-radius: 11px;
  box-shadow: var(--shadow-1);
}
.experience-mode-toggle button {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 6px 15px; border-radius: 8px;
  border: 0; background: transparent; cursor: pointer;
  font-size: 12.5px; font-weight: 600; color: var(--t3); transition: all 0.15s;
}
.experience-mode-toggle button:hover { color: var(--t1); }
.experience-mode-toggle button.active { background: var(--t1); color: #fff; }
.experience-mode-toggle button.active .mode-lock { color: #fff; }
.mode-lock { font-size: 10px; opacity: 0.8; }

[data-theme="dark"] .experience-mode-toggle {
  background: var(--surface-2);
  border-color: var(--line-strong);
}
[data-theme="dark"] .experience-mode-toggle button {
  color: var(--t3);
}
[data-theme="dark"] .experience-mode-toggle button:hover {
  color: var(--t1);
}
[data-theme="dark"] .experience-mode-toggle button.active {
  background: var(--accent);
  color: #fff;
}
[data-theme="dark"] .experience-mode-toggle button.active .mode-lock {
  color: #fff;
}

.experience-canvas-stage {
  flex: 1; min-height: 0; overflow-y: auto;
  display: flex; align-items: flex-start; justify-content: center;
  padding: 22px 24px 96px;
  scroll-padding-bottom: 96px;
}
.experience-empty-canvas {
  margin: auto; text-align: center; color: var(--t3);
  display: flex; flex-direction: column; align-items: center; gap: 14px; max-width: 280px;
}
.experience-empty-canvas i { font-size: 34px; color: var(--t4); }
.experience-empty-canvas p { font-size: 13.5px; line-height: 1.5; }

/* ----- Phone frame ------------------------------------------------------- */
.experience-phone-frame {
  box-sizing: border-box;
  width: 390px; flex-shrink: 0;
  background: #0C0C10;
  border-radius: 46px;
  overflow: hidden;
  padding: 10px;
  box-shadow:
    0 0 0 2px rgba(12,12,16,0.85),
    0 40px 80px -30px rgba(12,12,16,0.5),
    0 8px 24px -8px rgba(12,12,16,0.3);
  position: relative;
}
.experience-phone-screen {
  position: relative;
  box-sizing: border-box;
  background: var(--surface);
  border-radius: 38px;
  overflow: hidden;
  isolation: isolate;
  clip-path: inset(0 round 38px);
  contain: paint;
  height: 800px;
  display: flex; flex-direction: column;
}
.experience-phone-island {
  position: absolute; top: 10px; left: 50%; transform: translateX(-50%);
  width: 110px; height: 30px; background: #0C0C10; border-radius: 20px; z-index: 40;
}
.experience-phone-status {
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  z-index: 35;
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 28px 8px; font-size: 12px; font-weight: 800; color: #ffffff;
  flex-shrink: 0;
  pointer-events: none;
  text-shadow: 0 1px 5px rgba(0,0,0,0.45);
}
.experience-phone-status .dots { display: inline-flex; gap: 5px; align-items: center; color: #ffffff; }

.experience-phone-scroll { flex: 1; overflow-y: auto; overflow-x: hidden; }
.experience-phone-scroll::-webkit-scrollbar { width: 0; }

.experience-phone-hero {
  position: relative; height: 200px;
  background: linear-gradient(135deg, oklch(0.82 0.09 30), oklch(0.6 0.14 45));
  display: grid; place-items: center; color: rgba(255,255,255,0.5); font-size: 40px;
}
.experience-phone-hero img { width: 100%; height: 100%; object-fit: cover; }
.experience-phone-hero::after {
  content: none;
}
.experience-phone-hero-cap {
  position: absolute; left: 18px; right: 18px; bottom: 8px; z-index: 1; color: #fff;
  text-shadow: 0 1px 7px rgba(0,0,0,0.55);
}
.experience-phone-hero-cap span { font-size: 11px; font-weight: 600; opacity: 0.85; letter-spacing: 0.02em; }
.experience-phone-hero-cap h2 {
  font-size: 21px; font-weight: 700; letter-spacing: -0.02em; line-height: 1.15;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}

.experience-phone-body { padding: 30px 16px 90px; display: flex; flex-direction: column; gap: 12px; }

/* ----- Validation interface --------------------------------------------- */
.experience-valid-intro { text-align: center; padding: 8px 8px 8px; }
.experience-valid-intro .badge {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 10.5px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em;
  color: var(--accent-2); background: var(--accent-soft); padding: 4px 10px; border-radius: 999px;
}
.experience-valid-intro h3 { font-size: 17px; font-weight: 700; margin: 10px 0 5px; letter-spacing: -0.01em; }
.experience-valid-intro p { font-size: 12.5px; color: var(--t3); line-height: 1.5; }

.experience-valid-group-label {
  font-size: 10.5px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em;
  color: var(--t3); margin: 8px 2px 2px;
}
.experience-valid-field {
  display: flex; align-items: center; gap: 12px;
  padding: 13px 14px; border-radius: 13px;
  background: var(--surface-2); border: 1px solid var(--line);
}
.experience-valid-field .vf-ico {
  width: 34px; height: 34px; border-radius: 10px; flex-shrink: 0;
  display: grid; place-items: center; font-size: 14px;
  background: var(--accent-soft); color: var(--accent-2); box-shadow: var(--shadow-1);
}
.experience-valid-field.is-required .vf-ico { background: var(--accent-soft); color: var(--accent-2); }
.experience-valid-field .vf-main {
  display: flex;
  flex: 1;
  flex-direction: column;
  min-width: 0;
}
.experience-valid-field .vf-label {
  color: var(--t1);
  display: block;
  font-size: 13.5px;
  font-weight: 600;
  line-height: 1.2;
}
.experience-valid-field .vf-hint {
  color: var(--t3);
  display: block;
  font-size: 11px;
  line-height: 1.3;
  margin-top: 3px;
}
.experience-valid-field .vf-tag {
  font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.03em;
  padding: 3px 8px; border-radius: 999px; background: var(--surface-3); color: var(--t3);
  flex-shrink: 0;
}
.experience-valid-field.is-required .vf-tag { background: var(--accent); color: #fff; }

.experience-valid-special {
  display: flex; align-items: center; gap: 12px;
  padding: 14px; border-radius: 13px; border: 1.5px dashed var(--line-strong);
  background: var(--surface); color: var(--t2);
}
.experience-valid-special i { font-size: 18px; color: var(--accent); }
.experience-valid-special .vs-main { flex: 1; }
.experience-valid-special strong { display: block; font-size: 13px; color: var(--t1); }
.experience-valid-special span { font-size: 11.5px; color: var(--t3); }

.experience-time-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 16px;
  display: grid;
  gap: 12px;
  margin-bottom: 12px;
  padding: 14px;
}
.experience-time-card h4 {
  color: var(--t1);
  font-size: 19px;
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.15;
}
.experience-time-row {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.experience-time-row label {
  display: grid;
  gap: 5px;
  min-width: 0;
}
.experience-time-row span {
  color: var(--t2);
  font-size: 12px;
  font-weight: 650;
}
.experience-time-row strong {
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 11px;
  color: var(--t1);
  font-size: 16px;
  font-weight: 650;
  min-width: 0;
  padding: 10px 12px;
}
.experience-time-row small {
  color: var(--t3);
  font-size: 11px;
  line-height: 1.35;
}
.experience-time-cta {
  align-items: center;
  background: var(--accent);
  border: 0;
  border-radius: 12px;
  color: #fff;
  display: inline-flex;
  font: inherit;
  font-size: 14px;
  font-weight: 750;
  gap: 8px;
  justify-content: center;
  min-height: 42px;
  width: 100%;
}

.experience-valid-cta {
  width: 100%; height: 46px; border-radius: 13px; margin-top: 6px;
  border: 0; cursor: pointer;
  background: linear-gradient(180deg, var(--accent), var(--accent-2)); color: #fff;
  font-size: 14px; font-weight: 700;
  box-shadow: 0 8px 18px -6px var(--accent-ring), inset 0 1px 0 rgba(255,255,255,0.25);
}

.experience-locked-teaser {
  margin-top: 4px; padding: 16px; border-radius: 14px;
  background: var(--surface-2); border: 1px solid var(--line);
  display: flex; flex-direction: column; align-items: center; gap: 6px; text-align: center;
  position: relative; overflow: hidden;
}
.experience-locked-teaser .lock-ic {
  width: 40px; height: 40px; border-radius: 12px; display: grid; place-items: center;
  background: var(--surface-3); color: var(--t3); font-size: 16px;
}
.experience-locked-teaser strong { font-size: 13px; color: var(--t1); }
.experience-locked-teaser span { font-size: 11.5px; color: var(--t3); }

/* ----- Guide interface : tabs + blocks ---------------------------------- */
.experience-client-tabs {
  display: flex; gap: 6px; padding: 2px 0 6px; overflow-x: auto;
}
.experience-client-tabs span {
  flex-shrink: 0; padding: 7px 13px; border-radius: 999px;
  font-size: 12px; font-weight: 600; color: var(--t3); background: var(--surface-3);
  cursor: pointer; transition: all 0.15s;
}
.experience-client-tabs span.active { background: var(--t1); color: #fff; }

.experience-blocks-wrap { display: flex; flex-direction: column; }

/* insertion zone with "+" */
.experience-insert-zone {
  height: 14px; position: relative; display: flex; align-items: center; justify-content: center;
}
.experience-insert-zone .ins-line {
  position: absolute; left: 8px; right: 8px; height: 2px; border-radius: 2px;
  background: transparent; transition: background 0.12s;
}
.experience-insert-zone .ins-add {
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--surface); border: 1px solid var(--line-strong); color: var(--t3);
  display: grid; place-items: center; font-size: 10px; opacity: 0; transform: scale(0.7);
  transition: all 0.15s; z-index: 2;
}
.experience-blocks-wrap:hover .experience-insert-zone .ins-add { opacity: 1; transform: scale(1); }
.experience-insert-zone .ins-add:hover { background: var(--accent); border-color: var(--accent); color: #fff; }
.experience-insert-zone.drop-target .ins-line { background: var(--accent); }
.experience-insert-zone.drop-target { height: 26px; }

/* a guide block in preview */
.experience-guide-block {
  position: relative; text-align: left; width: 100%;
  border-radius: 14px; padding: 14px;
  background: var(--surface); border: 1px solid var(--line);
  box-shadow: var(--shadow-1);
  transition: box-shadow 0.15s, transform 0.15s, border-color 0.15s;
}
.experience-guide-block:hover { box-shadow: var(--shadow-2); transform: translateY(-1px); }
.experience-guide-block.selected {
  border-color: var(--accent);
  box-shadow: 0 0 0 2px var(--accent-ring), var(--shadow-2);
}
.experience-guide-block.dragging { opacity: 0.4; }
.experience-guide-block.is-hidden-block { opacity: 0.55; }

.experience-guide-block-head { display: flex; align-items: center; gap: 9px; margin-bottom: 7px; }
.experience-guide-block-head .gb-ico {
  width: 30px; height: 30px; border-radius: 9px; flex-shrink: 0;
  display: grid; place-items: center; font-size: 13px;
  background: var(--accent-soft); color: var(--accent-2);
}
.experience-guide-block-head .gb-title {
  flex: 1; min-width: 0; font-size: 14px; font-weight: 700; color: var(--t1);
  outline: none; border-radius: 5px; letter-spacing: -0.01em;
}
.experience-guide-block-head .gb-title:focus { box-shadow: 0 0 0 2px var(--accent-ring); background: var(--accent-soft); }
.experience-vis-tag {
  font-size: 9.5px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.03em;
  padding: 3px 7px; border-radius: 999px; flex-shrink: 0;
}
.experience-vis-tag.always { background: var(--green-soft); color: var(--green); }
.experience-vis-tag.after { background: var(--surface-3); color: var(--t3); }
.experience-guide-block .gb-content {
  font-size: 12.5px; line-height: 1.55; color: var(--t2); white-space: pre-wrap;
  outline: none; border-radius: 6px;
}
.experience-guide-block .gb-content:focus { box-shadow: 0 0 0 2px var(--accent-ring); background: var(--accent-soft); padding: 4px; margin: -4px; }

/* rich block extras */
.gb-gallery { display: grid; gap: 5px; margin-top: 10px; }
.gb-gallery.count-1 { grid-template-columns: 1fr; }
.gb-gallery.count-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.gb-gallery.count-3 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.gb-gallery.count-3 > :last-child { grid-column: 1 / -1; justify-self: center; width: calc(50% - 3px); }
.gb-gallery.count-4 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.gb-gallery.count-5,
.gb-gallery.count-6 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.gb-gallery.count-5 > :nth-child(4) { grid-column: 1 / 2; }
.gb-gallery.count-5 > :nth-child(5) { grid-column: 2 / 3; }
.gb-gallery > div,
.gb-gallery > button {
  aspect-ratio: 1;
  border: 0;
  border-radius: 8px;
  background: linear-gradient(135deg, oklch(0.84 0.07 var(--h, 30)), oklch(0.64 0.12 var(--h, 30)));
  cursor: zoom-in;
  overflow: hidden;
  padding: 0;
}
.gb-gallery img { width: 100%; height: 100%; display: block; object-fit: cover; }
.gb-map {
  margin-top: 10px; height: 96px; border-radius: 10px; position: relative; overflow: hidden;
  background:
    linear-gradient(0deg, rgba(0,0,0,0.05), rgba(0,0,0,0.05)),
    repeating-linear-gradient(0deg, var(--surface-3) 0 13px, transparent 13px 26px),
    repeating-linear-gradient(90deg, var(--surface-3) 0 13px, transparent 13px 26px),
    var(--surface-2);
  display: grid; place-items: center;
}
.gb-map i { font-size: 20px; color: var(--accent); filter: drop-shadow(0 2px 4px rgba(0,0,0,0.15)); }
.gb-list { margin: 10px 0 0; padding: 0; list-style: none; display: flex; flex-direction: column; gap: 6px; }
.gb-list li { display: flex; align-items: center; gap: 8px; font-size: 12.5px; color: var(--t2); }
.gb-list li i { color: var(--green); font-size: 11px; }
.gb-callout {
  margin-top: 10px; padding: 11px 12px; border-radius: 10px;
  background: var(--accent-soft); border: 1px solid var(--accent-ring);
  display: flex; gap: 9px; font-size: 12px; color: var(--accent-2); line-height: 1.45;
}
.gb-callout i { margin-top: 1px; }
.gb-video {
  margin-top: 10px; aspect-ratio: 16/9; border-radius: 10px; background: #0C0C10;
  display: grid; place-items: center; color: rgba(255,255,255,0.9); position: relative;
  overflow: hidden;
}
.gb-video .play { width: 42px; height: 42px; border-radius: 50%; background: rgba(255,255,255,0.92); color: #0C0C10; display: grid; place-items: center; font-size: 14px; }
.gb-video video,
.gb-video iframe {
  border: 0;
  height: 100%;
  inset: 0;
  position: absolute;
  width: 100%;
}
.gb-video small {
  bottom: 9px;
  color: rgba(255,255,255,0.72);
  font-size: 9px;
  left: 10px;
  max-width: calc(100% - 20px);
  overflow: hidden;
  position: absolute;
  right: 10px;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.gb-wifi {
  margin-top: 10px; display: grid; grid-template-columns: 1fr 1fr; gap: 8px;
}
.gb-wifi div { background: var(--surface-2); border: 1px solid var(--line); border-radius: 10px; padding: 9px 11px; }
.gb-wifi small { display: block; font-size: 10px; color: var(--t3); text-transform: uppercase; letter-spacing: 0.04em; }
.gb-wifi strong { font-size: 13px; color: var(--t1); }
.gb-access {
  margin-top: 10px; display: flex; align-items: center; justify-content: space-between;
  background: var(--t1); color: #fff; border-radius: 11px; padding: 12px 14px;
}
.gb-access .code { font-size: 22px; font-weight: 700; letter-spacing: 4px; font-variant-numeric: tabular-nums; }
.gb-access .lab { font-size: 10px; text-transform: uppercase; letter-spacing: 0.05em; opacity: 0.7; }

/* floating block handles */
.experience-block-handles {
  position: absolute; top: 8px; right: 8px; display: flex; gap: 4px; z-index: 5;
  opacity: 0; transform: translateY(-2px); transition: all 0.15s; pointer-events: none;
}
.experience-guide-block.selected .experience-block-handles,
.experience-guide-block:hover .experience-block-handles { opacity: 1; transform: none; pointer-events: auto; }
.experience-handle {
  width: 26px; height: 26px; border-radius: 8px;
  cursor: pointer; padding: 0;
  background: var(--surface); border: 1px solid var(--line-strong); color: var(--t2);
  display: grid; place-items: center; font-size: 11px; box-shadow: var(--shadow-1);
  transition: all 0.12s;
}
.experience-handle:hover { background: var(--t1); color: #fff; border-color: var(--t1); }
.experience-handle.grip { cursor: grab; }
.experience-handle.grip:active { cursor: grabbing; }
.experience-handle.grip { display: none; }
.experience-handle.danger:hover { background: #c14343; border-color: #c14343; }

.experience-add-inline {
  width: 100%; margin-top: 8px;
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  height: 44px; border-radius: 13px;
  border: 1.5px dashed var(--line-strong); background: var(--surface-2);
  color: var(--t3); font-size: 12.5px; font-weight: 600; transition: all 0.15s;
}
.experience-add-inline:hover { border-color: var(--accent); color: var(--accent); background: var(--accent-soft); }

/* phone bottom tab bar */
.experience-phone-tabbar {
  position: absolute; bottom: 0; left: 0; right: 0; z-index: 30;
  box-sizing: border-box;
  max-width: 100%;
  width: 100%;
  overflow: hidden;
  transform: translateZ(0);
  display: flex; align-items: center; justify-content: space-around;
  padding: 8px 6px 22px;
  background: color-mix(in srgb, var(--surface) 85%, transparent);
  backdrop-filter: saturate(180%) blur(16px);
  -webkit-backdrop-filter: saturate(180%) blur(16px);
  border-top: 1px solid var(--line);
  border-radius: 0 0 38px 38px;
  clip-path: inset(0 round 0 0 38px 38px);
}
.experience-phone-tabbar button {
  flex: 1; display: flex; flex-direction: column; align-items: center; gap: 3px;
  border: 0; background: transparent; cursor: pointer;
  color: var(--t3); font-size: 10px; font-weight: 600;
}
.experience-phone-tabbar button i { font-size: 16px; }
.experience-phone-tabbar button.active { color: var(--accent); }
.experience-phone-preview-back {
  align-items: center;
  background: color-mix(in srgb, var(--surface) 92%, transparent);
  border: 1px solid var(--line);
  border-radius: 12px;
  box-shadow: var(--shadow-1);
  color: var(--t1);
  cursor: pointer;
  display: inline-flex;
  height: 34px;
  justify-content: center;
  left: 16px;
  position: absolute;
  top: 58px;
  width: 34px;
  z-index: 45;
}
.experience-phone-preview-back:hover {
  background: var(--surface);
}

/* ----- Right inspector --------------------------------------------------- */
.experience-inspector {
  border-left: 1px solid var(--line);
  background: var(--surface);
  overflow-y: auto;
  padding: 20px;
  display: none; flex-direction: column; gap: 20px;
}
.experience-inspector-empty {
  margin: auto; text-align: center; color: var(--t3);
  display: flex; flex-direction: column; align-items: center; gap: 8px; padding: 30px 10px;
}
.experience-inspector-empty i { font-size: 26px; color: var(--t4); }
.experience-inspector-empty strong { font-size: 14px; color: var(--t1); }
.experience-inspector-empty span { font-size: 12px; }
.experience-inspector-head h2 { font-size: 18px; font-weight: 700; letter-spacing: -0.02em; margin-top: 2px; }
.experience-inspector-head p { font-size: 12px; color: var(--t3); margin-top: 5px; line-height: 1.5; }
.experience-inspector-close {
  display: none;
}
.experience-mobile-settings {
  display: none;
}
.experience-mobile-flow {
  display: none;
}
.experience-mobile-empty,
.experience-mobile-card,
.experience-mobile-head,
.experience-mobile-mode,
.experience-mobile-actions {
  display: none;
}
.experience-current-blocks {
  border-top: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 16px;
  padding-top: 16px;
}
.experience-current-blocks > strong {
  color: var(--t1);
  font-size: 13px;
  font-weight: 700;
}
.experience-current-blocks > p {
  color: var(--t3);
  font-size: 12px;
}
.experience-current-blocks button {
  align-items: center;
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 11px;
  color: var(--t1);
  cursor: pointer;
  display: grid;
  gap: 9px;
  grid-template-columns: auto minmax(0, 1fr) auto;
  min-height: 44px;
  padding: 9px 11px;
  text-align: left;
}
.experience-current-blocks button.active {
  background: var(--accent-soft);
  border-color: var(--accent-ring);
}
.experience-current-blocks button i {
  color: var(--accent);
  text-align: center;
  width: 18px;
}
.experience-current-blocks button span {
  font-size: 12.5px;
  font-weight: 700;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.experience-current-blocks button small {
  color: var(--t3);
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
}

.experience-toggle-list { display: flex; flex-direction: column; gap: 8px; }
.experience-valid-section-label {
  font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em;
  color: var(--t3); margin: 6px 2px 0;
}
.experience-inspector-toggle {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  padding: 11px 13px; border-radius: 11px;
  background: var(--surface-2); border: 1px solid var(--line); cursor: pointer;
  min-width: 0;
  width: 100%;
}
.experience-inspector-toggle span { display: inline-flex; align-items: center; gap: 9px; font-size: 13px; font-weight: 600; color: var(--t1); min-width: 0; }
.experience-inspector-toggle span i { width: 16px; text-align: center; color: var(--t3); }
.experience-inspector-toggle input { display: none; }
.exp-switch {
  display: inline-block !important;
  width: 38px; height: 22px; border-radius: 999px; background: var(--surface-3);
  border: 1px solid var(--line-strong); position: relative; flex-shrink: 0; transition: all 0.18s;
}
.exp-switch::after {
  content: ""; position: absolute; top: 1px; left: 1px; width: 18px; height: 18px;
  border-radius: 50%; background: #fff; box-shadow: 0 1px 3px rgba(0,0,0,0.2); transition: all 0.18s;
}
.experience-inspector-toggle input:checked + .exp-switch { background: var(--accent); border-color: var(--accent); }
.experience-inspector-toggle input:checked + .exp-switch::after { transform: translateX(16px); }
.experience-inspector-toggle input:disabled + .exp-switch { opacity: 0.5; }

/* Lignes réordonnables des "Informations demandées" */
.experience-inspector-toggle.is-sortable {
  grid-template-columns: auto minmax(0, 1fr) auto;
  cursor: default;
}
.experience-field-arrows {
  display: inline-flex !important;
  flex-direction: column;
  gap: 3px !important;
  flex-shrink: 0;
}
.experience-field-arrow {
  width: 24px; height: 17px;
  display: grid; place-items: center;
  border: 1px solid var(--line-strong); border-radius: 6px;
  background: var(--surface); color: var(--t3);
  font-size: 9px; cursor: pointer; padding: 0;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.experience-field-arrow:hover:not(:disabled) { background: var(--accent-soft); border-color: var(--accent-ring); color: var(--accent-2); }
.experience-field-arrow:disabled { opacity: 0.35; cursor: default; }
.experience-field-name { min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.experience-field-switch { display: inline-flex !important; align-items: center; gap: 0 !important; cursor: pointer; }

/* block editor form */
.experience-editor-form { display: flex; flex-direction: column; gap: 12px; }
.experience-editor-form > label { display: flex; flex-direction: column; gap: 6px; font-size: 11.5px; font-weight: 600; color: var(--t2); }
.experience-block-title-row {
  align-items: flex-end;
  display: grid;
  gap: 10px;
  grid-template-columns: minmax(0, 1fr) auto;
}
.experience-block-title-row label:first-child {
  color: var(--t2);
  display: flex;
  flex-direction: column;
  font-size: 11.5px;
  font-weight: 600;
  gap: 6px;
  min-width: 0;
}
.experience-block-active-toggle {
  align-items: center;
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 11px;
  cursor: pointer;
  display: inline-flex;
  height: 38px;
  justify-content: center;
  width: 42px;
}
.experience-block-active-toggle input {
  display: none;
}
.experience-block-active-toggle span {
  align-items: center;
  color: var(--t3);
  display: inline-flex;
  font-size: 14px;
  justify-content: center;
}
.experience-block-active-toggle .fa-eye-slash {
  display: inline-block;
}
.experience-block-active-toggle .fa-eye {
  display: none;
}
.experience-block-active-toggle input:checked + span {
  background: var(--accent-soft);
  border-radius: 9px;
  color: var(--accent-2);
  height: 30px;
  width: 30px;
}
.experience-block-active-toggle input:checked + span .fa-eye {
  display: inline-block;
}
.experience-block-active-toggle input:checked + span .fa-eye-slash {
  display: none;
}
.experience-editor-form input[type="text"],
.experience-editor-form textarea,
.experience-editor-form select {
  width: 100%; padding: 9px 12px; border-radius: 10px;
  border: 1px solid var(--line-strong); background: var(--surface);
  font-size: 13px; color: var(--t1); outline: none; transition: all 0.15s; resize: vertical;
}
.experience-editor-form input:focus, .experience-editor-form textarea:focus, .experience-editor-form select:focus {
  border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-ring);
}
.experience-editor-actions { display: flex; gap: 6px; margin-top: 2px; }
.experience-editor-actions .ms-btn-ghost { flex-shrink: 0; }
.experience-editor-actions .grow { flex: 1; }

.experience-custom-editor,
.experience-gallery-picker {
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 13px;
  display: grid;
  gap: 10px;
  padding: 12px;
}
.experience-custom-editor > strong,
.experience-gallery-picker > span {
  color: var(--t1);
  font-size: 13px;
  font-weight: 750;
}
.experience-gallery-picker > span {
  align-items: center;
  display: flex;
  justify-content: space-between;
}
.experience-gallery-picker > span small {
  color: var(--accent);
  font-size: 11px;
  font-weight: 800;
}
.experience-custom-editor label {
  color: var(--t2);
  display: grid;
  font-size: 11.5px;
  font-weight: 600;
  gap: 6px;
}
.experience-custom-editor input,
.experience-custom-editor textarea {
  background: var(--surface);
  border: 1px solid var(--line-strong);
  border-radius: 10px;
  color: var(--t1);
  font: inherit;
  font-weight: 400;
  padding: 9px 11px;
  resize: vertical;
  width: 100%;
}
.experience-custom-icon-grid {
  display: grid;
  gap: 7px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
.experience-custom-icon-grid button {
  align-items: center;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 11px;
  color: var(--t2);
  cursor: pointer;
  display: grid;
  gap: 5px;
  justify-items: center;
  min-height: 58px;
  padding: 7px 4px;
}
.experience-custom-icon-grid button.active {
  background: var(--accent-soft);
  border-color: var(--accent-ring);
  color: var(--accent-2);
}
.experience-custom-icon-grid button span {
  font-size: 9.5px;
  font-weight: 650;
}
/* Champs personnalisés multiples */
.experience-custom-field {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 12px;
  display: grid;
  gap: 10px;
  padding: 11px;
}
.experience-custom-field-head {
  align-items: center;
  display: flex;
  justify-content: space-between;
}
.experience-custom-field-head span {
  color: var(--t3);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.experience-custom-remove {
  align-items: center;
  background: transparent;
  border: 1px solid var(--line);
  border-radius: 8px;
  color: #c14343;
  cursor: pointer;
  display: inline-flex;
  font-size: 12px;
  height: 28px;
  justify-content: center;
  width: 28px;
}
.experience-custom-remove:hover { background: rgba(193, 67, 67, 0.08); border-color: rgba(193, 67, 67, 0.35); }
.experience-custom-add {
  align-items: center;
  background: var(--surface);
  border: 1px dashed var(--line-strong);
  border-radius: 11px;
  color: var(--accent-2);
  cursor: pointer;
  display: flex;
  font: inherit;
  font-size: 12.5px;
  font-weight: 700;
  gap: 8px;
  justify-content: center;
  padding: 10px;
  width: 100%;
}
.experience-custom-add:hover { background: var(--accent-soft); border-color: var(--accent-ring); }

/* ============ Éditeur Guide : aperçu téléphone (rubriques + détail) ============ */
.experience-phone-body.is-guide { padding: 0 14px 96px; }
.gpv-intro-wrap {
  align-items: flex-start;
  background: color-mix(in srgb, var(--surface) 96%, transparent);
  border: 1px solid var(--line);
  border-radius: 16px;
  box-shadow: 0 16px 34px -22px rgba(12, 12, 16, .42);
  display: flex;
  gap: 12px;
  margin: -18px 8px 24px;
  padding: 15px;
  position: relative;
  z-index: 3;
}
.gpv-intro-avatar {
  align-items: center;
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 50%;
  color: var(--accent);
  display: flex;
  flex-shrink: 0;
  height: 34px;
  justify-content: center;
  width: 34px;
}
.gpv-intro-avatar.has-image {
  background: var(--surface);
  color: transparent;
  overflow: hidden;
}
.gpv-intro-avatar.has-image img {
  display: block;
  height: 100%;
  object-fit: cover;
  width: 100%;
}
.gpv-intro-wrap strong {
  color: var(--t1);
  display: block;
  font-size: 15px;
  font-weight: 800;
  letter-spacing: -0.01em;
  line-height: 1.25;
  margin-bottom: 6px;
}
.gpv-intro { color: var(--t2); font-size: 13px; line-height: 1.55; margin: 0; }
.gpv-intro-empty { color: var(--t4); font-style: italic; }
.gpv-heading { color: var(--t1); font-size: 17px; font-weight: 800; letter-spacing: -0.01em; margin: 8px 0 12px; }
.gpv-rubrics.gpv-list { display: grid; gap: 0; }
.gpv-rubrics.gpv-list .gpv-rubric {
  align-items: center;
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--line);
  cursor: pointer;
  display: grid;
  font: inherit;
  gap: 12px;
  grid-template-columns: 26px minmax(0, 1fr) auto;
  padding: 14px 2px;
  text-align: left;
  width: 100%;
}
.gpv-rubrics.gpv-cards { display: grid; gap: 10px; grid-template-columns: repeat(2, minmax(0, 1fr)); }
.gpv-rubrics.gpv-cards .gpv-rubric {
  align-items: center;
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 14px;
  cursor: pointer;
  display: grid;
  font: inherit;
  gap: 10px;
  justify-items: center;
  padding: 14px 12px;
  text-align: center;
}
.gpv-rubric[data-disabled="1"] { opacity: .45; }
.gpv-rubric-ic { color: var(--t1); font-size: 18px; }
.gpv-rubrics.gpv-cards .gpv-rubric-ic {
  align-items: center;
  background: var(--accent-soft);
  border-radius: 11px;
  color: var(--accent);
  display: flex;
  height: 40px;
  justify-content: center;
  width: 40px;
}
.gpv-rubric-title { color: var(--t1); font-size: 14px; font-weight: 650; min-width: 0; }
.gpv-rubrics.gpv-cards .gpv-rubric-title { text-align: center; }
.gpv-chev { color: var(--t4); font-size: 12px; }
.gpv-aux-tab { display: grid; gap: 12px; padding: 58px 2px 2px; }
.gpv-aux-head { align-items: center; display: flex; gap: 10px; margin-bottom: 2px; }
.gpv-aux-tab h3 { color: var(--t1); font-size: 18px; font-weight: 850; letter-spacing: -0.01em; margin: 0; }
.gpv-aux-card {
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 14px;
  display: grid;
  gap: 4px;
  padding: 14px;
}
.gpv-aux-card strong, .gpv-aux-grid strong, .gpv-aux-list strong { color: var(--t1); }
.gpv-aux-card span, .gpv-aux-grid small { color: var(--t3); font-size: 12px; }
.gpv-aux-grid { display: grid; gap: 10px; grid-template-columns: repeat(2, minmax(0, 1fr)); }
.gpv-aux-grid div {
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 13px;
  display: grid;
  gap: 3px;
  padding: 12px;
}
.gpv-aux-list {
  align-items: center;
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 12px;
  color: var(--t2);
  display: flex;
  justify-content: space-between;
  padding: 12px 14px;
}
.gpv-extra-row {
  align-items: center;
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 14px;
  cursor: pointer;
  display: grid;
  gap: 10px;
  grid-template-columns: 18px 42px minmax(0, 1fr) auto;
  padding: 10px 12px;
}
.gpv-extra-row input { -webkit-appearance: none; appearance: none; border: 2px solid var(--line-strong); border-radius: 50%; cursor: pointer; flex-shrink: 0; height: 18px; margin: 0; width: 18px; }
.gpv-extra-row input[type="checkbox"] { border-radius: 5px; }
.gpv-extra-row input[type="checkbox"]:checked { background: var(--accent) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 10'%3E%3Cpath d='M1 5l3.5 3.5L11 1' stroke='%23fff' stroke-width='2' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/10px no-repeat; border-color: var(--accent); }
.gpv-extra-row input[type="radio"]:checked { background: radial-gradient(circle, #fff 32%, var(--accent) 33%); border-color: var(--accent); }
[data-theme="dark"] .gpv-extra-row input[type="radio"]:checked { background: radial-gradient(circle, var(--surface) 32%, var(--accent) 33%); }
.gpv-extras-group-label { margin: 14px 0 4px; padding: 0 2px; }
.gpv-extras-group-label em { color: var(--t3); font-size: 10.5px; font-style: italic; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; }
.gpv-extras-group-label:first-child { margin-top: 0; }
.gpv-extra-thumb {
  align-items: center;
  background: var(--accent-soft);
  border: 0;
  border-radius: 11px;
  color: var(--accent);
  cursor: default;
  display: flex;
  height: 42px;
  justify-content: center;
  overflow: hidden;
  width: 42px;
}
.gpv-extra-thumb.is-zoomable { cursor: zoom-in; padding: 0; }
.gpv-extra-thumb.is-zoomable:hover { filter: brightness(.96); }
.gpv-extra-thumb img { height: 100%; object-fit: cover; width: 100%; }
.gpv-extra-main { display: grid; gap: 2px; min-width: 0; }
.gpv-extra-main strong { color: var(--t1); font-size: 13px; font-weight: 800; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.gpv-extra-main small { color: var(--t3); font-size: 11.5px; line-height: 1.25; }
.gpv-powered-by {
  position: absolute;
  bottom: 62px;
  left: 0; right: 0;
  z-index: 28;
  text-align: center;
  font-size: 10.5px;
  color: #999;
  padding: 5px 0 4px;
  background: rgba(255,255,255,0.88);
  -webkit-backdrop-filter: blur(6px);
  backdrop-filter: blur(6px);
  pointer-events: none;
}
[data-theme="dark"] .gpv-powered-by { background: rgba(26,26,30,0.88); color: #666; }
.gpv-powered-by a { color: #777; font-weight: 700; text-decoration: none; pointer-events: auto; }
.gpv-extras-sep { border-top: 1px solid rgba(0,0,0,.07); margin: 10px 0; }
.gpv-pay-toast {
  position: absolute;
  bottom: 130px;
  left: 12px; right: 12px;
  z-index: 50;
  background: #1a1a1e;
  color: #fff;
  border-radius: 12px;
  font-size: 12px;
  font-weight: 600;
  padding: 12px 16px;
  display: flex;
  align-items: center;
  gap: 10px;
  box-shadow: 0 8px 24px rgba(0,0,0,.25);
  animation: gpv-toast-in .25s ease;
}
.gpv-pay-toast i { color: #4ade80; flex-shrink: 0; }
.gpv-pay-toast-out { animation: gpv-toast-out .4s ease forwards; }
@keyframes gpv-toast-in { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }
@keyframes gpv-toast-out { to { opacity: 0; transform: translateY(8px); } }
.gpv-extra-price { color: var(--t1); font-size: 12px; font-weight: 850; white-space: nowrap; }
.gpv-extra-total {
  align-items: center;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 16px;
  box-shadow: var(--shadow-1);
  display: grid;
  gap: 10px;
  grid-template-columns: minmax(0, 1fr) auto auto;
  margin-top: 4px;
  padding: 12px;
  position: sticky;
  bottom: 74px;
  z-index: 6;
}
.gpv-extra-total span { color: var(--t3); font-size: 12px; font-weight: 750; }
.gpv-extra-total strong { color: var(--t1); font-size: 15px; font-weight: 900; }
.gpv-extra-total button {
  background: var(--accent);
  border: 0;
  border-radius: 999px;
  color: white;
  cursor: pointer;
  font-size: 12px;
  font-weight: 850;
  padding: 9px 14px;
}
.gpv-extra-total button:disabled { cursor: not-allowed; opacity: .45; }
.gpv-empty { align-items: center; color: var(--t4); display: grid; gap: 8px; justify-items: center; padding: 30px 10px; text-align: center; font-size: 12.5px; }
.gpv-empty i { font-size: 22px; }
.gpv-detail-head { align-items: center; display: flex; gap: 10px; margin-bottom: 14px; }
.gpv-back {
  align-items: center; background: var(--surface-2); border: 1px solid var(--line); border-radius: 9px;
  color: var(--t1); cursor: pointer; display: flex; flex-shrink: 0; height: 30px; justify-content: center; width: 30px;
}
.gpv-detail-ic {
  align-items: center; background: var(--accent-soft); border-radius: 10px; color: var(--accent);
  display: flex; height: 32px; justify-content: center; width: 32px; font-size: 14px;
}
.gpv-detail-head h3 { color: var(--t1); font-size: 16px; font-weight: 800; margin: 0; }
.gpv-blocks { display: grid; gap: 12px; }
.gpv-h { color: var(--t1); margin: 4px 0 0; }
.gpv-h1 { font-size: 18px; font-weight: 800; }
.gpv-h2 { font-size: 15px; font-weight: 750; }
.gpv-text { color: var(--t2); font-size: 13px; line-height: 1.55; margin: 0; }
.gpv-sep { border: 0; border-top: 1px solid var(--line); margin: 4px 0; }
.gpv-callout { align-items: flex-start; background: var(--accent-soft); border: 1px solid var(--accent-ring); border-radius: 11px; color: var(--accent-2); display: flex; font-size: 12.5px; gap: 9px; line-height: 1.45; padding: 11px 12px; }
.gpv-ul, .gpv-ol { color: var(--t2); font-size: 13px; line-height: 1.5; margin: 0; padding-left: 20px; }
.gpv-ul li, .gpv-ol li { margin-bottom: 4px; }
.gpv-check { display: grid; gap: 7px; list-style: none; margin: 0; padding: 0; }
.gpv-check li { align-items: center; color: var(--t2); display: flex; font-size: 13px; gap: 9px; }
.gpv-check-box { border: 1.5px solid var(--line-strong); border-radius: 5px; flex-shrink: 0; height: 16px; width: 16px; }
.gpv-img { margin: 0; }
.gpv-img img { border-radius: 12px; display: block; width: 100%; }
.gpv-img figcaption { color: var(--t4); font-size: 11.5px; margin-top: 5px; text-align: center; }
.gpv-img-empty { align-items: center; background: var(--surface-2); border: 1px dashed var(--line-strong); border-radius: 12px; color: var(--t4); display: flex; font-size: 22px; height: 110px; justify-content: center; }
.gpv-video { aspect-ratio: 16/9; background: #0C0C10; border-radius: 12px; overflow: hidden; position: relative; }
.gpv-video video, .gpv-video iframe { border: 0; height: 100%; width: 100%; }
.gpv-video.is-empty { align-items: center; color: rgba(255,255,255,.9); display: flex; justify-content: center; }
.gpv-video.is-empty span { align-items: center; background: rgba(255,255,255,.92); border-radius: 50%; color: #0C0C10; display: flex; height: 40px; justify-content: center; width: 40px; }
.gpv-wifi { background: var(--surface-2); border: 1px solid var(--line); border-radius: 12px; display: grid; gap: 10px; grid-template-columns: 1fr 1fr; padding: 12px; }
.gpv-wifi small { color: var(--t4); display: block; font-size: 10.5px; }
.gpv-wifi strong { color: var(--t1); font-size: 13px; }
.gpv-code { align-items: center; background: var(--accent-soft); border: 1px solid var(--accent-ring); border-radius: 12px; display: flex; gap: 12px; justify-content: space-between; padding: 12px 14px; }
.gpv-code span { color: var(--accent-2); display: grid; font-size: 12px; font-weight: 700; gap: 2px; }
.gpv-code span small { color: var(--t4); font-size: 10px; font-weight: 750; text-transform: uppercase; }
.gpv-code strong { color: var(--t1); font-size: 16px; font-weight: 800; letter-spacing: .08em; text-align: right; }
.gpv-code em { color: var(--t3); display: block; flex-basis: 100%; font-size: 11.5px; font-style: normal; line-height: 1.35; margin-top: 6px; }
.gpv-code.is-locked { align-items: flex-start; flex-wrap: wrap; }
.gpv-code.is-locked strong { align-items: center; display: inline-flex; gap: 6px; letter-spacing: 0; }
.gpv-address strong { font-size: 13px; letter-spacing: 0; line-height: 1.35; max-width: 58%; }

/* ============ Éditeur Guide : panneau inspecteur ============ */
.experience-guide-field { display: grid; gap: 9px; margin-top: 18px; border-top: 1px solid var(--line); padding-top: 16px; }
.experience-guide-field:first-of-type { border-top: 0; margin-top: 14px; padding-top: 0; }
.experience-guide-label {
  align-items: center;
  color: var(--t3);
  display: flex;
  font-size: 10.5px;
  font-weight: 850;
  gap: 7px;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.experience-guide-label::before {
  background: var(--accent);
  border-radius: 2px;
  content: "";
  height: 12px;
  width: 3px;
}
.experience-display-toggle { background: var(--surface-2); border: 1px solid var(--line); border-radius: 11px; display: grid; gap: 4px; grid-template-columns: 1fr 1fr; padding: 4px; }
.experience-display-toggle button {
  align-items: center; background: transparent; border: 0; border-radius: 8px; color: var(--t2);
  cursor: pointer; display: flex; font: inherit; font-size: 12.5px; font-weight: 650; gap: 7px; justify-content: center; padding: 8px;
}
.experience-display-toggle button.active { background: var(--accent); color: #fff; }
.experience-guide-header-preview { align-items: center; aspect-ratio: 16 / 9; background: var(--surface-2); border: 1px solid var(--line); border-radius: 14px; color: var(--t4); display: flex; font-size: 22px; justify-content: center; max-height: 420px; min-height: 230px; overflow: hidden; }
.experience-guide-header-preview img { height: 100%; object-fit: cover; object-position: center center; width: 100%; }
.experience-guide-header-actions { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 12px; }
.experience-guide-intro-input {
  background: var(--surface); border: 1px solid var(--line-strong); border-radius: 10px; color: var(--t1);
  font: inherit; font-weight: 400; padding: 9px 11px; resize: vertical; width: 100%;
}
.experience-intro-visual-editor {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}
.experience-intro-visual-preview {
  align-items: center;
  background: var(--accent-soft);
  border: 1px solid var(--accent-ring);
  border-radius: 16px;
  color: var(--accent);
  display: inline-flex;
  flex-shrink: 0;
  font-size: 18px;
  height: 58px;
  justify-content: center;
  overflow: hidden;
  width: 58px;
}
.experience-intro-visual-preview.has-image {
  background: var(--surface-2);
  color: transparent;
}
.experience-intro-visual-preview img {
  display: block;
  height: 100%;
  object-fit: cover;
  width: 100%;
}
.experience-intro-visual-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.experience-intro-icon-grid {
  margin-top: 12px;
}
.experience-rubric-list { display: grid; gap: 8px; }
.experience-rubric-row { align-items: center; display: grid; gap: 8px; grid-template-columns: auto minmax(0, 1fr) auto; }
.experience-rubric-row.is-off { opacity: .55; }
.experience-rubric-open {
  align-items: center; background: var(--surface-2); border: 1px solid var(--line); border-radius: 11px;
  cursor: pointer; display: grid; font: inherit; gap: 9px; grid-template-columns: 30px minmax(0, 1fr) auto; min-width: 0; padding: 9px 11px; text-align: left;
}
.experience-rubric-ic { align-items: center; background: var(--accent-soft); border-radius: 8px; color: var(--accent-2); display: flex; height: 30px; justify-content: center; width: 30px; }
.experience-rubric-name { color: var(--t1); font-size: 13px; font-weight: 650; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.experience-rubric-edit { color: var(--t4); font-size: 11px; }
.experience-rubric-empty { color: var(--t4); font-size: 12.5px; margin: 0; }
.experience-rubric-back-link { align-items: center; background: transparent; border: 0; color: var(--accent-2); cursor: pointer; display: inline-flex; font: inherit; font-size: 12px; font-weight: 700; gap: 6px; margin-bottom: 8px; padding: 0; }
.experience-rubric-icon-grid { display: flex; flex-wrap: wrap; gap: 8px; }
.experience-rubric-icon-grid button {
  align-items: center; background: var(--surface-2); border: 1px solid var(--line); border-radius: 10px;
  color: var(--t2); cursor: pointer; display: flex; font-size: 14px; height: 42px; justify-content: center; width: 42px;
}
.experience-rubric-icon-grid button.active { background: var(--accent-soft); border-color: var(--accent-ring); color: var(--accent-2); }
.experience-rubric-delete { margin-top: 16px; }
.experience-cb-list { display: grid; gap: 16px; }
.experience-cb-card { background: transparent; border: 0; border-radius: 0; overflow: visible; }
.experience-cb-card-head { align-items: center; background: transparent; border-bottom: 0; display: flex; justify-content: space-between; padding: 0 0 8px; }
.experience-cb-card-head > span:first-child { align-items: center; color: var(--t1); display: inline-flex; font-size: 15px; font-weight: 850; gap: 8px; }
.experience-cb-card-head > span:first-child i { color: var(--accent); width: 18px; }
.experience-cb-card-actions { display: inline-flex; gap: 5px; }
.experience-cb-card-body { display: grid; gap: 8px; padding: 0 0 4px 26px; }
.experience-cb-card-body input, .experience-cb-card-body textarea, .experience-cb-card-body select {
  background: var(--surface); border: 1px solid var(--line-strong); border-radius: 9px; color: var(--t1);
  font: inherit; font-weight: 400; padding: 8px 10px; resize: vertical; width: 100%;
}
.experience-cb-items { display: grid; gap: 7px; }
.experience-cb-item { align-items: center; display: grid; gap: 7px; grid-template-columns: minmax(0, 1fr) auto; }
.experience-cb-item-add {
  align-items: center; background: transparent; border: 1px dashed var(--line-strong); border-radius: 9px; color: var(--accent-2);
  cursor: pointer; display: flex; font: inherit; font-size: 12px; font-weight: 650; gap: 6px; justify-content: center; padding: 7px;
}
.experience-cb-image-preview { align-items: center; background: var(--surface); border: 1px dashed var(--line-strong); border-radius: 10px; color: var(--t4); display: flex; font-size: 20px; height: 110px; justify-content: center; overflow: hidden; }
.experience-cb-image-preview img { height: 100%; object-fit: cover; width: 100%; }
.experience-cb-sep-note { color: var(--t4); font-size: 12px; text-align: center; padding: 4px; }
.experience-cb-lock {
  align-items: center;
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 12px;
  color: var(--t2);
  display: flex;
  font-size: 12.5px;
  font-weight: 650;
  gap: 9px;
  line-height: 1.35;
  padding: 11px 12px;
}
.experience-cb-lock input { accent-color: var(--accent); flex-shrink: 0; height: 16px; width: 16px; }
.experience-cb-add-wrap { margin-top: 14px; position: relative; }
.experience-cb-add-trigger {
  align-items: center;
  background: var(--surface);
  border: 1px dashed var(--line-strong);
  border-radius: 999px;
  color: var(--accent-2);
  cursor: pointer;
  display: inline-flex;
  font: inherit;
  font-size: 13px;
  font-weight: 750;
  gap: 8px;
  min-height: 36px;
  padding: 0 14px;
}
.experience-cb-add-trigger:hover { background: var(--accent-soft); border-color: var(--accent-ring); }
.experience-cb-palette {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 14px;
  box-shadow: var(--shadow-pop);
  display: grid;
  gap: 6px;
  left: 0;
  margin-top: 8px;
  max-width: 320px;
  padding: 8px;
  position: absolute;
  top: 100%;
  width: min(320px, calc(100vw - 48px));
  z-index: 40;
}
.experience-cb-palette[hidden] { display: none; }
.experience-cb-filter {
  align-items: center;
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 10px;
  display: flex;
  gap: 8px;
  padding: 0 10px;
}
.experience-cb-filter i { color: var(--t4); font-size: 12px; }
.experience-cb-filter input {
  background: transparent;
  border: 0;
  color: var(--t1);
  font: inherit;
  height: 36px;
  outline: none;
  width: 100%;
}
.experience-cb-palette button {
  align-items: center; background: transparent; border: 0; border-radius: 9px; color: var(--t2);
  cursor: pointer; display: inline-flex; font: inherit; font-size: 13px; font-weight: 700; gap: 10px; padding: 10px 11px;
  text-align: left;
}
.experience-cb-palette button:hover { background: var(--accent-soft); border-color: var(--accent-ring); color: var(--accent-2); }
.experience-cb-palette button i { color: var(--accent); font-size: 14px; width: 18px; }

/* Texte enrichi (contenteditable) + barre flottante */
.exp2-rte {
  background: var(--surface); border: 1px solid var(--line-strong); border-radius: 9px;
  color: var(--t1); font: inherit; font-weight: 400; line-height: 1.55; min-height: 58px;
  outline: none; padding: 10px 12px; width: 100%;
}
.exp2-rte:focus { border-color: var(--accent-ring); box-shadow: 0 0 0 3px var(--accent-soft); }
.exp2-rte:empty::before { color: var(--t4); content: attr(data-placeholder); pointer-events: none; }
.exp2-rte a { color: var(--accent-2); text-decoration: underline; }
.exp2-rte-toolbar {
  align-items: center; background: #1c1c22; border: 1px solid rgba(255,255,255,.12); border-radius: 10px;
  box-shadow: 0 10px 30px -8px rgba(0,0,0,.5); display: flex; gap: 2px; padding: 4px; position: fixed; z-index: 1400;
}
.exp2-rte-toolbar[hidden] { display: none; }
.exp2-rte-toolbar button {
  align-items: center; background: transparent; border: 0; border-radius: 7px; color: #fff; cursor: pointer;
  display: grid; font-size: 13px; height: 30px; place-items: center; width: 30px;
}
.exp2-rte-toolbar button:hover { background: rgba(255,255,255,.14); }
.exp2-rte-sep { background: rgba(255,255,255,.18); height: 18px; margin: 0 3px; width: 1px; }

.exp2-link-modal {
  align-items: center;
  display: flex;
  inset: 0;
  justify-content: center;
  padding: 18px;
  position: fixed;
  z-index: 1500;
}
.exp2-link-modal[hidden] { display: none; }
.exp2-link-backdrop {
  background: rgba(12, 12, 16, .52);
  inset: 0;
  position: absolute;
}
.exp2-link-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 18px;
  box-shadow: var(--shadow-3);
  display: grid;
  gap: 12px;
  max-width: 420px;
  padding: 18px;
  position: relative;
  width: min(100%, 420px);
}
.exp2-link-title {
  align-items: center;
  color: var(--t1);
  display: flex;
  font-size: 17px;
  font-weight: 800;
  gap: 9px;
}
.exp2-link-title i { color: var(--accent); }
.exp2-link-input {
  background: var(--surface-2);
  border: 1px solid var(--line-strong);
  border-radius: 12px;
  color: var(--t1);
  font: inherit;
  height: 46px;
  outline: none;
  padding: 0 13px;
  width: 100%;
}
.exp2-link-input:focus { border-color: var(--accent-ring); box-shadow: 0 0 0 4px var(--accent-soft); }
.exp2-link-actions { display: flex; gap: 8px; justify-content: flex-end; }
.exp2-link-actions .ms-btn-ghost,
.exp2-link-actions .ms-btn-primary { justify-content: center; min-width: 120px; }

/* ====================================================================== */
/*  Studio 2 parties : sidebar + colonne unique (pile)                    */
/* ====================================================================== */
.experience-studio2 { width: 100%; }
/* La colonne unique laisse la page défiler naturellement */
.main:has(.experience-studio2),
.page-main:has(.experience-studio2) { overflow-y: auto; overflow-x: hidden; }
.exp2-main {
  margin: 0 auto;
  max-width: 1180px;
  padding: 18px 24px 70px;
  width: 100%;
}

/* --- Niveau 1 : sélecteur de logement --- */
/* ---- Picker header ---- */
.exp2-picker-head { margin: 14px 0 20px; }
.exp2-picker-top { align-items: center; display: flex; justify-content: space-between; }
.exp2-picker-head h1 { color: var(--t1); font-size: 24px; font-weight: 800; letter-spacing: -0.02em; margin: 5px 0 0; }
.exp2-picker-count {
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--t3);
  font-size: 12px;
  font-weight: 600;
  padding: 4px 12px;
}

/* ---- Barre de recherche ---- */
.exp2-search {
  align-items: center;
  background: var(--surface);
  border: 1px solid var(--line-strong);
  border-radius: 12px;
  display: flex;
  gap: 10px;
  margin-bottom: 20px;
  padding: 0 14px;
}
.exp2-search.exp2-search-pill { border-radius: 999px; }
.exp2-search i { color: var(--t4); font-size: 14px; }
.exp2-search input { background: transparent; border: 0; color: var(--t1); flex: 1; font: inherit; height: 44px; outline: none; }

/* ---- Grille de cartes ---- */
.exp2-prop-grid { display: grid; gap: 16px; grid-template-columns: repeat(3, minmax(0, 1fr)); }
.exp2-prop-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 16px;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  font: inherit;
  min-width: 0;
  overflow: hidden;
  padding: 0;
  text-align: left;
  transition: border-color .15s, box-shadow .15s, transform .1s;
}
.exp2-prop-card:hover { border-color: var(--accent-ring); box-shadow: 0 10px 28px -10px rgba(0,0,0,.18); }
.exp2-prop-card:active { transform: scale(.98); }

/* Vignette */
.exp2-prop-thumb {
  aspect-ratio: 4 / 3;
  background: var(--surface-2);
  display: block;
  overflow: hidden;
  position: relative;
  width: 100%;
}
.exp2-prop-thumb img { height: 100%; object-fit: cover; transition: transform .3s ease; width: 100%; }
.exp2-prop-card:hover .exp2-prop-thumb img { transform: scale(1.04); }
.exp2-prop-fallback { align-items: center; color: #fff; display: flex; font-size: 26px; font-weight: 800; height: 100%; justify-content: center; width: 100%; }
.exp2-prop-badge {
  background: rgba(0,0,0,0.48);
  border-radius: 6px;
  bottom: 10px;
  color: #fff;
  font-size: 10.5px;
  font-weight: 600;
  left: 10px;
  letter-spacing: .04em;
  padding: 3px 8px;
  position: absolute;
  text-transform: uppercase;
}

/* Meta */
.exp2-prop-meta { display: flex; flex-direction: column; gap: 4px; min-width: 0; padding: 14px 16px 16px; }
.exp2-prop-meta small { color: var(--t3); display: none; font-size: 11px; font-weight: 600; letter-spacing: .06em; text-transform: uppercase; }
.exp2-prop-meta strong { color: var(--t1); font-size: 15px; font-weight: 750; line-height: 1.25; margin-bottom: 8px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.exp2-prop-meta em {
  align-items: center;
  align-self: start;
  background: transparent;
  border: 1.5px solid var(--accent);
  border-radius: 8px;
  color: var(--accent-2);
  display: inline-flex;
  font-size: 11.5px;
  font-style: normal;
  font-weight: 700;
  gap: 5px;
  padding: 5px 10px;
}
.exp2-prop-meta em i { font-size: 11px; }
.exp2-prop-card:hover .exp2-prop-meta em { background: var(--accent); color: #fff; }
.exp2-empty { align-items: center; color: var(--t4); display: flex; flex-direction: column; gap: 10px; grid-column: 1 / -1; padding: 50px 20px; }
.exp2-empty i { font-size: 26px; }

/* --- Niveau 2/3 : barre d'édition + corps --- */
.exp2-editbar {
  align-items: center;
  background: var(--surface);
  backdrop-filter: blur(10px);
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: var(--shadow-1);
  display: flex;
  flex-wrap: wrap;
  gap: 12px 16px;
  margin: 0 0 18px;
  padding: 14px 16px;
  position: sticky;
  top: 14px;
  z-index: 8;
}
.exp2-back {
  align-items: center;
  background: var(--surface-2);
  border: 1px solid var(--line);
  color: var(--t1);
  cursor: pointer;
  display: inline-flex;
  flex-shrink: 0;
  font: inherit;
  font-size: 13px;
  font-weight: 650;
  gap: 7px;
  height: 38px;
  justify-content: center;
  padding: 0;
  width: 38px;
}
.exp2-back:hover { background: var(--surface-3); }
.exp2-editbar-title { flex: 1; min-width: 0; }
.exp2-editbar-title h1 { color: var(--t1); font-size: 18px; font-weight: 800; letter-spacing: -0.01em; margin: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.exp2-editbar-title .experience-eyebrow { display: block; margin-bottom: 1px; }
.exp2-editbar-actions { display: flex; flex-wrap: wrap; gap: 8px; }
.exp2-editor-body { display: block; }
.exp2-editor-body .experience-guide-field:first-of-type { margin-top: 0; }

.exp2-guide-shell {
  align-items: start;
  display: grid;
  gap: 24px;
  grid-template-columns: 276px minmax(0, 1fr);
}
.exp2-rubric-rail {
  align-self: start;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: var(--shadow-1);
  display: grid;
  gap: 16px;
  max-height: calc(100vh - 116px);
  overflow-y: auto;
  padding: 18px;
  position: sticky;
  scrollbar-color: color-mix(in srgb, var(--t4) 32%, transparent) transparent;
  scrollbar-width: thin;
  top: 86px;
}
.exp2-rubric-rail::-webkit-scrollbar { width: 7px; }
.exp2-rubric-rail::-webkit-scrollbar-track { background: transparent; }
.exp2-rubric-rail::-webkit-scrollbar-thumb {
  background: color-mix(in srgb, var(--t4) 22%, transparent);
  background-clip: content-box;
  border: 2px solid transparent;
  border-radius: 999px;
}
.exp2-rubric-rail::-webkit-scrollbar-thumb:hover {
  background: color-mix(in srgb, var(--t4) 36%, transparent);
  background-clip: content-box;
}
.exp2-rubric-head {
  display: grid;
  gap: 3px;
  padding: 0 4px 4px;
}
.exp2-rubric-head h2 {
  color: var(--t1);
  font-size: 18px;
  font-weight: 850;
  letter-spacing: -0.02em;
  line-height: 1.15;
  margin: 0;
}
.exp2-rubric-head p { color: var(--t3); font-size: 12.5px; margin: 0; }
.exp2-rubric-group {
  background: transparent;
  display: grid;
  gap: 8px;
}
.exp2-rubric-group.is-primary {
  border-bottom: 1px solid var(--line);
  padding-bottom: 14px;
}
.exp2-rubric-group-title {
  color: var(--t4);
  font-size: 11px;
  font-weight: 850;
  letter-spacing: .06em;
  padding: 0 4px 3px;
  text-transform: uppercase;
}
.exp2-rubric-row {
  align-items: center;
  display: grid;
  gap: 6px;
  grid-template-columns: minmax(0, 1fr) 32px;
}
.exp2-rubric-row.is-off { opacity: .58; }
.exp2-rubric-order {
  align-items: center;
  background: transparent;
  border: 0;
  border-radius: 8px;
  color: var(--t4);
  cursor: pointer;
  display: flex;
  height: 26px;
  justify-content: center;
  width: 26px;
}
.exp2-rubric-order:hover:not(:disabled) { background: var(--surface-2); color: var(--accent-2); }
.exp2-rubric-order:disabled { opacity: .25; cursor: default; }
.exp2-rubric-item {
  align-items: center;
  background: transparent;
  border: 1px solid transparent;
  border-radius: 8px;
  color: var(--t2);
  cursor: pointer;
  display: grid;
  font: inherit;
  gap: 10px;
  grid-template-columns: 34px minmax(0, 1fr) auto;
  min-width: 0;
  padding: 9px 10px;
  text-align: left;
}
.exp2-rubric-item:hover { background: var(--surface-2); }
.exp2-rubric-item.active {
  background: var(--surface);
  border-color: var(--line);
  box-shadow: var(--shadow-1);
  color: var(--t1);
}
.exp2-rubric-item-top.active { background: var(--accent-soft); border-color: var(--accent-ring); }
.exp2-rubric-icon {
  align-items: center;
  background: var(--accent-soft);
  border: 1px solid var(--accent-ring);
  border-radius: 9px;
  color: var(--accent);
  display: flex;
  height: 34px;
  justify-content: center;
  width: 34px;
}
.exp2-rubric-item span:nth-child(2) { display: grid; gap: 2px; min-width: 0; }
.exp2-rubric-item strong {
  color: var(--t1);
  font-size: 13.5px;
  font-weight: 750;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.exp2-rubric-item small {
  color: var(--t3);
  font-size: 11.5px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.exp2-rubric-item > i:last-child { color: var(--t4); font-size: 11px; }
.exp2-rubric-more {
  align-items: center;
  background: transparent;
  border: 1px solid transparent;
  border-radius: 9px;
  color: var(--t4);
  cursor: pointer;
  display: inline-flex;
  height: 32px;
  justify-content: center;
  width: 32px;
}
.exp2-rubric-more:hover,
.exp2-rubric-more:focus-visible {
  background: var(--surface-2);
  border-color: var(--line);
  color: var(--t1);
  outline: none;
}
.exp2-rubric-popover {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 12px;
  box-shadow: var(--shadow-pop);
  display: grid;
  gap: 3px;
  min-width: 156px;
  padding: 6px;
  position: fixed;
  z-index: 1600;
}
.exp2-rubric-popover[hidden] { display: none; }
.exp2-rubric-popover button {
  align-items: center;
  background: transparent;
  border: 0;
  border-radius: 9px;
  color: var(--t2);
  cursor: pointer;
  display: inline-flex;
  font: inherit;
  font-size: 12.5px;
  font-weight: 700;
  gap: 9px;
  justify-content: flex-start;
  padding: 9px 10px;
  text-align: left;
}
.exp2-rubric-popover button:hover { background: var(--surface-2); color: var(--t1); }
.exp2-rubric-popover button.danger { color: #c14343; }
.exp2-add-rubric {
  align-items: center;
  background: transparent;
  border: 1px dashed var(--line-strong);
  border-radius: 10px;
  color: var(--accent-2);
  cursor: pointer;
  display: flex;
  font: inherit;
  font-size: 13px;
  font-weight: 750;
  gap: 8px;
  justify-content: center;
  margin-top: 4px;
  padding: 11px;
}
.exp2-add-rubric:hover { background: var(--accent-soft); border-color: var(--accent-ring); }
.exp2-block-editor { min-width: 0; }
.exp2-editor-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: var(--shadow-1);
  padding: 22px;
}
.exp2-editor-heading {
  align-items: center;
  border-bottom: 1px solid var(--line);
  display: grid;
  gap: 14px;
  grid-template-columns: 50px minmax(0, 1fr);
  margin: -22px -22px 18px;
  padding: 18px 22px;
}
.exp2-editor-icon {
  align-items: center;
  background: var(--accent-soft);
  border: 1px solid var(--accent-ring);
  border-radius: 12px;
  color: var(--accent);
  display: flex;
  font-size: 18px;
  height: 50px;
  justify-content: center;
  width: 50px;
}
.exp2-editor-heading h2 {
  color: var(--t1);
  font-size: 24px;
  font-weight: 850;
  letter-spacing: -0.025em;
  line-height: 1.1;
  margin: 1px 0 4px;
}
.exp2-editor-heading p {
  color: var(--t3);
  font-size: 13.5px;
  line-height: 1.45;
  margin: 0;
}

/* --- Volet d'aperçu téléphone --- */
.exp2-preview { position: fixed; inset: 0; z-index: 1200; }
.exp2-preview[hidden] { display: none; }
.exp2-preview-backdrop { position: absolute; inset: 0; background: rgba(12,12,16,.5); opacity: 0; transition: opacity .2s; }
.exp2-preview.open .exp2-preview-backdrop { opacity: 1; }
.exp2-preview-sheet {
  background: var(--surface-2);
  border-left: 1px solid var(--line);
  bottom: 0;
  box-shadow: -20px 0 60px -20px rgba(0,0,0,.4);
  display: flex;
  flex-direction: column;
  position: absolute;
  right: 0;
  top: 0;
  transform: translateX(100%);
  transition: transform .24s cubic-bezier(.22,1,.36,1);
  width: min(440px, 100%);
}
.exp2-preview.open .exp2-preview-sheet { transform: translateX(0); }
.exp2-preview-bar { align-items: center; border-bottom: 1px solid var(--line); display: flex; justify-content: space-between; padding: 14px 18px; }
.exp2-preview-title { align-items: center; color: var(--t1); display: inline-flex; font-size: 14px; font-weight: 750; gap: 9px; }
.exp2-preview-title i { color: var(--accent); }
.exp2-preview-x { align-items: center; background: var(--surface); border: 1px solid var(--line); border-radius: 9px; color: var(--t1); cursor: pointer; display: flex; height: 34px; justify-content: center; width: 34px; }
.exp2-preview-stage { flex: 1; min-height: 0; overflow: hidden; }
.exp2-preview-phone { height: 100%; width: 100%; }
.exp2-preview-frame { background: var(--surface-2); border: 0; display: block; height: 100%; width: 100%; }

@media (max-width: 760px) {
  .exp2-main { padding: 4px 14px 90px; }
  .exp2-editbar { border-radius: 14px; margin: 0 0 16px; padding: 12px; position: static; }
  .exp2-editbar-actions { width: 100%; }
  .exp2-editbar-actions .ms-btn-ghost, .exp2-editbar-actions .ms-btn-primary { flex: 1; justify-content: center; }
  .exp2-prop-grid { grid-template-columns: 1fr; }
  .exp2-prop-card { border-radius: 12px; display: grid; gap: 12px; grid-template-columns: 72px minmax(0, 1fr); padding: 10px; }
  .exp2-prop-thumb { aspect-ratio: 1; border-radius: 10px; height: 72px; width: 72px; }
  .exp2-prop-badge { display: none; }
  .exp2-prop-meta { padding: 0; align-self: center; }
  .exp2-prop-meta small { display: block; margin-bottom: 2px; }
  .exp2-prop-meta strong { font-size: 14px; margin-bottom: 5px; }
  .exp2-prop-meta em { font-size: 11px; padding: 4px 8px; }
  .exp2-guide-shell { display: block; }
  .exp2-guide-shell:not(.is-menu-only) .exp2-rubric-rail { display: none; }
  .exp2-guide-shell.is-menu-only .exp2-rubric-rail {
    display: grid;
    margin: 0 auto;
    max-width: 560px;
    position: static;
    width: 100%;
  }
  .exp2-rubric-rail { border-radius: 14px; max-height: none; overflow: visible; padding: 14px; position: static; }
  .exp2-rubric-head { margin-bottom: 8px; }
  .exp2-rubric-row { grid-template-columns: minmax(0, 1fr) 34px; }
  .exp2-rubric-row .exp2-rubric-order { display: none; }
  .exp2-rubric-group { gap: 6px; }
  .exp2-rubric-item { border-radius: 10px; min-height: 54px; padding: 8px 9px; }
  .exp2-rubric-icon { border-radius: 9px; height: 32px; width: 32px; }
  .exp2-rubric-item strong { font-size: 13.5px; }
  .exp2-rubric-item small { font-size: 11px; }
  .exp2-editor-card { border-radius: 14px; margin: 0 -2px; padding: 16px; }
  .exp2-editor-heading { grid-template-columns: 42px minmax(0, 1fr); margin: -16px -16px 16px; padding: 15px 16px; }
  .exp2-editor-icon { height: 42px; width: 42px; }
  .exp2-editor-heading h2 { font-size: 20px; }
  .experience-cb-card-body { padding-left: 0; }
  .experience-cb-palette { max-width: none; width: min(320px, calc(100vw - 56px)); }
  .exp2-preview-sheet { width: 100%; border-left: 0; }
}

@media (min-width: 761px) and (max-width: 1080px) {
  .exp2-prop-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .exp2-guide-shell { grid-template-columns: 238px minmax(0, 1fr); }
}
.experience-gallery-picker > div {
  display: grid;
  gap: 7px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
.experience-gallery-choice {
  border: 2px solid transparent;
  border-radius: 11px;
  display: block;
  overflow: hidden;
  position: relative;
}
.experience-gallery-choice-preview {
  display: block;
  position: relative;
  width: 100%;
}
.experience-gallery-choice input {
  position: absolute;
  inset: 0;
  opacity: 0;
}
.experience-gallery-choice img {
  aspect-ratio: 1;
  display: block;
  object-fit: cover;
  width: 100%;
}
.experience-gallery-choice span {
  align-items: center;
  background: rgba(12,12,16,0.72);
  border-radius: 999px;
  color: #fff;
  display: inline-flex;
  font-size: 10px;
  font-weight: 800;
  height: 20px;
  justify-content: center;
  left: 5px;
  position: absolute;
  top: 5px;
  width: 20px;
}
.experience-gallery-choice-remove {
  align-items: center;
  background: rgba(255,255,255,0.92);
  border: 1px solid var(--line);
  border-radius: 999px;
  bottom: 5px;
  color: #c14343;
  cursor: pointer;
  display: inline-flex;
  font-size: 11px;
  height: 24px;
  justify-content: center;
  opacity: 0;
  position: absolute;
  right: 5px;
  transition: opacity 0.15s, transform 0.15s;
  width: 24px;
}
.experience-gallery-choice:hover .experience-gallery-choice-remove,
.experience-gallery-choice-remove:focus-visible {
  opacity: 1;
}
.experience-gallery-choice.selected {
  border-color: var(--accent);
}
.experience-gallery-empty {
  align-items: center;
  color: var(--t3);
  display: flex !important;
  font-size: 12px;
  grid-column: 1 / -1;
  justify-content: center;
  min-height: 54px;
  text-align: center;
  width: 100%;
}
.experience-gallery-upload {
  align-items: center;
  background: var(--surface);
  border: 1px dashed var(--line-strong);
  border-radius: 12px;
  color: var(--t2);
  cursor: pointer;
  display: grid;
  gap: 3px;
  grid-template-columns: auto minmax(0, 1fr);
  padding: 12px;
}
.experience-gallery-upload input {
  display: none;
}
.experience-gallery-upload i {
  align-items: center;
  background: var(--accent-soft);
  border-radius: 10px;
  color: var(--accent);
  display: inline-flex;
  grid-row: span 2;
  height: 34px;
  justify-content: center;
  width: 34px;
}
.experience-gallery-upload strong {
  color: var(--t1);
  font-size: 13px;
  font-weight: 750;
}
.experience-gallery-upload em {
  color: var(--t3);
  font-size: 11.5px;
  font-style: normal;
}
.gb-gallery-empty-preview {
  align-items: center;
  border: 1px dashed var(--line-strong);
  border-radius: 10px;
  color: var(--t3);
  display: flex;
  gap: 8px;
  margin-top: 10px;
  padding: 12px;
  font-size: 12px;
}
.gb-gallery-empty-preview span {
  font-size: 0;
}
.gb-gallery-empty-preview span::after {
  content: "Ajoutez des photos à cette galerie.";
  font-size: 12px;
}
.gb-extras-empty {
  align-items: center;
  border: 1px dashed var(--line-strong);
  border-radius: 10px;
  color: var(--t3);
  display: flex;
  font-size: 12px;
  gap: 8px;
  margin-top: 10px;
  padding: 12px;
}
.gb-extras { display: grid; gap: 8px; margin-top: 10px; }
.gb-extra-card {
  align-items: center;
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 12px;
  display: grid;
  gap: 10px;
  grid-template-columns: 44px minmax(0, 1fr) auto;
  padding: 9px 10px;
}
.gb-extra-thumb {
  align-items: center;
  background: var(--accent-soft);
  border-radius: 9px;
  color: var(--accent);
  display: flex;
  font-size: 15px;
  height: 44px;
  justify-content: center;
  overflow: hidden;
  width: 44px;
}
.gb-extra-thumb img { height: 100%; object-fit: cover; width: 100%; }
.gb-extra-main { display: grid; gap: 2px; min-width: 0; }
.gb-extra-main strong { color: var(--t1); font-size: 12.5px; }
.gb-extra-main small {
  color: var(--t3);
  display: -webkit-box;
  font-size: 11px;
  line-height: 1.35;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}
.gb-extra-meta { display: grid; gap: 2px; justify-items: end; text-align: right; }
.gb-extra-meta strong { color: var(--t1); font-size: 12.5px; }
.gb-extra-meta small { color: var(--t3); font-size: 10.5px; }
.gb-extra-meta em {
  border-radius: 999px;
  font-size: 9.5px;
  font-style: normal;
  font-weight: 700;
  letter-spacing: .02em;
  padding: 2px 7px;
}
.gb-extra-meta em.is-direct { background: var(--accent-soft); color: var(--accent-2); }
.gb-extra-meta em.is-request { background: var(--surface); border: 1px solid var(--line-strong); color: var(--t2); }
.experience-gallery-zoom-modal {
  align-items: center;
  background: rgba(12, 12, 16, 0.92);
  border-radius: 22px;
  display: grid;
  max-height: min(860px, calc(100vh - 48px));
  max-width: min(980px, calc(100vw - 48px));
  overflow: hidden;
  padding: 44px 18px 18px;
  position: relative;
  width: 100%;
}
.experience-gallery-zoom-modal img {
  border-radius: 14px;
  display: block;
  max-height: calc(100vh - 120px);
  max-width: 100%;
  object-fit: contain;
  width: 100%;
}
.experience-gallery-zoom-modal .experience-preview-close {
  right: 14px;
  top: 14px;
}

/* palette */
.experience-palette { border-top: 1px solid var(--line); padding-top: 16px; }
.experience-palette > strong { display: block; font-size: 13px; font-weight: 700; margin-bottom: 4px; }
.experience-palette > p { font-size: 11.5px; color: var(--t3); margin-bottom: 12px; line-height: 1.4; }
.experience-palette-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.experience-palette-grid button {
  display: flex; align-items: center; gap: 9px;
  padding: 10px 11px; border-radius: 11px;
  background: var(--surface-2); border: 1px solid var(--line);
  text-align: left; transition: all 0.15s; cursor: grab;
}
.experience-palette-grid button:hover { border-color: var(--accent); background: var(--accent-soft); transform: translateY(-1px); box-shadow: var(--shadow-1); }
.experience-palette-grid button:active { cursor: grabbing; }
.experience-palette-grid button.dragging { opacity: 0.5; }
.experience-palette-grid button i { width: 28px; height: 28px; border-radius: 8px; flex-shrink: 0; display: grid; place-items: center; font-size: 12px; background: var(--surface); color: var(--accent-2); box-shadow: var(--shadow-1); }
.experience-palette-grid button span { font-size: 12px; font-weight: 600; color: var(--t1); line-height: 1.2; }

/* ----- Modal ------------------------------------------------------------- */
.experience-modal-backdrop {
  position: fixed; inset: 0; z-index: 900;
  background: rgba(12,12,16,0.45); backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px);
  display: grid; place-items: center; padding: 24px;
  opacity: 0; pointer-events: none; transition: opacity 0.2s;
}
.experience-modal-backdrop.open { opacity: 1; pointer-events: auto; }
.experience-modal {
  width: 100%; max-width: 380px; background: var(--surface);
  border: 1px solid var(--line); border-radius: 20px; padding: 24px;
  box-shadow: var(--shadow-pop); text-align: center;
  transform: translateY(8px) scale(0.98); transition: transform 0.2s;
}
.experience-modal-backdrop.open .experience-modal { transform: none; }
.experience-modal-ic {
  width: 52px; height: 52px; border-radius: 16px; margin: 0 auto 14px;
  display: grid; place-items: center; font-size: 22px;
  background: var(--green-soft); color: var(--green);
}
.experience-modal h3 { font-size: 18px; font-weight: 700; letter-spacing: -0.01em; }
.experience-modal p { font-size: 13px; color: var(--t3); margin-top: 6px; line-height: 1.5; }
.experience-modal-actions { display: flex; gap: 8px; margin-top: 20px; }
.experience-modal-actions button { flex: 1; justify-content: center; }

/* ---- Chip de progression (toolbar) ---- */
.experience-title-row { align-items: center; display: flex; gap: 10px; min-width: 0; }
.experience-title-row h1 { min-width: 0; }
.experience-progress-chip {
  align-items: center;
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  display: inline-flex;
  flex-shrink: 0;
  font-size: 11px;
  font-weight: 750;
  gap: 6px;
  letter-spacing: .01em;
  padding: 4px 10px;
  white-space: nowrap;
}
.experience-progress-chip.is-low { background: var(--surface-2); color: var(--t2); }
.experience-progress-chip.is-mid { background: var(--accent-soft); border-color: var(--accent-ring); color: var(--accent-2); }
.experience-progress-chip.is-full { background: var(--accent); border-color: var(--accent); color: #fff; }

/* ---- Checklist qualité du guide (inspecteur) ---- */
.experience-checklist {
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 14px;
  display: grid;
  gap: 9px;
  margin-top: 16px;
  padding: 14px;
}
.experience-checklist-head { align-items: baseline; display: flex; justify-content: space-between; }
.experience-checklist-head strong { color: var(--t1); font-size: 13px; }
.experience-checklist-head span { color: var(--t3); font-size: 11.5px; font-weight: 750; }
.experience-checklist-bar {
  background: var(--line);
  border-radius: 999px;
  height: 5px;
  overflow: hidden;
}
.experience-checklist-bar span {
  background: var(--accent);
  border-radius: inherit;
  display: block;
  height: 100%;
  transition: width .25s ease;
}
.experience-checklist-item {
  align-items: flex-start;
  display: flex;
  gap: 9px;
}
.experience-checklist-item i { color: var(--t4); font-size: 13px; margin-top: 2px; }
.experience-checklist-item.ok i { color: var(--accent); }
.experience-checklist-item span { display: grid; gap: 1px; min-width: 0; }
.experience-checklist-item strong { color: var(--t2); font-size: 12px; font-weight: 650; }
.experience-checklist-item.ok strong { color: var(--t1); }
.experience-checklist-item small { color: var(--t4); font-size: 11px; }

/* ---- Modale « Copier le guide vers… » ---- */
.experience-copy-modal {
  max-width: 480px;
  padding: 22px;
  position: relative;
  text-align: left;
}
.experience-copy-list {
  border: 1px solid var(--line);
  border-radius: 14px;
  display: grid;
  margin-top: 14px;
  max-height: 300px;
  overflow-y: auto;
}
.experience-copy-check {
  align-items: center;
  border-bottom: 1px solid var(--line);
  cursor: pointer;
  display: grid;
  gap: 10px;
  grid-template-columns: auto 38px minmax(0, 1fr);
  padding: 10px 12px;
}
.experience-copy-check:last-child { border-bottom: 0; }
.experience-copy-check img,
.experience-copy-fallback {
  border-radius: 9px;
  height: 38px;
  object-fit: cover;
  width: 38px;
}
.experience-copy-fallback {
  align-items: center;
  color: #fff;
  display: flex;
  font-size: 14px;
  font-weight: 800;
  justify-content: center;
}
.experience-copy-check span:last-child { display: grid; gap: 2px; min-width: 0; }
.experience-copy-check strong { color: var(--t1); font-size: 13px; }
.experience-copy-check small { color: var(--t3); font-size: 11.5px; }
.experience-copy-empty {
  align-items: center;
  color: var(--t3);
  display: flex;
  font-size: 12.5px;
  gap: 8px;
  justify-content: center;
  padding: 22px 14px;
}
.experience-block-picker {
  max-width: 560px;
  padding: 22px;
  position: relative;
  text-align: left;
}
.experience-block-picker-close {
  align-items: center;
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 12px;
  color: var(--t2);
  cursor: pointer;
  display: inline-flex;
  height: 38px;
  justify-content: center;
  position: absolute;
  right: 14px;
  top: 14px;
  width: 38px;
}
.experience-block-picker-grid {
  display: grid;
  gap: 9px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 18px;
}
.experience-block-picker-grid button {
  align-items: center;
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 13px;
  color: var(--t1);
  cursor: pointer;
  display: grid;
  gap: 11px;
  grid-template-columns: auto minmax(0, 1fr);
  min-height: 68px;
  padding: 12px;
  text-align: left;
}
.experience-block-picker-grid button:hover {
  background: var(--accent-soft);
  border-color: var(--accent-ring);
}
.experience-block-choice-ic {
  align-items: center;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 11px;
  color: var(--accent);
  display: inline-flex;
  height: 38px;
  justify-content: center;
  width: 38px;
}
.experience-block-picker-grid strong {
  display: block;
  font-size: 13px;
  font-weight: 800;
}
.experience-block-picker-grid small {
  color: var(--t3);
  display: block;
  font-size: 11.5px;
  line-height: 1.25;
  margin-top: 2px;
}

.experience-preview-open {
  overflow: hidden;
}
.experience-preview-backdrop {
  position: fixed;
  inset: 0;
  z-index: 9998;
  background: rgba(12, 12, 16, 0.48);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  display: grid;
  place-items: center;
  padding: 24px;
}
.experience-preview-backdrop[hidden] {
  display: none;
}
.experience-preview-modal {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 24px;
  box-shadow: var(--shadow-pop);
  max-height: min(860px, calc(100vh - 48px));
  max-width: 560px;
  overflow: auto;
  padding: 34px 24px 24px;
  position: relative;
  width: 100%;
}
.experience-preview-close {
  align-items: center;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 12px;
  color: var(--t2);
  cursor: pointer;
  display: inline-flex;
  height: 38px;
  justify-content: center;
  position: absolute;
  right: 14px;
  top: 14px;
  width: 38px;
  z-index: 4;
}
.experience-preview-close:hover {
  background: var(--surface-2);
  color: var(--t1);
}
.experience-preview-content {
  display: grid;
  justify-items: center;
}
.experience-preview-content .experience-phone-frame {
  max-width: 100%;
  width: min(390px, calc(100vw - 96px));
}
.experience-preview-content .experience-phone-screen {
  height: min(800px, calc(100vh - 142px));
  min-height: 560px;
}
.experience-preview-content .experience-block-handles,
.experience-preview-content .experience-insert-zone {
  pointer-events: none;
}
.experience-preview-content .experience-block-handles,
.experience-preview-content .experience-insert-zone {
  display: none !important;
}

/* drag ghost helper */
.experience-drag-image {
  position: fixed; top: -1000px; left: -1000px; padding: 8px 14px;
  background: var(--t1); color: #fff; border-radius: 10px; font-size: 12px; font-weight: 600;
}

/* ----- Responsive : repli des colonnes ---------------------------------- */
@media (max-width: 1180px) {
  .experience-studio { grid-template-columns: 300px minmax(0,1fr); }
}
@media (max-width: 960px) {
  .experience-studio { grid-template-columns: 1fr; grid-template-rows: auto 1fr; }
  .experience-rail { flex-direction: row; align-items: center; gap: 12px; overflow-x: auto; border-right: 0; border-bottom: 1px solid var(--line); padding: 12px; }
  .experience-rail-head, .experience-search-wrap { flex-shrink: 0; margin: 0; }
  .experience-property-list { flex-direction: row; padding: 0; }
  .experience-property-card-mini { width: auto; }
  .experience-inspector {
    display: none;
    border-left: 0;
    border-top: 1px solid var(--line);
    max-height: none;
  }
  .experience-palette-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

/* Boutons ghost de l'éditeur (look compact conforme au design handoff) */
.experience-inspector .ms-btn-ghost,
.experience-editor-actions .ms-btn-ghost {
  height: 34px; padding: 0 12px; border-radius: 9px;
  border: 1px solid var(--line-strong); background: var(--surface);
  color: var(--t2); font-size: 12.5px; font-weight: 600;
}
.experience-inspector .ms-btn-ghost:hover,
.experience-editor-actions .ms-btn-ghost:hover {
  background: var(--surface-2); color: var(--t1); border-color: var(--line-strong);
}
.experience-inspector .ms-btn-ghost.danger { color: #c14343; border-color: var(--line-strong); }
.experience-inspector .ms-btn-ghost.danger:hover { background: #fdeaea; border-color: #f3c9c9; color: #c14343; }

@media (max-width: 760px) {
  .experience-preview-backdrop {
    align-items: stretch;
    padding: 0;
  }
  .experience-preview-modal {
    border: 0;
    border-radius: 0;
    max-height: none;
    max-width: none;
    min-height: 100vh;
    min-height: 100dvh;
    padding: 58px 14px 24px;
  }
  .experience-preview-content .experience-phone-frame {
    width: min(390px, calc(100vw - 28px));
  }
  .experience-preview-content .experience-phone-screen {
    height: calc(100dvh - 96px);
    min-height: 0;
  }
  .experience-preview-close {
    position: fixed;
    right: 14px;
    top: 14px;
  }
  body:has(.experience-studio) {
    overflow-x: hidden;
  }
  .main:has(.experience-studio),
  .page-main:has(.experience-studio) {
    min-height: 0;
    overflow-x: hidden;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
  .experience-studio {
    display: block;
    min-height: auto;
    max-width: 100%;
    overflow: visible;
    width: 100%;
  }
  .experience-studio[data-mobile-step="mode"] .experience-rail,
  .experience-studio[data-mobile-step="edit"] .experience-rail {
    display: none;
  }
  .experience-studio[data-mobile-step="select"] .experience-mobile-flow {
    display: none;
  }
  .experience-rail {
    align-items: stretch;
    flex-direction: column;
    overflow: visible;
    padding: 12px;
  }
  .experience-rail-head {
    padding: 0 2px;
  }
  .experience-search-wrap {
    width: 100%;
  }
  .experience-property-list {
    align-content: start;
    display: grid;
    flex: 0 0 auto;
    gap: 4px;
    grid-auto-rows: min-content;
    grid-template-columns: 1fr;
    overflow: visible;
    padding: 0;
  }
  .experience-property-list::-webkit-scrollbar {
    display: none;
  }
  .experience-property-card-mini {
    align-self: start;
    flex: none;
    gap: 10px;
    min-height: 50px;
    padding: 7px 8px;
    width: 100%;
  }
  .experience-property-thumb,
  .experience-property-fallback {
    border-radius: 9px;
    height: 38px;
    width: 38px;
  }
  .experience-property-card-mini strong {
    font-size: 13px;
    line-height: 1.15;
  }
  .experience-property-card-mini small {
    font-size: 11px;
    line-height: 1.2;
  }
  .experience-canvas-panel {
    display: none;
  }
  .experience-inspector {
    display: none;
  }
  .experience-mobile-flow {
    display: block;
    max-width: 100%;
    min-height: calc(100dvh - 56px);
    overflow: visible;
    padding: 14px 14px calc(130px + env(safe-area-inset-bottom, 0px));
  }
  .experience-mobile-back {
    align-items: center;
    display: inline-flex;
    margin-bottom: 12px;
  }
  .experience-mobile-back i {
    color: currentColor;
  }
  .experience-mobile-choice-card {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 16px;
    display: grid;
    gap: 10px;
    padding: 14px;
  }
  .experience-mobile-choice-card > button {
    align-items: center;
    background: var(--surface-2);
    border: 1px solid var(--line);
    border-radius: 14px;
    color: var(--t1);
    cursor: pointer;
    display: grid;
    font: inherit;
    gap: 3px 12px;
    grid-template-columns: 42px minmax(0, 1fr);
    min-height: 76px;
    padding: 12px;
    text-align: left;
    width: 100%;
  }
  .experience-mobile-choice-card > button i {
    align-items: center;
    background: var(--accent-soft);
    border: 1px solid var(--accent-ring);
    border-radius: 12px;
    color: var(--accent);
    display: inline-flex;
    height: 42px;
    justify-content: center;
    width: 42px;
  }
  .experience-mobile-choice-card > button strong {
    color: var(--t1);
    font-size: 15px;
    font-weight: 850;
    min-width: 0;
  }
  .experience-mobile-choice-card > button small {
    color: var(--t3);
    font-size: 12px;
    grid-column: 2;
    line-height: 1.35;
    min-width: 0;
  }
  .experience-mobile-empty {
    align-items: center;
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 16px;
    color: var(--t3);
    display: grid;
    gap: 8px;
    justify-items: center;
    padding: 28px 18px;
    text-align: center;
  }
  .experience-mobile-empty i {
    color: var(--accent);
    font-size: 26px;
  }
  .experience-mobile-empty strong {
    color: var(--t1);
    font-size: 16px;
  }
  .experience-mobile-head {
    display: block;
    margin-bottom: 12px;
  }
  .experience-mobile-head h2 {
    color: var(--t1);
    font-size: 22px;
    line-height: 1.1;
    margin: 2px 0 3px;
  }
  .experience-mobile-head p {
    color: var(--t3);
    font-size: 13px;
  }
  .experience-mobile-mode {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 14px;
    display: grid;
    gap: 4px;
    grid-template-columns: 1fr 1fr;
    margin-bottom: 14px;
    padding: 4px;
  }
  .experience-mobile-mode button {
    align-items: center;
    background: transparent;
    border: 0;
    border-radius: 10px;
    color: var(--t2);
    display: inline-flex;
    font: inherit;
    font-weight: 800;
    gap: 8px;
    justify-content: center;
    min-height: 42px;
  }
  .experience-mobile-mode button.active {
    background: var(--t1);
    color: #fff;
  }
  .experience-mobile-card {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 16px;
    display: grid;
    gap: 10px;
    margin-bottom: 14px;
    padding: 14px;
  }
  .experience-mobile-section-head span {
    color: var(--accent);
    display: block;
    font-size: 11px;
    font-weight: 900;
    text-transform: uppercase;
  }
  .experience-mobile-section-head h3 {
    color: var(--t1);
    font-size: 17px;
    line-height: 1.1;
    margin-top: 3px;
  }
  .experience-mobile-toggle {
    align-items: center;
    background: var(--surface-2);
    border: 1px solid var(--line);
    border-radius: 13px;
    display: grid;
    gap: 10px;
    grid-template-columns: minmax(0, 1fr) auto;
    min-height: 54px;
    padding: 10px 12px;
  }
  .experience-mobile-toggle > span:first-child {
    align-items: center;
    display: inline-flex;
    gap: 10px;
    min-width: 0;
  }
  .experience-mobile-toggle.is-sortable {
    grid-template-columns: auto minmax(0, 1fr) auto;
  }
  .experience-mobile-toggle.is-sortable .experience-field-name {
    align-items: center;
    display: inline-flex;
    gap: 10px;
    min-width: 0;
  }
  .experience-mobile-toggle i {
    color: var(--t3);
    text-align: center;
    width: 18px;
  }
  .experience-mobile-toggle strong {
    color: var(--t1);
    display: block;
    font-size: 14px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .experience-mobile-toggle input {
    display: none;
  }
  .experience-mobile-toggle input:checked + .exp-switch {
    background: var(--accent);
    border-color: var(--accent);
  }
  .experience-mobile-toggle input:checked + .exp-switch::after {
    transform: translateX(16px);
  }
  .experience-mobile-toggle input:disabled + .exp-switch {
    opacity: 0.58;
  }
  .experience-mobile-custom,
  .experience-mobile-block {
    background: var(--surface-2);
    border: 1px solid var(--line);
    border-radius: 14px;
    display: grid;
    gap: 10px;
    padding: 12px;
  }
  .experience-mobile-block-top {
    align-items: stretch;
    display: grid;
    gap: 8px;
    grid-template-columns: minmax(0, 1fr) 46px;
  }
  .experience-mobile-block-top .experience-mobile-toggle {
    min-width: 0;
  }
  .experience-mobile-trash {
    align-items: center;
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 13px;
    color: #c14343;
    display: inline-flex;
    font-size: 15px;
    justify-content: center;
    min-height: 54px;
    padding: 0;
  }
  .experience-mobile-custom label,
  .experience-mobile-block label {
    color: var(--t2);
    display: grid;
    font-size: 12px;
    font-weight: 600;
    gap: 6px;
  }
  .experience-mobile-custom-head {
    align-items: center;
    display: flex;
    justify-content: space-between;
  }
  .experience-mobile-custom-head span {
    color: var(--t3);
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .04em;
    text-transform: uppercase;
  }
  .experience-mobile-custom-label {
    color: var(--t2);
    font-size: 12px;
    font-weight: 600;
  }
  .experience-mobile-custom-label {
    font-size: 0;
  }
  .experience-mobile-custom-label::after {
    content: "Icone";
    font-size: 12px;
  }
  .experience-mobile-icon-grid {
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
  .experience-mobile-icon-grid button {
    align-items: center;
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 12px;
    color: var(--t2);
    cursor: pointer;
    display: grid;
    font: inherit;
    gap: 5px;
    justify-items: center;
    min-height: 62px;
    padding: 8px 4px;
  }
  .experience-mobile-icon-grid button.active {
    background: var(--accent-soft);
    border-color: var(--accent-ring);
    color: var(--accent-2);
  }
  .experience-mobile-icon-grid button i {
    color: currentColor;
    font-size: 16px;
    width: auto;
  }
  .experience-mobile-icon-grid button span {
    font-size: 10px;
    font-weight: 650;
    line-height: 1.1;
  }
  .experience-mobile-custom select[data-exp-custom-icon] {
    display: none;
  }
  .experience-mobile-custom label:has(select[data-exp-custom-icon]) {
    display: none;
  }
  .experience-mobile-custom input,
  .experience-mobile-custom textarea,
  .experience-mobile-custom select,
  .experience-mobile-block input,
  .experience-mobile-block textarea,
  .experience-mobile-block select {
    background: var(--surface);
    border: 1px solid var(--line-strong);
    border-radius: 11px;
    color: var(--t1);
    font: inherit;
    font-weight: 400;
    min-height: 42px;
    padding: 10px 12px;
    width: 100%;
  }
  .experience-mobile-linked-summary {
    align-items: center;
    background: var(--accent-soft);
    border: 1px solid var(--accent-ring);
    border-radius: 14px;
    color: var(--t2);
    display: flex;
    gap: 11px;
    padding: 12px;
  }
  .experience-mobile-linked-summary > i {
    align-items: center;
    background: var(--surface);
    border-radius: 10px;
    color: var(--accent);
    display: inline-flex;
    height: 34px;
    justify-content: center;
    width: 34px;
  }
  .experience-mobile-linked-summary strong {
    color: var(--t1);
    display: block;
    font-size: 13px;
    font-weight: 650;
  }
  .experience-mobile-linked-summary span {
    color: var(--t3);
    display: block;
    font-size: 12px;
    line-height: 1.35;
    margin-top: 2px;
  }
  .experience-mobile-guide-tabs {
    display: grid;
    gap: 8px;
    grid-template-columns: 1fr 1fr;
    margin-bottom: 14px;
  }
  .experience-mobile-guide-tabs button,
  .experience-mobile-add-grid button,
  .experience-mobile-block-actions button {
    align-items: center;
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 12px;
    color: var(--t2);
    display: inline-flex;
    font: inherit;
    font-size: 13px;
    font-weight: 800;
    gap: 8px;
    justify-content: center;
    min-height: 42px;
    padding: 0 10px;
  }
  .experience-mobile-guide-tabs button.active {
    background: var(--t1);
    border-color: var(--t1);
    color: #fff;
  }
  .experience-mobile-add-grid {
    display: grid;
    gap: 8px;
    grid-template-columns: 1fr 1fr;
  }
  .experience-mobile-insert {
    align-items: center;
    background: var(--surface);
    border: 1px dashed var(--line-strong);
    border-radius: 999px;
    color: var(--accent);
    display: inline-flex;
    font: inherit;
    font-size: 12px;
    font-weight: 800;
    gap: 7px;
    justify-content: center;
    min-height: 34px;
    padding: 0 12px;
    width: 100%;
  }
  .experience-mobile-block-actions {
    display: grid;
    gap: 8px;
    grid-template-columns: 1fr 1fr;
  }
  .experience-mobile-block .experience-gallery-picker {
    background: var(--surface);
  }
  .experience-mobile-block .experience-gallery-picker > div {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .experience-mobile-block .experience-gallery-choice {
    display: block;
    font-size: inherit;
    gap: 0;
  }
  .experience-mobile-block .experience-gallery-choice input {
    inset: 0;
    min-height: 0;
    opacity: 0;
    padding: 0;
    position: absolute;
  }
  .experience-mobile-block .experience-gallery-choice-remove {
    opacity: 1;
  }
  .experience-block-picker-backdrop {
    padding: 12px;
  }
  .experience-block-picker {
    border-radius: 20px;
    max-height: calc(100dvh - 24px);
    overflow-y: auto;
    padding: 20px 16px 16px;
  }
  .experience-block-picker-grid {
    grid-template-columns: 1fr;
  }
  .experience-mobile-empty-inline {
    color: var(--t3);
    font-size: 13px;
    padding: 8px 0;
  }
  .experience-mobile-actions {
    background: color-mix(in srgb, var(--surface) 92%, transparent);
    border-top: 1px solid var(--line);
    bottom: 0;
    display: grid;
    gap: 8px;
    grid-template-columns: 1fr 1fr 1fr;
    left: 0;
    padding: 10px 10px calc(10px + env(safe-area-inset-bottom, 0px));
    position: fixed;
    right: 0;
    z-index: 640;
  }
  .experience-mobile-actions .ms-btn-ghost,
  .experience-mobile-actions .ms-btn-primary {
    justify-content: center;
    min-height: 42px;
    min-width: 0;
    padding-left: 8px;
    padding-right: 8px;
  }
  .experience-inspector-toggle {
    grid-template-columns: minmax(0, 1fr) 48px;
    min-height: 56px;
    padding: 10px 12px;
  }
  .experience-inspector-toggle > span:first-child {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .exp-switch {
    justify-self: end;
  }
}

@media (max-width: 760px) {
  .property-guide-workspace {
    grid-template-columns: 1fr;
    gap: 12px;
  }
  .property-guide-nav {
    position: static;
    flex-direction: row;
    gap: 8px;
    overflow-x: auto;
    border-right: 0;
    border-bottom: 1px solid var(--line);
    padding: 0 0 10px;
    scrollbar-width: none;
  }
  .property-guide-nav::-webkit-scrollbar {
    display: none;
  }
  .property-guide-nav-item {
    flex: 0 0 auto;
    white-space: nowrap;
    border: 1px solid var(--line);
    background: var(--surface);
  }
  .property-guide-overview-grid,
  .property-guide-check-grid {
    grid-template-columns: 1fr;
  }
  .property-guide-channel-table label {
    grid-template-columns: 1fr;
  }
  .property-guide-intro {
    align-items: stretch;
    flex-direction: column;
  }
  .property-guide-intro .ms-btn-ghost {
    width: 100%;
    justify-content: center;
  }
  .property-guide-intro-actions {
    width: 100%;
  }
  .property-guide-intro-actions .ms-btn-ghost {
    flex: 1 1 160px;
  }
  .property-guide-section-head {
    grid-template-columns: auto auto minmax(0, 1fr);
  }
  .property-guide-grip {
    display: none;
  }
  .property-guide-toggle {
    grid-column: 1;
    grid-row: 2;
    justify-content: flex-start;
  }
  .property-guide-title-input {
    grid-column: 3;
  }
  .property-guide-actions {
    grid-column: 2 / 4;
    grid-row: 2;
    justify-content: flex-end;
  }
  .property-guide-section-body {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 860px) {
  .property-guide-preview-backdrop {
    align-items: stretch;
    padding: 0;
  }
  .property-guide-preview-modal {
    max-width: 100vw;
    max-height: 100vh;
    border-radius: 0;
  }
  .property-guide-preview-shell {
    grid-template-columns: 1fr;
    min-height: 100vh;
  }
  .property-guide-preview-toolbar {
    border-right: 0;
    border-bottom: 1px solid var(--line);
    padding: 14px;
  }
  .guest-guide-preview-phone {
    width: 100%;
    max-height: none;
    min-height: calc(100vh - 78px);
    border: 0;
    border-radius: 0;
    box-shadow: none;
    padding: 14px;
  }
}

/* ─── Templates de messages ─────────────────────────────────────────────────── */

/* Canal pills */
.tpl-channel-pills { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 4px; }
.tpl-channel-pill {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 7px 16px; border-radius: 20px;
  border: 1.5px solid var(--line); background: transparent;
  color: var(--t2); font-size: 13px; font-weight: 500;
  cursor: pointer; transition: border-color .15s, color .15s, background .15s;
}
.tpl-channel-pill:hover { border-color: var(--accent); color: var(--accent); }
.tpl-channel-pill.active { background: var(--accent); border-color: var(--accent); color: #fff; }

/* Mode toggle Rédiger / Aperçu */
.tpl-mode-toggle {
  display: flex; gap: 2px; background: var(--surface-2);
  border-radius: 8px; padding: 3px; width: fit-content; margin-bottom: 8px;
}
.tpl-mode-btn {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 5px 14px; border-radius: 6px; font-size: 13px;
  border: none; background: none; color: var(--t2);
  cursor: pointer; font-weight: 500; transition: background .12s, color .12s;
}
.tpl-mode-btn.active {
  background: var(--surface); color: var(--t1);
  box-shadow: 0 1px 3px rgba(0,0,0,.08);
}

/* Barre de variables */
.tpl-var-toolbar { display: flex; flex-direction: column; gap: 6px; margin-bottom: 10px; }
.tpl-var-hint {
  display: flex; align-items: center; gap: 6px;
  font-size: 12px; color: var(--t4); margin-bottom: 4px;
}
.tpl-var-hint i { font-size: 11px; }
.tpl-var-group  {
  display: flex; flex-direction: row; align-items: baseline;
  flex-wrap: wrap; gap: 5px;
}
.tpl-var-group-label {
  font-size: 10.5px; font-weight: 700; color: var(--t4);
  text-transform: uppercase; letter-spacing: .06em;
  flex-shrink: 0; min-width: 80px;
}
.tpl-var-chips { display: flex; flex-wrap: wrap; gap: 4px; flex: 1; }
.tpl-var-chip {
  font-size: 12px; padding: 3px 10px; border-radius: 10px;
  border: 1px solid var(--line); background: var(--surface-2);
  color: var(--t2); cursor: pointer; font-family: var(--font, inherit);
  transition: background .12s, color .12s, border-color .12s;
}
.tpl-var-chip:hover { background: var(--accent-soft); color: var(--accent); border-color: var(--accent); }

/* Textarea corps du message */
.tpl-body-textarea {
  width: 100%; min-height: 220px; resize: vertical;
}

/* Aperçu rendu */
.tpl-preview-box {
  background: var(--surface-2); border: 1px solid var(--line);
  border-radius: 10px; padding: 18px 20px; margin-top: 12px;
  font-size: 14px; line-height: 1.8; color: var(--t1);
  min-height: 80px; word-break: break-word;
}
.tpl-preview-empty {
  font-size: 13px; color: var(--t4); font-style: italic;
}
mark.tpl-preview-var {
  background: var(--accent-soft); color: var(--accent);
  border-radius: 4px; padding: 1px 5px; font-size: 12px;
  font-weight: 600; font-style: normal;
}
mark.tpl-preview-unknown {
  background: rgba(239,68,68,.1); color: #EF4444;
}

/* Liste des templates */
.tpl-item {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 16px; cursor: pointer;
  border-bottom: 1px solid var(--line); transition: background .12s;
}
.tpl-item:hover   { background: var(--surface-2); }
.tpl-item.is-active { background: var(--accent-soft); }
.tpl-item-inactive .tpl-item-name,
.tpl-item-inactive .tpl-item-meta { opacity: .45; }

/* Toggle actif/inactif — dans la liste et dans le formulaire */
.tpl-item-toggle {
  flex-shrink: 0; padding: 4px; cursor: pointer;
  display: flex; align-items: center;
}
.tpl-active-toggle {
  display: inline-flex; align-items: center; gap: 7px;
  cursor: pointer; flex-shrink: 0; user-select: none;
}
.tpl-toggle-label {
  font-size: 12px; font-weight: 500; color: var(--t3);
}
.tpl-toggle-track {
  width: 32px; height: 18px; border-radius: 9px;
  background: var(--line-strong); position: relative; display: block;
  transition: background .2s; flex-shrink: 0;
}
.tpl-toggle-track.is-on { background: var(--accent); }
.tpl-toggle-thumb {
  position: absolute; top: 2px; left: 2px;
  width: 14px; height: 14px; border-radius: 7px;
  background: #fff; box-shadow: 0 1px 3px rgba(0,0,0,.25);
  transition: transform .2s;
}
.tpl-toggle-track.is-on .tpl-toggle-thumb { transform: translateX(14px); }

.tpl-item-icon {
  width: 36px; height: 36px; border-radius: 10px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center; font-size: 15px;
}
.tpl-item-name {
  font-size: 14px; font-weight: 600; color: var(--t1);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.tpl-item-meta { font-size: 12px; color: var(--t3); margin-top: 2px; }

/* En-tête template (avatar canal) */
.tpl-header-avatar {
  width: 40px; height: 40px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 16px; flex-shrink: 0;
}

/* État vide */
.tpl-empty {
  display: flex; flex-direction: column; align-items: center;
  justify-content: center; padding: 48px 24px;
  text-align: center; color: var(--t3); gap: 10px;
}
.tpl-empty i  { font-size: 34px; color: var(--t4); }
.tpl-empty p  { font-size: 14px; margin: 0; line-height: 1.65; }

/* ── Template : sélecteur de logements ─────────────────────────────────────── */
.tpl-property-list { display: flex; flex-direction: column; gap: 6px; }

.tpl-prop-check {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 12px; border-radius: 10px;
  border: 1.5px solid var(--line); cursor: pointer;
  transition: background .12s, border-color .12s;
  user-select: none;
}
.tpl-prop-check:hover  { background: var(--surface-2); border-color: var(--accent); }
.tpl-prop-check.is-checked { background: var(--accent-soft); border-color: var(--accent); }

.tpl-prop-check-box {
  width: 18px; height: 18px; border-radius: 5px; flex-shrink: 0;
  border: 1.5px solid var(--line-strong); background: var(--surface);
  display: flex; align-items: center; justify-content: center;
  font-size: 10px; color: var(--accent); transition: border-color .12s, background .12s;
}
.tpl-prop-check.is-checked .tpl-prop-check-box {
  background: var(--accent); border-color: var(--accent); color: #fff;
}

.tpl-prop-avatar {
  width: 28px; height: 28px; border-radius: 7px; flex-shrink: 0;
  object-fit: cover;
}
.tpl-prop-avatar-letter {
  display: flex; align-items: center; justify-content: center;
  background: var(--surface-3); color: var(--t2);
  font-size: 12px; font-weight: 700;
}

.tpl-prop-check-name { font-size: 13px; font-weight: 600; color: var(--t1); flex: 1; }
.tpl-prop-check-meta { font-size: 12px; color: var(--t3); }

/* Chip personnalisé — same visual as regular chips (no orange differentiation) */
.tpl-var-chip-custom {
  /* intentionally inherits .tpl-var-chip styles unchanged */
}
.tpl-var-chip-custom:hover {
  background: var(--accent-soft); color: var(--accent); border-color: var(--accent);
  border-color: var(--accent);
}

/* Note vide dans la barre de variables */
.tpl-var-empty-note {
  font-size: 12px; color: var(--t4); margin: 2px 0 0; font-style: italic;
}

/* ── Trigger delay row ─────────────────────────────────────── */
.tpl-time-row {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.tpl-time-item {
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex: 1;
  min-width: 90px;
}
.tpl-time-item > span {
  font-size: 12px;
  color: var(--t3);
  font-weight: 500;
}
.tpl-time-item input {
  text-align: center;
}

/* ── Platform list ─────────────────────────────────────────── */
.tpl-platform-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.tpl-platform-check {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 7px 13px;
  border: 1.5px solid var(--line-strong);
  border-radius: 8px;
  cursor: pointer;
  font-size: 13px;
  font-weight: 500;
  color: var(--t2);
  transition: border-color .15s, background .15s, color .15s;
  user-select: none;
}
.tpl-platform-check:hover {
  border-color: var(--accent);
  background: var(--accent-soft);
}
.tpl-platform-check.is-checked {
  border-color: var(--accent);
  background: var(--accent-soft);
}

/* ── HTML Editor ───────────────────────────────────────────── */
.tpl-html-tabs {
  display: flex;
  gap: 4px;
  margin-bottom: 6px;
}
.tpl-html-tab {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 13px;
  border: 1.5px solid var(--line-strong);
  border-radius: 7px;
  background: transparent;
  color: var(--t2);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: all .15s;
}
.tpl-html-tab i { font-size: 12px; }
.tpl-html-tab.active {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}
/* Wrapper unique toolbar + canvas — porte le contour */
.tpl-html-editor-box {
  border: 1px solid var(--line-strong);
  border-radius: 8px;
  overflow: hidden;
  transition: border-color .15s, box-shadow .15s;
}
.tpl-html-editor-box:focus-within {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-ring);
}
.tpl-html-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 1px;
  padding: 5px 7px;
  background: var(--surface-2);
  border-bottom: 1px solid var(--line-strong);
}
.tpl-html-toolbar button {
  width: 28px;
  height: 28px;
  border: none;
  background: transparent;
  color: var(--t2);
  border-radius: 5px;
  cursor: pointer;
  display: grid;
  place-items: center;
  font-size: 12px;
  transition: background .1s, color .1s;
}
.tpl-html-toolbar button:hover {
  background: var(--surface-3);
  color: var(--t1);
}
.tpl-html-sep {
  display: inline-block;
  width: 1px;
  height: 18px;
  background: var(--line-strong);
  align-self: center;
  margin: 0 3px;
  border-radius: 1px;
}
.tpl-html-canvas {
  min-height: 150px;
  padding: 12px 14px;
  font-size: 14px;
  line-height: 1.6;
  color: var(--t1);
  background: var(--surface);
  outline: none;
  cursor: text;
}
.tpl-html-canvas h2 { font-size: 1.15em; font-weight: 700; margin: .5em 0; }
.tpl-html-canvas p  { margin: .4em 0; }
.tpl-html-canvas ul, .tpl-html-canvas ol { padding-left: 1.5em; margin: .4em 0; }
.tpl-html-canvas a  { color: var(--blue); text-decoration: underline; }
.tpl-html-source {
  display: block;
  width: 100%;
  border: 1px solid var(--line-strong);
  border-radius: 8px;
  padding: 10px 12px;
  font-family: 'Courier New', Courier, monospace;
  font-size: 12.5px;
  line-height: 1.5;
  color: var(--t1);
  background: var(--surface);
  resize: vertical;
  box-sizing: border-box;
}
.tpl-html-source:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-ring);
}

/* ── Dual preview (email) ──────────────────────────────────── */
.tpl-preview-dual {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}
@media (max-width: 700px) {
  .tpl-preview-dual { grid-template-columns: 1fr; }
}
.tpl-preview-col { display: flex; flex-direction: column; gap: 6px; }
.tpl-preview-subtitle {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--t3);
}
.tpl-preview-body {
  font-size: 13.5px;
  line-height: 1.65;
  color: var(--t1);
}

/* ── Trigger badge in list item ────────────────────────────── */
.tpl-item-trigger {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  font-weight: 500;
}
.tpl-item-trigger i { font-size: 10px; }

/* ── Platform OTA logo image ── */
.tpl-plat-img {
  width: 20px;
  height: 20px;
  object-fit: contain;
  border-radius: 4px;
  flex-shrink: 0;
  display: block;
}

/* ── Section sublabel (inside form field) ── */
.tpl-section-label {
  font-size: 12px;
  font-weight: 600;
  color: var(--t2);
  margin-bottom: 5px;
  margin-top: 2px;
}
.tpl-section-label-hint {
  font-weight: 400;
  color: var(--t4);
}

/* ── Sélecteur de couleur (position:fixed, affiché par le JS) ──────────── */
.tpl-color-panel {
  position: fixed; z-index: 600;
  background: var(--surface); border: 1px solid var(--line-strong);
  border-radius: 10px; padding: 8px;
  box-shadow: 0 4px 20px rgba(0,0,0,.15);
  display: flex; flex-wrap: wrap; gap: 5px; width: 162px;
}
.tpl-color-panel[hidden] { display: none; }
.tpl-color-swatch {
  width: 22px; height: 22px; border-radius: 50%;
  border: 2px solid transparent; cursor: pointer; flex-shrink: 0;
  transition: transform .1s, border-color .1s;
}
.tpl-color-swatch:hover { transform: scale(1.2); border-color: rgba(0,0,0,.3); }

/* ── Popup insertion de lien ───────────────────────────────────────────── */
.tpl-link-popup {
  position: fixed; inset: 0; z-index: 700;
  display: flex; align-items: center; justify-content: center;
  background: rgba(0,0,0,.35); backdrop-filter: blur(2px);
}
.tpl-link-popup[hidden] { display: none; }
.tpl-link-popup-inner {
  background: var(--surface); border-radius: 14px;
  padding: 22px 24px; width: 340px; max-width: calc(100vw - 32px);
  box-shadow: 0 8px 32px rgba(0,0,0,.22);
  display: flex; flex-direction: column; gap: 14px;
}
.tpl-link-popup-title {
  font-size: 15px; font-weight: 700; color: var(--t1);
  display: flex; align-items: center; gap: 8px;
}
.tpl-link-popup-title i { color: var(--accent); }
.tpl-link-popup-input {
  width: 100%; padding: 9px 12px; border-radius: 8px;
  border: 1.5px solid var(--line-strong); background: var(--surface-2);
  font-size: 14px; color: var(--t1); outline: none;
  transition: border-color .15s, box-shadow .15s;
}
.tpl-link-popup-input:focus {
  border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-ring);
}
.tpl-link-popup-actions {
  display: flex; gap: 8px; justify-content: flex-end;
}

/* ── Conditions d'envoi ────────────────────────────────────────────────── */
.tpl-cond-count-badge {
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--accent); color: #fff;
  font-size: 10px; font-weight: 700; border-radius: 10px;
  min-width: 18px; height: 18px; padding: 0 5px;
  margin-left: 6px; vertical-align: middle;
}

.tpl-cond-list {
  display: flex; flex-direction: column; gap: 6px; margin-bottom: 10px;
}

.tpl-cond-empty {
  font-size: 12.5px; color: var(--t4); font-style: italic;
  display: flex; align-items: center; gap: 6px;
  padding: 10px 12px; background: var(--surface-2);
  border-radius: 8px; border: 1px dashed var(--line-strong);
  margin: 0;
}
.tpl-cond-empty i { font-size: 11px; flex-shrink: 0; }

.tpl-cond-row {
  display: flex; align-items: center; gap: 6px;
  background: var(--surface-2); border: 1px solid var(--line-strong);
  border-radius: 9px; padding: 6px 8px;
  animation: cond-in .15s ease;
}
@keyframes cond-in { from { opacity: 0; transform: translateY(-4px); } to { opacity: 1; transform: none; } }

.tpl-cond-selects {
  display: flex; gap: 6px; flex: 1; flex-wrap: wrap; align-items: center;
}

.tpl-cond-select {
  flex: 1; min-width: 0;
  height: 32px; padding: 0 8px; border-radius: 7px;
  border: 1px solid var(--line-strong); background: var(--surface);
  font-size: 13px; color: var(--t1); cursor: pointer;
  appearance: auto;
}
.tpl-cond-select:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 2px var(--accent-ring); }
.tpl-cond-select-op  { flex: 0 0 auto; min-width: 110px; }
.tpl-cond-select-val { flex: 0 0 auto; min-width: 120px; }

.tpl-cond-input {
  width: 70px; height: 32px; padding: 0 8px; border-radius: 7px;
  border: 1px solid var(--line-strong); background: var(--surface);
  font-size: 13px; color: var(--t1); text-align: center;
}
.tpl-cond-input:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 2px var(--accent-ring); }

.tpl-cond-remove {
  flex-shrink: 0; width: 26px; height: 26px; border-radius: 6px;
  border: none; background: transparent; color: var(--t4);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; font-size: 12px;
  transition: background .1s, color .1s;
}
.tpl-cond-remove:hover { background: rgba(239,68,68,.1); color: #EF4444; }

.tpl-cond-add-btn {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 13px; font-weight: 500; color: var(--accent);
  background: transparent; border: 1.5px dashed var(--accent);
  border-radius: 8px; padding: 6px 14px; cursor: pointer;
  transition: background .12s, color .12s;
}
.tpl-cond-add-btn:hover { background: var(--accent-soft); }
.tpl-cond-add-btn i { font-size: 11px; }

[data-tpl-split] {
  height: 100%;
  min-height: 0;
  overflow: hidden;
}

[data-tpl-split] .page-split-list {
  height: 100%;
  min-height: 0;
  overflow: hidden;
}

[data-tpl-split] .page-split-list-body {
  min-height: 0;
  overflow-y: auto;
}

[data-tpl-split] .page-split-detail {
  min-height: 0;
  overflow-y: auto;
}

.tpl-detail-empty {
  min-height: 360px;
  text-align: center;
}

.tpl-detail-empty p {
  margin: 0;
}

[data-tpl-workspace] {
  padding-bottom: 0;
}

[data-tpl-form] {
  min-height: 100%;
}

.tpl-action-bar.ms-action-bar {
  -webkit-backdrop-filter: none;
  align-items: center;
  backdrop-filter: none;
  background: transparent;
  border: 0;
  border-top: 1px solid var(--line);
  border-radius: 0;
  bottom: auto;
  box-shadow: none;
  margin: 0;
  padding: 14px 18px;
  position: static;
  width: 100%;
}

[data-theme="dark"] .tpl-action-bar.ms-action-bar {
  background: transparent;
  box-shadow: none;
}

.tpl-message-modal .app-modal-title {
  margin-bottom: 8px;
}

.tpl-action-bar .ms-btn-primary,
.tpl-action-bar .ms-btn-ghost {
  border-radius: 999px;
  font-size: 14px;
  font-weight: 700;
  min-height: 42px;
  padding: 0 18px;
}

/* Properties: navigation laterale et footer d'actions */
.property-detail-form.ms-detail-content {
  align-items: start;
  display: grid;
  gap: 14px 20px;
  grid-template-columns: 182px minmax(0, 820px);
  max-width: 1042px;
  padding-bottom: 0;
}

.property-detail-form.ms-detail-content > :not(.property-tabs) {
  grid-column: 2;
  min-width: 0;
  width: 100%;
}

.property-detail-form.ms-detail-content > .property-tabs {
  -webkit-backdrop-filter: none;
  align-items: stretch;
  align-self: start;
  backdrop-filter: none;
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  display: flex;
  flex-direction: column;
  gap: 4px;
  grid-column: 1;
  grid-row: 1 / span 50;
  margin: 0;
  max-height: calc(100vh - 118px);
  overflow: auto;
  padding: 2px 0;
  position: sticky;
  scrollbar-width: thin;
  top: 18px;
  z-index: 10;
}

.page-split.prop-mode .pg-search {
  margin: 0 14px 10px;
}

.page-split.prop-mode .pg-prop-list {
  margin: 0;
  padding: 0 14px 12px;
}

.page-split.prop-mode .pg-prop-list .prop-group-section {
  padding-left: 0;
  padding-right: 0;
}

.page-split.prop-mode .pg-prop-list .prop-group-section-title {
  padding-left: 4px;
  padding-right: 4px;
}

.page-split.prop-mode .pg-prop-row.ms-prop-list-item {
  border-bottom: 0;
  width: 100%;
}

.page-split.prop-mode .pg-search i {
  color: var(--t4);
  left: 11px;
  font-size: 12px;
}

.page-split.prop-mode .pg-search input {
  background: var(--surface-2);
  border: 1px solid var(--line-strong);
  border-radius: 9px;
  color: var(--t1);
  font: inherit;
  font-size: 13px;
  height: 36px;
  outline: none;
  padding: 0 12px 0 32px;
  transition: border-color .13s, background .13s;
}

.page-split.prop-mode .pg-search input:focus {
  background: var(--surface);
  border-color: var(--accent);
}

.property-detail-form.ms-detail-content > .property-tabs .property-tab,
.property-detail-form.ms-detail-content > .property-tabs .property-detail-subtab {
  align-items: center;
  background: transparent;
  border: 0;
  border-radius: 8px;
  box-shadow: none;
  color: var(--t3);
  cursor: pointer;
  display: flex;
  font-family: inherit;
  font-size: 13px;
  font-weight: 650;
  gap: 8px;
  justify-content: flex-start;
  min-height: 32px;
  padding: 0 9px;
  text-align: left;
  white-space: normal;
  width: 100%;
}

.property-detail-form.ms-detail-content > .property-tabs .property-tab:hover,
.property-detail-form.ms-detail-content > .property-tabs .property-detail-subtab:hover {
  background: rgba(12, 12, 16, 0.05);
  color: var(--t1);
}

.property-detail-form.ms-detail-content > .property-tabs .property-tab.active,
.property-detail-form.ms-detail-content > .property-tabs .property-tab.is-on,
.property-detail-form.ms-detail-content > .property-tabs .property-detail-subtab.active {
  background: transparent;
  color: var(--t1);
  font-weight: 850;
}

.property-detail-subnav {
  border-left: 1px solid var(--line);
  display: grid;
  gap: 2px;
  margin: 0 0 6px 13px;
  padding-left: 10px;
}

.property-detail-subtab {
  line-height: 1.2;
}

.property-money-field {
  align-items: stretch;
  display: flex;
  min-width: 0;
}

.property-money-field .ms-field-input {
  border-radius: 10px 0 0 10px;
  flex: 1;
  min-width: 0;
}

.property-currency-addon {
  align-items: center;
  background: var(--surface-3);
  border: 1px solid var(--line-strong);
  border-left: 0;
  border-radius: 0 10px 10px 0;
  color: var(--t2);
  display: inline-flex;
  font-size: 12.5px;
  font-weight: 700;
  justify-content: center;
  min-width: 66px;
  padding: 0 12px;
}

.property-deposit-amount-field {
  max-width: 420px;
}

.property-deposit-platforms {
  border-top: 1px solid var(--line);
  margin-top: 18px;
  padding-top: 18px;
}

.property-deposit-platform-list {
  display: grid;
  gap: 10px;
}

.property-deposit-platform {
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 12px;
}

.property-deposit-toggle-row.perm-toggle-row {
  background: transparent;
  border: 0;
  border-radius: 0;
  padding: 0;
}

.property-deposit-platform-name {
  align-items: center;
  display: flex;
  gap: 9px;
  min-width: 0;
}

.property-deposit-platform-logo {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 6px;
  flex: 0 0 auto;
  height: 22px;
  object-fit: contain;
  padding: 2px;
  width: 22px;
}

.property-deposit-platform-logo.is-fallback {
  align-items: center;
  color: var(--t3);
  display: inline-flex;
  font-size: 11px;
  font-weight: 800;
  justify-content: center;
}

.property-deposit-platform-note {
  color: var(--t3);
  font-size: 12px;
  font-weight: 500;
}

.property-deposit-override-row {
  align-items: center;
  color: var(--t3);
  cursor: pointer;
  display: inline-flex;
  font-size: 12.5px;
  gap: 7px;
  margin-top: 10px;
}

.property-deposit-override-row input {
  --cb-accent: var(--accent);
  height: 14px;
  margin: 0;
  width: 14px;
}

.property-deposit-override-row input:disabled + span {
  opacity: 0.45;
}

.property-deposit-platform-amount {
  margin-top: 8px;
  max-width: 280px;
}

.property-amenities-card .ms-card-head {
  align-items: center;
}

.property-amenities-card .ms-card-head .tag {
  margin-left: auto;
  white-space: nowrap;
}

.property-amenities-toolbar {
  align-items: center;
  display: flex;
  gap: 10px;
  margin-bottom: 14px;
}

.property-amenities-search {
  align-items: center;
  background: var(--surface-2);
  border: 1px solid var(--line-strong);
  border-radius: 10px;
  display: flex;
  flex: 1 1 auto;
  gap: 8px;
  min-height: 40px;
  min-width: 0;
  padding: 0 12px;
}

.property-amenities-search i {
  color: var(--t4);
  font-size: 13px;
}

.property-amenities-search input {
  background: transparent;
  border: 0;
  color: var(--t1);
  flex: 1;
  font: inherit;
  font-size: 13px;
  min-width: 0;
  outline: 0;
}

.property-description-fields {
  display: grid;
  gap: 14px;
}

.property-description-field {
  position: relative;
}

.property-description-field .ms-textarea {
  min-height: 112px;
  resize: vertical;
}

.property-description-counter {
  align-self: flex-end;
  color: var(--t4);
  font-size: 11.5px;
  font-weight: 650;
  margin-top: 4px;
}

.property-quality-card {
  display: grid;
  gap: 10px;
  padding: 16px;
}

.property-quality-head {
  align-items: flex-start;
  display: flex;
  gap: 14px;
  justify-content: space-between;
}

.property-quality-eyebrow {
  color: var(--t3);
  display: block;
  font-size: 11px;
  font-weight: 750;
  letter-spacing: .04em;
  margin-bottom: 3px;
  text-transform: uppercase;
}

.property-quality-head h3 {
  color: var(--t1);
  font-size: 15px;
  margin: 0;
}

.property-quality-score {
  align-items: center;
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--t1);
  display: inline-flex;
  font-size: 13px;
  font-weight: 800;
  min-height: 34px;
  padding: 0 12px;
}

.property-quality-progress {
  background: var(--surface-3);
  border-radius: 999px;
  height: 8px;
  overflow: hidden;
}

.property-quality-progress span {
  background: var(--accent);
  border-radius: inherit;
  display: block;
  height: 100%;
  transition: width .18s ease;
  width: 0;
}

.property-quality-card:not(.is-open) .property-quality-progress {
  display: none;
}

.property-quality-list {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
}

.property-quality-item {
  align-items: center;
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 10px;
  color: inherit;
  cursor: pointer;
  display: grid;
  font: inherit;
  gap: 10px;
  grid-template-columns: 28px minmax(0, 1fr) auto;
  min-width: 0;
  padding: 10px;
  text-align: left;
  transition: background .15s ease, border-color .15s ease, transform .15s ease;
  width: 100%;
}

.property-quality-item:hover {
  background: var(--surface);
  border-color: var(--line-strong);
  transform: translateY(-1px);
}

.property-quality-icon {
  align-items: center;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 50%;
  color: var(--t3);
  display: inline-flex;
  height: 28px;
  justify-content: center;
  width: 28px;
}

.property-quality-item strong {
  color: var(--t1);
  display: block;
  font-size: 12.5px;
}

.property-quality-item small {
  color: var(--t3);
  display: block;
  font-size: 11px;
  line-height: 1.3;
  margin-top: 2px;
}

.property-quality-item em {
  border-radius: 999px;
  font-size: 10px;
  font-style: normal;
  font-weight: 800;
  padding: 4px 7px;
  white-space: nowrap;
}

.property-quality-item.ok .property-quality-icon,
.property-quality-item.ok em {
  background: rgba(46, 204, 113, .13);
  border-color: rgba(46, 204, 113, .28);
  color: #1E9B57;
}

.property-quality-item.warn .property-quality-icon,
.property-quality-item.warn em {
  background: rgba(245, 135, 77, .14);
  border-color: rgba(245, 135, 77, .28);
  color: var(--accent-2);
}

.property-quality-item.missing .property-quality-icon,
.property-quality-item.missing em {
  background: rgba(239, 68, 68, .12);
  border-color: rgba(239, 68, 68, .24);
  color: #D33F3F;
}

.property-quality-mobile-toggle {
  align-items: center;
  background: transparent;
  border: 0;
  color: var(--t1);
  cursor: pointer;
  display: grid;
  font: inherit;
  gap: 10px;
  grid-template-columns: minmax(0, 1fr) auto auto;
  padding: 0;
  text-align: left;
  width: 100%;
}

.property-quality-mobile-toggle span {
  font-size: 15px;
  font-weight: 750;
}

.property-quality-mobile-toggle strong {
  background: var(--accent-soft);
  border: 1px solid var(--accent-ring);
  border-radius: 999px;
  color: var(--accent-2);
  font-size: 12.5px;
  padding: 5px 9px;
}

.property-quality-mobile-toggle i {
  color: var(--t3);
  font-size: 13px;
  transition: transform .15s ease;
}

.property-quality-mobile.is-open .property-quality-mobile-toggle i {
  transform: rotate(180deg);
}

.property-quality-card.is-open .property-quality-mobile-toggle i {
  transform: rotate(180deg);
}

.property-quality-mobile {
  display: none;
}

@media (max-width: 640px) {
  .page-split.prop-mode[data-prop-panel="tabs"] .property-quality-mobile:not([hidden]) {
    display: grid;
  }
  .pg-loc-grid .pg-fields-row,
  .pg-loc-grid .pg-fields-row.cols-3 {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  }
}

.property-measure-field {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 112px;
}

.property-pricing-stack {
  display: grid;
  gap: 16px;
}

#property-section-booking .property-context-panel:nth-of-type(4) {
  display: none;
}

.property-pricing-stack .property-context-panel {
  display: grid;
  gap: 14px;
}

.property-pricing-stack .property-context-title {
  margin-bottom: 0;
}

.property-pricing-stack .property-mini-grid {
  gap: 14px;
}

.property-channel-pricing-grid,
.property-extras-grid {
  display: grid;
  gap: 12px;
  grid-template-columns: minmax(0, 1fr);
}

.property-pricing-channel-row {
  align-items: center;
  background: var(--surface-soft);
  border: 1px solid var(--line);
  border-radius: 14px;
  display: grid;
  gap: 12px;
  grid-template-columns: minmax(150px, .75fr) minmax(260px, 1fr);
  padding: 12px;
}

.property-pricing-channel-name {
  align-items: center;
  display: flex;
  gap: 8px;
}

.property-pricing-channel-name .property-channel-logo {
  flex: 0 0 auto;
}

.property-adjustment-field {
  display: grid;
  grid-template-columns: 70px minmax(0, 1fr) 108px;
}

.property-adjustment-field .ms-field-input:first-child {
  border-bottom-right-radius: 0;
  border-top-right-radius: 0;
}

.property-adjustment-field .ms-field-input:nth-child(2) {
  border-bottom-left-radius: 0;
  border-left: 0;
  border-top-left-radius: 0;
  border-bottom-right-radius: 0;
  border-top-right-radius: 0;
}

.property-adjustment-unit-select {
  border-bottom-left-radius: 0;
  border-left: 0;
  border-top-left-radius: 0;
}

.property-extras-list {
  display: grid;
  gap: 10px;
}

.property-extra-row {
  align-items: center;
  background: var(--surface-soft);
  border: 1px solid var(--line);
  border-radius: 14px;
  display: grid;
  gap: 12px;
  grid-template-columns: 68px minmax(0, 1.3fr) minmax(130px, .55fr) minmax(170px, .7fr) auto;
  padding: 12px;
}

.property-extra-card {
  cursor: pointer;
  transition: background .15s, border-color .15s, box-shadow .15s, transform .12s;
}

.property-extra-card:hover,
.property-extra-card:focus-visible {
  background: var(--surface);
  border-color: var(--accent-ring);
  box-shadow: 0 8px 22px rgba(12, 12, 16, .06);
  outline: 0;
}

.property-extra-thumb {
  align-items: center;
  background: var(--accent-soft);
  border: 1px solid var(--line);
  border-radius: 14px;
  color: var(--accent);
  display: flex;
  height: 58px;
  justify-content: center;
  overflow: hidden;
  width: 58px;
}

.property-extra-thumb img {
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.property-extra-main {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.property-extra-main strong {
  color: var(--t1);
  font-size: 14px;
  line-height: 1.2;
}

.property-extra-main small,
.property-extra-meta small {
  color: var(--t3);
  font-size: 12px;
  line-height: 1.3;
}

.property-extra-meta {
  display: grid;
  gap: 4px;
}

.property-extra-meta span {
  color: var(--t1);
  font-size: 14px;
  font-weight: 800;
}

.property-extra-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.property-extra-badges span {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--t2);
  font-size: 11px;
  font-weight: 750;
  padding: 5px 8px;
}

.property-extra-actions {
  display: flex;
  gap: 6px;
  justify-content: flex-end;
}

.property-extra-edit,
.property-extra-remove {
  height: 44px;
  min-width: 44px;
  padding: 0 14px;
}

.property-extra-edit {
  color: var(--t2);
}

.property-extra-add {
  justify-self: start;
  margin-top: 10px;
}

.property-extra-section-head {
  align-items: center;
  display: flex;
  gap: 12px;
  justify-content: space-between;
}

.property-extra-copy {
  flex-shrink: 0;
}

.property-extra-modal {
  max-width: 860px;
  padding: 0;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  max-height: calc(100vh - 40px);
}

.property-extra-modal .property-photo-modal-head {
  flex-shrink: 0;
}

.property-extra-modal .app-modal-actions {
  border-top: 1px solid var(--line);
  flex-shrink: 0;
  padding: 14px 20px 18px;
}

.property-extra-modal-body {
  display: grid;
  gap: 18px;
  grid-template-columns: 230px minmax(0, 1fr);
  padding: 18px 20px;
  overflow-y: auto;
  min-height: 0;
  flex: 1 1 auto;
}

.property-extra-photo-editor {
  align-content: start;
  display: grid;
  gap: 10px;
}

.property-extra-photo-preview {
  align-items: center;
  aspect-ratio: 1 / 1;
  background: var(--surface-2);
  border: 1px dashed var(--line-strong);
  border-radius: 18px;
  color: var(--accent);
  display: flex;
  font-size: 28px;
  justify-content: center;
  overflow: hidden;
}

.property-extra-photo-preview img {
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.property-extra-photo-remove {
  color: #ef4444;
}

.property-extra-modal-fields {
  display: grid;
  gap: 12px;
}

.property-extra-modal-toggle {
  margin: 0;
}

.property-extra-copy-modal {
  max-width: 760px;
  padding: 0;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  max-height: calc(100vh - 40px);
}

.property-extra-copy-modal .property-photo-modal-head {
  flex-shrink: 0;
}

.property-extra-copy-modal .app-modal-actions {
  border-top: 1px solid var(--line);
  flex-shrink: 0;
  padding: 14px 20px 18px;
}

.property-extra-copy-body {
  display: grid;
  gap: 18px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  padding: 18px 20px;
  overflow-y: auto;
  min-height: 0;
  flex: 1 1 auto;
}

.property-extra-copy-title {
  color: var(--t3);
  font-size: 11px;
  font-weight: 850;
  letter-spacing: .05em;
  margin-bottom: 10px;
  text-transform: uppercase;
}

.property-extra-copy-list {
  border: 1px solid var(--line);
  border-radius: 14px;
  display: grid;
  max-height: 290px;
  overflow-y: auto;
}

.property-extra-copy-check {
  align-items: center;
  border-bottom: 1px solid var(--line);
  cursor: pointer;
  display: grid;
  gap: 10px;
  grid-template-columns: auto minmax(0, 1fr);
  padding: 11px 12px;
}

.property-extra-copy-check:last-child {
  border-bottom: 0;
}

.property-extra-copy-check span {
  display: grid;
  gap: 3px;
  min-width: 0;
}

.property-extra-copy-check strong {
  color: var(--t1);
  font-size: 13px;
}

.property-extra-copy-check small {
  color: var(--t3);
  font-size: 12px;
}

.property-extra-copy-terms {
  grid-column: 1 / -1;
  margin: 0;
}

.property-empty-inline {
  border: 1px dashed var(--line-strong);
  border-radius: 12px;
  color: var(--t4);
  padding: 14px;
}

/* ---- Marge extra (modale + cartes) ---- */
.property-extra-margin {
  align-items: center;
  background: var(--accent-soft);
  border: 1px solid var(--accent-ring);
  border-radius: 10px;
  color: var(--accent-2);
  display: flex;
  font-size: 12.5px;
  gap: 8px;
  padding: 9px 12px;
}
.property-extra-margin strong { font-weight: 800; }
.property-extra-margin.is-negative {
  background: rgba(239, 68, 68, 0.08);
  border-color: rgba(239, 68, 68, 0.35);
  color: #ef4444;
}
.property-extra-badge-margin { font-weight: 700; }
.property-extra-badge-margin.is-negative { color: #ef4444; }

/* ---- Extras voyageur : étiquette de groupe ---- */
.guest-extras-group-label {
  margin: 18px 0 6px;
  padding: 0 2px;
}
.guest-extras-group-label em {
  color: var(--t3);
  font-size: 11.5px;
  font-style: italic;
  font-weight: 600;
  letter-spacing: .03em;
  text-transform: uppercase;
}
.guest-extras-group-label:first-child { margin-top: 0; }
.guest-extras-sep { border-top: 1px solid var(--line); margin: 12px 0; }

/* ---- Extra check : variante radio (round) ---- */
.guest-extra-check.is-radio { border-radius: 50%; }
.guest-extra-check.is-radio.on {
  background: radial-gradient(circle, #fff 32%, var(--accent) 33%);
  border-color: var(--accent);
}
[data-theme="dark"] .guest-extra-check.is-radio.on {
  background: radial-gradient(circle, var(--surface) 32%, var(--accent) 33%);
  border-color: var(--accent);
}

/* ---- Affichage des rubriques : visual cards ---- */
.exp-display-cards-row { display: flex; gap: 10px; }
.exp-display-card {
  background: var(--surface-2);
  border: 2px solid var(--line);
  border-radius: 12px;
  cursor: pointer;
  padding: 12px 16px 10px;
  text-align: center;
  transition: border-color .15s, background .15s;
  min-width: 88px;
}
.exp-display-card:hover { border-color: var(--line-strong); }
.exp-display-card.active { background: var(--accent-soft); border-color: var(--accent); }
.exp-display-preview { height: 42px; margin-bottom: 8px; display: flex; flex-direction: column; justify-content: center; gap: 5px; }
.exp-display-preview-list span {
  background: var(--line-strong);
  border-radius: 3px;
  display: block;
  height: 7px;
  width: 100%;
}
.exp-display-preview-list span:nth-child(2) { width: 80%; }
.exp-display-preview-list span:nth-child(3) { width: 65%; }
.exp-display-preview-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 4px; }
.exp-display-preview-cards span { background: var(--line-strong); border-radius: 5px; display: block; height: 18px; }
.exp-display-card em { color: var(--t3); font-size: 11.5px; font-style: normal; font-weight: 700; letter-spacing: .02em; text-transform: uppercase; }
.exp-display-card.active em { color: var(--accent); }

/* ---- Color picker accentuation guide ---- */
.exp-accent-row { align-items: center; display: flex; flex-wrap: wrap; gap: 8px; }
.exp-accent-chip {
  border: 3px solid transparent;
  border-radius: 50%;
  cursor: pointer;
  flex-shrink: 0;
  height: 28px;
  outline: none;
  transition: transform .12s, border-color .12s;
  width: 28px;
}
.exp-accent-chip:hover { transform: scale(1.15); }
.exp-accent-chip.active { border-color: var(--t1); transform: scale(1.12); }
.exp-accent-custom {
  align-items: center;
  background: var(--surface-2);
  border: 1.5px solid var(--line);
  border-radius: 50%;
  color: var(--t3);
  cursor: pointer;
  display: flex;
  font-size: 12px;
  height: 28px;
  justify-content: center;
  overflow: hidden;
  position: relative;
  width: 28px;
}
.exp-accent-custom input[type="color"] {
  border: none;
  cursor: pointer;
  height: 200%;
  left: -50%;
  opacity: 0;
  position: absolute;
  top: -50%;
  width: 200%;
}

/* ---- Powered by footer ---- */
.guest-powered-by {
  color: var(--t4);
  font-size: 10.5px;
  letter-spacing: .03em;
  padding: 12px 0 calc(12px + env(safe-area-inset-bottom));
  text-align: center;
}
.guest-powered-by a { color: inherit; text-decoration: none; }
.guest-powered-by a:hover { color: var(--t2); }

/* ---- Groupe extra — rangée de création inline ---- */
.extra-group-create-row {
  align-items: center;
  display: flex;
  gap: 6px;
  margin-top: 6px;
}
.extra-group-create-row .pg-input { flex: 1; min-width: 0; }
.extra-grp-btn {
  border-radius: 8px;
  flex-shrink: 0;
  font-size: 12px;
  height: 36px;
  padding: 0 10px;
}

/* ---- Simulateur de séjour ---- */
.property-sim-result { margin-top: 4px; }
.property-sim-lines {
  border: 1px solid var(--line);
  border-radius: 12px;
  overflow: hidden;
}
.property-sim-line {
  align-items: baseline;
  border-bottom: 1px solid var(--line);
  display: flex;
  font-size: 13px;
  gap: 12px;
  justify-content: space-between;
  padding: 10px 14px;
}
.property-sim-line:last-child { border-bottom: 0; }
.property-sim-line span { color: var(--t2); min-width: 0; }
.property-sim-line strong { color: var(--t1); flex-shrink: 0; font-weight: 700; }
.property-sim-line.is-muted span,
.property-sim-line.is-muted strong { color: var(--t4); }
.property-sim-line.is-onsite span,
.property-sim-line.is-onsite strong { color: var(--t3); }
.property-sim-total {
  align-items: baseline;
  background: var(--surface-2);
  border: 1px solid var(--line-strong);
  border-radius: 12px;
  display: flex;
  gap: 12px;
  justify-content: space-between;
  margin-top: 8px;
  padding: 12px 14px;
}
.property-sim-total span { color: var(--t1); font-size: 13px; font-weight: 750; }
.property-sim-total strong { color: var(--t1); font-size: 16px; font-weight: 850; letter-spacing: -0.01em; }
.property-sim-warning {
  align-items: center;
  background: rgba(239, 68, 68, 0.08);
  border: 1px solid rgba(239, 68, 68, 0.35);
  border-radius: 10px;
  color: #ef4444;
  display: flex;
  font-size: 12.5px;
  gap: 8px;
  margin-top: 8px;
  padding: 9px 12px;
}

.property-contract-body {
  display: grid;
  gap: 16px;
}

.property-contract-toggle {
  margin: 0;
}

.property-contract-editor textarea {
  font-family: inherit;
  line-height: 1.55;
  min-height: 430px;
  padding: 14px;
  resize: vertical;
}

.property-contract-tools {
  align-items: start;
  border-top: 1px solid var(--line);
  display: grid;
  gap: 14px;
  grid-template-columns: minmax(0, 1fr);
  padding-top: 14px;
}

.property-contract-var-toolbar {
  margin-bottom: 0;
}

.property-contract-tools > .ms-btn-ghost {
  justify-self: start;
}

@media (max-width: 700px) {
  .property-pricing-channel-row {
    grid-template-columns: minmax(0, 1fr);
  }

  .property-adjustment-field {
    grid-template-columns: 58px minmax(0, 1fr) 82px;
  }

  .property-extra-row {
    grid-template-columns: minmax(0, 1fr);
  }

  .property-extra-thumb {
    height: 72px;
    width: 100%;
  }

  .property-extra-actions {
    justify-content: flex-end;
  }

  .property-extra-remove {
    justify-self: end;
  }

  .property-extra-section-head {
    align-items: stretch;
    flex-direction: column;
  }

  .property-extra-copy,
  .property-extra-add {
    justify-content: center;
    width: 100%;
  }

  .property-extra-modal-body,
  .property-extra-copy-body {
    grid-template-columns: minmax(0, 1fr);
  }

  .property-extra-modal,
  .property-extra-copy-modal {
    max-height: calc(100vh - 24px);
  }

  .property-contract-editor textarea {
    min-height: 360px;
  }
}

.property-measure-field .ms-field-input:first-child {
  border-bottom-right-radius: 0;
  border-top-right-radius: 0;
}

.property-measure-field .ms-field-input:last-child {
  border-bottom-left-radius: 0;
  border-left: 0;
  border-top-left-radius: 0;
}

.property-amenity-categories {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 18px;
}

.property-amenity-category {
  background: var(--surface);
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  color: var(--t2);
  cursor: pointer;
  font-family: inherit;
  font-size: 13px;
  font-weight: 650;
  min-height: 34px;
  padding: 0 13px;
}

.property-amenity-category:hover {
  border-color: var(--t4);
  color: var(--t1);
}

.property-amenity-category.active {
  background: #0C0C10;
  border-color: #0C0C10;
  color: #fff;
}

[data-theme="dark"] .property-amenity-category.active {
  background: var(--surface-3);
  border-color: var(--line-strong);
  color: var(--t1);
}

.property-amenity-list {
  display: grid;
  gap: 18px;
}

.property-amenity-group {
  display: grid;
  gap: 10px;
}

.property-amenity-group-head {
  align-items: center;
  color: var(--t2);
  display: flex;
  font-size: 13px;
  font-weight: 800;
  gap: 8px;
}

.property-amenity-group-head i {
  color: var(--accent);
  width: 16px;
}

.property-amenity-grid {
  display: grid;
  gap: 9px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.property-amenity-item {
  align-items: center;
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 12px;
  cursor: pointer;
  display: flex;
  gap: 10px;
  min-height: 58px;
  padding: 10px 12px;
  transition: background .13s, border-color .13s, box-shadow .13s;
}

.property-amenity-item:hover {
  background: var(--surface);
  border-color: var(--line-strong);
}

.property-amenity-item input {
  opacity: 0;
  position: absolute;
  pointer-events: none;
}

.property-amenity-icon,
.property-amenity-check {
  align-items: center;
  border-radius: 9px;
  display: inline-flex;
  flex: 0 0 auto;
  justify-content: center;
}

.property-amenity-icon {
  background: var(--surface);
  border: 1px solid var(--line);
  color: var(--t3);
  height: 34px;
  width: 34px;
}

.property-amenity-copy {
  display: grid;
  flex: 1 1 auto;
  gap: 3px;
  min-width: 0;
}

.property-amenity-copy strong {
  color: var(--t1);
  font-size: 13.5px;
  font-weight: 550;
  line-height: 1.18;
}

.property-amenity-copy small {
  color: var(--t4);
  font-size: 11.5px;
  font-weight: 650;
}

.property-amenity-check {
  background: rgba(245, 135, 77, .12);
  color: var(--accent);
  height: 24px;
  opacity: 0;
  transform: scale(.86);
  transition: opacity .13s, transform .13s;
  width: 24px;
}

.property-amenity-item:has(input:checked) {
  background: rgba(245, 135, 77, .08);
  border-color: rgba(245, 135, 77, .42);
  box-shadow: inset 0 0 0 1px rgba(245, 135, 77, .14);
}

.property-amenity-item:has(input:checked) .property-amenity-icon {
  border-color: rgba(245, 135, 77, .28);
  color: var(--accent);
}

.property-amenity-item:has(input:checked) .property-amenity-check {
  opacity: 1;
  transform: scale(1);
}

.property-policy-stack {
  display: grid;
  gap: 14px;
}

.property-policy-toggle-grid {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 10px;
}

.property-policy-toggle-grid .toggle-line {
  align-items: center;
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 12px;
  display: flex !important;
  gap: 10px;
  justify-content: flex-start;
  margin: 0;
  min-height: 48px;
  padding: 10px 14px;
  position: relative;
}

.property-policy-toggle-grid .toggle-line > input {
  height: 1px;
  left: 0;
  opacity: 0;
  position: absolute;
  top: 0;
  width: 1px;
}

.property-policy-toggle-grid .toggle-line .pg-toggle-track {
  flex: 0 0 auto;
  margin-left: 0;
}

.property-policy-toggle-grid .toggle-line .pg-toggle-label {
  margin-left: 0;
}

.property-policy-group {
  display: grid;
  gap: 10px;
  margin-top: 12px;
}

.property-policy-group .property-policy-subtitle {
  margin: 0;
}

.property-policy-wide-toggle,
.property-policy-quiet-wrap {
  grid-column: 1 / -1;
}

.property-policy-quiet-wrap {
  display: grid;
  gap: 8px;
}

.property-policy-textarea {
  margin-top: 12px;
}

.property-policy-quiet-panel {
  background: rgba(245, 135, 77, .07);
  border: 1px solid rgba(245, 135, 77, .24);
  border-radius: 12px;
  padding: 12px;
}

.property-policy-quiet-title {
  color: var(--accent);
  font-size: 12.5px;
  font-weight: 800;
  margin-bottom: 10px;
}

.property-policy-quiet-hours {
  margin-top: 0;
}

.property-policy-subtitle {
  align-items: center;
  color: var(--t2);
  display: flex;
  font-size: 13px;
  font-weight: 800;
  gap: 8px;
  margin: 16px 0 8px;
}

.property-policy-subtitle:first-child {
  margin-top: 0;
}

.property-cancellation-help {
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 12px;
  display: grid;
  gap: 0;
  margin-top: 12px;
  overflow: hidden;
}

.property-cancellation-help > div {
  display: grid;
  gap: 3px;
  padding: 10px 12px;
}

.property-cancellation-help > div + div {
  border-top: 1px solid var(--line);
}

.property-cancellation-help strong {
  color: var(--t1);
  font-size: 13px;
  font-weight: 750;
}

.property-cancellation-help span {
  color: var(--t3);
  font-size: 12.5px;
  line-height: 1.35;
}

@media (max-width: 640px) {
  .property-deposit-amount-field,
  .property-deposit-platform-amount {
    max-width: none;
  }

  .property-amenities-card .ms-card-head {
    align-items: flex-start;
  }

  .property-amenities-card .ms-card-head .tag {
    margin-left: 0;
  }

  .property-amenities-toolbar {
    align-items: stretch;
    flex-direction: column;
  }

  .property-amenity-categories {
    flex-wrap: nowrap;
    margin-left: -2px;
    margin-right: -2px;
    overflow-x: auto;
    padding: 0 2px 4px;
    scrollbar-width: none;
  }

  .property-amenity-categories::-webkit-scrollbar {
    display: none;
  }

  .property-amenity-category {
    flex: 0 0 auto;
  }

  .property-amenity-grid {
    grid-template-columns: 1fr;
  }

  .property-policy-toggle-grid {
    grid-template-columns: 1fr;
  }
}

.property-action-bar.ms-action-bar {
  -webkit-backdrop-filter: none;
  backdrop-filter: none;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 14px;
  bottom: auto;
  box-shadow: var(--shadow-1);
  margin: 0;
  padding: 14px 18px;
  position: static;
  width: 100%;
}

[data-theme="dark"] .property-action-bar.ms-action-bar {
  background: var(--surface);
  box-shadow: none;
}

.property-action-bar .ms-btn-primary,
.property-action-bar .ms-btn-ghost,
.property-action-bar .pg-action-primary,
.property-action-bar .pg-action-danger {
  border-radius: 999px;
  font-size: 14px;
  font-weight: 700;
  min-height: 42px;
  padding: 0 18px;
}

.property-action-bar .pg-action-primary,
.property-action-bar .pg-action-danger {
  height: auto;
}

@media (max-width: 980px) {
  .property-detail-form.ms-detail-content {
    display: flex;
    max-width: 820px;
  }
}

@media (max-width: 640px) {
  .page-split.prop-mode .page-split-tabs .property-mobile-menu {
    margin-top: 14px;
  }

  .property-detail-form.ms-detail-content > .prop-back-btn {
    align-self: flex-start;
    flex: 0 0 30px;
    min-width: 30px;
    width: 30px;
  }

  .property-action-bar.ms-action-bar {
    align-items: center;
    display: flex;
    flex-wrap: nowrap;
    gap: 12px;
    justify-content: flex-end;
  }

  .property-action-bar .pg-action-spacer {
    display: block;
    flex: 1 1 auto;
    min-width: 8px;
  }

  .property-action-bar .pg-action-danger {
    flex: 0 0 auto;
    justify-self: start;
    margin-right: 0;
  }

  .property-action-bar [data-cancel-property-edit] {
    flex: 0 0 auto;
    justify-self: end;
  }

  .property-action-bar [data-property-submit] {
    flex: 0 1 auto;
    justify-self: end;
    max-width: 100%;
    min-width: 0;
    padding-left: 16px;
    padding-right: 16px;
    white-space: nowrap;
  }

  .property-action-bar [data-property-submit] span {
    display: none;
  }

  .property-action-bar [data-property-submit]::after {
    content: 'Enregistrer';
  }
}

/* ── Mobile : page templates — afficher une seule colonne à la fois ─────── */
@media (max-width: 860px) {
  [data-tpl-split] {
    flex-direction: column;
    overflow-y: auto;
  }
  [data-tpl-split] .page-split-list {
    width: 100%;
    border-right: none;
    border-bottom: 1px solid var(--line);
    max-height: none;
    flex-shrink: 0;
  }
  [data-tpl-split] .page-split-detail {
    overflow-y: visible;
    padding: 16px;
  }
  /* Clic sur un item ou Nouveau : masquer la liste, afficher l'éditeur */
  [data-tpl-split].detail-open .page-split-list  { display: none; }
  [data-tpl-split]:not(.detail-open) .page-split-detail { display: none; }
  /* Bouton retour visible uniquement sur mobile */
  [data-tpl-split] .prop-back-btn { display: inline-flex; }
}
@media (min-width: 861px) {
  [data-tpl-split] .prop-back-btn { display: none; }
}

/* ============================================================
   INBOX — Bouton Template + Modal d'envoi assisté
   ============================================================ */

/* Bouton Templates (pill avec icône + texte, en premier dans compose) */
.inbox-tpl-open-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 0 12px;
  height: 38px;
  border-radius: 10px;
  border: 1.5px solid var(--line-strong);
  background: var(--surface);
  color: var(--t2);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  flex-shrink: 0;
  transition: background 0.14s, border-color 0.14s, color 0.14s;
}
.inbox-tpl-open-btn i { font-size: 13px; }
.inbox-tpl-open-btn:hover {
  background: var(--accent-soft);
  border-color: var(--accent);
  color: var(--accent-2);
}

/* ── Modal overlay ───────────────────────────────────────────────────────── */
.ism-overlay {
  position: fixed;
  inset: 0;
  z-index: 9998;
  background: rgba(12, 12, 16, 0.50);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
}
.ism-overlay[hidden] { display: none; }

body.ism-open { overflow: hidden; }

/* ── Panneau modal ───────────────────────────────────────────────────────── */
.ism-panel {
  background: var(--surface);
  border-radius: 18px;
  width: 100%;
  max-width: 520px;
  max-height: 94dvh;
  display: flex;
  flex-direction: column;
  box-shadow: 0 24px 64px -8px rgba(12,12,16,0.32), 0 2px 4px rgba(12,12,16,0.08);
  overflow: hidden;
}

/* ── En-tête ─────────────────────────────────────────────────────────────── */
.ism-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid var(--line);
  flex-shrink: 0;
}
.ism-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--t1);
  display: flex;
  align-items: center;
  gap: 8px;
}
.ism-title i { color: var(--accent); font-size: 16px; }
.ism-x {
  width: 30px;
  height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: none;
  background: var(--bg-soft);
  border-radius: 8px;
  color: var(--t3);
  font-size: 14px;
  cursor: pointer;
  transition: background 0.12s, color 0.12s;
}
.ism-x:hover { background: var(--line-strong); color: var(--t1); }

/* ── Corps scrollable ────────────────────────────────────────────────────── */
.ism-body {
  overflow-y: auto;
  flex: 1;
  padding: 0;
}

/* ── Section générique ───────────────────────────────────────────────────── */
.ism-sect {
  padding: 14px 20px;
  border-bottom: 1px solid var(--line);
}
.ism-sect:last-child { border-bottom: none; }
.ism-sect[hidden] { display: none; }

.ism-slbl {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--t3);
  margin-bottom: 10px;
}

/* ── Liste de templates ──────────────────────────────────────────────────── */
.ism-tpl-scroll {
  display: flex;
  flex-direction: column;
  gap: 4px;
  max-height: 220px;
  overflow-y: auto;
}

.ism-tpl-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 10px;
  border-radius: 10px;
  border: 1.5px solid transparent;
  background: var(--surface-2);
  cursor: pointer;
  text-align: left;
  transition: background 0.1s, border-color 0.1s;
}
.ism-tpl-item:hover { background: var(--accent-soft); border-color: var(--accent-ring); }
.ism-tpl-item.is-selected {
  background: var(--accent-soft);
  border-color: var(--accent);
}
.ism-tpl-item--inactive { opacity: 0.45; pointer-events: none; }

.ism-tpl-icon {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: rgba(0,0,0,0.05);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
  flex-shrink: 0;
}
.ism-tpl-info {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.ism-tpl-name {
  font-size: 13px;
  font-weight: 600;
  color: var(--t1);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ism-tpl-badge {
  display: inline-block;
  padding: 1px 7px;
  border-radius: 20px;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
  width: fit-content;
}
.ism-tpl-arr {
  color: var(--t4);
  font-size: 12px;
  flex-shrink: 0;
}

.ism-empty {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 10px;
  color: var(--t3);
  font-size: 13px;
}
.ism-empty i { font-size: 18px; color: var(--t4); flex-shrink: 0; }

/* ── Onglets "Envoyer via" ───────────────────────────────────────────────── */
.ism-via-tabs {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.ism-via-tab {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 13px;
  border-radius: 8px;
  border: 1.5px solid var(--line-strong);
  background: var(--surface);
  color: var(--t2);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: background 0.1s, border-color 0.1s, color 0.1s, opacity 0.1s;
}
.ism-via-tab:hover:not([disabled]) {
  border-color: var(--accent);
  color: var(--accent-2);
  background: var(--accent-soft);
}
.ism-via-tab.is-active {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
  font-weight: 600;
}
.ism-via-tab[disabled] {
  opacity: 0.35;
  cursor: not-allowed;
}

/* ── Champs e-mail ───────────────────────────────────────────────────────── */
.ism-ef {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 8px;
}
.ism-ef:last-child { margin-bottom: 0; }
.ism-ef-lbl {
  font-size: 12px;
  font-weight: 600;
  color: var(--t3);
  width: 38px;
  flex-shrink: 0;
}
.ism-ef-input {
  flex: 1;
  height: 36px;
  padding: 0 10px;
  border: 1.5px solid var(--line-strong);
  border-radius: 8px;
  font: inherit;
  font-size: 13px;
  color: var(--t1);
  background: var(--surface-2);
  outline: none;
  transition: border-color 0.15s;
}
.ism-ef-input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-ring);
  background: var(--surface);
}

/* ── Zone aperçu ─────────────────────────────────────────────────────────── */
.ism-preview {
  max-height: 380px;
  overflow-y: auto;
  border-radius: 10px;
  background: var(--surface-2);
  border: 1px solid var(--line-strong);
}
.ism-prev-text {
  padding: 14px 16px;
  font-size: 14px;
  line-height: 1.65;
  color: var(--t1);
  white-space: pre-wrap;
  word-break: break-word;
}
.ism-prev-html {
  padding: 14px 16px;
  font-size: 14px;
  line-height: 1.65;
  color: var(--t1);
  overflow-x: auto;
}
.ism-prev-html img { max-width: 100%; height: auto; }
.ism-prev-html a   { color: var(--blue); }
.ism-prev-html p   { margin: 0 0 8px; }
.ism-prev-html p:last-child { margin-bottom: 0; }

/* ── Pied de modal (boutons) ─────────────────────────────────────────────── */
.ism-footer {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  padding: 14px 20px;
  border-top: 1px solid var(--line);
  flex-shrink: 0;
  background: var(--surface-2);
}
.ism-footer[hidden] { display: none; }

.ism-btn-ghost {
  padding: 8px 16px;
  border-radius: 9px;
  border: 1.5px solid var(--line-strong);
  background: var(--surface);
  color: var(--t2);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.12s, border-color 0.12s;
}
.ism-btn-ghost:hover { background: var(--bg-soft); border-color: var(--t3); }

.ism-btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 8px 18px;
  border-radius: 9px;
  border: none;
  background: var(--accent);
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  transition: opacity 0.14s, transform 0.1s;
}
.ism-btn-primary:hover  { opacity: 0.88; }
.ism-btn-primary:active { transform: scale(0.97); }

/* ── Mobile ──────────────────────────────────────────────────────────────── */
@media (max-width: 600px) {
  .ism-overlay { align-items: flex-end; padding: 0; }
  .ism-panel {
    border-radius: 0;
    max-width: 100%;
    width: 100%;
    height: 100dvh;
    max-height: 100dvh;
  }
}

/* ═══════════════════════════════════════════════════════════════
   CALENDRIER — Popover action 2 colonnes
   Gauche : infos réservation + Détail / Messagerie
   Droite  : Nouvelle rés / Prix / Blocage / Inventaire
   ═══════════════════════════════════════════════════════════════ */
.cal-action-popover {
  position: fixed;
  z-index: 1200;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 14px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.16), 0 2px 8px rgba(0,0,0,0.08);
  overflow: hidden;
  animation: calPopIn .14s cubic-bezier(.2,.6,.4,1);
}
@keyframes calPopIn {
  from { opacity: 0; transform: scale(.94) translateY(-5px); }
  to   { opacity: 1; transform: scale(1)   translateY(0);    }
}

/* Layout 2 colonnes */
.cap-cols { display: flex; align-items: stretch; }

.cap-left  { padding: 8px 6px; min-width: 208px; }
.cap-right { padding: 8px 6px; min-width: 200px; }

/* Séparateur vertical */
.cap-vsep {
  width: 1px;
  background: var(--line);
  flex-shrink: 0;
  margin: 6px 0;
}

/* En-tête réservation (logo OTA + nom + propriété) */
.cap-res-header {
  display: flex; align-items: center; gap: 8px;
  padding: 4px 6px 8px;
}
.cap-res-logo {
  width: 26px; height: 26px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
}
.cap-res-logo .source-logo { width: 22px; height: 22px; border-radius: 5px; object-fit: contain; }
.cap-res-logo .source-logo-fallback {
  width: 22px; height: 22px; border-radius: 5px;
  background: var(--surface-3);
  display: flex; align-items: center; justify-content: center;
  font-size: 10px; font-weight: 800; color: var(--t2);
}
.cap-res-info { min-width: 0; flex: 1; }
.cap-res-name {
  font-size: 13px; font-weight: 700; color: var(--t1);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.cap-res-sub {
  font-size: 11px; color: var(--t3); margin-top: 1px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
/* Dates du séjour — colonne gauche, sous la propriété */
.cap-res-dates {
  display: flex; align-items: center; gap: 5px;
  font-size: 11px; font-weight: 600; color: var(--t2);
  padding: 0 10px 8px;
  margin-top: -2px;
}
.cap-res-dates::before {
  content: '\f073'; /* fa-calendar */
  font-family: 'Font Awesome 6 Free'; font-weight: 900;
  font-size: 10px; color: var(--t3);
}

/* Label date cliquée — colonne droite */
.cap-right-date {
  display: flex; align-items: center; gap: 6px;
  font-size: 11px; font-weight: 700; color: var(--t2);
  padding: 4px 10px 7px; border-bottom: 1px solid var(--line); margin-bottom: 2px;
}

/* Séparateur horizontal */
.cap-divider { height: 1px; background: var(--line); margin: 2px 4px 6px; }

/* Boutons communs */
.cap-btn {
  display: flex; align-items: center; gap: 8px;
  width: 100%; padding: 8px 10px;
  border: none; border-radius: 8px; background: transparent;
  font: 500 13px/1.2 var(--font); color: var(--t2);
  cursor: pointer; text-align: left;
  transition: background .1s, color .1s;
}
.cap-btn:hover { background: var(--surface-2); color: var(--t1); }
.cap-btn i {
  width: 24px; height: 24px; border-radius: 6px;
  background: var(--surface-2); border: 1px solid var(--line);
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; color: var(--accent); flex-shrink: 0;
  transition: background .1s, color .1s;
}
.cap-btn:hover i { background: var(--surface-3); }

/* Icônes colorées par type */
.cap-btn--msg i    { color: var(--accent); }
.cap-btn--newres i { color: var(--accent); }
.cap-btn--price i  { color: #2EAB6E; background: rgba(46,171,110,.1); border-color: rgba(46,171,110,.2); }
.cap-btn--block i  { color: #EF4444; background: rgba(239,68,68,.08); border-color: rgba(239,68,68,.15); }
.cap-btn--inv i    { color: #7C6FF7; background: rgba(124,111,247,.1); border-color: rgba(124,111,247,.2); }

/* Bouton désactivé (inventaire plein, pas de permission) */
.cap-btn.is-disabled {
  opacity: 0.38;
  cursor: not-allowed;
  pointer-events: none;
}

/* ── Mode surbooking (colonne gauche multi-réservations) ─────────────────── */
.cap-ob-head {
  display: flex; align-items: center; gap: 7px;
  padding: 8px 12px 9px;
  font-size: 11px; font-weight: 700; color: #EF4444;
  border-bottom: 1px solid var(--line); margin-bottom: 4px;
}
.cap-ob-head i { font-size: 11px; flex-shrink: 0; }

.cap-ob-list { padding: 4px 4px 4px; }

.cap-ob-item {
  display: flex; align-items: center; gap: 9px;
  width: 100%; padding: 9px 10px;
  border: none; border-radius: 8px; background: transparent;
  cursor: pointer; text-align: left;
  transition: background .1s;
  font-family: inherit;
}
.cap-ob-item:hover { background: var(--surface-2); }
.cap-ob-item + .cap-ob-item { margin-top: 2px; }

.cap-ob-item-logo {
  width: 24px; height: 24px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
}
.cap-ob-item-logo .source-logo { width: 20px; height: 20px; border-radius: 4px; object-fit: contain; }
.cap-ob-item-logo .source-logo-fallback {
  width: 20px; height: 20px; border-radius: 4px;
  background: var(--surface-3);
  display: flex; align-items: center; justify-content: center;
  font-size: 9px; font-weight: 800; color: var(--t2);
}

.cap-ob-item-info { flex: 1; min-width: 0; }
.cap-ob-item-name  { font-size: 13px; font-weight: 600; color: var(--t1); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cap-ob-item-dates { font-size: 10px; color: var(--t3); margin-top: 2px; }

.cap-ob-item-actions {
  display: flex; gap: 4px; flex-shrink: 0;
}
.cap-ob-item-action {
  width: 26px; height: 26px; border-radius: 7px;
  border: 1px solid var(--line); background: var(--surface-2);
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; color: var(--t3); cursor: pointer;
  transition: background .1s, color .1s, border-color .1s;
}
.cap-ob-item-action:hover { background: var(--surface-3); color: var(--t1); border-color: var(--line-strong); }
.cap-ob-item-action--msg:hover { color: var(--accent); border-color: var(--accent); }

/* ═══════════════════════════════════════════════════════════════
   CALENDRIER — Drawer messagerie
   ═══════════════════════════════════════════════════════════════ */
.cal-msg-drawer {
  position: fixed; top: 0; right: 0;
  width: min(400px, 100vw); height: 100dvh;
  background: var(--surface); border-left: 1px solid var(--line);
  box-shadow: -8px 0 28px rgba(20,28,36,.14);
  transform: translateX(110%);
  visibility: hidden;
  transition: transform .26s cubic-bezier(.25,.46,.45,.94), visibility 0s linear .26s;
  z-index: 800; display: flex; flex-direction: column; overflow: hidden;
}
.cal-msg-drawer.open {
  transform: translateX(0);
  visibility: visible;
  transition: transform .26s cubic-bezier(.25,.46,.45,.94), visibility 0s linear 0s;
}
@media (max-width: 768px) {
  /* Drawer messagerie : plein écran absolu sur mobile (doit être après les styles de base) */
  .cal-msg-drawer {
    inset: 0;
    width: 100%;
    height: 100%;
    max-height: none;
    border: none;
    border-radius: 0;
  }
}

.cal-msg-drawer-head {
  padding: 14px 16px 12px; border-bottom: 1px solid var(--line);
  display: flex; align-items: center; gap: 10px;
  flex-shrink: 0; background: var(--surface);
}
.cal-msg-drawer-avatar {
  width: 38px; height: 38px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: 14px; color: #fff; flex-shrink: 0;
}
.cal-msg-drawer-info { flex: 1; min-width: 0; }
.cal-msg-drawer-name {
  font-size: 14px; font-weight: 600; color: var(--t1);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  display: flex; align-items: center; gap: 6px;
}
.cal-msg-drawer-sub { font-size: 11px; color: var(--t3); margin-top: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cal-msg-drawer-inbox-link {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 11px; color: var(--accent); font-weight: 600;
  padding: 5px 9px; border-radius: 8px;
  border: 1.5px solid rgba(245,135,77,.3); background: var(--accent-soft);
  white-space: nowrap; flex-shrink: 0; text-decoration: none;
  transition: background .12s;
}
.cal-msg-drawer-inbox-link:hover { background: rgba(245,135,77,.18); }
.cal-msg-drawer-close {
  width: 30px; height: 30px; border-radius: 7px;
  border: 1px solid var(--line-strong); background: var(--surface);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; color: var(--t3); font-size: 13px; flex-shrink: 0;
  transition: background .12s, color .12s;
}
.cal-msg-drawer-close:hover { background: var(--surface-2); color: var(--t1); }

.cal-msg-drawer-msgs {
  flex: 1; overflow-y: auto; padding: 16px 14px;
  display: flex; flex-direction: column; gap: 2px; background: var(--bg);
}
.cal-msg-date-sep { text-align: center; margin: 10px 0 6px; }
.cal-msg-date-sep span { font-size: 10px; color: var(--t3); background: var(--surface-2); padding: 2px 10px; border-radius: 20px; }
.cal-msg-bubble-wrap { display: flex; flex-direction: column; max-width: 80%; margin-bottom: 4px; }
.cal-msg-bubble-wrap.guest { align-self: flex-start; }
.cal-msg-bubble-wrap.host  { align-self: flex-end; }
.cal-msg-bubble { padding: 9px 13px; border-radius: 16px; font-size: 13px; line-height: 1.55; word-break: break-word; }
.cal-msg-bubble-wrap.guest .cal-msg-bubble { background: var(--surface); border: 1px solid var(--line); border-bottom-left-radius: 4px; color: var(--t1); box-shadow: var(--shadow-1); }
.cal-msg-bubble-wrap.host  .cal-msg-bubble { background: var(--accent); color: #fff; border-bottom-right-radius: 4px; }
.cal-msg-time { font-size: 10px; color: var(--t4); margin-top: 3px; padding: 0 3px; }
.cal-msg-bubble-wrap.host .cal-msg-time { text-align: right; }
.cal-msg-empty { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 12px; color: var(--t4); text-align: center; }
.cal-msg-empty i { font-size: 40px; opacity: .3; }
.cal-msg-empty p { font-size: 13px; }

.cal-msg-drawer-compose { padding: 10px 12px 12px; background: var(--surface); border-top: 1px solid var(--line); flex-shrink: 0; }

/* ==========================================================================
   Guest client page
========================================================================== */

.guest-client-page {
  min-height: 100vh;
  background: var(--surface-2);
  color: var(--t1);
  font-family: 'Inter Tight', system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

.guest-client-shell {
  min-height: 100vh;
  width: min(100%, 520px);
  margin: 0 auto;
  background: var(--surface);
  box-shadow: 0 24px 80px rgba(15, 23, 42, .12);
  position: relative;
  padding-bottom: 88px;
}

.guest-client-hero {
  position: relative;
  min-height: 300px;
  overflow: hidden;
  background: #17171d;
}

.guest-client-hero img,
.guest-client-hero-empty {
  display: block;
  width: 100%;
  height: 300px;
  object-fit: cover;
}

.guest-client-hero-empty {
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 42px;
  background: linear-gradient(135deg, #17171d, #ff7d45);
}

.guest-client-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,.28) 0%, rgba(0,0,0,.08) 38%, rgba(0,0,0,.58) 100%);
  pointer-events: none;
}

.guest-client-hero-caption {
  position: absolute;
  z-index: 2;
  left: 24px;
  right: 24px;
  bottom: 26px;
  color: #fff;
  text-shadow: 0 2px 18px rgba(0,0,0,.36);
}

.guest-client-hero-caption span {
  display: block;
  margin-bottom: 8px;
  font-size: 14px;
  font-weight: 800;
}

.guest-client-hero-caption h1 {
  max-width: 440px;
  margin: 0;
  color: #fff;
  font-size: 34px;
  line-height: 1.02;
  letter-spacing: 0;
}

.guest-client-content {
  position: relative;
  z-index: 3;
  margin-top: -20px;
  padding: 20px 18px 24px;
  background: var(--surface);
  border-radius: 22px 22px 0 0;
}

.guest-client-step,
.guest-client-guide,
.guest-client-reservation,
.guest-client-block,
.guest-client-empty-guide,
.guest-client-missing {
  border: 1px solid var(--line);
  background: var(--surface);
  border-radius: 24px;
  box-shadow: var(--shadow-1);
}

.guest-client-step {
  padding: 22px;
  text-align: center;
}

.guest-client-pill {
  width: fit-content;
  margin: 0 auto 14px;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  border-radius: 999px;
  background: var(--accent-soft);
  color: var(--accent);
  padding: 5px 12px;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.guest-client-step h2,
.guest-client-reservation h2 {
  margin: 0;
  color: var(--t1);
  font-size: 24px;
  line-height: 1.12;
  letter-spacing: 0;
}

.guest-client-step p {
  margin: 10px auto 24px;
  max-width: 360px;
  color: var(--t3);
  font-size: 15px;
  line-height: 1.45;
}

.guest-client-validation-list,
.guest-client-blocks {
  display: grid;
  gap: 12px;
}

.guest-client-validation-item,
.guest-client-arrival-box {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: var(--surface-2);
  color: var(--t1);
}

.guest-client-validation-item {
  min-height: 74px;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  padding: 12px;
  text-align: left;
  font: inherit;
}

.guest-client-item-icon {
  width: 44px;
  height: 44px;
  border-radius: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--accent-soft);
  color: var(--accent);
  flex: 0 0 auto;
  line-height: 1;
  margin: 0;
  text-align: center;
}

.guest-client-item-icon i {
  color: var(--accent);
  display: block;
  font-size: 17px;
  line-height: 1;
}

.guest-client-validation-item strong,
.guest-client-validation-item small {
  display: block;
}

.guest-client-validation-item strong {
  color: var(--t1);
  font-size: 16px;
  font-weight: 800;
}

.guest-client-validation-item small {
  margin-top: 3px;
  color: var(--t3);
  font-size: 13px;
  line-height: 1.25;
}

.guest-client-validation-item em {
  border-radius: 999px;
  background: var(--accent);
  color: #fff;
  padding: 6px 10px;
  font-size: 11px;
  font-style: normal;
  font-weight: 900;
  text-transform: uppercase;
  white-space: nowrap;
}

.guest-client-form-field {
  width: 100%;
  min-height: 82px;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 12px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: var(--surface-2);
  color: var(--t1);
  padding: 12px;
  text-align: left;
}

.guest-client-form-field.is-check {
  grid-template-columns: auto minmax(0, 1fr) auto;
}

.guest-client-form-field.guest-client-file-field {
  grid-template-columns: auto minmax(0, 1fr) auto;
}

.guest-client-form-control {
  display: grid;
  gap: 7px;
  min-width: 0;
}

.guest-client-form-control strong {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 7px;
  color: var(--t1);
  font-size: 15px;
  font-weight: 850;
  line-height: 1.2;
}

.guest-client-form-control em {
  border-radius: 999px;
  background: var(--accent);
  color: #fff;
  padding: 3px 8px;
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
  text-transform: uppercase;
}

.guest-client-form-control small {
  color: var(--t3);
  font-size: 13px;
  line-height: 1.3;
}

.guest-client-form-control input {
  width: 100%;
  min-height: 44px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--surface);
  color: var(--t1);
  padding: 0 12px;
  font: inherit;
  font-size: 15px;
  font-weight: 500;
}

.guest-client-form-control input[type="file"] {
  display: flex;
  align-items: center;
  min-height: auto;
  border: 0;
  border-radius: 0;
  background: transparent;
  padding: 2px 0 0;
  color: var(--t2);
  font-size: 13px;
}

.guest-client-file-field .guest-file-input {
  position: absolute;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}

.guest-file-status {
  color: var(--t3);
  font-size: 12px;
  font-weight: 700;
  line-height: 1.25;
}

.guest-file-button {
  align-items: center;
  align-self: center;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--t1);
  cursor: pointer;
  display: inline-flex;
  flex-shrink: 0;
  font: inherit;
  font-size: 13px;
  font-weight: 850;
  gap: 8px;
  min-height: 42px;
  padding: 0 14px;
  transition: background .15s, border-color .15s, color .15s, transform .12s;
}

.guest-file-button i {
  color: var(--accent);
}

.guest-file-button:hover,
.guest-file-button:focus-visible {
  background: var(--accent-soft);
  border-color: var(--accent-ring);
  color: var(--accent-2);
  outline: 0;
}

.guest-file-button:active {
  transform: translateY(1px);
}

.guest-client-form-field.is-check > input[type="checkbox"] {
  width: 22px;
  height: 22px;
  border-radius: 7px;
}

.guest-client-address-box,
.guest-client-payment-box,
.guest-client-camera-box,
.guest-client-contract-box {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: var(--surface-2);
  color: var(--t1);
  padding: 12px;
  text-align: left;
}

.guest-client-payment-box,
.guest-client-camera-box,
.guest-client-contract-box {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
}

.guest-client-payment-box.is-done,
.guest-client-camera-box.is-done,
.guest-client-contract-box.is-done {
  border-color: rgba(46, 171, 110, .35);
  background: rgba(46, 171, 110, .08);
}

.guest-client-payment-box strong,
.guest-client-camera-box strong,
.guest-client-contract-box strong,
.guest-client-address-head strong {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 7px;
  color: var(--t1);
  font-size: 15px;
  font-weight: 850;
  line-height: 1.2;
}

.guest-client-payment-box em,
.guest-client-camera-box em,
.guest-client-contract-box em,
.guest-client-address-head em {
  border-radius: 999px;
  background: var(--accent);
  color: #fff;
  padding: 3px 8px;
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
  text-transform: uppercase;
}

.guest-client-payment-box > div small,
.guest-client-payment-box > div span,
.guest-client-camera-box > div small,
.guest-client-camera-box > div span,
.guest-client-contract-box > div small,
.guest-client-contract-box > div span,
.guest-client-address-head small {
  display: block;
  margin-top: 5px;
  color: var(--t3);
  font-size: 13px;
  line-height: 1.3;
}

.guest-client-payment-box.is-done > div span,
.guest-client-camera-box.is-done > div span,
.guest-client-contract-box.is-done > div span {
  color: #2EAB6E;
  font-weight: 800;
}

.guest-client-payment-box button,
.guest-client-camera-box button,
.guest-client-contract-box button,
.guest-inline-action {
  min-height: 38px;
  border: 0;
  border-radius: 999px;
  background: var(--accent);
  color: #fff;
  cursor: pointer;
  font: inherit;
  font-size: 13px;
  font-weight: 850;
  padding: 0 14px;
  white-space: nowrap;
}

.guest-client-address-head {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
}

.guest-client-address-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.guest-client-address-grid label {
  display: grid;
  gap: 6px;
  color: var(--t2);
  font-size: 12px;
  font-weight: 750;
}

.guest-client-address-grid input {
  width: 100%;
  min-height: 44px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--surface);
  color: var(--t1);
  padding: 0 12px;
  font: inherit;
  font-size: 14px;
  font-weight: 500;
}

.guest-inline-action {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 12px;
  background: var(--surface);
  border: 1px solid var(--line);
  color: var(--t1);
}

.guest-inline-status {
  min-height: 18px;
  margin-top: 8px;
  color: var(--t3);
  font-size: 12px;
  font-weight: 700;
}

.guest-inline-status.is-ok {
  color: #2EAB6E;
}

.guest-client-arrival-box {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  padding: 14px;
  text-align: left;
}

.guest-client-arrival-box label,
.guest-client-arrival-box small {
  display: block;
}

.guest-client-arrival-box label {
  margin-bottom: 7px;
  color: var(--t2);
  font-size: 13px;
  font-weight: 700;
}

.guest-client-arrival-box select {
  width: 100%;
  height: 46px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--surface);
  color: var(--t1);
  padding: 0 12px;
  font: inherit;
  font-weight: 700;
}

.guest-client-arrival-box small {
  margin-top: 7px;
  color: var(--t3);
  font-size: 12px;
}

.guest-client-primary {
  width: 100%;
  min-height: 56px;
  margin-top: 18px;
  border: 0;
  border-radius: 18px;
  background: var(--accent);
  color: #fff;
  cursor: pointer;
  font: inherit;
  font-size: 16px;
  font-weight: 900;
  box-shadow: 0 12px 28px rgba(255, 125, 69, .24);
}

.guest-client-guide {
  border: 0;
  background: transparent;
  box-shadow: none;
  display: grid;
  gap: 14px;
}

.guest-client-reservation {
  padding: 18px;
}

.guest-client-reservation-card {
  display: grid;
  grid-template-columns: 76px minmax(0, 1fr);
  gap: 14px;
  align-items: center;
  margin-top: 16px;
}

.guest-client-reservation-card img,
.guest-client-reservation-empty {
  width: 76px;
  height: 76px;
  border-radius: 16px;
  object-fit: cover;
}

.guest-client-reservation-empty {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--accent-soft);
  color: var(--accent);
}

.guest-client-reservation-card strong,
.guest-client-reservation-card span {
  display: block;
}

.guest-client-reservation-card strong {
  color: var(--t1);
  font-size: 17px;
  font-weight: 900;
}

.guest-client-reservation-card span {
  margin-top: 4px;
  color: var(--t3);
  font-size: 14px;
  line-height: 1.35;
}

.guest-client-reservation-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 18px;
}

.guest-client-reservation-grid div {
  min-width: 0;
  color: var(--t3);
  font-size: 13px;
}

.guest-client-reservation-grid i {
  margin-right: 6px;
  color: var(--accent);
}

.guest-client-reservation-grid span,
.guest-client-reservation-grid strong,
.guest-client-reservation-grid small {
  display: block;
}

.guest-client-reservation-grid strong {
  margin-top: 4px;
  color: var(--t1);
  font-size: 15px;
}

.guest-client-block {
  padding: 16px;
}

.guest-client-block-head {
  display: flex;
  align-items: center;
  gap: 12px;
}

.guest-client-block h3 {
  margin: 0;
  color: var(--t1);
  font-size: 17px;
  font-weight: 900;
}

.guest-client-block-head small {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  margin-top: 4px;
  border-radius: 999px;
  background: var(--surface-3);
  color: var(--t3);
  padding: 4px 8px;
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
}

.guest-client-block p {
  margin: 14px 0 0;
  color: var(--t2);
  font-size: 15px;
  line-height: 1.5;
}

.guest-client-code,
.guest-client-wifi,
.guest-client-callout {
  margin-top: 14px;
  border-radius: 16px;
  background: var(--surface-2);
  border: 1px solid var(--line);
  padding: 14px;
}

.guest-client-code span,
.guest-client-code strong,
.guest-client-wifi small,
.guest-client-wifi strong {
  display: block;
}

.guest-client-code span,
.guest-client-wifi small {
  color: var(--t3);
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
}

.guest-client-code strong {
  margin-top: 6px;
  color: var(--t1);
  font-size: 28px;
  letter-spacing: 4px;
}

.guest-client-wifi {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.guest-client-wifi strong {
  margin-top: 5px;
  color: var(--t1);
  font-size: 15px;
  word-break: break-word;
}

.guest-client-list {
  display: grid;
  gap: 8px;
  margin: 14px 0 0;
  padding: 0;
  list-style: none;
}

.guest-client-list li {
  display: flex;
  gap: 9px;
  color: var(--t2);
  font-size: 14px;
}

.guest-client-list i,
.guest-client-callout i {
  color: var(--accent);
}

.guest-client-callout {
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--t2);
}

.guest-client-extras { display: grid; gap: 10px; margin-top: 14px; }
.guest-client-extra-card {
  align-items: center;
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 16px;
  display: grid;
  gap: 12px;
  grid-template-columns: 56px minmax(0, 1fr) auto;
  padding: 12px;
}
.guest-client-extra-thumb {
  align-items: center;
  background: var(--accent-soft);
  border-radius: 12px;
  color: var(--accent);
  display: flex;
  font-size: 18px;
  height: 56px;
  justify-content: center;
  overflow: hidden;
  width: 56px;
}
.guest-client-extra-thumb img { height: 100%; object-fit: cover; width: 100%; }
.guest-client-extra-main { display: grid; gap: 3px; min-width: 0; }
.guest-client-extra-main strong { color: var(--t1); font-size: 14px; }
.guest-client-extra-main small {
  color: var(--t3);
  display: -webkit-box;
  font-size: 12px;
  line-height: 1.4;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}
.guest-client-extra-price { color: var(--t1); font-size: 13px; font-weight: 750; }
.guest-client-extra-price em { color: var(--t3); font-size: 11.5px; font-style: normal; font-weight: 600; }
.guest-client-extra-cta {
  align-items: center;
  background: var(--accent);
  border: 1px solid var(--accent);
  border-radius: 999px;
  color: #fff;
  cursor: pointer;
  display: inline-flex;
  font-family: inherit;
  font-size: 12.5px;
  font-weight: 750;
  gap: 6px;
  justify-content: center;
  padding: 8px 14px;
  transition: filter .15s ease;
}
.guest-client-extra-cta:hover { filter: brightness(1.05); }
.guest-client-extra-card.is-requested .guest-client-extra-cta {
  background: var(--surface);
  border-color: var(--line-strong);
  color: var(--t2);
}

@media (max-width: 560px) {
  .guest-client-extra-card { grid-template-columns: 48px minmax(0, 1fr); }
  .guest-client-extra-thumb { height: 48px; width: 48px; }
  .guest-client-extra-cta { grid-column: 1 / -1; }
}

.guest-client-map {
  height: 170px;
  margin-top: 14px;
  border-radius: 18px;
  background:
    radial-gradient(circle at 30% 35%, rgba(255,125,69,.2), transparent 28%),
    linear-gradient(135deg, var(--surface-2), var(--surface-3));
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--accent);
  font-size: 42px;
}

.guest-client-gallery {
  display: grid;
  gap: 8px;
  margin-top: 14px;
}

.guest-client-gallery button {
  min-height: 116px;
  border: 0;
  border-radius: 16px;
  overflow: hidden;
  padding: 0;
  background: var(--surface-2);
  cursor: zoom-in;
}

.guest-client-gallery img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.guest-client-gallery.count-1 { grid-template-columns: 1fr; }
.guest-client-gallery.count-2,
.guest-client-gallery.count-4 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.guest-client-gallery.count-3,
.guest-client-gallery.count-5,
.guest-client-gallery.count-6 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.guest-client-gallery.count-3 button:nth-child(3) { grid-column: 2; }
.guest-client-gallery.count-5 button:nth-child(4) { grid-column: 1 / span 1; }
.guest-client-gallery.count-5 button:nth-child(5) { grid-column: 2 / span 1; }

.guest-client-gallery-empty,
.guest-client-empty-guide,
.guest-client-missing {
  display: grid;
  place-items: center;
  gap: 8px;
  min-height: 130px;
  text-align: center;
  color: var(--t3);
}

.guest-client-video {
  margin-top: 14px;
  border-radius: 18px;
  overflow: hidden;
  background: #111;
  aspect-ratio: 16 / 9;
}

.guest-client-video iframe,
.guest-client-video video {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}

.guest-client-video.is-empty {
  display: grid;
  place-items: center;
}

.guest-client-video.is-empty span {
  width: 54px;
  height: 54px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,.18);
  color: #fff;
}

.guest-client-tabs {
  position: fixed;
  z-index: 20;
  left: 50%;
  bottom: 0;
  width: min(100%, 520px);
  transform: translateX(-50%);
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 4px;
  padding: 9px 10px calc(9px + env(safe-area-inset-bottom));
  background: color-mix(in srgb, var(--surface) 94%, transparent);
  border-top: 1px solid var(--line);
  box-shadow: 0 -16px 30px rgba(15, 23, 42, .08);
  backdrop-filter: blur(14px);
}

.guest-client-tabs button {
  min-height: 50px;
  border: 0;
  border-radius: 16px;
  background: transparent;
  color: var(--t3);
  cursor: pointer;
  font: inherit;
  font-size: 12px;
  font-weight: 800;
}

.guest-client-tabs i,
.guest-client-tabs span {
  display: block;
}

.guest-client-tabs i {
  margin-bottom: 4px;
  font-size: 16px;
}

.guest-client-tabs button.active {
  background: var(--accent-soft);
  color: var(--accent);
}

/* ===== Onglets voyageur (Réservation / Guide / Messagerie / Extras) ===== */
.guest-tab-pane { display: grid; gap: 16px; }

/* État vide générique */
.guest-empty-pane {
  align-items: center;
  display: grid;
  gap: 8px;
  justify-items: center;
  padding: 48px 20px;
  text-align: center;
}
.guest-empty-ic {
  align-items: center;
  background: var(--accent-soft);
  border-radius: 18px;
  color: var(--accent);
  display: flex;
  font-size: 24px;
  height: 60px;
  justify-content: center;
  width: 60px;
}
.guest-empty-pane h2 { color: var(--t1); font-size: 18px; margin: 4px 0 0; }
.guest-empty-pane p { color: var(--t3); font-size: 13.5px; max-width: 320px; }

/* --- Onglet Réservation --- */
.guest-res-head {
  align-items: center;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 18px;
  display: grid;
  gap: 14px;
  grid-template-columns: 72px minmax(0, 1fr);
  padding: 14px;
}
.guest-res-head img,
.guest-res-head-empty {
  border-radius: 14px;
  height: 72px;
  object-fit: cover;
  width: 72px;
}
.guest-res-head-empty {
  align-items: center;
  background: var(--accent-soft);
  color: var(--accent);
  display: flex;
  font-size: 22px;
  justify-content: center;
}
.guest-res-head h2 { color: var(--t1); font-size: 17px; margin: 0 0 4px; }
.guest-res-head p { align-items: baseline; color: var(--t3); display: flex; font-size: 13px; gap: 6px; margin: 0; }
.guest-res-head p i { color: var(--accent); }
.guest-res-grid {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.guest-res-stat {
  align-items: flex-start;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 16px;
  display: flex;
  gap: 11px;
  padding: 13px;
}
.guest-res-stat-ic {
  align-items: center;
  background: var(--accent-soft);
  border-radius: 11px;
  color: var(--accent-2);
  display: flex;
  flex-shrink: 0;
  font-size: 14px;
  height: 36px;
  justify-content: center;
  width: 36px;
}
.guest-res-stat-label { color: var(--t3); display: block; font-size: 11.5px; font-weight: 600; margin-bottom: 2px; }
.guest-res-stat strong { color: var(--t1); display: block; font-size: 14px; line-height: 1.25; }
.guest-res-stat small { color: var(--t3); display: block; font-size: 11.5px; margin-top: 2px; }
.guest-res-total {
  align-items: center;
  background: var(--accent-soft);
  border: 1px solid var(--accent-ring);
  border-radius: 16px;
  display: flex;
  justify-content: space-between;
  padding: 14px 16px;
}
.guest-res-total span { align-items: center; color: var(--accent-2); display: flex; font-size: 13.5px; font-weight: 700; gap: 8px; }
.guest-res-total strong { color: var(--t1); font-size: 19px; font-weight: 850; letter-spacing: -0.01em; }

/* --- Intro du guide --- */
.guest-guide-intro { color: var(--t2); font-size: 14px; line-height: 1.6; margin: 0; }
.guest-guide-h { color: var(--t1); font-size: 18px; font-weight: 800; letter-spacing: -0.01em; margin: 0; }

/* --- Rubriques du guide (liste / cards) --- */
.guest-rubrics-list { display: grid; }
.guest-rubrics-list .guest-rubric {
  align-items: center; background: transparent; border: 0; border-bottom: 1px solid var(--line);
  cursor: pointer; display: grid; font: inherit; gap: 14px; grid-template-columns: 30px minmax(0,1fr) auto;
  padding: 16px 2px; text-align: left; width: 100%;
}
.guest-rubrics-cards { display: grid; gap: 12px; grid-template-columns: repeat(2, minmax(0,1fr)); }
.guest-rubrics-cards .guest-rubric {
  align-items: flex-start; background: var(--surface); border: 1px solid var(--line); border-radius: 16px;
  cursor: pointer; display: grid; font: inherit; gap: 12px; padding: 16px 14px; text-align: left;
}
.guest-rubric-ic { color: var(--t1); font-size: 20px; }
.guest-rubrics-cards .guest-rubric-ic {
  align-items: center; background: var(--accent-soft); border-radius: 12px; color: var(--accent);
  display: flex; height: 44px; justify-content: center; width: 44px;
}
.guest-rubric-title { color: var(--t1); font-size: 15px; font-weight: 650; min-width: 0; }
.guest-rubric-chev { color: var(--t4); font-size: 13px; }

/* --- Détail d'une rubrique --- */
.guest-rubric-detail-head { align-items: center; display: flex; gap: 12px; margin-bottom: 4px; }
.guest-rubric-back {
  align-items: center; background: var(--surface); border: 1px solid var(--line); border-radius: 11px;
  color: var(--t1); cursor: pointer; display: flex; flex-shrink: 0; height: 40px; justify-content: center; width: 40px;
}
.guest-rubric-detail-ic {
  align-items: center; background: var(--accent-soft); border-radius: 12px; color: var(--accent);
  display: flex; font-size: 16px; height: 40px; justify-content: center; width: 40px;
}
.guest-rubric-detail-head h2 { color: var(--t1); font-size: 19px; font-weight: 800; margin: 0; }
.guest-rubric-blocks { display: grid; gap: 16px; margin-top: 8px; }
.grb-h { color: var(--t1); margin: 0; }
.grb-h1 { font-size: 20px; font-weight: 800; }
.grb-h2 { font-size: 16px; font-weight: 750; }
.grb-text { color: var(--t2); font-size: 14.5px; line-height: 1.6; margin: 0; }
.grb-text a, .grb-callout a { color: var(--accent-2); text-decoration: underline; }
.grb-sep { border: 0; border-top: 1px solid var(--line); margin: 0; }
.grb-callout { align-items: flex-start; background: var(--accent-soft); border: 1px solid var(--accent-ring); border-radius: 14px; color: var(--accent-2); display: flex; font-size: 13.5px; gap: 10px; line-height: 1.5; padding: 14px; }
.grb-ul, .grb-ol { color: var(--t2); font-size: 14.5px; line-height: 1.55; margin: 0; padding-left: 22px; }
.grb-ul li, .grb-ol li { margin-bottom: 6px; }
.grb-check { display: grid; gap: 10px; list-style: none; margin: 0; padding: 0; }
.grb-check li { align-items: center; color: var(--t2); display: flex; font-size: 14.5px; gap: 11px; }
.grb-check li span.done { color: var(--t4); text-decoration: line-through; }
.grb-check-box {
  align-items: center; background: var(--surface); border: 2px solid var(--line-strong); border-radius: 7px;
  color: #fff; cursor: pointer; display: flex; flex-shrink: 0; font-size: 11px; height: 24px; justify-content: center; width: 24px;
}
.grb-check-box.on { background: var(--accent); border-color: var(--accent); }
.grb-img { margin: 0; }
.grb-img img { border-radius: 14px; cursor: zoom-in; display: block; width: 100%; }
.grb-img figcaption { color: var(--t4); font-size: 12.5px; margin-top: 6px; text-align: center; }
.grb-video { aspect-ratio: 16/9; background: #0C0C10; border-radius: 14px; overflow: hidden; }
.grb-video video, .grb-video iframe { border: 0; height: 100%; width: 100%; }
.grb-wifi { background: var(--surface); border: 1px solid var(--line); border-radius: 14px; display: grid; gap: 12px; grid-template-columns: 1fr 1fr; padding: 14px; }
.grb-wifi small { color: var(--t4); display: block; font-size: 11px; }
.grb-wifi strong { color: var(--t1); font-size: 14px; }
.grb-code { align-items: center; background: var(--accent-soft); border: 1px solid var(--accent-ring); border-radius: 14px; display: flex; justify-content: space-between; padding: 14px 16px; }
.grb-code span { color: var(--accent-2); font-size: 13px; font-weight: 700; }
.grb-code strong { color: var(--t1); font-size: 18px; font-weight: 800; letter-spacing: .08em; }

/* --- CTA extras depuis un bloc du guide --- */
.guest-client-extra-link {
  align-items: center;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 14px;
  color: var(--t1);
  cursor: pointer;
  display: flex;
  font: inherit;
  font-size: 13.5px;
  font-weight: 650;
  gap: 12px;
  margin-top: 10px;
  padding: 13px 14px;
  width: 100%;
}
.guest-client-extra-link > i:first-child { color: var(--accent); font-size: 16px; }
.guest-client-extra-link span { flex: 1; min-width: 0; text-align: left; }
.guest-client-extra-link > i:last-child { color: var(--t4); font-size: 12px; }

/* --- Onglet Extras --- */
.guest-extras-pane { padding-bottom: 88px; }
.guest-extras-head h2 { color: var(--t1); font-size: 18px; margin: 0 0 4px; }
.guest-extras-head p { color: var(--t3); font-size: 13px; margin: 0; }
.guest-extras-list { display: grid; gap: 12px; }
.guest-extra-card {
  align-items: center;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 16px;
  display: grid;
  gap: 12px;
  grid-template-columns: 56px minmax(0, 1fr) auto;
  padding: 12px;
  transition: border-color .15s, box-shadow .15s;
}
.guest-extra-card.is-selected { border-color: var(--accent-ring); box-shadow: 0 0 0 1px var(--accent-ring); }
.guest-extra-card.is-paid { opacity: .6; }
.guest-extra-thumb {
  align-items: center;
  background: var(--accent-soft);
  border: 0;
  border-radius: 12px;
  color: var(--accent);
  cursor: default;
  display: flex;
  font-size: 18px;
  height: 56px;
  justify-content: center;
  overflow: hidden;
  width: 56px;
}
.guest-extra-thumb.is-zoomable { cursor: zoom-in; padding: 0; }
.guest-extra-thumb.is-zoomable:hover { filter: brightness(.96); }
.guest-extra-thumb img { height: 100%; object-fit: cover; width: 100%; }
.guest-extra-main { display: grid; gap: 3px; min-width: 0; }
.guest-extra-main strong { color: var(--t1); font-size: 14px; }
.guest-extra-main small {
  color: var(--t3);
  display: -webkit-box;
  font-size: 12px;
  line-height: 1.4;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}
.guest-extra-price { color: var(--t1); font-size: 13px; font-weight: 750; }
.guest-extra-price em { color: var(--t3); font-size: 11.5px; font-style: normal; font-weight: 600; }
.guest-extra-paidnote { align-items: center; color: var(--accent-2); display: flex; font-size: 11.5px; font-weight: 700; gap: 5px; }
.guest-extra-control { flex-shrink: 0; }
.guest-extra-paid { align-items: center; color: var(--t3); display: inline-flex; font-size: 12px; font-weight: 700; gap: 6px; }
.guest-extra-paid i { color: var(--accent); }
.guest-extra-check {
  align-items: center;
  background: var(--surface);
  border: 2px solid var(--line-strong);
  border-radius: 9px;
  color: #fff;
  cursor: pointer;
  display: flex;
  font-size: 13px;
  height: 30px;
  justify-content: center;
  width: 30px;
}
.guest-extra-check.on { background: var(--accent); border-color: var(--accent); }
.guest-extra-stepper {
  align-items: center;
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: 999px;
  display: inline-flex;
  gap: 2px;
  padding: 3px;
}
.guest-extra-stepper button {
  align-items: center;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 50%;
  color: var(--t1);
  cursor: pointer;
  display: flex;
  font-size: 15px;
  height: 30px;
  justify-content: center;
  width: 30px;
}
.guest-extra-stepper button:disabled { color: var(--t4); cursor: default; opacity: .5; }
.guest-extra-stepper span { font-size: 14px; font-weight: 750; min-width: 22px; text-align: center; }
.guest-extras-bar {
  align-items: center;
  background: color-mix(in srgb, var(--surface) 94%, transparent);
  backdrop-filter: blur(14px);
  border: 1px solid var(--line);
  border-radius: 16px;
  bottom: calc(78px + env(safe-area-inset-bottom));
  box-shadow: 0 12px 30px rgba(15, 23, 42, .12);
  display: flex;
  gap: 12px;
  justify-content: space-between;
  left: 50%;
  padding: 12px 14px;
  position: fixed;
  transform: translateX(-50%);
  width: min(calc(100% - 32px), 488px);
  z-index: 19;
}
.guest-extras-total { display: grid; }
.guest-extras-total span { color: var(--t3); font-size: 11.5px; font-weight: 600; }
.guest-extras-total strong { color: var(--t1); font-size: 18px; font-weight: 850; }
.guest-extras-pay { flex-shrink: 0; margin: 0; width: auto; }

.guest-lightbox {
  position: fixed;
  z-index: 1000;
  inset: 0;
  background: rgba(0,0,0,.86);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}

.guest-lightbox[hidden] {
  display: none;
}

.guest-lightbox img {
  max-width: min(100%, 980px);
  max-height: 86vh;
  border-radius: 18px;
  object-fit: contain;
  box-shadow: 0 24px 80px rgba(0,0,0,.38);
}

.guest-lightbox-close {
  position: absolute;
  top: 18px;
  right: 18px;
  width: 44px;
  height: 44px;
  border: 0;
  border-radius: 50%;
  background: #fff;
  color: #111;
  cursor: pointer;
  font-size: 18px;
}

.guest-action-modal {
  position: fixed;
  z-index: 1001;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 18px;
  background: rgba(12, 12, 16, .62);
  backdrop-filter: blur(10px);
}

.guest-action-modal[hidden] {
  display: none;
}

.guest-action-card {
  position: relative;
  width: min(100%, 520px);
  max-height: calc(100vh - 36px);
  overflow-y: auto;
  border: 1px solid var(--line);
  border-radius: 26px;
  background: var(--surface);
  box-shadow: 0 24px 90px rgba(0,0,0,.24);
  padding: 24px;
  text-align: center;
}

.guest-action-close {
  position: absolute;
  top: 14px;
  right: 14px;
  width: 40px;
  height: 40px;
  border: 1px solid var(--line);
  border-radius: 50%;
  background: var(--surface-2);
  color: var(--t2);
  cursor: pointer;
}

.guest-action-card h2 {
  margin: 12px 0 8px;
  color: var(--t1);
  font-size: 24px;
  letter-spacing: 0;
}

.guest-action-card p {
  margin: 0 0 18px;
  color: var(--t3);
  font-size: 14px;
  line-height: 1.45;
}

.guest-camera-card video,
.guest-camera-error {
  width: 100%;
  min-height: 280px;
  border-radius: 20px;
  background: #111;
  color: #fff;
  object-fit: cover;
}

.guest-camera-error {
  display: grid;
  place-items: center;
  padding: 24px;
}

.guest-action-row {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 16px;
}

.guest-action-row .guest-client-primary {
  width: auto;
  margin-top: 0;
  padding: 0 18px;
}

.guest-action-row .guest-client-primary:disabled {
  background: var(--surface-3);
  color: var(--t4);
  cursor: not-allowed;
  box-shadow: none;
}

.guest-contract-card {
  width: min(100%, 760px);
  text-align: left;
}

.guest-contract-body {
  max-height: 34vh;
  overflow-y: auto;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: var(--surface-2);
  color: var(--t2);
  padding: 16px;
  font-size: 14px;
  line-height: 1.55;
}

.guest-contract-accept {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 14px 0;
  color: var(--t1);
  font-size: 14px;
  font-weight: 750;
}

.guest-signature-box {
  display: grid;
  gap: 8px;
}

.guest-signature-box span {
  color: var(--t2);
  font-size: 13px;
  font-weight: 800;
}

.guest-signature-box canvas {
  width: 100%;
  height: 170px;
  border: 1.5px dashed var(--line-strong);
  border-radius: 18px;
  background: var(--surface);
  touch-action: none;
}

.guest-signature-box canvas.is-disabled {
  background: var(--surface-2);
  cursor: not-allowed;
  opacity: .55;
}

[data-theme="dark"] .guest-contract-body,
[data-theme="dark"] .guest-contract-accept,
[data-theme="dark"] .guest-signature-box span {
  color: var(--t1);
}

[data-theme="dark"] .guest-signature-box canvas {
  background: #15161b;
  border-color: rgba(255, 255, 255, .28);
}

[data-theme="dark"] .guest-signature-box canvas.is-disabled {
  background: var(--surface-2);
}

@media (max-width: 560px) {
  .guest-client-form-field.guest-client-file-field {
    grid-template-columns: auto minmax(0, 1fr);
  }

  .guest-file-button {
    grid-column: 1 / -1;
    justify-content: center;
    width: 100%;
  }
}

@media (max-width: 560px) {
  .guest-client-shell {
    width: 100%;
    min-height: 100vh;
    box-shadow: none;
  }

  .guest-client-hero,
  .guest-client-hero img,
  .guest-client-hero-empty {
    height: 286px;
    min-height: 286px;
  }

  .guest-client-status {
    padding: 0 18px;
  }

  .guest-client-hero-caption {
    left: 18px;
    right: 18px;
  }

  .guest-client-hero-caption h1 {
    font-size: 28px;
  }

  .guest-client-content {
    padding: 18px 12px 22px;
  }

  .guest-client-step {
    padding: 20px 16px;
  }

  .guest-client-arrival-box {
    grid-template-columns: 1fr;
  }

  .guest-client-validation-item {
    grid-template-columns: auto minmax(0, 1fr);
  }

  .guest-client-validation-item em {
    grid-column: 2;
    width: fit-content;
  }

  .guest-client-gallery.count-3,
  .guest-client-gallery.count-5,
  .guest-client-gallery.count-6 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .guest-client-gallery.count-3 button:nth-child(3),
  .guest-client-gallery.count-5 button:nth-child(4),
  .guest-client-gallery.count-5 button:nth-child(5) {
    grid-column: auto;
  }

  .guest-client-address-grid {
    grid-template-columns: 1fr;
  }

  .guest-client-payment-box,
  .guest-client-camera-box,
  .guest-client-contract-box {
    grid-template-columns: auto minmax(0, 1fr);
  }

  .guest-client-payment-box button,
  .guest-client-camera-box button,
  .guest-client-contract-box button {
    grid-column: 1 / -1;
    width: 100%;
  }

  .guest-action-card {
    border-radius: 22px;
    padding: 22px 16px;
  }

  .guest-action-row {
    flex-direction: column-reverse;
  }

  .guest-action-row .guest-client-primary,
  .guest-action-row .ms-btn-ghost {
    width: 100%;
  }
}
.cal-msg-drawer-compose-row { display: flex; align-items: center; gap: 7px; }
.cal-msg-tpl-btn {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 0 11px; height: 36px; border-radius: 9px;
  border: 1.5px solid var(--line-strong); background: var(--surface);
  color: var(--t2); font-size: 12px; font-weight: 600; cursor: pointer;
  white-space: nowrap; flex-shrink: 0; font-family: inherit; transition: background .12s;
}
.cal-msg-tpl-btn:hover { background: var(--surface-2); }
.cal-msg-tpl-btn i { color: var(--accent); }
.cal-msg-textarea {
  flex: 1; min-height: 36px; max-height: 45vh; padding: 8px 12px;
  border: 1.5px solid var(--line-strong); border-radius: 14px;
  font: inherit; font-size: 13px; color: var(--t1);
  resize: none; background: var(--surface-2); outline: none; line-height: 1.55;
  overflow-y: hidden;
}
.cal-msg-textarea:focus { border-color: var(--accent); background: var(--surface); }
.cal-msg-send-btn {
  width: 36px; height: 36px; border-radius: 50%;
  background: var(--accent); border: none; color: #fff;
  font-size: 14px; display: flex; align-items: center; justify-content: center;
  cursor: pointer; flex-shrink: 0; transition: background .14s;
}
.cal-msg-send-btn:hover { background: var(--accent-2); }

/* ═══════════════════════════════════════════════════════════════
   CALENDRIER — Modal réservation desktop (Option D)
   ═══════════════════════════════════════════════════════════════ */
.cal-modal-overlay {
  position: fixed; inset: 0;
  background: rgba(10, 16, 28, .52);
  display: flex; align-items: center; justify-content: center;
  padding: 32px 24px;
  z-index: 900;
  backdrop-filter: blur(3px);
  -webkit-backdrop-filter: blur(3px);
}
.cal-modal-overlay[hidden] { display: none; }

.cal-modal {
  background: var(--surface);
  border-radius: 20px;
  width: 100%; max-width: 900px;
  height: min(740px, 88vh);
  display: flex; flex-direction: column;
  box-shadow: 0 28px 72px rgba(10,16,28,.26), 0 4px 16px rgba(0,0,0,.10);
  overflow: hidden;
  animation: calModalIn .22s cubic-bezier(.34,1.2,.64,1);
}
@keyframes calModalIn {
  from { opacity: 0; transform: scale(.95) translateY(10px); }
  to   { opacity: 1; transform: scale(1) translateY(0); }
}

/* Header */
.cal-modal-header {
  padding: 22px 26px 0;
  background: var(--surface);
  flex-shrink: 0;
  border-bottom: 2px solid var(--line);
}
.cal-modal-hdr-top {
  display: flex; align-items: flex-start; gap: 14px;
  margin-bottom: 18px;
}
.cal-modal-avatar {
  width: 52px; height: 52px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-weight: 800; font-size: 19px; color: #fff; flex-shrink: 0;
}
.cal-modal-info { flex: 1; min-width: 0; }
.cal-modal-name {
  font-size: 17px; font-weight: 700; color: var(--t1);
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
  line-height: 1.3;
}
.cal-modal-sub { font-size: 13px; color: var(--t3); margin-top: 5px; }
.cal-modal-close {
  width: 34px; height: 34px; border-radius: 9px;
  border: 1.5px solid var(--line-strong); background: var(--surface);
  color: var(--t3); cursor: pointer; font-size: 15px;
  display: flex; align-items: center; justify-content: center;
  transition: all .15s; flex-shrink: 0;
}
.cal-modal-close:hover { background: var(--surface-2); color: var(--t1); }

/* Tabs */
.cal-modal-tabs { display: flex; gap: 0; }
.cal-modal-tab {
  padding: 12px 22px;
  font-size: 13px; font-weight: 600; font-family: inherit;
  color: var(--t3); background: none; border: none; cursor: pointer;
  border-bottom: 2.5px solid transparent;
  margin-bottom: -2px;
  display: flex; align-items: center; gap: 7px;
  transition: color .15s;
}
.cal-modal-tab.active { color: var(--accent); border-bottom-color: var(--accent); }
.cal-modal-tab:hover:not(.active) { color: var(--t1); }
.cal-modal-tab-badge {
  background: var(--accent); color: #fff;
  border-radius: 20px; padding: 1px 6px; font-size: 10px; font-weight: 700;
}

/* Body */
.cal-modal-body {
  flex: 1; overflow: hidden; min-height: 0;
  display: flex; flex-direction: column;
}
.cal-modal-pane {
  flex: 1; overflow-y: auto; padding: 22px 26px;
}
.cal-modal-pane--msg {
  flex: 1; display: flex; flex-direction: column; overflow: hidden; padding: 0;
}

/* Thread messagerie */
.cal-modal-thread {
  flex: 1; overflow-y: auto; padding: 18px 20px;
  display: flex; flex-direction: column; gap: 2px;
  background: var(--bg);
}

/* Zone de composition */
.cal-modal-compose {
  padding: 12px 16px 14px;
  border-top: 1px solid var(--line);
  background: var(--surface);
  flex-shrink: 0;
}
.cal-modal-compose-row { display: flex; align-items: center; gap: 8px; }
.cal-modal-textarea {
  flex: 1; min-height: 38px; max-height: 35vh; padding: 9px 14px;
  border: 1.5px solid var(--line-strong); border-radius: 12px;
  font: inherit; font-size: 13px; color: var(--t1);
  resize: none; background: var(--surface-2); outline: none; line-height: 1.55;
  overflow-y: hidden;
  transition: border-color .15s, background .15s;
}
.cal-modal-textarea:focus { border-color: var(--accent); background: var(--surface); }

/* Sur mobile : le modal n'est pas utilisé (panneaux plein écran à la place) */
@media (max-width: 768px) {
  .cal-modal-overlay { display: none !important; }
}

/* ── Badges header modal ───────────────────────────────────────────────────── */
.cal-modal-ota-badge {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 3px 10px 3px 7px; border-radius: 20px;
  background: var(--surface-2); color: var(--t2);
  font-size: 12px; font-weight: 600; vertical-align: middle;
  border: 1px solid var(--line);
}
.cal-modal-ota-badge .source-logo { width: 16px; height: 16px; border-radius: 3px; object-fit: contain; }
.cal-modal-ota-badge .source-logo-fallback {
  width: 16px; height: 16px; border-radius: 3px;
  background: var(--surface-3); display: inline-flex; align-items: center; justify-content: center;
  font-size: 10px; font-weight: 800; color: var(--t2);
}
.cal-modal-status-badge {
  display: inline-flex; align-items: center;
  padding: 3px 10px; border-radius: 20px;
  font-size: 11px; font-weight: 700; vertical-align: middle;
}

/* ═══════════════════════════════════════════════════════════════════════════
   MODAL DÉTAIL — Layout moderne (cmd-*)
   ═══════════════════════════════════════════════════════════════════════════ */

/* Carte logement (photo 4:3 à gauche + infos à droite) */
.cmd-banner {
  display: flex; gap: 0;
  background: var(--surface-2);
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid var(--line);
  margin-bottom: 20px;
  min-height: 0;
}
.cmd-prop-photo {
  width: 260px; flex-shrink: 0;
  aspect-ratio: 4/3;
  object-fit: cover; object-position: center 25%;
  display: block;
}
.cmd-prop-photo.property-photo-fallback {
  width: 260px; flex-shrink: 0;
  aspect-ratio: 4/3;
  display: flex; align-items: center; justify-content: center;
  font-size: 56px; font-weight: 900; color: rgba(255,255,255,.55);
  background: linear-gradient(135deg, var(--accent), #c05c20);
}
.cmd-banner-overlay {
  flex: 1; min-width: 0;
  padding: 20px 22px;
  display: flex; flex-direction: column; justify-content: center; gap: 6px;
  background: transparent;
}
.cmd-prop-name {
  font-size: 17px; font-weight: 700; color: var(--t1); line-height: 1.2;
}
.cmd-prop-addr {
  font-size: 12px; color: var(--t3);
  display: flex; align-items: center; gap: 5px;
}

/* Cartes infos */
.cmd-cards {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 10px; margin-bottom: 12px;
}
.cmd-cards-status {
  margin-bottom: 20px;
}
.cmd-card {
  background: var(--surface-2); border-radius: 14px;
  padding: 14px 12px; display: flex; gap: 10px; align-items: flex-start;
  border: 1px solid var(--line);
}
.cmd-card-button {
  color: inherit;
  cursor: pointer;
  font: inherit;
  text-align: left;
  transition: background 0.15s, border-color 0.15s, transform 0.12s;
  width: 100%;
}
.cmd-card-button:hover {
  background: var(--surface-3);
  border-color: var(--line-strong);
}
.cmd-card-button:active {
  transform: scale(0.99);
}
.cmd-card-ico {
  width: 32px; height: 32px; border-radius: 9px;
  background: var(--surface); display: flex; align-items: center; justify-content: center;
  font-size: 13px; color: var(--accent); flex-shrink: 0;
  border: 1px solid var(--line);
}
.cmd-card-label {
  font-size: 10px; font-weight: 700; color: var(--t3);
  text-transform: uppercase; letter-spacing: .05em; margin-bottom: 4px;
}
.cmd-card-value { font-size: 14px; font-weight: 700; color: var(--t1); }
.cmd-card-sub   { font-size: 11px; color: var(--t3); margin-top: 3px; }

.reservation-deposit-modal {
  max-width: 460px;
}
.reservation-deposit-summary {
  border: 1px solid var(--line);
  border-radius: 14px;
  display: grid;
  gap: 0;
  margin: 14px 0;
  overflow: hidden;
}
.reservation-deposit-summary > div {
  align-items: center;
  background: var(--surface-2);
  border-bottom: 1px solid var(--line);
  display: flex;
  gap: 12px;
  justify-content: space-between;
  padding: 12px 14px;
}
.reservation-deposit-summary > div:last-child {
  border-bottom: 0;
}
.reservation-deposit-summary span {
  color: var(--t3);
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
}
.reservation-deposit-summary strong {
  color: var(--t1);
  font-size: 13px;
  text-align: right;
}
.reservation-deposit-actions {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-bottom: 12px;
}
.reservation-deposit-actions .app-modal-btn {
  justify-content: center;
  min-width: 0;
  width: 100%;
}
.reservation-deposit-actions .app-modal-btn i {
  flex-shrink: 0;
}

@media (max-width: 720px) {
  .cmd-cards {
    grid-template-columns: 1fr;
  }

  .reservation-deposit-actions {
    grid-template-columns: 1fr;
  }

  .reservation-deposit-summary > div {
    align-items: flex-start;
    flex-direction: column;
    gap: 4px;
  }

  .reservation-deposit-summary strong {
    text-align: left;
  }
}

/* Sections */
.cmd-section { margin-bottom: 18px; }
.cmd-section-title {
  font-size: 10px; font-weight: 800; color: var(--t3);
  text-transform: uppercase; letter-spacing: .07em;
  margin-bottom: 10px;
  display: flex; align-items: center; gap: 6px;
}

/* Finances */
.cmd-finance-row {
  display: flex; gap: 0;
  background: var(--surface-2); border-radius: 14px; overflow: hidden;
  border: 1px solid var(--line);
}
.cmd-finance-item {
  flex: 1; padding: 14px 16px;
  border-right: 1px solid var(--line);
}
.cmd-finance-item:last-child { border-right: none; }
.cmd-fi-net { background: rgba(46,171,110,.07); }
.cmd-fl { font-size: 10px; font-weight: 700; color: var(--t3); text-transform: uppercase; letter-spacing: .05em; margin-bottom: 5px; }
.cmd-fv { font-size: 17px; font-weight: 800; color: var(--t1); }
.cmd-fv-red   { color: #e05555; }
.cmd-fv-green { color: #2EAB6E; }

/* Voyageur */
.cmd-guest-row {
  display: flex; align-items: center; gap: 13px;
  background: var(--surface-2); border-radius: 14px; padding: 14px 16px;
  border: 1px solid var(--line);
}
.cmd-guest-av {
  width: 42px; height: 42px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-weight: 800; font-size: 15px; color: #fff; flex-shrink: 0;
}
.cmd-guest-name { font-size: 14px; font-weight: 700; color: var(--t1); }
.cmd-guest-meta {
  font-size: 12px; color: var(--t3); margin-top: 4px;
  display: flex; align-items: center; gap: 5px;
}

/* Ménage */
.cmd-cleaning {
  background: var(--surface-2); border-radius: 14px; padding: 13px 16px;
  font-size: 13px; color: var(--t2); border: 1px solid var(--line);
}

/* Actions */
.cmd-actions { padding-top: 4px; padding-bottom: 4px; display: flex; flex-direction: column; gap: 8px; }
.cmd-delete-btn {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 9px 16px; border-radius: 10px;
  border: 1.5px solid rgba(224,85,85,.3); background: rgba(224,85,85,.07);
  color: #e05555; font-size: 13px; font-weight: 600; cursor: pointer;
  font-family: inherit; transition: background .14s, border-color .14s;
}
.cmd-delete-btn:hover { background: rgba(224,85,85,.14); border-color: rgba(224,85,85,.5); }
.cmd-edit-btn {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 9px 16px; border-radius: 10px;
  border: 1.5px solid var(--accent); background: transparent;
  color: var(--accent); font-size: 13px; font-weight: 600; cursor: pointer;
  font-family: inherit; text-decoration: none;
  transition: background .14s, color .14s;
}
.cmd-edit-btn:hover { background: var(--accent); color: #fff; }

.reservations-mode [data-reservation-detail-inline] .cmd-actions {
  align-items: center;
  display: flex;
  flex-direction: row;
  gap: 10px;
  justify-content: flex-end;
  margin: 20px -24px -20px;
  padding: 14px 24px;
  border-top: 1px solid var(--line);
}

.reservations-mode [data-reservation-detail-inline] .cmd-edit-btn {
  align-items: center;
  background: var(--accent);
  border: 0;
  border-radius: 999px;
  color: #fff;
  display: inline-flex;
  font-size: 14px;
  font-weight: 700;
  gap: 8px;
  min-height: 42px;
  padding: 0 18px;
}

.reservations-mode [data-reservation-detail-inline] .cmd-edit-btn:hover {
  background: var(--accent-2);
  color: #fff;
}

.reservations-mode [data-reservation-detail-inline] .cmd-delete-btn {
  align-items: center;
  background: transparent;
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  color: #ef4444;
  display: inline-flex;
  font-size: 14px;
  font-weight: 700;
  gap: 8px;
  min-height: 42px;
  padding: 0 18px;
}

.reservations-mode [data-reservation-detail-inline] .cmd-delete-btn:hover {
  background: rgba(239, 68, 68, 0.08);
  border-color: rgba(239, 68, 68, 0.35);
}

#calModalPaneDetail .cmd-actions,
#rdmPaneDetail .cmd-actions {
  align-items: center;
  border-top: 1px solid var(--line);
  display: flex;
  flex-direction: row;
  gap: 10px;
  justify-content: flex-end;
  margin: 20px -26px -22px;
  padding: 14px 26px;
}

#calModalPaneDetail .cmd-edit-btn,
#rdmPaneDetail .cmd-edit-btn {
  align-items: center;
  background: var(--accent);
  border: 0;
  border-radius: 999px;
  color: #fff;
  display: inline-flex;
  font-size: 14px;
  font-weight: 700;
  gap: 8px;
  min-height: 42px;
  padding: 0 18px;
}

#calModalPaneDetail .cmd-edit-btn:hover,
#rdmPaneDetail .cmd-edit-btn:hover {
  background: var(--accent-2);
  color: #fff;
}

#calModalPaneDetail .cmd-delete-btn,
#rdmPaneDetail .cmd-delete-btn {
  align-items: center;
  background: transparent;
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  color: #ef4444;
  display: inline-flex;
  font-size: 14px;
  font-weight: 700;
  gap: 8px;
  min-height: 42px;
  padding: 0 18px;
}

#calModalPaneDetail .cmd-delete-btn:hover,
#rdmPaneDetail .cmd-delete-btn:hover {
  background: rgba(239, 68, 68, 0.08);
  border-color: rgba(239, 68, 68, 0.35);
}

/* ── Réservations page : carte blanche avec onglets ─────────────────────── */
.res-page-card {
  background: var(--surface);
  border-radius: 16px;
  border: 1px solid var(--line);
  box-shadow: var(--shadow-1);
  display: flex;
  flex-direction: column;
}
.res-page-tabs {
  display: flex;
  border-bottom: 2px solid var(--line);
  padding: 0 6px;
  flex-shrink: 0;
  border-radius: 16px 16px 0 0;
}
.res-page-pane:last-child,
.res-page-pane--msg:last-child {
  border-radius: 0 0 16px 16px;
}
.res-page-tab {
  padding: 12px 20px;
  font-size: 13px; font-weight: 600; font-family: inherit;
  color: var(--t3); background: none; border: none; cursor: pointer;
  border-bottom: 2.5px solid transparent;
  margin-bottom: -2px;
  display: flex; align-items: center; gap: 7px;
  transition: color .15s;
}
.res-page-tab.active  { color: var(--accent); border-bottom-color: var(--accent); }
.res-page-tab:hover:not(.active) { color: var(--t1); }
.res-page-pane { padding: 20px 24px; }
.res-page-pane--billing { background: var(--bg); }
.res-page-pane--msg {
  padding: 0;
  height: 480px;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
/* Sur grand écran le panneau est plus haut — on peut mettre plus de hauteur */
@media (min-height: 800px) {
  .res-page-pane--msg { height: 560px; }
}
/* Sur mobile, hauteur auto */
@media (max-width: 900px) {
  .res-page-pane--msg { height: 420px; }
}

/* ── Mode messagerie étendu : pleine hauteur viewport (desktop ≥ 641px) ─── */
@media (min-width: 641px) {
  /* Verrouiller body/.app à 100vh — même technique que la page Messagerie */
  body:has(.page-split-detail.res-msg-active) {
    height: 100vh;
    overflow: hidden;
  }
  body:has(.page-split-detail.res-msg-active) .app {
    height: 100vh;
    overflow: hidden;
  }
  body:has(.page-split-detail.res-msg-active) .main {
    min-height: 0;
    overflow: hidden;
  }

  /* 1. Le panneau de droite → colonne flex fixe
        padding identique à l'onglet Détail → même position, même espace en bas */
  .page-split-detail.res-msg-active {
    display: flex;
    flex-direction: column;
    overflow: hidden;
    padding: 24px 28px;          /* idem mode Détail : même marges haut/bas/côtés */
  }
  /* 2. Workspace → remplit la hauteur disponible dans le padding du panneau */
  .res-msg-active [data-reservation-workspace] {
    flex: 1;
    min-height: 0;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    padding-bottom: 0 !important; /* pas de padding-bottom interne (ms-detail-content en a 78px) */
  }
  /* 3. Header guest → taille fixe en haut */
  .res-msg-active [data-reservation-workspace] > .ms-prop-card {
    flex-shrink: 0;
  }
  /* 4. Conteneur inline → propage le flex vers la carte */
  .res-msg-active [data-reservation-detail-inline] {
    flex: 1;
    min-height: 0;
    display: flex;
    flex-direction: column;
    overflow: hidden;
  }
  /* 5. La carte → remplit la hauteur, garde bordures + coins arrondis */
  .res-msg-active .res-page-card {
    flex: 1;
    min-height: 0;
    overflow: hidden;
  }
  /* 6. Panneau messagerie → remplit la carte */
  .res-msg-active .res-page-pane--msg {
    flex: 1;
    height: auto !important;
    min-height: 0;
  }
}
/* Thread : fond blanc → cohérence avec l'onglet Détail */
.res-msg-active .cal-modal-thread {
  background: var(--surface);
}

/* ── Formulaire d'édition inline (popup calendrier, dashboard, page réservations) */
.res-inline-edit-form {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.res-edit-section {
  padding: 16px 0;
  border-bottom: 1px solid var(--line);
}
.res-edit-section:last-of-type { border-bottom: none; }
.res-edit-section-title {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--t3);
  margin-bottom: 12px;
}
.res-edit-actions {
  border-top: 1px solid var(--line);
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin: 0 -24px -20px;
  padding: 16px 24px;
}

.res-edit-actions .btn,
.res-edit-actions .btn-primary,
.res-edit-actions .btn-secondary {
  border-radius: 999px;
  font-size: 14px;
  font-weight: 700;
  min-height: 42px;
  padding: 0 18px;
}

/* ══════════════════════════════════════════════════════════════════════════════
   RÉTABLISSEMENT MODALES BACKDROP
   Le .cal-modal de l'Option D (z-index 900, overlay) surcharge .cal-modal
   (z-index 1100, backdrop) car il est déclaré plus bas dans le fichier.
   Ces règles plus spécifiques rétablissent les styles corrects pour les modales
   calendrier classiques (blocage / prix / nouvelle réservation).
   ══════════════════════════════════════════════════════════════════════════════ */
.cal-modal-backdrop > .cal-modal {
  max-width: 480px;
  width: 100%;
  height: auto;
  max-height: none;      /* le backdrop scroll, la modale grandit librement */
  overflow: visible;     /* les panneaux date-picker ne sont pas coupés */
  border-radius: 16px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.22), 0 4px 16px rgba(0,0,0,0.12);
  animation: none;
  margin: auto;          /* centrage vertical quand le backdrop a de l'espace */
}
/* Largeur élargie pour la modale nouvelle réservation */
.cal-modal-backdrop > .cal-newres-modal {
  max-width: 680px;
}
/* Sur mobile : la modale prend tout l'écran et défile elle-même */
@media (max-width: 600px) {
  .cal-modal-backdrop > .cal-modal {
    max-width: 100%;
    border-radius: 0;
    height: 100%;
    overflow-y: auto;
    margin: 0;
    align-self: stretch;
  }
}

/* ══════════════════════════════════════════════════════════════
   VUE JOUR — Design moderne 2025
   ══════════════════════════════════════════════════════════════ */

.cdv-outer {
  max-width: 1280px;
  padding: 24px 28px 48px;
}

/* ── Vignettes (cards) ── */
.cdv-cards {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 12px;
}

.cdv-card {
  background: var(--surface);
  border: 1.5px solid var(--line);
  border-radius: 14px;
  padding: 16px 12px 14px;
  text-align: center;
  cursor: pointer;
  transition: all 0.18s ease;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
}

.cdv-card:hover {
  border-color: var(--line-strong);
  box-shadow: 0 4px 16px -4px rgba(12,12,16,0.08);
  transform: translateY(-2px);
}

.cdv-card.is-today {
  border-color: var(--accent);
  box-shadow: 0 0 0 1px var(--accent-ring);
}

.cdv-card.is-selected {
  border-color: var(--accent);
  background: var(--accent-soft);
  box-shadow: 0 0 0 3px var(--accent-ring), 0 4px 16px -4px rgba(245,135,77,0.15);
}

.cdv-card.is-selected:hover {
  transform: none;
}

.cdv-card-day {
  font-size: 11px;
  font-weight: 600;
  color: var(--t4);
  text-transform: capitalize;
  letter-spacing: 0.02em;
}

.cdv-card.is-today .cdv-card-day,
.cdv-card.is-today .cdv-card-month {
  color: var(--accent-2);
  font-weight: 700;
}

.cdv-card-num {
  font-size: 32px;
  font-weight: 800;
  color: var(--t1);
  line-height: 1.1;
  letter-spacing: -0.02em;
}

.cdv-card.is-today .cdv-card-num {
  color: var(--accent-2);
}

.cdv-card-month {
  font-size: 10.5px;
  color: var(--t4);
  margin-bottom: 8px;
}

.cdv-card-counts {
  display: flex;
  flex-direction: column;
  gap: 2px;
  font-size: 11px;
  color: var(--t4);
  width: 100%;
}

.cdv-card-counts.is-empty .cdv-count {
  opacity: 0.5;
}

.cdv-count {
  white-space: nowrap;
  line-height: 1.5;
}

/* Couleurs des compteurs quand > 0 */
.cdv-count[data-type="arrivals"].has-data { color: #1E9E5F; font-weight: 600; }
.cdv-count[data-type="departures"].has-data { color: var(--accent-2); font-weight: 600; }
.cdv-count[data-type="cleaning"].has-data { color: #3478F6; font-weight: 600; }

/* ── Onglets Ménage / Départs / Arrivées ── */
.cdv-tabs {
  display: flex;
  gap: 0;
  border-bottom: 1.5px solid var(--line);
  margin-top: 28px;
}

.cdv-tab {
  padding: 11px 22px;
  font-size: 13.5px;
  font-weight: 600;
  color: var(--t3);
  background: none;
  border: none;
  border-bottom: 2.5px solid transparent;
  margin-bottom: -1.5px;
  cursor: pointer;
  transition: color 0.15s, border-color 0.15s;
  display: flex;
  align-items: center;
  gap: 7px;
}

.cdv-tab:hover { color: var(--t1); }

.cdv-tab.is-active {
  color: var(--t1);
  border-bottom-color: var(--accent);
}

.cdv-tab-badge {
  background: var(--accent);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 10px;
  min-width: 18px;
  text-align: center;
  line-height: 1.4;
}

/* ── En-tête colonnes ── */
.cdv-detail-head {
  display: grid;
  grid-template-columns: 240px 1fr 140px 1fr;
  gap: 16px;
  padding: 14px 20px;
  font-size: 11.5px;
  font-weight: 600;
  color: var(--t4);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  border-bottom: 1px solid var(--line);
}

/* ── Lignes de détail ── */
.cdv-detail-body {
  /* conteneur des lignes */
}

.cdv-detail-row {
  display: grid;
  grid-template-columns: 240px 1fr 140px 1fr;
  gap: 16px;
  padding: 16px 20px;
  align-items: center;
  border-bottom: 1px solid var(--line);
  cursor: pointer;
  transition: background 0.12s;
  border-radius: 0;
}

.cdv-detail-row:hover {
  background: var(--surface-2);
}

.cdv-detail-row:last-child {
  border-bottom: none;
}

.cdv-detail-prop {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}

.cdv-detail-photo {
  width: 42px;
  height: 42px;
  border-radius: 10px;
  object-fit: cover;
  flex-shrink: 0;
  border: 1px solid var(--line);
}

.cdv-detail-photo-fallback {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--surface-3);
  color: var(--t3);
  font-size: 15px;
  font-weight: 700;
}

.cdv-detail-prop-name {
  font-size: 13.5px;
  font-weight: 600;
  color: var(--t1);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.cdv-detail-guest-name {
  font-size: 13.5px;
  font-weight: 500;
  color: var(--t1);
}

.cdv-detail-guest-meta {
  font-size: 11.5px;
  color: var(--t3);
  margin-top: 3px;
  display: flex;
  align-items: center;
  gap: 10px;
}

.cdv-detail-guest-meta i {
  font-size: 10px;
  margin-right: 3px;
  opacity: 0.6;
}

.cdv-detail-time {
  font-size: 14px;
  font-weight: 600;
  color: var(--t1);
}

.cdv-detail-cleaning {
  font-size: 12.5px;
}

.cdv-clean-status {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 12px;
  border-radius: 8px;
  font-size: 12px;
  font-weight: 500;
}

.cdv-clean-done {
  color: #1E9E5F;
  background: rgba(30,158,95,0.08);
}

.cdv-clean-assigned {
  color: #3478F6;
  background: rgba(52,120,246,0.08);
}

.cdv-clean-none {
  color: var(--t4);
  background: var(--surface-3);
}

.cdv-clean-assigned-label {
  color: var(--t2);
  font-size: 12px;
}

.cdv-detail-empty {
  padding: 56px 18px;
  text-align: center;
  color: var(--t4);
  font-size: 13.5px;
}

.cdv-detail-empty i {
  display: block;
  font-size: 28px;
  margin-bottom: 10px;
  opacity: 0.4;
}

/* ── Responsive ── */
@media (max-width: 1100px) {
  .cdv-cards { grid-template-columns: repeat(4, 1fr); }
}

@media (max-width: 768px) {
  .cdv-outer { padding: 16px 14px 32px; }
  .cdv-cards { grid-template-columns: repeat(3, 1fr); gap: 8px; }
  .cdv-detail-head,
  .cdv-detail-row { grid-template-columns: 160px 1fr 100px; }
  .cdv-detail-cleaning { display: none; }
}

@media (max-width: 500px) {
  .cdv-cards { grid-template-columns: repeat(2, 1fr); }
}

/* ====================================================================== */
/*  EXPERIENCE — Mode « Site de réservation » (config côté hôte)         */
/* ====================================================================== */
.booking-intro-text { color: var(--t3); font-size: 14px; line-height: 1.55; margin: 10px 0 0; max-width: 720px; }

.booking-site-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 16px;
  margin-top: 22px;
}
.booking-site-card {
  border: 1px solid var(--line);
  background: var(--surface);
  border-radius: 16px;
  overflow: hidden;
  cursor: pointer;
  text-align: left;
  padding: 0;
  display: flex;
  flex-direction: column;
  transition: border-color .2s ease, box-shadow .2s ease, transform .15s ease;
}
.booking-site-card:hover { border-color: var(--bs-accent, var(--accent)); box-shadow: 0 10px 28px -12px rgba(0,0,0,.2); }
.booking-site-card:active { transform: scale(.99); }
.booking-site-card-top {
  position: relative;
  height: 92px;
  background: linear-gradient(135deg, var(--bs-accent, var(--accent)), color-mix(in srgb, var(--bs-accent, var(--accent)) 60%, #000));
  display: flex; align-items: center; justify-content: center;
}
.booking-site-card-top i { color: #fff; font-size: 26px; opacity: .92; }
.booking-site-card-badge {
  position: absolute; top: 10px; right: 10px;
  background: rgba(255,255,255,.92); color: #1a1a1e;
  font-size: 10.5px; font-weight: 700;
  padding: 3px 9px; border-radius: 999px;
}
.booking-site-card-meta { display: flex; flex-direction: column; gap: 4px; padding: 14px 16px 16px; }
.booking-site-card-meta strong { color: var(--t1); font-size: 15px; font-weight: 750; }
.booking-site-card-meta small { color: var(--t3); font-size: 12px; }
.booking-site-card-meta em {
  align-self: start; margin-top: 6px;
  display: inline-flex; align-items: center; gap: 5px;
  font-style: normal; font-size: 11.5px; font-weight: 700;
  color: var(--bs-accent, var(--accent));
  border: 1.5px solid var(--bs-accent, var(--accent));
  border-radius: 8px; padding: 5px 10px;
}
.booking-site-create {
  border: 2px dashed var(--line-strong);
  background: var(--surface-2);
  border-radius: 16px;
  cursor: pointer;
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 6px;
  min-height: 200px; padding: 20px;
  color: var(--t2); text-align: center;
  transition: border-color .2s ease, color .2s ease, background .2s ease;
}
.booking-site-create:hover { border-color: var(--accent); color: var(--accent); background: var(--accent-soft); }
.booking-site-create-ic { width: 44px; height: 44px; border-radius: 50%; background: var(--accent); color: #fff; display: grid; place-items: center; font-size: 18px; }
.booking-site-create span { font-size: 14px; font-weight: 700; }
.booking-site-create small { font-size: 12px; color: var(--t3); }

/* ---- Éditeur d'un site ---- */
.booking-editor { display: flex; flex-direction: column; gap: 16px; max-width: 760px; margin: 0 auto; }
.booking-editor-head { display: flex; align-items: center; gap: 12px; }
.booking-editor-head .prop-back-btn { flex-shrink: 0; }
.booking-editor-titles { flex: 1; min-width: 0; }
.booking-editor-titles h1 { font-size: 22px; margin: 2px 0 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.booking-preview-btn {
  flex-shrink: 0;
  display: inline-flex; align-items: center; gap: 7px;
  background: var(--bs-accent, var(--accent)); color: #fff;
  border: 0; border-radius: 10px; cursor: pointer;
  font-size: 13px; font-weight: 700; padding: 9px 14px;
}
.booking-preview-btn:hover { filter: brightness(.95); }

.booking-card { background: var(--surface); border: 1px solid var(--line); border-radius: 16px; padding: 20px; }
.booking-card-head { display: flex; align-items: flex-start; gap: 12px; margin-bottom: 16px; }
.booking-card-ic { flex-shrink: 0; width: 38px; height: 38px; border-radius: 10px; background: var(--accent-soft); color: var(--bs-accent, var(--accent)); display: grid; place-items: center; font-size: 15px; }
.booking-card-ic.is-danger { background: rgba(239,68,68,.12); color: #ef4444; }
.booking-card-head h2 { font-size: 15px; font-weight: 750; margin: 1px 0 0; }
.booking-card-head p { font-size: 12.5px; color: var(--t3); margin: 3px 0 0; line-height: 1.45; }

.booking-input {
  width: 100%; box-sizing: border-box;
  border: 1px solid var(--line-strong); border-radius: 10px;
  background: var(--surface-2); color: var(--t1);
  font-size: 14px; padding: 11px 14px;
}
.booking-input:focus { outline: none; border-color: var(--bs-accent, var(--accent)); }

.booking-prop-search { margin-bottom: 12px; }
.booking-prop-list { display: flex; flex-direction: column; gap: 8px; max-height: 360px; overflow-y: auto; }
.booking-prop-row {
  display: flex; align-items: center; gap: 12px;
  border: 1px solid var(--line); border-radius: 12px;
  background: var(--surface-2); cursor: pointer;
  padding: 8px 12px 8px 8px; text-align: left;
  transition: border-color .15s ease, background .15s ease;
}
.booking-prop-row:hover { border-color: var(--line-strong); }
.booking-prop-row.is-on { border-color: var(--bs-accent, var(--accent)); background: var(--accent-soft); }
.booking-prop-thumb { flex-shrink: 0; width: 46px; height: 46px; border-radius: 9px; overflow: hidden; background: var(--accent-soft); }
.booking-prop-thumb img { width: 100%; height: 100%; object-fit: cover; }
.booking-prop-fallback { width: 100%; height: 100%; display: grid; place-items: center; color: var(--accent); font-weight: 800; font-size: 18px; }
.booking-prop-info { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.booking-prop-info strong { font-size: 14px; font-weight: 700; color: var(--t1); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.booking-prop-info small { font-size: 12px; color: var(--t3); }
.booking-prop-check {
  flex-shrink: 0; width: 24px; height: 24px; border-radius: 7px;
  border: 2px solid var(--line-strong); display: grid; place-items: center;
  color: #fff; font-size: 12px;
}
.booking-prop-check.on { background: var(--bs-accent, var(--accent)); border-color: var(--bs-accent, var(--accent)); }

.booking-swatches { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; }
.booking-swatch { width: 34px; height: 34px; border-radius: 50%; border: 2px solid transparent; cursor: pointer; box-shadow: 0 0 0 1px var(--line) inset; }
.booking-swatch.is-active { border-color: var(--surface); box-shadow: 0 0 0 2px var(--t1); }
.booking-swatch-custom { position: relative; width: 34px; height: 34px; border-radius: 50%; border: 2px dashed var(--line-strong); display: grid; place-items: center; cursor: pointer; color: var(--t2); overflow: hidden; }
.booking-swatch-custom input[type="color"] { position: absolute; inset: 0; opacity: 0; cursor: pointer; border: 0; padding: 0; }

.booking-mode-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.booking-mode-opt {
  display: flex; flex-direction: column; gap: 4px; align-items: flex-start;
  border: 1.5px solid var(--line-strong); border-radius: 12px;
  background: var(--surface-2); cursor: pointer; padding: 14px;
  text-align: left; transition: border-color .15s ease, background .15s ease;
}
.booking-mode-opt i { font-size: 18px; color: var(--t2); margin-bottom: 4px; }
.booking-mode-opt strong { font-size: 13.5px; color: var(--t1); }
.booking-mode-opt small { font-size: 11.5px; color: var(--t3); line-height: 1.4; }
.booking-mode-opt.is-active { border-color: var(--bs-accent, var(--accent)); background: var(--accent-soft); }
.booking-mode-opt.is-active i { color: var(--bs-accent, var(--accent)); }

.booking-pay-list { display: flex; flex-direction: column; gap: 8px; }
.booking-pay-row {
  display: flex; align-items: center; gap: 12px;
  border: 1px solid var(--line); border-radius: 12px;
  background: var(--surface-2); cursor: pointer; padding: 10px 14px;
  text-align: left; transition: border-color .15s ease;
}
.booking-pay-row.is-on { border-color: var(--bs-accent, var(--accent)); }
.booking-pay-ic { flex-shrink: 0; width: 36px; height: 36px; border-radius: 9px; background: var(--surface); border: 1px solid var(--line); display: grid; place-items: center; font-size: 15px; color: var(--t2); }
.booking-pay-row.is-on .booking-pay-ic { color: var(--bs-accent, var(--accent)); border-color: var(--bs-accent, var(--accent)); }
.booking-pay-info { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 1px; }
.booking-pay-info strong { font-size: 13.5px; font-weight: 700; color: var(--t1); }
.booking-pay-info small { font-size: 11.5px; color: var(--t3); }
.booking-toggle { flex-shrink: 0; width: 42px; height: 24px; border-radius: 999px; background: var(--line-strong); position: relative; transition: background .2s ease; }
.booking-toggle.on { background: var(--bs-accent, var(--accent)); }
.booking-toggle-knob { position: absolute; top: 2px; left: 2px; width: 20px; height: 20px; border-radius: 50%; background: #fff; transition: transform .2s ease; box-shadow: 0 1px 3px rgba(0,0,0,.25); }
.booking-toggle.on .booking-toggle-knob { transform: translateX(18px); }

.booking-embed {
  width: 100%; box-sizing: border-box;
  border: 1px solid var(--line-strong); border-radius: 10px;
  background: var(--surface-2); color: var(--t2);
  font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace;
  font-size: 12px; line-height: 1.5; padding: 12px 14px; resize: vertical;
}
.booking-embed:focus { outline: none; border-color: var(--bs-accent, var(--accent)); }
.booking-embed-actions { display: flex; gap: 10px; margin-top: 12px; flex-wrap: wrap; }
.booking-copy-btn, .booking-link-btn {
  display: inline-flex; align-items: center; gap: 7px;
  border-radius: 10px; cursor: pointer; font-size: 13px; font-weight: 700; padding: 10px 14px;
}
.booking-copy-btn { background: var(--bs-accent, var(--accent)); color: #fff; border: 0; }
.booking-copy-btn:hover { filter: brightness(.95); }
.booking-copy-btn.is-copied { background: #16a34a; }
.booking-link-btn { background: var(--surface-2); color: var(--t1); border: 1px solid var(--line-strong); }
.booking-link-btn:hover { border-color: var(--bs-accent, var(--accent)); color: var(--bs-accent, var(--accent)); }

.booking-card-danger { border-color: rgba(239,68,68,.3); }
.booking-delete-btn { background: rgba(239,68,68,.1); color: #ef4444; border: 1px solid rgba(239,68,68,.3); border-radius: 10px; cursor: pointer; font-size: 13px; font-weight: 700; padding: 10px 16px; }
.booking-delete-btn:hover { background: #ef4444; color: #fff; }
.booking-save-bar { position: static; bottom: auto; z-index: 5; display: flex; justify-content: flex-end; padding: 16px 0 0; margin-top: 4px; background: transparent; }
.booking-save-btn { display: inline-flex; align-items: center; gap: 9px; background: var(--bs-accent, var(--accent)); color: #fff; border: 0; border-radius: 12px; cursor: pointer; font-size: 15px; font-weight: 700; padding: 13px 26px; box-shadow: 0 8px 22px -10px rgba(0,0,0,.4); }
.booking-save-btn:hover { filter: brightness(.95); }

@media (max-width: 640px) {
  .booking-mode-grid { grid-template-columns: 1fr; }
  .booking-editor-titles h1 { font-size: 18px; }
}

/* ---- Logo ---- */
.booking-logo-preview { display: flex; align-items: center; justify-content: center; min-height: 80px; border: 1px solid var(--line); border-radius: 12px; background: var(--surface-2); padding: 14px; margin-bottom: 12px; }
.booking-logo-preview.is-empty { flex-direction: column; gap: 6px; color: var(--t3); font-size: 12.5px; }
.booking-logo-preview.is-empty i { font-size: 22px; }
.booking-logo-preview img { max-width: 100%; object-fit: contain; }
.booking-logo-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.booking-logo-upload { display: inline-flex; align-items: center; gap: 8px; background: var(--bs-accent, var(--accent)); color: #fff; border-radius: 10px; cursor: pointer; font-size: 13px; font-weight: 700; padding: 9px 14px; }
.booking-logo-upload:hover { filter: brightness(.95); }
.booking-logo-remove { display: inline-flex; align-items: center; gap: 7px; background: var(--surface-2); border: 1px solid var(--line-strong); color: var(--t2); border-radius: 10px; cursor: pointer; font-size: 13px; font-weight: 600; padding: 9px 14px; }
.booking-logo-remove:hover { border-color: #ef4444; color: #ef4444; }
.booking-range-field { display: flex; flex-direction: column; gap: 8px; margin-top: 14px; }
.booking-range-field span { font-size: 12.5px; color: var(--t2); font-weight: 600; }
.booking-range-field input[type="range"] { width: 100%; accent-color: var(--bs-accent, var(--accent)); }
.booking-logo-recrop { display: inline-flex; align-items: center; gap: 7px; background: var(--surface-2); border: 1px solid var(--line-strong); color: var(--t1); border-radius: 10px; cursor: pointer; font-size: 13px; font-weight: 600; padding: 9px 14px; }
.booking-logo-recrop:hover { border-color: var(--bs-accent, var(--accent)); color: var(--bs-accent, var(--accent)); }

/* ---- Modal de recadrage logo ---- */
.logo-crop-backdrop { position: fixed; inset: 0; z-index: 2000; background: rgba(12,12,16,.55); display: grid; place-items: center; padding: 20px; -webkit-backdrop-filter: blur(3px); backdrop-filter: blur(3px); }
.logo-crop-card { background: var(--surface); border: 1px solid var(--line); border-radius: 18px; padding: 22px; width: 100%; max-width: 380px; box-shadow: 0 30px 80px -30px rgba(0,0,0,.5); }
.logo-crop-title { display: flex; align-items: center; gap: 9px; font-size: 16px; font-weight: 750; color: var(--t1); }
.logo-crop-title i { color: var(--accent); }
.logo-crop-hint { font-size: 12.5px; color: var(--t3); margin: 6px 0 16px; }
.logo-crop-stage { position: relative; margin: 0 auto; border-radius: 12px; overflow: hidden; background: repeating-conic-gradient(#e9e9ee 0% 25%, #f7f7fa 0% 50%) 50% / 18px 18px; cursor: grab; touch-action: none; }
[data-theme="dark"] .logo-crop-stage { background: repeating-conic-gradient(#2a2a30 0% 25%, #232329 0% 50%) 50% / 18px 18px; }
.logo-crop-stage:active { cursor: grabbing; }
.logo-crop-stage img { position: absolute; user-select: none; -webkit-user-drag: none; max-width: none; }
.logo-crop-frame { position: absolute; inset: 0; box-shadow: 0 0 0 1px rgba(255,255,255,.6) inset, 0 0 0 9999px rgba(0,0,0,0); pointer-events: none; border-radius: 12px; }
.logo-crop-zoom { display: flex; align-items: center; gap: 10px; margin: 16px 0; color: var(--t3); font-size: 13px; }
.logo-crop-zoom input[type="range"] { flex: 1; accent-color: var(--accent); }
.logo-crop-actions { display: flex; justify-content: flex-end; gap: 10px; }

/* ---- Paramètres par défaut ---- */
.booking-defaults-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 12px; }
.booking-def-field { display: flex; flex-direction: column; gap: 6px; }
.booking-def-field span { font-size: 12.5px; font-weight: 700; color: var(--t3); }
.booking-def-field select.booking-input, .booking-def-field input.booking-input { width: 100%; box-sizing: border-box; }
.booking-def-block { margin-top: 18px; }
.booking-def-label { display: block; font-size: 12.5px; font-weight: 700; color: var(--t3); margin-bottom: 8px; }
.booking-seg-group { display: inline-flex; border: 1px solid var(--line-strong); border-radius: 10px; overflow: hidden; background: var(--surface-2); }
.booking-seg { border: 0; background: transparent; color: var(--t2); cursor: pointer; font-size: 13px; font-weight: 600; padding: 9px 16px; }
.booking-seg + .booking-seg { border-left: 1px solid var(--line); }
.booking-seg.is-active { background: var(--bs-accent, var(--accent)); color: #fff; }
.booking-seg:disabled { opacity: .4; cursor: not-allowed; }

/* ---- Champs du formulaire ---- */
.booking-locked-fields { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 14px; }
.booking-locked-fields span { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 600; color: var(--t3); background: var(--surface-2); border: 1px solid var(--line); border-radius: 999px; padding: 5px 11px; }
.booking-locked-fields i { font-size: 10px; color: var(--bs-accent, var(--accent)); }
.booking-field-list { display: flex; flex-direction: column; gap: 8px; }
.booking-field-row { display: flex; align-items: center; justify-content: space-between; gap: 14px; flex-wrap: wrap; padding: 8px 0; border-bottom: 1px solid var(--line); }
.booking-field-row:last-child { border-bottom: 0; }
.booking-field-name { display: inline-flex; align-items: center; gap: 9px; font-size: 13.5px; font-weight: 600; color: var(--t1); }
.booking-field-name i { color: var(--t3); width: 16px; text-align: center; }
.booking-field-segs { display: inline-flex; border: 1px solid var(--line-strong); border-radius: 9px; overflow: hidden; background: var(--surface-2); }
.booking-field-seg { border: 0; background: transparent; color: var(--t2); cursor: pointer; font-size: 12px; font-weight: 600; padding: 7px 12px; }
.booking-field-seg + .booking-field-seg { border-left: 1px solid var(--line); }
.booking-field-seg.is-active.val-required { background: var(--bs-accent, var(--accent)); color: #fff; }
.booking-field-seg.is-active.val-optional { background: var(--t2); color: #fff; }
.booking-field-seg.is-active.val-off { background: var(--line-strong); color: var(--t1); }
@media (max-width: 560px) {
  .booking-field-row { align-items: flex-start; }
  .booking-field-segs { width: 100%; }
  .booking-field-seg { flex: 1; }
}

/* ====================================================================== */
/*  BOOK.HTML — Site de réservation voyageur                             */
/* ====================================================================== */
.book-page { margin: 0; background: var(--surface-2); color: var(--t1); font-family: "Inter Tight", system-ui, sans-serif; -webkit-font-smoothing: antialiased; }
.book-shell { min-height: 100vh; display: flex; flex-direction: column; }

.book-topbar { position: sticky; top: 0; z-index: 20; background: color-mix(in srgb, var(--surface) 92%, transparent); -webkit-backdrop-filter: blur(12px); backdrop-filter: blur(12px); border-bottom: 1px solid var(--line); }
.book-topbar-inner { max-width: 1120px; margin: 0 auto; padding: 14px 24px; display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.book-brand { display: inline-flex; align-items: center; gap: 10px; font-size: 16px; font-weight: 800; color: var(--t1); }
.book-brand-mark { width: 32px; height: 32px; border-radius: 9px; background: var(--accent); color: #fff; display: grid; place-items: center; font-size: 15px; }
.book-topbar-back { display: inline-flex; align-items: center; gap: 7px; background: var(--surface-2); border: 1px solid var(--line-strong); border-radius: 999px; color: var(--t1); cursor: pointer; font-size: 13px; font-weight: 600; padding: 8px 14px; }
.book-topbar-back:hover { border-color: var(--accent); color: var(--accent); }

.book-hero { background: linear-gradient(150deg, var(--accent-soft), transparent 70%); border-bottom: 1px solid var(--line); }
.book-hero-inner { max-width: 1120px; margin: 0 auto; padding: 54px 24px 30px; }
.book-hero h1 { font-size: 34px; font-weight: 800; margin: 0; letter-spacing: -0.02em; }
.book-hero p { font-size: 16px; color: var(--t2); margin: 8px 0 26px; }

.book-searchbar { display: flex; flex-wrap: wrap; align-items: flex-end; gap: 12px; background: var(--surface); border: 1px solid var(--line); border-radius: 18px; padding: 14px; box-shadow: 0 18px 40px -24px rgba(0,0,0,.3); }
.book-searchbar.is-compact { box-shadow: none; padding: 12px; margin: 14px 0; }
.book-search-field { flex: 1; min-width: 150px; display: flex; flex-direction: column; gap: 6px; }
.book-search-field label { font-size: 12px; font-weight: 700; color: var(--t3); display: inline-flex; align-items: center; gap: 6px; padding-left: 2px; }
.book-search-field label i { color: var(--accent); }
.book-search-field input[type="date"] { border: 1px solid var(--line-strong); border-radius: 12px; background: var(--surface-2); color: var(--t1); font-size: 14px; font-family: inherit; padding: 12px 14px; width: 100%; box-sizing: border-box; }
.book-search-field input[type="date"]:focus { outline: none; border-color: var(--accent); }
.book-stepper { display: flex; align-items: center; justify-content: space-between; border: 1px solid var(--line-strong); border-radius: 12px; background: var(--surface-2); padding: 5px 8px; height: 46px; box-sizing: border-box; }
.book-stepper button { width: 32px; height: 32px; border-radius: 8px; border: 0; background: var(--surface); color: var(--t1); font-size: 18px; cursor: pointer; box-shadow: 0 1px 2px rgba(0,0,0,.08); }
.book-stepper button:hover { color: var(--accent); }
.book-stepper span { font-size: 15px; font-weight: 700; min-width: 28px; text-align: center; }
.book-search-btn { flex-shrink: 0; height: 46px; display: inline-flex; align-items: center; gap: 8px; background: var(--accent); color: #fff; border: 0; border-radius: 12px; cursor: pointer; font-size: 14px; font-weight: 700; padding: 0 22px; }
.book-search-btn:hover { filter: brightness(.95); }

.book-results { max-width: 1120px; margin: 0 auto; width: 100%; box-sizing: border-box; padding: 32px 24px 48px; flex: 1; }
.book-results-head h2 { font-size: 22px; font-weight: 800; margin: 0; }
.book-results-head p { font-size: 14px; color: var(--t3); margin: 6px 0 0; }
.book-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 20px; margin-top: 22px; }
.book-card { text-align: left; border: 1px solid var(--line); background: var(--surface); border-radius: 18px; overflow: hidden; cursor: pointer; padding: 0; display: flex; flex-direction: column; transition: border-color .2s ease, box-shadow .2s ease, transform .15s ease; }
.book-card:hover { border-color: var(--accent); box-shadow: 0 16px 36px -20px rgba(0,0,0,.3); transform: translateY(-2px); }
.book-card-media { display: block; aspect-ratio: 3 / 2; background: var(--accent-soft); overflow: hidden; }
.book-card-media img { width: 100%; height: 100%; object-fit: cover; }
.book-card-noimg { width: 100%; height: 100%; display: grid; place-items: center; color: var(--accent); font-size: 26px; }
.book-card-body { display: flex; flex-direction: column; gap: 5px; padding: 16px; flex: 1; }
.book-card-loc { font-size: 12px; color: var(--t3); display: inline-flex; align-items: center; gap: 6px; }
.book-card-loc i { color: var(--accent); }
.book-card-title { font-size: 16px; font-weight: 750; color: var(--t1); line-height: 1.3; }
.book-card-facts { display: flex; gap: 14px; margin-top: 2px; }
.book-card-facts span { font-size: 12.5px; color: var(--t2); display: inline-flex; align-items: center; gap: 5px; }
.book-card-facts i { color: var(--t3); }
.book-card-price { margin-top: auto; padding-top: 12px; display: flex; align-items: baseline; gap: 7px; }
.book-card-price strong { font-size: 18px; font-weight: 800; color: var(--t1); }
.book-card-price small { font-size: 12px; color: var(--t3); }

.book-empty { text-align: center; padding: 60px 20px; color: var(--t3); }
.book-empty i { font-size: 38px; color: var(--accent); opacity: .7; }
.book-empty h2 { font-size: 19px; color: var(--t1); margin: 16px 0 6px; }
.book-empty p { font-size: 14px; max-width: 380px; margin: 0 auto; line-height: 1.55; }

/* ---- Détail ---- */
.book-detail { max-width: 1120px; margin: 0 auto; width: 100%; box-sizing: border-box; padding: 24px 24px 48px; flex: 1; }
.book-back { display: inline-flex; align-items: center; gap: 8px; background: none; border: 0; color: var(--t2); cursor: pointer; font-size: 14px; font-weight: 600; padding: 6px 0; margin-bottom: 16px; }
.book-back:hover { color: var(--accent); }
.book-gallery { display: grid; grid-template-columns: 2fr 1fr 1fr; grid-template-rows: 1fr 1fr; gap: 8px; border-radius: 18px; overflow: hidden; height: 380px; }
/* 1 photo : bannière pleine largeur ; 2 photos : deux colonnes égales */
.book-gallery-1 { grid-template-columns: 1fr; grid-template-rows: 1fr; }
.book-gallery-1 .book-gallery-cell.is-main { grid-row: auto; }
.book-gallery-2 { grid-template-columns: 1fr 1fr; grid-template-rows: 1fr; }
.book-gallery-2 .book-gallery-cell.is-main { grid-row: auto; }
.book-gallery-cell { padding: 0; border: 0; cursor: zoom-in; overflow: hidden; background: var(--accent-soft); }
.book-gallery-cell.is-main { grid-row: 1 / 3; }
.book-gallery-cell img { width: 100%; height: 100%; object-fit: cover; transition: transform .3s ease; }
.book-gallery-cell:hover img { transform: scale(1.04); }
.book-gallery-empty { display: grid; place-items: center; color: var(--accent); font-size: 40px; grid-template-columns: none; grid-template-rows: none; }
.book-detail-grid { display: grid; grid-template-columns: 1fr 360px; gap: 32px; margin-top: 28px; align-items: start; }
.book-detail-main h1 { font-size: 26px; font-weight: 800; margin: 6px 0 0; letter-spacing: -0.01em; }
.book-facts { display: flex; flex-wrap: wrap; gap: 18px; margin: 18px 0; padding: 16px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.book-fact { display: inline-flex; align-items: center; gap: 8px; font-size: 14px; color: var(--t1); font-weight: 600; }
.book-fact i { color: var(--accent); font-size: 16px; }
.book-section { margin-top: 24px; }
.book-section h3 { font-size: 17px; font-weight: 750; margin: 0 0 10px; }
.book-desc { font-size: 14.5px; color: var(--t2); line-height: 1.65; margin: 0; }
.book-amenities { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; }
.book-amenity { display: inline-flex; align-items: center; gap: 9px; font-size: 14px; color: var(--t1); }
.book-amenity i { color: var(--accent); font-size: 12px; }

.book-detail-aside { position: sticky; top: 84px; }
.book-summary { background: var(--surface); border: 1px solid var(--line); border-radius: 18px; padding: 22px; box-shadow: 0 16px 40px -28px rgba(0,0,0,.3); }
.book-summary-price { display: flex; align-items: baseline; gap: 8px; margin-bottom: 16px; }
.book-summary-price strong { font-size: 26px; font-weight: 800; }
.book-summary-price small { font-size: 13px; color: var(--t3); }
.book-summary-hint { font-size: 14px; color: var(--t3); margin: 0 0 4px; }
.book-unavailable { display: flex; gap: 9px; align-items: flex-start; background: rgba(239,68,68,.08); border: 1px solid rgba(239,68,68,.25); color: #b91c1c; border-radius: 12px; padding: 12px 14px; font-size: 13.5px; font-weight: 600; line-height: 1.45; margin-bottom: 12px; }
.book-unavailable i { margin-top: 2px; }
.book-summary-dates { display: flex; align-items: center; gap: 12px; background: var(--surface-2); border: 1px solid var(--line); border-radius: 12px; padding: 12px 14px; margin-bottom: 14px; }
.book-summary-dates > div { flex: 1; display: flex; flex-direction: column; gap: 2px; }
.book-summary-dates small { font-size: 11px; color: var(--t3); text-transform: uppercase; letter-spacing: .04em; }
.book-summary-dates span { font-size: 14px; font-weight: 700; }
.book-summary-dates i { color: var(--t3); }
.book-summary-lines { display: flex; flex-direction: column; gap: 9px; padding: 4px 0 14px; }
.book-summary-line { display: flex; justify-content: space-between; gap: 12px; font-size: 13.5px; color: var(--t2); }
.book-summary-line span:last-child { font-weight: 600; color: var(--t1); white-space: nowrap; }
.book-summary-line.is-onsite { color: var(--t3); font-style: italic; }
.book-summary-line.is-muted { color: var(--t3); font-size: 12px; }
.book-summary-line.is-muted span:last-child { font-weight: 600; color: var(--t3); }
.book-summary-total { display: flex; justify-content: space-between; align-items: baseline; border-top: 1px solid var(--line); padding-top: 14px; }
.book-summary-total span { font-size: 15px; font-weight: 700; }
.book-summary-total strong { font-size: 20px; font-weight: 800; }
.book-summary-prop { display: flex; align-items: center; gap: 12px; margin-bottom: 16px; }
.book-summary-prop img { width: 56px; height: 56px; border-radius: 11px; object-fit: cover; }
.book-summary-prop strong { display: block; font-size: 15px; font-weight: 750; }
.book-summary-prop small { font-size: 12px; color: var(--t3); }

.book-primary { background: var(--accent); color: #fff; border: 0; border-radius: 12px; cursor: pointer; font-size: 15px; font-weight: 700; padding: 14px 22px; font-family: inherit; }
.book-primary:hover { filter: brightness(.95); }
.book-primary:disabled { opacity: .5; cursor: not-allowed; }
.book-cta { width: 100%; margin-top: 16px; }

/* ---- Checkout ---- */
.book-checkout { max-width: 1000px; margin: 0 auto; width: 100%; box-sizing: border-box; padding: 24px 24px 48px; flex: 1; }
.book-checkout h1 { font-size: 24px; font-weight: 800; margin: 8px 0 0; }
.book-checkout-grid { display: grid; grid-template-columns: 1fr 340px; gap: 28px; margin-top: 24px; align-items: start; }
.book-checkout-main { display: flex; flex-direction: column; gap: 18px; }
.book-form-card { margin-top: 0; background: var(--surface); border: 1px solid var(--line); border-radius: 16px; padding: 20px; }
.book-form-card h3 { margin-top: 0; }
.book-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.book-field { display: flex; flex-direction: column; gap: 6px; margin-bottom: 12px; }
.book-field:last-child { margin-bottom: 0; }
.book-field span { font-size: 12.5px; font-weight: 700; color: var(--t3); }
.book-field input { border: 1px solid var(--line-strong); border-radius: 10px; background: var(--surface-2); color: var(--t1); font-size: 14px; font-family: inherit; padding: 11px 13px; }
.book-field input:focus { outline: none; border-color: var(--accent); }
.book-pay-list { display: flex; flex-direction: column; gap: 9px; }
.book-pay-opt { display: flex; align-items: center; gap: 12px; border: 1.5px solid var(--line-strong); border-radius: 12px; background: var(--surface-2); cursor: pointer; padding: 12px 14px; text-align: left; }
.book-pay-opt.is-on { border-color: var(--accent); background: var(--accent-soft); }
.book-pay-ic { width: 38px; height: 38px; border-radius: 9px; background: var(--surface); border: 1px solid var(--line); display: grid; place-items: center; font-size: 16px; color: var(--t2); flex-shrink: 0; }
.book-pay-opt.is-on .book-pay-ic { color: var(--accent); border-color: var(--accent); }
.book-pay-txt { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 1px; }
.book-pay-txt strong { font-size: 14px; font-weight: 700; }
.book-pay-txt small { font-size: 12px; color: var(--t3); }
.book-radio { width: 20px; height: 20px; border-radius: 50%; border: 2px solid var(--line-strong); flex-shrink: 0; }
.book-radio.on { border-color: var(--accent); background: radial-gradient(circle, #fff 32%, var(--accent) 33%); }
[data-theme="dark"] .book-radio.on { background: radial-gradient(circle, var(--surface) 32%, var(--accent) 33%); }
.book-checkout-aside { position: sticky; top: 84px; }

/* ---- Confirmation ---- */
.book-confirmed { flex: 1; display: grid; place-items: center; padding: 40px 24px; }
.book-confirmed-card { max-width: 480px; width: 100%; background: var(--surface); border: 1px solid var(--line); border-radius: 20px; padding: 38px 32px; text-align: center; box-shadow: 0 20px 50px -30px rgba(0,0,0,.3); }
.book-confirmed-ic { width: 64px; height: 64px; border-radius: 50%; background: #16a34a; color: #fff; display: grid; place-items: center; font-size: 28px; margin: 0 auto 18px; }
.book-confirmed-card h1 { font-size: 24px; font-weight: 800; margin: 0 0 10px; }
.book-confirmed-card > p { font-size: 14.5px; color: var(--t2); line-height: 1.6; margin: 0 0 22px; }
.book-confirmed-rows { display: flex; flex-direction: column; gap: 10px; text-align: left; background: var(--surface-2); border: 1px solid var(--line); border-radius: 14px; padding: 16px; margin-bottom: 18px; }
.book-confirmed-rows > div { display: flex; justify-content: space-between; gap: 12px; }
.book-confirmed-rows small { font-size: 13px; color: var(--t3); }
.book-confirmed-rows span { font-size: 13.5px; font-weight: 700; color: var(--t1); }
.book-stripe-note { display: flex; align-items: center; gap: 9px; justify-content: center; background: var(--accent-soft); color: var(--accent-2); border-radius: 11px; padding: 11px 14px; font-size: 12.5px; font-weight: 600; margin-bottom: 20px; }

.book-powered { text-align: center; padding: 22px; font-size: 12px; color: var(--t3); border-top: 1px solid var(--line); }
.book-powered a { color: var(--t2); font-weight: 700; text-decoration: none; }
.book-powered a:hover { color: var(--accent); }
.book-fatal { flex: 1; display: grid; place-items: center; text-align: center; padding: 60px 24px; color: var(--t3); }
.book-fatal i { font-size: 44px; color: var(--accent); opacity: .7; }
.book-fatal h1 { font-size: 22px; color: var(--t1); margin: 18px 0 8px; }

@media (max-width: 880px) {
  .book-detail-grid { grid-template-columns: 1fr; }
  .book-checkout-grid { grid-template-columns: 1fr; }
  .book-detail-aside, .book-checkout-aside { position: static; }
  .book-gallery { grid-template-columns: 1fr 1fr; height: 300px; }
  .book-gallery-cell:nth-child(n+4) { display: none; }
  .book-gallery-cell.is-main { grid-row: 1 / 3; }
}
@media (max-width: 560px) {
  .book-hero-inner { padding: 36px 18px 22px; }
  .book-hero h1 { font-size: 26px; }
  .book-results, .book-detail, .book-checkout { padding-left: 16px; padding-right: 16px; }
  .book-search-field { min-width: 100%; }
  .book-search-btn { width: 100%; justify-content: center; }
  .book-amenities { grid-template-columns: 1fr; }
  .book-form-row { grid-template-columns: 1fr; }
  .book-gallery { grid-template-columns: 1fr; height: 240px; }
  .book-gallery-cell:nth-child(n+2) { display: none; }
  .book-gallery-cell.is-main { grid-row: auto; }
}

/* ====================================================================== */
/*  BOOK — barre de recherche v2 (champs cliquables + calendrier + logo)  */
/* ====================================================================== */
.book-searchbar { position: relative; }
.book-brand-logo { display: block; object-fit: contain; max-width: 220px; }
.book-date-field, .book-guests-field { cursor: pointer; position: relative; }
.book-date-value { border: 1px solid var(--line-strong); border-radius: 12px; background: var(--surface-2); color: var(--t1); font-size: 14px; font-weight: 600; padding: 12px 14px; height: 46px; box-sizing: border-box; display: flex; align-items: center; }
.book-date-field:hover .book-date-value, .book-guests-field:hover .book-date-value { border-color: var(--accent); }

/* ---- Calendrier range ---- */
.book-cal { position: absolute; top: calc(100% + 8px); left: 0; z-index: 60; width: 300px; background: var(--surface); border: 1px solid var(--line); border-radius: 16px; box-shadow: 0 18px 50px -18px rgba(0,0,0,.35); padding: 14px; }
.book-cal .date-picker-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 8px; }
.book-cal .date-picker-head button { width: 32px; height: 32px; border-radius: 8px; border: 0; background: var(--surface-2); color: var(--t1); cursor: pointer; }
.book-cal .date-picker-head button:hover { background: var(--accent-soft); color: var(--accent); }
.book-cal .date-picker-title { font-size: 14px; font-weight: 700; }
.book-cal .date-picker-week { display: grid; grid-template-columns: repeat(7, 1fr); gap: 2px; margin-bottom: 4px; }
.book-cal .date-picker-week span { text-align: center; font-size: 11px; font-weight: 700; color: var(--t3); padding: 4px 0; }
.book-cal .date-picker-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 2px; }
.book-cal .date-picker-day { aspect-ratio: 1; border: 0; background: transparent; color: var(--t1); font-size: 13px; font-weight: 600; cursor: pointer; border-radius: 9px; }
.book-cal .date-picker-day:hover:not(.is-disabled):not(.is-empty) { background: var(--accent-soft); }
.book-cal .date-picker-day.is-empty { cursor: default; }
.book-cal .date-picker-day.is-today { box-shadow: inset 0 0 0 1.5px var(--line-strong); }
.book-cal .date-picker-day.is-disabled { color: var(--t3); opacity: .35; cursor: not-allowed; }
.book-cal .date-picker-day.is-in-range { background: var(--accent-soft); border-radius: 0; }
.book-cal .date-picker-day.is-start { background: var(--accent); color: #fff; border-radius: 9px 0 0 9px; }
.book-cal .date-picker-day.is-end { background: var(--accent); color: #fff; border-radius: 0 9px 9px 0; }
.book-cal .date-picker-day.is-start.is-end { border-radius: 9px; }
.book-cal-foot { margin-top: 10px; padding-top: 10px; border-top: 1px solid var(--line); font-size: 12.5px; font-weight: 600; color: var(--t2); text-align: center; }

/* ---- Voyageurs popover ---- */
.book-guests-pop { position: absolute; top: calc(100% + 8px); right: 0; z-index: 60; width: 260px; background: var(--surface); border: 1px solid var(--line); border-radius: 14px; box-shadow: 0 18px 50px -18px rgba(0,0,0,.35); padding: 8px; }
.book-guests-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 8px 10px; }
.book-guests-row span { font-size: 14px; font-weight: 600; }

/* ---- Widget compact embarqué ---- */
.book-widget { max-width: 1000px; margin: 0 auto; padding: 18px; }
.book-widget .book-searchbar { box-shadow: 0 6px 22px -14px rgba(0,0,0,.25); }
.book-widget-results { margin-top: 20px; }
.book-widget-results .book-grid { grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); }
.book-widget-powered { text-align: center; font-size: 11px; color: var(--t3); padding: 12px; }
.book-widget-powered a { color: var(--t2); font-weight: 700; text-decoration: none; }

/* ---- "À partir de" sur les cartes ---- */
.book-card-price small { color: var(--t3); font-size: 12px; }

/* ---- Checkout : champs configurables + autocomplete ville ---- */
.book-fields-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 12px; }
.book-field-full { grid-column: 1 / -1; }
.book-field select, .book-field textarea { border: 1px solid var(--line-strong); border-radius: 10px; background: var(--surface-2); color: var(--t1); font-size: 14px; font-family: inherit; padding: 11px 13px; }
.book-field select:focus, .book-field textarea:focus { outline: none; border-color: var(--accent); }
.book-field textarea { resize: vertical; }
.book-req { color: var(--accent); font-style: normal; }
.book-city-field { position: relative; }
.book-city-suggest { position: absolute; top: 100%; left: 0; right: 0; z-index: 40; background: var(--surface); border: 1px solid var(--line); border-radius: 10px; box-shadow: 0 14px 40px -18px rgba(0,0,0,.35); margin-top: 4px; overflow: hidden; max-height: 240px; overflow-y: auto; }
.book-city-opt { display: flex; align-items: baseline; justify-content: space-between; gap: 10px; width: 100%; text-align: left; border: 0; background: transparent; cursor: pointer; padding: 10px 13px; font-size: 14px; color: var(--t1); }
.book-city-opt:hover { background: var(--accent-soft); }
.book-city-opt small { color: var(--t3); font-size: 12px; }

@media (max-width: 560px) {
  .book-cal { width: calc(100vw - 48px); left: 0; }
  .book-guests-pop { width: calc(100vw - 48px); right: auto; left: 0; }
  .book-fields-grid { grid-template-columns: 1fr; }
  .book-form-line { flex-direction: column; gap: 0; }
  .book-form-line .book-field { flex: 0 0 auto; flex-basis: auto; }
}

/* ---- Checkout : blocs + lignes ---- */
.book-form-card h3 { display: flex; align-items: center; gap: 9px; }
.book-form-card h3 i { color: var(--accent); font-size: 15px; }
.book-form-line { display: flex; gap: 12px; flex-wrap: wrap; }
.book-form-line .book-field { flex: 1 1 180px; min-width: 0; margin-bottom: 12px; }
.book-form-line .book-field-full { flex-basis: 100%; }
@media (max-width: 560px) {
  .book-form-line { flex-direction: column; gap: 0; }
  .book-form-line .book-field { flex: 0 0 auto; flex-basis: auto; }
}
.book-amenity-group { margin-top: 16px; }
.book-amenity-group:first-child { margin-top: 4px; }
.book-amenity-group-title { display: flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 700; color: var(--t2); margin: 0 0 10px; }
.book-amenity-group-title i { color: var(--accent); font-size: 13px; width: 16px; text-align: center; }

/* ---- Amenities : accordéon par catégorie ---- */
.book-amenity-acc { border-top: 1px solid var(--line); }
.book-amenity-acc:first-of-type { border-top: 0; }
.book-amenity-acc-head { display: flex; align-items: center; gap: 10px; padding: 14px 2px; cursor: pointer; list-style: none; user-select: none; }
.book-amenity-acc-head::-webkit-details-marker { display: none; }
.book-amenity-acc-title { display: flex; align-items: center; gap: 10px; font-size: 14px; font-weight: 700; color: var(--t1); flex: 1; }
.book-amenity-acc-title i { color: var(--accent); width: 18px; text-align: center; }
.book-amenity-acc-count { font-size: 12px; font-weight: 700; color: var(--t3); background: var(--surface-2); border-radius: 999px; padding: 2px 9px; }
.book-amenity-acc-chev { color: var(--t3); font-size: 12px; transition: transform .2s ease; }
.book-amenity-acc[open] .book-amenity-acc-chev { transform: rotate(180deg); }
.book-amenity-acc .book-amenities { padding: 0 2px 16px; }
/* Desktop : tout déplié, en-têtes non interactifs */
@media (min-width: 721px) {
  .book-amenity-acc > .book-amenities { display: grid !important; content-visibility: visible !important; }
  .book-amenity-acc-head { cursor: default; padding: 16px 2px 10px; pointer-events: none; }
  .book-amenity-acc-count, .book-amenity-acc-chev { display: none; }
}

/* ---- Extras (checkout) ---- */
.book-extras-list { display: flex; flex-direction: column; gap: 10px; }
.book-extras-group { margin: 6px 0 2px; }
.book-extras-group em { font-style: italic; font-size: 11px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: var(--t3); }
.book-extras-sep { border-top: 1px solid var(--line); margin: 8px 0; }
.book-extra-card { display: flex; align-items: center; gap: 12px; border: 1px solid var(--line); border-radius: 12px; background: var(--surface-2); padding: 10px 12px; transition: border-color .15s ease, background .15s ease; }
.book-extra-card.is-selected { border-color: var(--accent); background: var(--accent-soft); }
.book-extra-thumb { flex-shrink: 0; width: 44px; height: 44px; border-radius: 9px; overflow: hidden; background: var(--accent-soft); display: grid; place-items: center; color: var(--accent); }
.book-extra-thumb img { width: 100%; height: 100%; object-fit: cover; }
.book-extra-main { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.book-extra-main strong { font-size: 13.5px; font-weight: 700; color: var(--t1); }
.book-extra-main small { font-size: 12px; color: var(--t3); line-height: 1.35; }
.book-extra-price { font-size: 12.5px; font-weight: 750; color: var(--t1); margin-top: 1px; }
.book-extra-price em { color: var(--t3); font-style: normal; font-weight: 600; font-size: 11px; }
.book-extra-badges { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 4px; }
.book-extra-impact { display: inline-flex; align-items: center; gap: 5px; font-size: 11px; font-weight: 700; color: var(--accent-2); background: var(--accent-soft); border-radius: 6px; padding: 2px 7px; }
.book-extra-req-badge { display: inline-flex; align-items: center; gap: 5px; font-size: 11px; font-weight: 700; color: #b45309; background: rgba(245,158,11,.14); border-radius: 6px; padding: 2px 7px; }
.book-extras-reqnote { display: flex; gap: 8px; align-items: flex-start; margin-top: 12px; font-size: 12.5px; line-height: 1.45; color: var(--t2); background: rgba(245,158,11,.1); border: 1px solid rgba(245,158,11,.25); border-radius: 10px; padding: 10px 12px; }
.book-extras-reqnote i { color: #b45309; margin-top: 2px; }
.book-extras-terms { margin-top: 14px; }
.book-extras-terms details { border: 1px solid var(--line); border-radius: 10px; padding: 10px 12px; background: var(--surface-2); }
.book-extras-terms summary { cursor: pointer; font-size: 13px; font-weight: 700; color: var(--t1); }
.book-extras-terms p { font-size: 12.5px; color: var(--t2); line-height: 1.5; margin: 10px 0 0; }
.book-terms-accept { display: flex; align-items: flex-start; gap: 9px; margin-top: 12px; font-size: 13px; color: var(--t1); cursor: pointer; }
.book-terms-accept input { margin-top: 2px; accent-color: var(--accent); width: 17px; height: 17px; }
.book-request-note { display: flex; gap: 9px; align-items: center; justify-content: center; background: rgba(245,158,11,.12); color: #b45309; border-radius: 11px; padding: 11px 14px; font-size: 12.5px; font-weight: 600; margin-bottom: 14px; }
.book-myres-link { display: inline-flex; align-items: center; justify-content: center; gap: 8px; text-decoration: none; margin-bottom: 10px; }
.book-ghost-btn { background: var(--surface-2); color: var(--t2); border: 1px solid var(--line-strong); border-radius: 12px; cursor: pointer; font-size: 14px; font-weight: 700; padding: 12px 22px; font-family: inherit; }
.book-ghost-btn:hover { border-color: var(--accent); color: var(--accent); }
.book-extra-control { flex-shrink: 0; }
.book-extra-check { width: 28px; height: 28px; border-radius: 8px; border: 2px solid var(--line-strong); background: var(--surface); color: #fff; cursor: pointer; display: grid; place-items: center; font-size: 12px; }
.book-extra-check.on { background: var(--accent); border-color: var(--accent); }
.book-extra-check.is-radio { border-radius: 50%; }
.book-extra-check.is-radio.on { background: radial-gradient(circle, #fff 32%, var(--accent) 33%); border-color: var(--accent); }
[data-theme="dark"] .book-extra-check.is-radio.on { background: radial-gradient(circle, var(--surface) 32%, var(--accent) 33%); }
.book-extra-stepper { display: inline-flex; align-items: center; gap: 2px; background: var(--surface); border: 1px solid var(--line-strong); border-radius: 999px; padding: 3px; }
.book-extra-stepper button { width: 28px; height: 28px; border-radius: 50%; border: 0; background: transparent; color: var(--t1); font-size: 16px; cursor: pointer; }
.book-extra-stepper button:disabled { opacity: .35; cursor: not-allowed; }
.book-extra-stepper span { min-width: 22px; text-align: center; font-size: 13px; font-weight: 700; }
.book-line-ic { font-size: 10px; color: var(--accent); margin-right: 5px; }
.book-time-locked { display: flex; align-items: center; gap: 8px; border: 1px solid var(--accent); border-radius: 10px; background: var(--accent-soft); color: var(--t1); font-size: 14px; font-weight: 700; padding: 11px 13px; }
.book-time-locked i { color: var(--accent); }
.book-time-locked small { color: var(--t3); font-weight: 600; font-size: 11px; margin-left: auto; }

/* ---- Réservations : demandes d'extras (validation requise) ---- */
.cmd-extra-requests { margin-top: 16px; border: 1px solid rgba(245,158,11,.3); border-radius: 14px; padding: 14px 16px; background: rgba(245,158,11,.06); }
.cmd-req-title { display: flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 800; color: var(--t1); margin-bottom: 10px; }
.cmd-req-title i { color: #b45309; }
.cmd-req-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 10px 0; border-top: 1px solid var(--line); flex-wrap: wrap; }
.cmd-req-row:first-of-type { border-top: 0; }
.cmd-req-main { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.cmd-req-main strong { font-size: 14px; color: var(--t1); }
.cmd-req-main small { font-size: 12px; color: var(--t3); }
.cmd-req-right { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.cmd-req-badge { font-size: 11px; font-weight: 800; padding: 3px 9px; border-radius: 999px; }
.cmd-req-badge.is-wait { background: rgba(245,158,11,.16); color: #b45309; }
.cmd-req-badge.is-ok { background: rgba(34,197,94,.16); color: #15803d; }
.cmd-req-badge.is-no { background: rgba(239,68,68,.14); color: #b91c1c; }
.cmd-req-actions { display: flex; gap: 8px; }
.cmd-req-btn { border-radius: 9px; cursor: pointer; font-size: 12.5px; font-weight: 700; padding: 7px 14px; border: 1px solid var(--line-strong); }
.cmd-req-accept { background: #16a34a; color: #fff; border-color: #16a34a; }
.cmd-req-accept:hover { filter: brightness(.95); }
.cmd-req-refuse { background: var(--surface); color: var(--t2); }
.cmd-req-refuse:hover { border-color: #ef4444; color: #ef4444; }

/* ---- Guide voyageur : extras à validation requise ---- */
.guest-extra-req-badge { display: inline-flex; align-items: center; gap: 5px; margin-top: 4px; font-size: 11px; font-weight: 700; color: #b45309; background: rgba(245,158,11,.14); border-radius: 6px; padding: 2px 8px; align-self: flex-start; }
.guest-extra-request-btn { display: inline-flex; align-items: center; gap: 7px; background: var(--accent); color: #fff; border: 0; border-radius: 9px; cursor: pointer; font-size: 12.5px; font-weight: 700; padding: 9px 14px; white-space: nowrap; }
.guest-extra-request-btn:hover { filter: brightness(.95); }
.guest-extra-paynow { display: inline-flex; align-items: center; gap: 7px; background: #16a34a; color: #fff; border: 0; border-radius: 9px; cursor: pointer; font-size: 12.5px; font-weight: 700; padding: 9px 14px; white-space: nowrap; }
.guest-extra-paynow:hover { filter: brightness(.95); }
.guest-extra-wait { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 700; color: #b45309; white-space: nowrap; }
.guest-extra-refused { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 700; color: #b91c1c; white-space: nowrap; }

/* ---- Calendrier : jour bloqué pour le ménage ---- */
.calendar-day-cell.is-cleaning { background: repeating-linear-gradient(45deg, var(--surface-2), var(--surface-2) 5px, rgba(120,120,130,.10) 5px, rgba(120,120,130,.10) 10px) !important; cursor: pointer; }
.cal-month-day.is-cleaning { cursor: pointer; }
.cal-cell-cleaning { display: flex; align-items: center; justify-content: center; height: 100%; color: var(--t3); font-size: 11px; }
.cal-month-day.is-cleaning .cal-month-day-blocked { color: var(--t2); }

/* ====================================================================== */
/*  LOGEMENTS — Plateformes : cartes canaux améliorées                   */
/* ====================================================================== */
.property-channel-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 16px 18px;
  transition: border-color .18s ease, box-shadow .18s ease, background .18s ease;
}
.property-channel-card:not(.is-disabled) {
  border-color: color-mix(in srgb, var(--green, #16a34a) 40%, var(--line));
  box-shadow: 0 1px 0 0 color-mix(in srgb, var(--green, #16a34a) 35%, transparent) inset;
}
.property-channel-card.is-disabled { opacity: 1; background: var(--surface-2); }
.property-channel-head { margin-bottom: 0; }
.property-channel-logo { width: 40px; height: 40px; border-radius: 10px; padding: 5px; }
.property-channel-logo.is-fallback { font-size: 15px; background: var(--accent-soft); color: var(--accent); border-color: transparent; }
.property-channel-title strong { font-size: 14.5px; }
.property-channel-status { padding: 5px 11px; font-size: 11px; text-transform: uppercase; letter-spacing: .03em; }
/* Toggle row : séparé visuellement */
.property-channel-toggle-row.perm-toggle-row { margin-top: 14px; padding-top: 14px; border-top: 1px solid var(--line); }
.property-channel-card.is-disabled .property-channel-toggle-row.perm-toggle-row { border-top-color: var(--line); }
/* Champs d'ID : révélés seulement quand le canal est activé */
.property-channel-fields {
  margin-top: 14px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 12px;
}
.property-channel-card.is-disabled .property-channel-fields { display: none; }
.property-channel-field span { font-size: 12px; font-weight: 700; color: var(--t3); }

/* ====================================================================== */
/*  LOGEMENTS — Tarification : majoration canal + jours de semaine       */
/* ====================================================================== */
.property-pricing-channel-row {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 12px 16px;
  display: flex !important;
  flex-direction: row !important;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 10px;
  transition: border-color .15s ease, box-shadow .15s ease;
}
.property-pricing-channel-row:hover { border-color: var(--line-strong); box-shadow: 0 6px 18px -12px rgba(0,0,0,.2); }
.property-pricing-channel-name { display: flex; align-items: center; gap: 11px; font-weight: 700; font-size: 14px; color: var(--t1); min-width: 0; }
.property-adjustment-field { display: inline-flex; gap: 8px; align-items: center; flex-shrink: 0; }
.property-adjustment-field .property-adjustment-sign { width: 54px; padding-left: 10px; }
.property-adjustment-field input[type="number"] { width: 92px; text-align: right; }
.property-adjustment-field .property-adjustment-unit-select { width: 62px; }

.prop-dow-grid { display: grid; grid-template-columns: repeat(7, minmax(0, 1fr)); gap: 8px; }
.prop-dow-grid .pg-field { gap: 5px; }
.prop-dow-grid .pg-field span { text-align: center; font-size: 11px; font-weight: 800; color: var(--t3); text-transform: uppercase; letter-spacing: .04em; }
.prop-dow-grid .pg-field input { text-align: center; padding: 9px 4px; font-weight: 600; }
@media (max-width: 560px) {
  .prop-dow-grid { grid-template-columns: repeat(4, 1fr); }
  .property-pricing-channel-row { flex-wrap: wrap; }
}

/* ====================================================================== */
/*  LOGEMENTS — picker aligné sur Expérience voyageur                    */
/* ====================================================================== */
.page-split.prop-mode:not([data-prop-panel]) {
  background: var(--surface-2);
}

.page-split.prop-mode:not([data-prop-panel]) .page-split-list {
  max-width: 1180px;
  padding: 28px 24px 84px;
}

.prop-picker-head {
  align-items: center;
  display: flex;
  justify-content: space-between;
  margin: 10px 0 18px;
  padding: 0 !important;
}

.prop-picker-title {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 8px 10px;
  min-width: 0;
}

.prop-picker-title .experience-eyebrow {
  flex-basis: 100%;
  line-height: 1;
}

.prop-picker-title h1 {
  color: var(--t1);
  font-size: 24px;
  font-weight: 850;
  letter-spacing: -0.025em;
  line-height: 1.05;
  margin: 0;
}

.prop-picker-count {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--t3);
  font-size: 12px;
  font-weight: 600;
  padding: 4px 12px;
}

.page-split.prop-mode:not([data-prop-panel]) .prop-add-head-btn {
  display: none;
}

.page-split.prop-mode:not([data-prop-panel]) .prop-picker-search {
  align-items: center;
  background: var(--surface);
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  display: flex;
  gap: 10px;
  margin: 0 0 16px;
  max-width: none;
  padding: 0 16px;
}

.page-split.prop-mode:not([data-prop-panel]) .prop-picker-search i {
  color: var(--t4);
  font-size: 16px;
  left: auto;
  position: static;
}

.page-split.prop-mode:not([data-prop-panel]) .prop-picker-search input {
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  color: var(--t1);
  flex: 1;
  font: inherit;
  font-size: 15px;
  height: 52px;
  min-width: 0;
  outline: none;
  padding: 0;
}

.page-split.prop-mode:not([data-prop-panel]) .pg-list-tools {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 10px;
  margin: 0 0 26px;
}

.page-split.prop-mode:not([data-prop-panel]) .pg-list-tools .prop-list-sort,
.page-split.prop-mode:not([data-prop-panel]) .pg-list-tools .prop-list-group {
  position: relative;
}

.page-split.prop-mode:not([data-prop-panel]) .prop-sort-control {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 12px;
  color: var(--t1);
  gap: 8px;
  height: 46px;
  padding: 0 16px;
  width: auto;
}

.page-split.prop-mode:not([data-prop-panel]) .prop-sort-control i {
  color: var(--t1);
  font-size: 14px;
}

.page-split.prop-mode:not([data-prop-panel]) .prop-sort-control span {
  font-size: 14px;
  font-weight: 800;
}

.page-split.prop-mode:not([data-prop-panel]) .prop-sort-control small {
  color: var(--t3);
  font-size: 12px;
  font-weight: 650;
  margin-left: 3px;
}

.page-split.prop-mode:not([data-prop-panel]) .pg-prop-list {
  display: block;
  margin: 0;
  overflow: visible;
  padding: 0;
}

.page-split.prop-mode:not([data-prop-panel]) .prop-create-section,
.page-split.prop-mode:not([data-prop-panel]) .prop-group-section {
  margin: 0 0 16px;
  padding: 0;
}

.page-split.prop-mode:not([data-prop-panel]) .prop-group-section-title {
  color: var(--t3);
  font-size: 12px;
  font-weight: 850;
  letter-spacing: .06em;
  margin: 0 0 9px;
  padding: 0 2px;
  text-transform: uppercase;
}

.page-split.prop-mode:not([data-prop-panel]) .pg-prop-list .prop-group-section-list {
  display: grid;
  gap: 16px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.page-split.prop-mode:not([data-prop-panel]) .pg-prop-list .pg-prop-row {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 16px;
  display: flex;
  flex-direction: column;
  min-height: 0;
  overflow: hidden;
  padding: 0;
}

.page-split.prop-mode:not([data-prop-panel]) .pg-prop-list .pg-prop-row:hover {
  border-color: var(--accent-ring);
  box-shadow: 0 10px 28px -12px rgba(0,0,0,.22);
  transform: none;
}

.page-split.prop-mode:not([data-prop-panel]) .pg-prop-list .pg-photo {
  aspect-ratio: 4 / 3;
  border-radius: 0;
  height: auto;
  width: 100%;
}

.page-split.prop-mode:not([data-prop-panel]) .pg-prop-list .pg-photo img {
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.page-split.prop-mode:not([data-prop-panel]) .pg-prop-main {
  padding: 14px 16px 16px;
}

.page-split.prop-mode:not([data-prop-panel]) .pg-prop-name {
  font-size: 15px;
  font-weight: 800;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.page-split.prop-mode:not([data-prop-panel]) .pg-prop-city {
  color: var(--t3);
  font-size: 12.5px;
}

.page-split.prop-mode:not([data-prop-panel]) .pg-prop-meta {
  color: var(--t2);
  font-size: 12px;
  margin-top: 4px;
}

.page-split.prop-mode:not([data-prop-panel]) .ms-prop-grip {
  display: none !important;
}

.prop-create-card {
  align-items: center !important;
  border: 1.5px dashed var(--line-strong) !important;
  justify-content: center;
}

.prop-create-card-icon {
  align-items: center;
  aspect-ratio: 4 / 3;
  background: color-mix(in srgb, var(--accent) 10%, var(--surface));
  color: var(--accent);
  display: flex;
  font-size: 28px;
  justify-content: center;
  width: 100%;
}

.prop-create-card:hover .prop-create-card-icon {
  background: var(--accent);
  color: #fff;
}

.prop-picker-empty {
  padding: 18px 2px;
}

@media (min-width: 761px) and (max-width: 1080px) {
  .page-split.prop-mode:not([data-prop-panel]) .pg-prop-list .prop-group-section-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .page-split.prop-mode:not([data-prop-panel]) .page-split-list {
    padding: 18px 14px 80px;
  }

  .prop-picker-head {
    margin: 10px 0 16px;
  }

  .prop-picker-title h1 {
    font-size: 28px;
  }

  .page-split.prop-mode:not([data-prop-panel]) .prop-picker-search {
    margin-bottom: 14px;
  }

  .page-split.prop-mode:not([data-prop-panel]) .prop-picker-search input {
    height: 54px;
  }

  .page-split.prop-mode:not([data-prop-panel]) .pg-list-tools {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-bottom: 24px;
  }

  .page-split.prop-mode:not([data-prop-panel]) .pg-list-tools .prop-sort-control {
    height: 58px;
    justify-content: center;
    width: 100%;
  }

  .page-split.prop-mode:not([data-prop-panel]) .pg-list-tools .prop-sort-control span {
    font-size: 15px;
  }

  .page-split.prop-mode:not([data-prop-panel]) .pg-list-tools .prop-sort-control small {
    display: inline;
    font-size: 13px;
  }

  .page-split.prop-mode:not([data-prop-panel]) .pg-prop-list .prop-group-section-list {
    display: grid;
    gap: 12px;
    grid-template-columns: 1fr;
  }

  .page-split.prop-mode:not([data-prop-panel]) .pg-prop-list .pg-prop-row {
    align-items: center;
    border-radius: 16px;
    display: grid;
    gap: 14px;
    grid-template-columns: 90px minmax(0, 1fr);
    min-height: 112px;
    padding: 12px;
  }

  .page-split.prop-mode:not([data-prop-panel]) .pg-prop-list .pg-photo,
  .page-split.prop-mode:not([data-prop-panel]) .prop-create-card-icon {
    aspect-ratio: 1;
    border-radius: 14px;
    height: 90px;
    width: 90px;
  }

  .page-split.prop-mode:not([data-prop-panel]) .pg-prop-main {
    align-self: center;
    padding: 0;
  }

  .page-split.prop-mode:not([data-prop-panel]) .pg-prop-name {
    font-size: 17px;
    margin-bottom: 4px;
  }

  .page-split.prop-mode:not([data-prop-panel]) .pg-prop-meta {
    flex-wrap: wrap;
  }

  .page-split.prop-mode:not([data-prop-panel]) .property-sort-menu {
    left: 0;
    min-width: min(280px, calc(100vw - 28px));
    right: auto;
  }
}

/* ====================================================================== */
/*  LOGEMENTS — alignement strict avec experience.html?tab=guide          */
/* ====================================================================== */
.main:has(.page-split.prop-mode),
.page-main:has(.page-split.prop-mode) {
  background: var(--surface-2);
  overflow-x: hidden;
  overflow-y: auto;
}

.page-split.prop-mode {
  background: var(--surface-2) !important;
  border: 0 !important;
}

.page-split.prop-mode:not([data-prop-panel]) .page-split-list {
  background: transparent !important;
  max-width: 1180px !important;
  padding: 18px 24px 70px !important;
}

.page-split.prop-mode:not([data-prop-panel]) .prop-picker-head {
  border: 0 !important;
  margin: 14px 0 20px !important;
  padding: 0 !important;
}

.page-split.prop-mode:not([data-prop-panel]) .prop-picker-title {
  align-items: flex-start !important;
  display: block !important;
}

.page-split.prop-mode:not([data-prop-panel]) .prop-picker-title .experience-eyebrow {
  display: block;
  line-height: 1.15;
}

.page-split.prop-mode:not([data-prop-panel]) .prop-picker-title h1 {
  font-size: 24px !important;
  font-weight: 800 !important;
  letter-spacing: -0.02em !important;
  line-height: 1.1 !important;
  margin: 5px 0 0 !important;
}

.page-split.prop-mode:not([data-prop-panel]) .page-split-list-hd::after,
.page-split.prop-mode:not([data-prop-panel]) .prop-picker-head::after {
  display: none !important;
}

.page-split.prop-mode:not([data-prop-panel]) .prop-picker-search {
  align-items: center !important;
  background: var(--surface) !important;
  border: 1px solid var(--line-strong) !important;
  border-radius: 999px !important;
  box-shadow: none !important;
  display: flex !important;
  gap: 10px !important;
  margin: 0 0 20px !important;
  max-width: none !important;
  padding: 0 14px !important;
}

.page-split.prop-mode:not([data-prop-panel]) .prop-picker-search i {
  color: var(--t4) !important;
  font-size: 14px !important;
  left: auto !important;
  position: static !important;
}

.page-split.prop-mode:not([data-prop-panel]) .prop-picker-search input {
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  color: var(--t1) !important;
  flex: 1 !important;
  font: inherit !important;
  font-size: inherit !important;
  height: 44px !important;
  outline: none !important;
  padding: 0 !important;
}

.page-split.prop-mode:not([data-prop-panel]) .pg-list-tools {
  margin: -4px 0 20px !important;
}

.page-split.prop-mode:not([data-prop-panel]) .pg-prop-list .prop-group-section-list {
  gap: 16px !important;
}

.page-split.prop-mode:not([data-prop-panel]) .pg-prop-list .pg-prop-row {
  border-radius: 16px !important;
}

.page-split.prop-mode:not([data-prop-panel]) .pg-prop-list .pg-prop-row:hover {
  box-shadow: 0 10px 28px -10px rgba(0,0,0,.18) !important;
}

.page-split.prop-mode:not([data-prop-panel]) .pg-prop-list .pg-photo {
  aspect-ratio: 4 / 3 !important;
}

.page-split.prop-mode:not([data-prop-panel]) .pg-prop-main {
  padding: 14px 16px 16px !important;
}

.page-split.prop-mode:not([data-prop-panel]) .pg-prop-name {
  font-size: 15px !important;
  font-weight: 750 !important;
  line-height: 1.25 !important;
  margin-bottom: 4px !important;
}

/* Edition logement : bloc plus intentionnel, façon atelier guide */
.page-split.prop-mode[data-prop-panel="detail"],
.page-split.prop-mode[data-prop-panel="tabs"] {
  padding: 18px 24px 70px;
}

.page-split.prop-mode .page-split-detail {
  background: transparent;
  max-width: 1180px !important;
  padding: 0 !important;
}

.page-split.prop-mode .property-detail-form.ms-detail-content {
  column-gap: 24px;
  grid-template-columns: 238px minmax(0, 1fr);
}

.page-split.prop-mode .page-split-detail .prop-back-btn {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 12px;
  box-shadow: var(--shadow-1);
  height: 42px;
  margin: 0 0 14px;
  width: 42px;
}

.property-detail-form.ms-detail-content > .property-tabs {
  background: transparent;
  max-height: calc(100vh - 118px);
  top: 18px;
}

.property-detail-form.ms-detail-content > .property-tabs .property-tab,
.property-detail-form.ms-detail-content > .property-tabs .property-detail-subtab {
  border-radius: 10px;
  min-height: 34px;
}

.property-detail-form.ms-detail-content > .property-tabs .property-tab.active,
.property-detail-form.ms-detail-content > .property-tabs .property-tab.is-on,
.property-detail-form.ms-detail-content > .property-tabs .property-detail-subtab.active {
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  color: var(--t1);
}

.page-split.prop-mode .pg-prop-header.ms-prop-card,
.page-split.prop-mode .property-quality-card.ms-card,
.page-split.prop-mode .pg-form-section.ms-card,
.page-split.prop-mode .pg-action-bar.ms-action-bar {
  border: 1px solid var(--line);
  border-radius: 16px;
  box-shadow: 0 8px 30px -24px rgba(0,0,0,.35);
}

.page-split.prop-mode .pg-form-section-head.ms-card-head {
  min-height: 66px;
}

@media (max-width: 760px) {
  .page-split.prop-mode:not([data-prop-panel]) .page-split-list,
  .page-split.prop-mode[data-prop-panel="detail"],
  .page-split.prop-mode[data-prop-panel="tabs"] {
    padding: 4px 14px 90px !important;
  }

  .page-split.prop-mode:not([data-prop-panel]) .prop-picker-head {
    margin: 14px 0 20px !important;
  }

  .page-split.prop-mode:not([data-prop-panel]) .prop-picker-title h1 {
    font-size: 24px !important;
  }

  .page-split.prop-mode:not([data-prop-panel]) .pg-list-tools {
    display: grid !important;
    gap: 10px !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    margin: -4px 0 20px !important;
  }

  .page-split.prop-mode:not([data-prop-panel]) .pg-list-tools .prop-sort-control {
    height: 50px !important;
    justify-content: center !important;
    width: 100% !important;
  }

  .page-split.prop-mode:not([data-prop-panel]) .pg-prop-list .pg-prop-row {
    grid-template-columns: 72px minmax(0, 1fr) !important;
    min-height: 94px !important;
    padding: 10px !important;
  }

  .page-split.prop-mode:not([data-prop-panel]) .pg-prop-list .pg-photo,
  .page-split.prop-mode:not([data-prop-panel]) .prop-create-card-icon {
    border-radius: 10px !important;
    height: 72px !important;
    width: 72px !important;
  }

  .page-split.prop-mode .property-detail-form.ms-detail-content {
    display: block;
  }
}

/* Dernier verrou : le picker Logements démarre exactement comme le picker Guide. */
.page-split.prop-mode:not([data-prop-panel]) {
  margin: 0 !important;
  padding: 0 !important;
}

.page-split.prop-mode:not([data-prop-panel]) > .page-split-list.pg-list {
  margin: 0 auto !important;
  padding-top: 18px !important;
}

/* Reservation billing tab mockup */
.reservation-billing {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.reservation-billing-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  padding: 18px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 16px;
  box-shadow: var(--shadow-1);
}

.reservation-billing-eyebrow {
  color: var(--accent);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .02em;
  text-transform: uppercase;
}

.reservation-billing-head h3 {
  margin: 2px 0 6px;
  color: var(--t1);
  font-size: 22px;
  line-height: 1.12;
}

.reservation-billing-head p {
  margin: 0;
  color: var(--t3);
  font-size: 14px;
}

.reservation-billing-state {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 800;
  margin: 0 0 8px;
}

.reservation-billing-state.is-draft {
  background: color-mix(in srgb, #f59e0b 13%, var(--surface));
  color: #b45309;
}

.reservation-billing-state.is-issued {
  background: color-mix(in srgb, #22c55e 13%, var(--surface));
  color: #15803d;
}

.reservation-billing-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px;
}

.reservation-billing-action {
  border: 1px solid var(--line);
  border-radius: 999px;
  min-height: 38px;
  padding: 0 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font: inherit;
  font-weight: 800;
  cursor: pointer;
  background: var(--surface);
  color: var(--t2);
}

.reservation-billing-action--primary {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}

.reservation-billing-action--ghost:hover {
  border-color: var(--accent);
  color: var(--accent);
}

.reservation-billing-lock-note {
  min-height: 38px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--t3);
  font-size: 13px;
  font-weight: 800;
}

.reservation-billing-primary-add,
.reservation-billing-insert button {
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--t2);
  border-radius: 999px;
  min-height: 38px;
  padding: 0 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-weight: 700;
  cursor: pointer;
  transition: border-color .15s, color .15s, background .15s, transform .15s;
}

.reservation-billing-primary-add {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
  flex: 0 0 auto;
}

.reservation-billing-primary-add:hover,
.reservation-billing-insert button:hover {
  transform: translateY(-1px);
}

.reservation-billing-table {
  overflow: visible;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 16px;
  box-shadow: var(--shadow-1);
}

.reservation-billing-rows {
  border-bottom-left-radius: 16px;
  border-bottom-right-radius: 16px;
}

.reservation-billing-row {
  position: relative;
  display: grid;
  /* Date | Description (large, flex) | Qté | Prix HT | Remise | TVA | Total HT | Montant TVA | Total TTC */
  grid-template-columns: 116px minmax(190px, 1fr) 56px 92px 134px 68px 88px 86px 92px;
  align-items: stretch;
  border-bottom: 1px solid var(--line);
}

.reservation-billing-rows .reservation-billing-row:last-child {
  border-bottom: 0;
}

/* « + » discret en bas à droite de chaque ligne, révélé au survol */
.reservation-billing-add {
  position: absolute;
  right: 14px;
  bottom: -12px;
  z-index: 4;
  width: 24px;
  height: 24px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--t3);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  line-height: 1;
  cursor: pointer;
  opacity: 0;
  box-shadow: var(--shadow-1);
  transition: opacity .15s, color .15s, border-color .15s, transform .15s;
}

.reservation-billing-row:hover > .reservation-billing-add,
.reservation-billing-add:focus-visible {
  opacity: 1;
}

.reservation-billing-add:hover {
  opacity: 1;
  color: var(--accent);
  border-color: var(--accent);
  transform: scale(1.1);
}

.reservation-billing-add-top {
  position: relative;
  height: 0;
  z-index: 4;
}

.reservation-billing-add--top {
  top: -12px;
  bottom: auto;
  opacity: .55;
}

.reservation-billing-add-top:hover .reservation-billing-add--top {
  opacity: 1;
}

.reservation-billing-row--header {
  background: var(--bg);
  color: var(--t3);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .02em;
  text-transform: uppercase;
}

.reservation-billing-row--header > div,
.reservation-billing-cell {
  padding: 12px 8px;
  border-right: 1px solid var(--line);
  min-width: 0;
}

/* En-têtes sur 2 lignes pour les colonnes étroites */
.reservation-billing-row--header > div { line-height: 1.2; }

.reservation-billing-row--header > div:last-child,
.reservation-billing-cell:last-child {
  border-right: 0;
}

.reservation-billing-cell {
  color: var(--t2);
  font-size: 13px;
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 52px;
}

.reservation-billing-desc {
  justify-content: space-between;
}

.reservation-billing-total {
  color: var(--t1);
  font-weight: 800;
}

.reservation-billing-chip {
  display: inline-flex;
  align-items: center;
  min-height: 22px;
  padding: 0 8px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  color: var(--accent);
  font-size: 11px;
  font-weight: 800;
  white-space: nowrap;
}

.reservation-billing-insert {
  padding: 8px 12px;
  background: color-mix(in srgb, var(--accent) 5%, var(--surface));
  border-bottom: 1px dashed var(--line);
  text-align: center;
}

.reservation-billing-insert button {
  min-height: 30px;
  padding: 0 12px;
  font-size: 12px;
  color: var(--accent);
  border-color: color-mix(in srgb, var(--accent) 24%, var(--line));
}

.reservation-billing-insert--last {
  border-bottom: 0;
}

.reservation-billing-row--edit {
  background: color-mix(in srgb, var(--accent) 4%, var(--surface));
}

.reservation-billing-cell input,
.reservation-billing-cell select {
  width: 100%;
  min-width: 0;
  height: 38px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface);
  color: var(--t1);
  font: inherit;
  font-weight: 500;
  padding: 0 8px;
}

/* La TVA est une colonne étroite : on resserre le select */
.reservation-billing-cell select[data-billing-field="taxRate"] {
  padding: 0 4px;
}

/* Sélecteur de date dans la facturation : même composant que le reste du site */
.reservation-billing-dp {
  width: 100%;
  position: relative;
}

.reservation-billing-dp .ms-field-input {
  width: 100%;
  height: 38px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface);
  color: var(--t1);
  font: inherit;
  font-weight: 500;
  padding: 0 10px;
  cursor: pointer;
}

.reservation-billing-dp .date-picker-panel {
  z-index: 30;
}

/* Montant de remise + type (€/%) toujours sur une seule ligne */
.reservation-billing-discount {
  display: flex;
  align-items: center;
  flex-wrap: nowrap;
  gap: 6px;
  width: 100%;
}

.reservation-billing-discount input {
  flex: 1 1 auto;
  min-width: 0;
}

.reservation-billing-discount select {
  flex: 0 0 56px;
  width: 56px;
  padding: 0 4px;
}

.reservation-billing-delete {
  width: 32px;
  height: 32px;
  border: 1px solid color-mix(in srgb, #ef4444 25%, var(--line));
  border-radius: 999px;
  background: var(--surface);
  color: #ef4444;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  margin-left: auto;
}

.reservation-billing-summary {
  align-self: flex-end;
  width: min(420px, 100%);
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 16px;
  box-shadow: var(--shadow-1);
  overflow: hidden;
}

.reservation-billing-summary > div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 14px 16px;
  border-bottom: 1px solid var(--line);
}

.reservation-billing-summary > div:last-child {
  border-bottom: 0;
}

.reservation-billing-summary > .reservation-billing-summary-action {
  justify-content: flex-end;
  background: var(--surface);
}

.reservation-billing-summary span {
  color: var(--t3);
  font-size: 13px;
  font-weight: 700;
}

.reservation-billing-summary strong {
  color: var(--t1);
  font-size: 18px;
}

.reservation-billing-balance {
  background: color-mix(in srgb, var(--accent) 8%, var(--surface));
}

.reservation-billing-balance strong {
  color: var(--accent);
}

.reservation-billing-payments {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 16px;
  box-shadow: var(--shadow-1);
  overflow: hidden;
}

.reservation-billing-payments.is-empty {
  padding: 14px 16px;
  color: var(--t3);
  font-size: 13px;
}

.reservation-billing-payment-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 13px 16px;
  border-bottom: 1px solid var(--line);
  color: var(--t2);
  font-size: 13px;
}

.reservation-billing-payment-row:last-child {
  border-bottom: 0;
}

.reservation-billing-payment-row i {
  color: #22c55e;
  margin-right: 7px;
}

.reservation-billing-payment-row strong {
  color: var(--t1);
}

.billing-payment-grid {
  display: grid;
  gap: 12px;
  margin-top: 14px;
}

.payment-method-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 10px;
}

.payment-method-option {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 48px;
  padding: 11px 12px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--surface);
  color: var(--t2);
  font-weight: 700;
}

.payment-method-option:has(input:checked) {
  background: color-mix(in srgb, var(--accent) 8%, var(--surface));
  border-color: color-mix(in srgb, var(--accent) 35%, var(--line));
  color: var(--t1);
}

.payment-method-option i {
  color: var(--accent);
  width: 18px;
  text-align: center;
}

/* ═══════════════ Réglages : navigation haute + footer local ═══════════════ */
.settings-mode .ms-settings-layout {
  display: flex;
  flex-direction: column;
  flex: 1;
  gap: 18px;
  min-height: 0;
  overflow-y: auto;
  padding: 32px clamp(20px, 6vw, 72px);
  background: var(--bg);
}

.settings-mode .ms-settings-list {
  width: 100%;
  max-width: 920px;
  margin: 0 auto;
  background: transparent;
  border-right: 0;
  overflow: visible;
  flex-shrink: 0;
}

.settings-mode .ms-settings-list .page-split-list-hd {
  display: none;
}

.settings-mode .ms-settings-list-body {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  padding: 0;
  overflow: visible;
}

.settings-mode .stg-nav-item {
  width: auto;
  flex: 0 0 auto;
  min-height: 46px;
  padding: 10px 14px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--surface);
  box-shadow: var(--shadow-1);
}

.settings-mode .stg-nav-item:last-child {
  border-bottom: 1px solid var(--line);
}

.settings-mode .stg-nav-item.active {
  border-color: var(--accent-ring);
  background: var(--accent-soft);
  color: var(--accent-2);
}

.settings-mode .stg-nav-chevron {
  display: none;
}

.settings-mode .ms-settings-detail {
  flex: 0 0 auto;
  overflow: visible;
  padding: 0;
  background: transparent;
}

.settings-mode [data-settings-panel] {
  max-width: 920px;
}

.settings-mode .pg-action-bar.ms-action-bar {
  position: static;
  bottom: auto;
  margin-top: 4px;
  box-shadow: var(--shadow-1);
}

.settings-mode .logo-preview {
  min-width: 180px;
}

@media (max-width: 768px) {
  .settings-mode .ms-settings-layout {
    padding: 16px;
  }

  .settings-mode .ms-settings-list {
    max-width: none;
    max-height: none;
    height: auto;
  }

  .settings-mode .ms-settings-list-body {
    flex-direction: column;
  }

  .settings-mode .stg-nav-item {
    width: 100%;
    min-height: 58px;
  }

  .settings-mode .stg-nav-chevron {
    display: block;
  }

  .settings-mode .ms-settings-layout[data-ms-mobile-panel="detail"] .ms-settings-list {
    display: none;
  }

  .settings-mode .ms-settings-layout:not([data-ms-mobile-panel="detail"]) .ms-settings-detail {
    display: none;
  }

  .settings-mode .ms-settings-detail {
    padding: 0;
  }

  .settings-mode .pg-action-bar.ms-action-bar {
    justify-content: flex-end;
    flex-wrap: wrap;
  }
}

/* La colonne Description est en fr : la grille tient toujours dans le panneau,
   plus besoin de scroll horizontal sur desktop. On garde un repli en dessous
   du seuil tablette uniquement. */
@media (max-width: 860px) and (min-width: 721px) {
  .reservation-billing-table {
    overflow-x: auto;
  }
  .reservation-billing-row {
    min-width: 760px;
  }
}

@media (max-width: 720px) {
  .res-page-pane--billing {
    padding: 14px;
  }

  .reservation-billing-head {
    flex-direction: column;
  }

  .reservation-billing-table {
    border: 0;
    background: transparent;
    box-shadow: none;
    overflow: visible;
  }

  /* Chaque ligne = une carte. Le bloc d'en-têtes n'a pas de sens en mobile. */
  .reservation-billing-table .reservation-billing-row--header {
    display: none;
  }

  .reservation-billing-rows {
    border-radius: 0;
  }

  .reservation-billing-row {
    min-width: 0;
    position: relative;
    display: grid;
    grid-template-columns: 1fr;
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 14px;
    margin-bottom: 14px;
    overflow: visible;
    box-shadow: var(--shadow-1);
  }

  .reservation-billing-rows .reservation-billing-row:last-child {
    border-bottom: 1px solid var(--line);
  }

  /* Une cellule = libellé à gauche, champ à droite, hauteurs cohérentes. */
  .reservation-billing-cell {
    justify-content: space-between;
    gap: 12px;
    border-right: 0;
    border-bottom: 1px solid var(--line);
    min-height: 50px;
    padding: 10px 14px;
  }

  .reservation-billing-cell:last-child {
    border-bottom: 0;
  }

  .reservation-billing-cell::before {
    content: attr(data-label);
    flex: 0 0 auto;
    color: var(--t3);
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .02em;
    text-transform: uppercase;
    padding-right: 0;
  }

  /* Tous les champs ont la MÊME largeur et le même bord droit → alignés. */
  .reservation-billing-cell > input,
  .reservation-billing-cell > select,
  .reservation-billing-cell > .reservation-billing-dp,
  .reservation-billing-cell > .reservation-billing-discount {
    flex: 0 0 56%;
    width: 56%;
    max-width: 56%;
    text-align: left;
  }

  .reservation-billing-dp { width: 56%; }

  .reservation-billing-desc {
    align-items: center;
  }

  .reservation-billing-desc::before {
    padding-top: 0;
  }

  /* Remise = exception : 2 contrôles, mais sur une seule ligne dans les 56%. */
  .reservation-billing-discount {
    justify-content: flex-start;
  }

  .reservation-billing-discount input { max-width: none; }

  /* Total TTC : valeur bien visible en bas de carte. */
  .reservation-billing-total {
    background: color-mix(in srgb, var(--accent) 5%, var(--surface));
  }

  /* Le « + » discret repasse au centre-bas, jamais coupé. */
  .reservation-billing-add {
    right: 50%;
    transform: translateX(50%);
    opacity: 1;
    bottom: -11px;
  }

  .reservation-billing-add:hover { transform: translateX(50%) scale(1.1); }

  .reservation-billing-add-top { text-align: center; }
  .reservation-billing-add--top { right: 50%; transform: translateX(50%); opacity: 1; }

  .reservation-billing-summary {
    width: 100%;
  }
}

/* ═══════════════ Réglages : logo société ═══════════════ */
.company-logo-row {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}
.company-logo-preview {
  width: 120px;
  height: 80px;
  border: 1px dashed var(--line-strong);
  border-radius: 12px;
  background: var(--surface);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  flex: 0 0 auto;
}
.company-logo-preview img { max-width: 100%; max-height: 100%; object-fit: contain; }
.company-logo-empty { color: var(--t4); font-size: 12px; display: inline-flex; gap: 6px; align-items: center; }
.company-logo-actions { display: flex; flex-direction: column; gap: 8px; align-items: flex-start; }
.company-logo-upload { cursor: pointer; }

/* ═══════════════ Bouton Imprimer / PDF (facturation) ═══════════════ */
.reservation-billing-print {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  height: 40px;
  padding: 0 16px;
  border-radius: 10px;
  border: 1px solid var(--line-strong);
  background: var(--surface);
  color: var(--t1);
  font-weight: 700;
  cursor: pointer;
  transition: border-color .15s, color .15s, transform .15s;
}
.reservation-billing-print:hover { border-color: var(--accent); color: var(--accent); transform: translateY(-1px); }

/* ═══════════════ Aperçu facture imprimable ═══════════════ */
.invoice-overlay {
  position: fixed;
  inset: 0;
  z-index: 4000;
  background: rgba(15, 18, 24, .55);
  display: flex;
  flex-direction: column;
  overflow: auto;
}
.invoice-toolbar {
  position: sticky;
  top: 0;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 12px 18px;
  background: var(--surface);
  border-bottom: 1px solid var(--line);
  box-shadow: var(--shadow-1);
}
.invoice-toolbar-title { font-weight: 700; color: var(--t1); font-size: 14px; }
.invoice-btn-ghost,
.invoice-btn-print {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  height: 40px;
  padding: 0 18px;
  border-radius: 10px;
  font-weight: 700;
  cursor: pointer;
  border: 1px solid var(--line-strong);
  background: var(--surface);
  color: var(--t1);
}
.invoice-btn-print { background: var(--accent); border-color: var(--accent); color: #fff; }
.invoice-btn-print:hover { filter: brightness(1.05); }
.invoice-scroll { padding: 28px 16px 64px; display: flex; justify-content: center; }

.invoice-sheet {
  width: 210mm;
  max-width: 100%;
  box-sizing: border-box;
  background: #fff;
  color: #1f2430;
  padding: 22mm 18mm;
  border-radius: 6px;
  box-shadow: 0 20px 60px -20px rgba(0,0,0,.5);
  font-size: 12px;
  line-height: 1.45;
}
.invoice-sheet .inv-head { display: flex; justify-content: space-between; gap: 24px; margin-bottom: 26px; }
.invoice-sheet .inv-logo { max-height: 64px; max-width: 220px; object-fit: contain; margin-bottom: 10px; display: block; }
.invoice-sheet .inv-logo-fallback { font-size: 20px; font-weight: 800; color: #1f2430; margin-bottom: 8px; }
.invoice-sheet .inv-company-name { font-weight: 800; font-size: 15px; }
.invoice-sheet .inv-company-addr { color: #4a5160; margin-top: 4px; }
.invoice-sheet .inv-company-meta { color: #6b7280; margin-top: 6px; font-size: 11px; }
.invoice-sheet .inv-head-right { text-align: right; flex: 0 0 auto; }
.invoice-sheet .inv-title { font-size: 26px; font-weight: 850; letter-spacing: .04em; color: var(--accent, #f5874d); margin-bottom: 10px; }
.invoice-sheet .inv-meta-table { border-collapse: collapse; margin-left: auto; }
.invoice-sheet .inv-meta-table td { padding: 2px 0 2px 14px; text-align: right; }
.invoice-sheet .inv-meta-table td:first-child { color: #6b7280; }
.invoice-sheet .inv-meta-table td:last-child { font-weight: 700; }

.invoice-sheet .inv-parties { display: flex; justify-content: space-between; gap: 24px; margin-bottom: 22px; }
.invoice-sheet .inv-label { text-transform: uppercase; letter-spacing: .05em; font-size: 10px; font-weight: 800; color: #9aa1ad; margin-bottom: 4px; }
.invoice-sheet .inv-client-name { font-weight: 800; font-size: 14px; }
.invoice-sheet .inv-client-addr { color: #4a5160; margin-top: 2px; }
.invoice-sheet .inv-client-meta { color: #6b7280; margin-top: 4px; font-size: 11px; }
.invoice-sheet .inv-stay { text-align: right; }

.invoice-sheet .inv-table { width: 100%; border-collapse: collapse; margin-bottom: 18px; }
.invoice-sheet .inv-table thead th {
  background: #f3f4f6;
  color: #4a5160;
  text-transform: uppercase;
  font-size: 9.5px;
  letter-spacing: .03em;
  font-weight: 800;
  padding: 8px 8px;
  text-align: right;
  border-bottom: 1px solid #e2e5ea;
}
.invoice-sheet .inv-table thead th:nth-child(1),
.invoice-sheet .inv-table thead th:nth-child(2) { text-align: left; }
.invoice-sheet .inv-table tbody td { padding: 8px 8px; border-bottom: 1px solid #eef0f3; text-align: right; vertical-align: top; }
.invoice-sheet .inv-table tbody td.inv-desc { text-align: left; }
.invoice-sheet .inv-table tbody td:first-child { text-align: left; white-space: nowrap; }
.invoice-sheet .inv-strong { font-weight: 800; }

.invoice-sheet .inv-totals { display: flex; justify-content: flex-end; }
.invoice-sheet .inv-totals-box { width: 280px; }
.invoice-sheet .inv-totals-box > div { display: flex; justify-content: space-between; padding: 6px 0; border-bottom: 1px solid #eef0f3; }
.invoice-sheet .inv-totals-box > div span { color: #6b7280; }
.invoice-sheet .inv-totals-box > div strong { font-weight: 700; }
.invoice-sheet .inv-ttc { border-top: 2px solid #1f2430; font-size: 14px; }
.invoice-sheet .inv-ttc strong { color: var(--accent, #f5874d); font-weight: 850; }
.invoice-sheet .inv-balance strong { color: #1f2430; font-weight: 850; }
.invoice-sheet .inv-payments {
  margin-top: 18px;
  margin-left: auto;
  width: 360px;
  max-width: 100%;
}
.invoice-sheet .inv-payments > div:not(.inv-label) {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 5px 0;
  border-bottom: 1px solid #eef0f3;
}
.invoice-sheet .inv-payments span { color: #4a5160; }
.invoice-sheet .inv-payments strong { font-weight: 800; }
.invoice-sheet .inv-legal { margin-top: 28px; padding-top: 14px; border-top: 1px solid #e2e5ea; color: #6b7280; font-size: 10.5px; line-height: 1.5; }

/* « screen » seulement : en impression A4 (~688px) ce media se déclencherait
   à tort et casserait la mise en page de la facture. */
@media screen and (max-width: 720px) {
  .invoice-sheet { padding: 16mm 10mm; }
  .invoice-sheet .inv-head,
  .invoice-sheet .inv-parties { flex-direction: column; }
  .invoice-sheet .inv-head-right,
  .invoice-sheet .inv-stay { text-align: left; }
  .invoice-sheet .inv-meta-table { margin-left: 0; }
  .invoice-sheet .inv-table { display: block; overflow-x: auto; }
}

/* Impression : on ne montre que la feuille */
@media print {
  body.invoice-open > *:not(#invoiceOverlay) { display: none !important; }
  #invoiceOverlay { position: static; background: #fff; overflow: visible; display: block; }
  #invoiceOverlay .invoice-toolbar { display: none !important; }
  #invoiceOverlay .invoice-scroll { padding: 0; display: block; }
  .invoice-sheet { box-shadow: none; border-radius: 0; width: auto; max-width: none; padding: 0; }
  /* On force la mise en page « desktop » de la facture, quelle que soit la largeur de page. */
  .invoice-sheet .inv-head,
  .invoice-sheet .inv-parties { display: flex; flex-direction: row; }
  .invoice-sheet .inv-head-right,
  .invoice-sheet .inv-stay { text-align: right; }
  .invoice-sheet .inv-meta-table { margin-left: auto; }
  .invoice-sheet .inv-table { display: table; }
  @page { size: A4; margin: 14mm; }
}

/* Harmonisation 20260616c: filtres, vues et retours */
.dashboard-property-filter {
  align-items: center;
  display: flex;
  gap: 8px;
  margin: -4px 0 18px;
  overflow-x: auto;
  padding: 2px 0 4px;
  scrollbar-width: thin;
}
.dashboard-property-chip {
  align-items: center;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--t2);
  cursor: pointer;
  display: inline-flex;
  flex: 0 0 auto;
  font-size: 12.5px;
  font-weight: 700;
  gap: 7px;
  min-height: 34px;
  padding: 0 12px;
}
.dashboard-property-chip.is-on {
  background: var(--accent-soft);
  border-color: rgba(245, 135, 77, .45);
  color: var(--accent);
}
.dashboard-property-dot {
  border-radius: 50%;
  height: 8px;
  width: 8px;
}
.reservation-status-filter {
  appearance: none;
  min-width: 132px;
}
.reservation-view-toggle {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 12px;
  display: grid;
  gap: 4px;
  grid-template-columns: 1fr 1fr;
  padding: 4px;
}
.reservation-view-toggle button {
  align-items: center;
  background: transparent;
  border: 0;
  border-radius: 9px;
  color: var(--t3);
  cursor: pointer;
  display: inline-flex;
  font-size: 12.5px;
  font-weight: 750;
  gap: 7px;
  justify-content: center;
  min-height: 32px;
  padding: 0 10px;
}
.reservation-view-toggle button.is-active {
  background: var(--t1);
  color: var(--surface);
}
.reservation-list-view {
  display: grid;
  gap: 6px;
  padding: 12px;
}
.reservation-list-head,
.reservation-list-row {
  align-items: center;
  display: grid;
  gap: 10px;
  grid-template-columns: minmax(150px, 1.4fr) minmax(120px, 1fr) minmax(150px, 1.1fr) minmax(100px, .8fr) minmax(90px, .7fr);
}
.reservation-list-head {
  color: var(--t3);
  font-size: 11px;
  font-weight: 800;
  padding: 0 12px 4px;
  text-transform: uppercase;
}
.reservation-list-row {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 12px;
  color: var(--t2);
  cursor: pointer;
  font-size: 12.5px;
  min-height: 54px;
  padding: 10px 12px;
  text-align: left;
}
.reservation-list-row:hover {
  border-color: var(--accent);
  box-shadow: var(--shadow-2);
}
.reservation-list-main {
  display: grid;
  gap: 2px;
  min-width: 0;
}
.reservation-list-main strong,
.reservation-list-row > span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.reservation-list-main strong {
  color: var(--t1);
  font-size: 13px;
}
.reservation-list-main small {
  color: var(--t3);
  font-size: 11.5px;
}
.prop-back-btn,
.ms-back-btn,
.exp2-back,
.dashboard-side-back,
.cln-users-back-btn,
.cln-back-btn,
.property-back-btn {
  border-radius: 10px !important;
  flex: 0 0 38px !important;
  height: 38px !important;
  min-height: 38px !important;
  min-width: 38px !important;
  padding: 0 !important;
  width: 38px !important;
}
.prop-back-btn i,
.ms-back-btn i,
.exp2-back i,
.dashboard-side-back i,
.cln-users-back-btn i,
.cln-back-btn i,
.property-back-btn i {
  font-size: 15px;
}
.settings-mode .ms-back-btn,
.page-split-detail > .prop-back-btn,
.property-detail-form.ms-detail-content > .prop-back-btn {
  margin-bottom: 16px !important;
}
@media (max-width: 760px) {
  .dashboard-property-filter {
    margin-bottom: 16px;
    padding-bottom: 6px;
  }
  .reservation-filter-row .reservation-status-filter {
    width: 100%;
  }
  .reservation-list-head {
    display: none;
  }
  .reservation-list-row {
    gap: 5px;
    grid-template-columns: 1fr;
  }
  .reservation-list-row > span {
    white-space: normal;
  }
}

/* Harmonisation 20260616d: booking footer, dashboard filters, reservations toolbar, back buttons */
.booking-save-bar.pg-action-bar.ms-action-bar {
  align-items: center !important;
  background: var(--surface) !important;
  border: 1px solid var(--line) !important;
  border-radius: 14px !important;
  bottom: auto !important;
  box-shadow: var(--shadow-2) !important;
  display: flex !important;
  gap: 8px !important;
  justify-content: flex-end !important;
  margin-left: 0 !important;
  margin-top: 18px !important;
  padding: 14px 18px !important;
  position: static !important;
  width: 100% !important;
}
.booking-save-btn.pg-action-primary {
  background: var(--accent) !important;
  border: 0 !important;
  border-radius: 10px !important;
  box-shadow: 0 4px 10px -3px var(--accent-ring) !important;
  color: #fff !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  height: 36px !important;
  min-height: 36px !important;
  padding: 0 16px !important;
}

.reservations-mode .reservation-toolbar {
  align-items: center !important;
  display: grid !important;
  gap: 10px !important;
  grid-template-columns: minmax(260px, 1.2fr) minmax(260px, .8fr) minmax(280px, .8fr) auto auto;
  padding: 0 0 14px !important;
}
.reservations-mode .reservation-picker-head {
  align-items: flex-start;
  display: grid;
  gap: 12px;
  grid-template-columns: minmax(0, 1fr) auto auto;
  height: auto;
}
.reservations-mode .reservation-picker-head .prop-picker-count {
  align-self: center;
  justify-self: end;
}
.reservations-mode .reservation-picker-head .reservation-add-btn {
  align-self: center;
  justify-self: end;
}
.reservations-mode .reservation-toolbar .res-search-wrap {
  flex: none !important;
  max-width: none !important;
  min-width: 0;
  width: 100%;
}
.reservations-mode .reservation-toolbar .reservation-filter-row {
  display: flex !important;
  flex-wrap: nowrap;
  gap: 10px;
  min-width: 0;
  width: 100%;
}
.reservations-mode .reservation-toolbar .date-picker,
.reservations-mode .reservation-toolbar .filter-dropdown,
.reservations-mode .reservation-status-filter {
  flex: 1 1 0;
  min-width: 0 !important;
  width: 100%;
}
.reservations-mode .reservation-filter-btn,
.reservations-mode .reservation-status-filter,
.reservations-mode .reservation-toolbar .date-picker .ms-field-input {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 12px;
  color: var(--t1);
  min-height: 42px;
}
.reservations-mode .reservation-filter-btn {
  justify-content: center;
  width: 100%;
}
.reservations-mode .reservation-status-filter {
  padding: 0 14px;
}
.reservations-mode .reservation-view-toggle {
  align-self: stretch;
  min-width: 152px;
}
.reservations-mode .reservation-search-btn {
  min-height: 42px;
  white-space: nowrap;
}
.reservations-mode .reservation-property-filter .filter-menu {
  min-width: 320px;
  width: min(360px, calc(100vw - 48px));
}
.reservation-list-view {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 16px;
  box-shadow: var(--shadow-1);
  margin-top: 12px;
}
.reservation-list-row {
  background: var(--surface);
}

.page-split.prop-mode .page-split-detail .prop-back-btn,
.page-split.reservations-mode .page-split-detail .prop-back-btn,
.settings-mode .ms-back-btn,
.experience-mobile-back,
.exp2-back {
  background: var(--surface) !important;
  border: 1px solid var(--line-strong) !important;
  box-shadow: none !important;
  color: var(--t2) !important;
  font-weight: 500 !important;
}

@media (max-width: 1100px) {
  .reservations-mode .reservation-toolbar {
    grid-template-columns: 1fr 1fr !important;
  }
}

@media (max-width: 760px) {
  .reservations-mode .reservation-toolbar {
    grid-template-columns: 1fr !important;
  }
  .reservations-mode .reservation-picker-head {
    grid-template-columns: 1fr auto;
  }
  .reservations-mode .reservation-picker-head .reservation-add-btn {
    grid-column: 1 / -1;
    justify-self: start;
  }
  .reservations-mode .reservation-toolbar .reservation-filter-row {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
  }
  .reservations-mode .reservation-property-filter .filter-menu {
    min-width: 0;
    width: 100%;
  }
  .reservations-mode .reservation-view-toggle,
  .reservations-mode .reservation-search-btn {
    width: 100%;
  }
  .page-split.prop-mode[data-prop-panel="tabs"] .page-split-list,
  .page-split.prop-mode[data-prop-panel="detail"] .page-split-detail {
    box-sizing: border-box;
    padding: 18px 16px 36px !important;
  }
  .page-split.prop-mode .page-split-tabs,
  .page-split.prop-mode .property-detail-form.ms-detail-content {
    box-sizing: border-box;
    margin-left: auto;
    margin-right: auto;
    max-width: 620px;
    width: 100%;
  }
  .page-split.prop-mode[data-prop-panel="tabs"] .page-split-tabs,
  .page-split.prop-mode[data-prop-panel="detail"] .page-split-detail,
  .page-split.prop-mode .property-detail-form.ms-detail-content {
    padding-top: 0 !important;
  }
  .page-split.prop-mode .page-split-tabs > .prop-back-btn,
  .page-split.prop-mode .property-detail-form.ms-detail-content > .prop-back-btn {
    border-radius: 10px !important;
    color: var(--t2) !important;
    flex: 0 0 38px !important;
    height: 38px !important;
    margin: 0 0 16px !important;
    min-height: 38px !important;
    min-width: 38px !important;
    width: 38px !important;
  }
}

/* ==========================================================================
   UI DESIGN SYSTEM
   Source of truth for reusable SaaS components.
   Old page-specific classes are temporarily mapped here when they are still
   used by JavaScript hooks or legacy markup.
   ========================================================================== */

/* Design tokens ----------------------------------------------------------- */
:root {
  --ui-color-primary: var(--accent);
  --ui-color-primary-hover: var(--accent-2);
  --ui-color-danger: var(--rose);
  --ui-color-danger-hover: #c73564;
  --ui-bg-page: var(--bg);
  --ui-bg-page-soft: var(--bg-soft);
  --ui-bg-card: var(--surface);
  --ui-bg-muted: var(--surface-2);
  --ui-bg-control: var(--surface);
  --ui-border: var(--line);
  --ui-border-strong: var(--line-strong);
  --ui-text: var(--t1);
  --ui-text-muted: var(--t3);
  --ui-radius-xs: 8px;
  --ui-radius-sm: 10px;
  --ui-radius-md: 12px;
  --ui-radius-lg: 14px;
  --ui-radius-xl: 16px;
  --ui-shadow-sm: var(--shadow-1);
  --ui-shadow-md: var(--shadow-2);
  --ui-shadow-pop: var(--shadow-pop);
  --ui-space-1: 4px;
  --ui-space-2: 8px;
  --ui-space-3: 12px;
  --ui-space-4: 16px;
  --ui-space-5: 20px;
  --ui-space-6: 24px;
  --ui-font-xs: 11px;
  --ui-font-sm: 12.5px;
  --ui-font-md: 13.5px;
  --ui-font-lg: 16px;
  --ui-font-xl: 22px;
  --ui-button-height: 38px;
  --ui-back-size: 38px;
  --ui-transition: 0.15s ease;
}

[data-theme="dark"] {
  --ui-color-danger-hover: #f05689;
}

/* Page layout ------------------------------------------------------------- */
body,
.main-content,
.page-main,
.page-split,
.experience-page,
.settings-mode {
  background: var(--ui-bg-page);
}

.ui-page-header,
.reservation-picker-head,
.booking-editor-head,
.exp2-editbar,
.settings-topbar {
  align-items: center;
  background: var(--ui-bg-card);
  border: 1px solid var(--ui-border);
  border-radius: var(--ui-radius-lg);
  box-shadow: var(--ui-shadow-sm);
  display: flex;
  gap: var(--ui-space-3);
  padding: var(--ui-space-4);
}

/* Buttons ---------------------------------------------------------------- */
.ui-button,
.ui-button--primary,
.ui-button--secondary,
.ui-button--ghost,
.ui-button--danger,
.ui-save-button,
.ui-back-button,
:where(.btn, .ms-btn-primary, .ms-btn-ghost, .ms-btn-danger, .pg-action-primary, .pg-action-danger, .pg-action-secondary, .app-modal-btn, .tool-btn, .reservation-filter-btn, .reservation-search-btn, .booking-save-btn) {
  align-items: center;
  border-radius: var(--ui-radius-sm);
  cursor: pointer;
  display: inline-flex;
  flex: 0 0 auto;
  font-family: inherit;
  font-size: var(--ui-font-md);
  font-weight: 750;
  gap: 8px;
  height: var(--ui-button-height);
  justify-content: center;
  line-height: 1;
  min-height: var(--ui-button-height);
  padding: 0 16px;
  text-decoration: none;
  transition: background var(--ui-transition), border-color var(--ui-transition), color var(--ui-transition), box-shadow var(--ui-transition), transform 0.1s ease;
  white-space: nowrap;
}

.ui-button:disabled,
.ui-button[aria-disabled="true"],
:where(.btn, .ms-btn-primary, .ms-btn-ghost, .ms-btn-danger, .pg-action-primary, .pg-action-danger, .pg-action-secondary, .app-modal-btn, .tool-btn, .reservation-filter-btn, .reservation-search-btn, .booking-save-btn):disabled {
  cursor: not-allowed;
  opacity: 0.52;
  transform: none;
}

.ui-button--primary,
.ui-save-button,
:where(.btn-primary, .pg-action-primary, .ms-btn-primary, .app-modal-btn-primary, .reservation-search-btn, .booking-save-btn.pg-action-primary, .booking-save-btn.ui-save-button) {
  background: var(--ui-color-primary) !important;
  border: 1px solid var(--ui-color-primary) !important;
  box-shadow: 0 4px 10px -3px var(--accent-ring);
  color: #fff !important;
}

.ui-button--primary:hover,
.ui-save-button:hover,
:where(.btn-primary, .pg-action-primary, .ms-btn-primary, .app-modal-btn-primary, .reservation-search-btn, .booking-save-btn.pg-action-primary):hover {
  background: var(--ui-color-primary-hover) !important;
  border-color: var(--ui-color-primary-hover) !important;
}

.ui-button--secondary,
:where(.btn-secondary, .pg-action-secondary, .app-modal-btn-ghost, .ms-btn-ghost) {
  background: var(--ui-bg-control) !important;
  border: 1px solid var(--ui-border-strong) !important;
  box-shadow: none;
  color: var(--t2) !important;
}

.ui-button--secondary:hover,
:where(.btn-secondary, .pg-action-secondary, .app-modal-btn-ghost, .ms-btn-ghost):hover {
  background: var(--ui-bg-muted) !important;
  color: var(--ui-text) !important;
}

.ui-button--ghost,
:where(.btn-ghost, .tool-btn, .reservation-filter-btn) {
  background: var(--ui-bg-control) !important;
  border: 1px solid var(--ui-border) !important;
  box-shadow: var(--ui-shadow-sm);
  color: var(--t2) !important;
}

.ui-button--ghost:hover,
:where(.btn-ghost, .tool-btn, .reservation-filter-btn):hover {
  background: var(--ui-bg-muted) !important;
  border-color: var(--ui-border-strong) !important;
  color: var(--ui-text) !important;
}

.ui-button--danger,
:where(.btn-danger, .pg-action-danger, .ms-btn-danger) {
  background: var(--ui-bg-control) !important;
  border: 1px solid rgba(224, 69, 123, 0.28) !important;
  color: var(--ui-color-danger) !important;
}

.ui-button--danger:hover,
:where(.btn-danger, .pg-action-danger, .ms-btn-danger):hover {
  background: var(--rose-soft) !important;
  border-color: rgba(224, 69, 123, 0.36) !important;
  color: var(--ui-color-danger-hover) !important;
}

.ui-back-button,
:where(.prop-back-btn, .ms-back-btn, .exp2-back, .experience-mobile-back, .dashboard-side-back, .cln-users-back-btn, .cln-back-btn, .property-back-btn, .inbox-back-btn, .automation-back-btn) {
  align-items: center !important;
  background: var(--ui-bg-control) !important;
  border: 1px solid var(--ui-border-strong) !important;
  border-radius: var(--ui-radius-sm) !important;
  box-shadow: var(--ui-shadow-sm) !important;
  color: var(--t2) !important;
  display: inline-flex !important;
  flex: 0 0 var(--ui-back-size) !important;
  font-size: 0 !important;
  font-weight: 500 !important;
  height: var(--ui-back-size) !important;
  justify-content: center !important;
  min-height: var(--ui-back-size) !important;
  min-width: var(--ui-back-size) !important;
  padding: 0 !important;
  width: var(--ui-back-size) !important;
}

.ui-back-button:hover,
:where(.prop-back-btn, .ms-back-btn, .exp2-back, .experience-mobile-back, .dashboard-side-back, .cln-users-back-btn, .cln-back-btn, .property-back-btn, .inbox-back-btn, .automation-back-btn):hover {
  background: var(--ui-bg-muted) !important;
  border-color: var(--ui-border-strong) !important;
  color: var(--ui-text) !important;
}

.ui-back-button i,
:where(.prop-back-btn, .ms-back-btn, .exp2-back, .experience-mobile-back, .dashboard-side-back, .cln-users-back-btn, .cln-back-btn, .property-back-btn, .inbox-back-btn, .automation-back-btn) i {
  font-size: 15px !important;
}

/* Action bars ------------------------------------------------------------- */
.ui-action-bar,
:where(.pg-action-bar, .pg-action-bar.ms-action-bar, .ms-action-bar, .booking-save-bar.pg-action-bar.ms-action-bar, .property-action-bar.ms-action-bar, .tpl-action-bar.ms-action-bar, .res-action-bar.ms-action-bar, .cleaning-settings-action-bar.ms-action-bar, .cleaning-users-action-bar.ms-action-bar, .cleaning-assign-action-bar.ms-action-bar) {
  align-items: center !important;
  background: var(--ui-bg-card) !important;
  border: 1px solid var(--ui-border) !important;
  border-radius: var(--ui-radius-lg) !important;
  box-shadow: var(--ui-shadow-md) !important;
  display: flex !important;
  gap: var(--ui-space-2) !important;
  justify-content: flex-end !important;
  margin-left: 0 !important;
  margin-top: var(--ui-space-5) !important;
  padding: 14px 18px !important;
  width: 100% !important;
}

.ui-action-bar.is-sticky,
:where(.pg-action-bar, .pg-action-bar.ms-action-bar, .ms-action-bar, .property-action-bar.ms-action-bar, .tpl-action-bar.ms-action-bar, .res-action-bar.ms-action-bar, .cleaning-settings-action-bar.ms-action-bar, .cleaning-users-action-bar.ms-action-bar) {
  bottom: 12px;
  position: sticky;
  z-index: 20;
}

.booking-save-bar.pg-action-bar.ms-action-bar {
  bottom: auto !important;
  position: static !important;
}

/* Cards ------------------------------------------------------------------ */
.ui-card,
:where(.card, .ms-card, .ms-prop-card, .pg-form-section, .booking-card, .book-form-card, .cmd-card, .res-page-card, .reservation-billing-card, .settings-card, .cleaning-detail-card, .cleaning-list-card, .dashboard-detail-card, .tpl-card, .property-sub-card, .property-channel-card, .guest-action-card, .cal-modal, .app-modal) {
  background: var(--ui-bg-card);
  border: 1px solid var(--ui-border);
  border-radius: var(--ui-radius-xl);
  box-shadow: var(--ui-shadow-sm);
}

.ui-card__header,
:where(.card-header, .card-head, .ms-card-head, .pg-form-section-head, .booking-card-head, .res-page-tabs, .cal-modal-header) {
  border-bottom: 1px solid var(--ui-border);
}

/* Forms ------------------------------------------------------------------ */
.ui-input,
.ui-select,
.ui-textarea,
:where(.ms-field-input, .pg-input, .booking-input, .app-modal-input, .res-search-input, .inbox-search-input, .inbox-compose-input, .adm-date-input, .cal-modal-input, .cal-msg-textarea, .reservation-billing-cell input, .reservation-billing-cell select, .book-field input, .book-field select, .book-field textarea, .html-tool-field input[type="text"], .html-tool-field input[type="url"]) {
  background: var(--ui-bg-control) !important;
  border: 1px solid var(--ui-border-strong) !important;
  border-radius: var(--ui-radius-sm) !important;
  color: var(--ui-text) !important;
  font-family: inherit;
  font-size: var(--ui-font-md);
  min-height: 40px;
  outline: none;
  transition: border-color var(--ui-transition), box-shadow var(--ui-transition), background var(--ui-transition);
}

.ui-input:focus,
.ui-select:focus,
.ui-textarea:focus,
:where(.ms-field-input, .pg-input, .booking-input, .app-modal-input, .res-search-input, .inbox-search-input, .inbox-compose-input, .adm-date-input, .cal-modal-input, .cal-msg-textarea, .reservation-billing-cell input, .reservation-billing-cell select, .book-field input, .book-field select, .book-field textarea, .html-tool-field input[type="text"], .html-tool-field input[type="url"]):focus {
  border-color: var(--ui-color-primary) !important;
  box-shadow: 0 0 0 3px var(--accent-ring) !important;
}

.ui-textarea,
:where(textarea.ms-field-input, textarea.pg-input, .book-field textarea) {
  line-height: 1.45;
  resize: vertical;
}

/* Modals ----------------------------------------------------------------- */
.ui-modal-backdrop,
:where(.cal-modal-backdrop, .app-modal-backdrop, .calendar-note-modal-backdrop, .guest-action-modal, .cal-modal-overlay) {
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

.ui-modal,
:where(.app-modal, .cal-modal, .calendar-note-modal, .property-photo-modal, .guest-action-card, .logo-crop-card) {
  background: var(--ui-bg-card) !important;
  border: 1px solid var(--ui-border) !important;
  border-radius: var(--ui-radius-xl) !important;
  box-shadow: var(--ui-shadow-pop) !important;
}

.ui-modal-actions,
:where(.app-modal-actions, .cal-modal-actions, .calendar-note-modal-actions, .property-photo-modal .app-modal-actions) {
  display: flex;
  gap: var(--ui-space-2);
  justify-content: flex-end;
}

/* Menus ------------------------------------------------------------------ */
.ui-menu,
:where(.property-sort-menu, .filter-menu, .automation-multiselect-menu, .cl-filter-menu, .dashboard-property-sort-menu) {
  background: var(--ui-bg-card) !important;
  border: 1px solid var(--ui-border) !important;
  border-radius: var(--ui-radius-lg) !important;
  box-shadow: var(--ui-shadow-pop) !important;
}

.ui-menu-item,
:where(.property-sort-option, .property-sort-row, .calendar-filter-check, .prop-group-filter-option, .reservation-filter-option, .cl-filter-menu .filter-option) {
  border-radius: var(--ui-radius-sm);
  transition: background var(--ui-transition), border-color var(--ui-transition), color var(--ui-transition);
}

.ui-menu-item:hover,
:where(.property-sort-option, .property-sort-row, .calendar-filter-check, .prop-group-filter-option, .reservation-filter-option, .cl-filter-menu .filter-option):hover {
  background: var(--ui-bg-muted);
}

/* Tabs ------------------------------------------------------------------- */
.ui-tabs,
:where(.page-split-tabs, .property-tabs, .cleaning-tabs, .automation-language-tabs, .calendar-view-tabs, .reservation-view-toggle, .cdv-tabs, .guest-client-tabs) {
  background: var(--ui-bg-card);
  border: 1px solid var(--ui-border);
  border-radius: var(--ui-radius-md);
}

.ui-tab,
:where(.property-tab, .property-detail-subtab, .cleaning-tabs button, .automation-language-tabs button, .calendar-view-tabs button, .reservation-view-toggle button, .cdv-tab, .guest-client-tabs button) {
  border-radius: var(--ui-radius-sm);
}

/* Tables ----------------------------------------------------------------- */
.ui-table,
:where(.reservation-list-view, .reservation-billing-table, .invoice-sheet .inv-table) {
  background: var(--ui-bg-card);
  border: 1px solid var(--ui-border);
  border-radius: var(--ui-radius-xl);
  box-shadow: var(--ui-shadow-sm);
}

.ui-table-row,
:where(.reservation-list-row, .reservation-billing-row) {
  border-color: var(--ui-border);
}

/* Badges, alerts, empty states ------------------------------------------ */
.ui-badge,
:where(.sb-badge, .account-badge, .cmd-req-badge, .adm-badge-assigned, .adm-badge-urgency, .booking-site-card-badge, .cal-modal-status-badge) {
  border-radius: 999px;
  font-weight: 800;
}

.ui-alert,
:where(.cleaning-report-alert, .form-message, .reservation-billing-warning) {
  border-radius: var(--ui-radius-md);
}

.ui-empty-state,
:where(.empty-state, .page-split-empty, .book-empty, .ism-empty, .guest-empty-pane, .cal-msg-empty, .cleaning-report-list-empty, .property-map-empty, .prop-picker-empty) {
  color: var(--ui-text-muted);
}

/* Utilities -------------------------------------------------------------- */
.ui-scrollbar,
* {
  scrollbar-color: rgba(118,118,126,0.35) transparent;
  scrollbar-width: thin;
}

*::-webkit-scrollbar {
  height: 8px;
  width: 8px;
}

*::-webkit-scrollbar-track {
  background: transparent;
}

*::-webkit-scrollbar-thumb {
  background: rgba(118,118,126,0.28);
  border: 2px solid transparent;
  border-radius: 999px;
  background-clip: padding-box;
}

*::-webkit-scrollbar-thumb:hover {
  background: rgba(118,118,126,0.46);
  border: 2px solid transparent;
  background-clip: padding-box;
}

@media (max-width: 760px) {
  :root {
    --ui-button-height: 40px;
    --ui-back-size: 38px;
  }

  .ui-action-bar,
  :where(.pg-action-bar, .pg-action-bar.ms-action-bar, .ms-action-bar, .property-action-bar.ms-action-bar, .tpl-action-bar.ms-action-bar, .res-action-bar.ms-action-bar, .cleaning-settings-action-bar.ms-action-bar, .cleaning-users-action-bar.ms-action-bar) {
    border-radius: var(--ui-radius-lg) !important;
    padding: 12px !important;
  }

  .page-split.prop-mode[data-prop-panel="tabs"] .page-split-list,
  .page-split.prop-mode[data-prop-panel="detail"] .page-split-detail,
  .settings-mode .page-split-detail,
  .reservations-mode .page-split-detail {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }
}

/* ══════════════════════════════════════════════════════════════════════════
   GABARIT CANONIQUE — Page liste (mockup validé : header + recherche + filtres
   + blocs). S'applique à properties (.prop-mode). Couleurs = variables du site
   → clair/sombre automatiques. Classes legacy conservées (hooks JS).
   ══════════════════════════════════════════════════════════════════════════ */

/* En-tête : carte blanche, bord, eyebrow + titre + pastille compteur */
.page-split.prop-mode:not([data-prop-panel]) .prop-picker-head {
  background: var(--surface) !important;
  border: 1.5px solid var(--line) !important;
  border-radius: 16px !important;
  padding: 16px 18px !important;
  margin: 6px 0 16px !important;
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
}
.page-split.prop-mode:not([data-prop-panel]) .prop-picker-title {
  flex: 1 !important;
  min-width: 0 !important;
}
.page-split.prop-mode:not([data-prop-panel]) .prop-picker-title .experience-eyebrow {
  color: var(--accent) !important;
  font-size: 11.5px !important;
  font-weight: 800 !important;
  letter-spacing: .06em !important;
  text-transform: uppercase !important;
  margin: 0 0 2px !important;
}
.page-split.prop-mode:not([data-prop-panel]) .prop-picker-title h1 {
  font-size: 23px !important;
  font-weight: 800 !important;
  letter-spacing: -.02em !important;
  line-height: 1.08 !important;
  margin: 0 !important;
}
.prop-mode .prop-picker-count {
  flex: 0 0 auto !important;
  background: var(--surface) !important;
  border: 1px solid var(--line-strong) !important;
  color: var(--t3) !important;
  border-radius: 999px !important;
  font-size: 12.5px !important;
  font-weight: 600 !important;
  padding: 6px 13px !important;
}

/* Barre de recherche : pilule */
.page-split.prop-mode:not([data-prop-panel]) .prop-picker-search {
  background: var(--surface) !important;
  border: 1.5px solid var(--line-strong) !important;
  border-radius: 999px !important;
  height: 46px !important;
  padding: 0 16px !important;
  margin: 0 0 14px !important;
  gap: 10px !important;
  max-width: none !important;
  box-shadow: none !important;
}

/* Boutons de filtres : ghost bien visibles */
.prop-mode .pg-list-tools .prop-sort-control {
  background: var(--surface) !important;
  border: 1.5px solid var(--line-strong) !important;
  color: var(--t1) !important;
  border-radius: 12px !important;
  min-height: 40px !important;
  height: 40px !important;
  font-weight: 700 !important;
  box-shadow: none !important;
}
.prop-mode .pg-list-tools .prop-sort-control small { color: var(--t3) !important; font-weight: 600 !important; }
.prop-mode .pg-list-tools .prop-sort-control:hover {
  border-color: var(--accent) !important;
  color: var(--accent) !important;
}

/* Grille de blocs */
.prop-mode .pg-prop-list .prop-group-section-list {
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)) !important;
  gap: 16px !important;
}

/* Carte logement : bord 1.5px */
.prop-mode .pg-prop-list .pg-prop-row {
  border: 1.5px solid var(--line) !important;
  background: var(--surface) !important;
}
.prop-mode .pg-prop-row:hover {
  border-color: var(--line-strong) !important;
  box-shadow: 0 10px 26px -16px rgba(0,0,0,.22) !important;
  transform: translateY(-2px);
}
.prop-mode .pg-prop-row.is-active { border-color: var(--accent) !important; box-shadow: 0 0 0 1px var(--accent) !important; }

/* Carte « Ajouter » : vignette + grand +, libellé centré dans la partie basse */
.prop-mode .prop-create-card {
  border: 1.5px solid var(--line) !important;
  flex-direction: column !important;
  padding: 0 !important;
}
.page-split.prop-mode:not([data-prop-panel]) .prop-create-card .prop-create-card-icon {
  display: flex !important;
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 4 / 3 !important;
  align-items: center !important;
  justify-content: center !important;
  background: var(--surface-2) !important;
  color: var(--accent) !important;
  font-size: 40px !important;
  border-radius: 0 !important;
}
.prop-mode .prop-create-card .pg-prop-main {
  align-items: center !important;
  text-align: center !important;
  padding: 14px 15px 16px !important;
}
.prop-mode .prop-create-card .pg-prop-name { display: none !important; }
.prop-mode .prop-create-card .pg-prop-city {
  font-size: 15px !important;
  font-weight: 700 !important;
  color: var(--t1) !important;
}
.prop-mode .prop-create-card .pg-prop-city i { display: none !important; }

/* Carte « Ajouter » isolée sur sa propre ligne + séparateur de groupe symétrique */
.prop-mode .prop-create-section {
  border-bottom: 1px solid var(--line) !important;
  padding: 0 0 22px !important;
  margin: 0 !important;
}
.prop-mode .pg-prop-list .prop-group-section {
  border-bottom: 1px solid var(--line) !important;
  padding: 22px 0 !important;
  margin: 0 !important;
}
.prop-mode .pg-prop-list .prop-group-section:last-child {
  border-bottom: 0 !important;
  padding-bottom: 0 !important;
}
.prop-mode .pg-prop-list .prop-group-section-title {
  margin: 0 0 14px !important;
  padding: 0 2px !important;
}

/* Menu « Grouper » : largeur identique à calendar (sinon le texte passe sur 2 lignes) */
.prop-list-group-menu.property-sort-menu {
  left: 0 !important;
  right: auto !important;
  width: min(430px, calc(100vw - 48px)) !important;
  padding: 12px !important;
  border-radius: 16px !important;
}

/* Cartes logement VERTICALES aussi en tablette/mobile (gabarit validé) */
@media (max-width: 1080px) {
  .page-split.prop-mode:not([data-prop-panel]) .pg-prop-list .pg-prop-row,
  .page-split.prop-mode:not([data-prop-panel]) .prop-create-card {
    display: flex !important;
    flex-direction: column !important;
    grid-template-columns: none !important;
    align-items: stretch !important;
    gap: 0 !important;
    padding: 0 !important;
    min-height: 0 !important;
  }
  .page-split.prop-mode:not([data-prop-panel]) .pg-prop-list .pg-photo,
  .page-split.prop-mode:not([data-prop-panel]) .prop-create-card .prop-create-card-icon {
    width: 100% !important;
    height: auto !important;
    aspect-ratio: 4 / 3 !important;
    border-radius: 0 !important;
  }
  .page-split.prop-mode:not([data-prop-panel]) .pg-prop-main {
    padding: 13px 15px 15px !important;
  }
}

/* ───── Parité stricte avec calendar.html (menu Grouper + boutons outils) ───── */
/* 1. Menu « Grouper » : mêmes couleurs que calendar (gris neutre, icône active orange) */
.prop-list-group-menu .property-sort-option {
  background: transparent !important;
  color: var(--t2) !important;
  font-weight: 500 !important;
  min-height: 32px !important;
  border-radius: 8px !important;
  font-size: 13px !important;
}
.prop-list-group-menu .property-sort-option i { color: var(--t3) !important; font-size: 12px !important; width: 14px !important; }
.prop-list-group-menu .property-sort-option:hover { background: var(--surface-2) !important; color: var(--t1) !important; }
.prop-list-group-menu .property-sort-option:hover i { color: var(--t1) !important; }
.prop-list-group-menu .property-sort-option.active { background: var(--surface-3, var(--surface-2)) !important; color: var(--t1) !important; font-weight: 600 !important; }
.prop-list-group-menu .property-sort-option.active i { color: var(--accent) !important; }
.prop-list-group-menu .calendar-filter-panel-head strong { color: var(--t1) !important; font-size: 13px !important; font-weight: 700 !important; }
.prop-list-group-menu .calendar-filter-panel-head span { color: var(--t3) !important; font-size: 11.5px !important; font-weight: 500 !important; margin-top: 2px !important; display: block !important; }
.prop-list-group-menu .property-sort-options { padding-top: 6px !important; border-top: 1px solid var(--line) !important; gap: 2px !important; }

/* 3. Boutons Trier / Grouper : rendu strictement identique à .tool-btn (calendar = 38px) */
.prop-mode .pg-list-tools .prop-sort-control {
  height: 38px !important;
  min-height: 38px !important;
  padding: 0 12px !important;
  border: 1px solid var(--line) !important;
  border-radius: 9px !important;
  font-size: 12.5px !important;
  font-weight: 600 !important;
  color: var(--t2) !important;
  background: var(--surface) !important;
  box-shadow: var(--shadow-1) !important;
  width: auto !important;
  gap: 7px !important;
}
.prop-mode .pg-list-tools .prop-sort-control span { font-weight: 600 !important; }
.prop-mode .pg-list-tools .prop-sort-control small { font-weight: 600 !important; color: var(--t3) !important; }
.prop-mode .pg-list-tools .prop-sort-control:hover { background: var(--surface-2) !important; color: var(--t1) !important; border-color: var(--line) !important; }

/* 5. Boutons de filtres alignés à gauche avec le header et la recherche */
.prop-mode .pg-list-tools.prop-list-tools { padding-left: 0 !important; padding-right: 0 !important; margin-left: 0 !important; }
.prop-mode .pg-list-tools.prop-list-tools > * { margin-left: 0 !important; }

/* 4. Carte « Ajouter » : corps de même hauteur que les logements */
.page-split.prop-mode:not([data-prop-panel]) .prop-create-card .pg-prop-main {
  min-height: 96px !important;
  justify-content: center !important;
  box-sizing: border-box !important;
}

/* 2. Menu déroulant qui ne sort plus du cadre sur mobile */
@media (max-width: 760px) {
  .prop-list-group .prop-list-group-menu.property-sort-menu,
  .prop-list-sort .prop-list-sort-menu.property-sort-menu {
    position: fixed !important;
    left: 14px !important;
    right: 14px !important;
    top: auto !important;
    width: auto !important;
    max-width: none !important;
  }
}

/* Menu « Trier » : même largeur que le menu « Grouper » (et que calendar) */
.prop-list-sort-menu.property-sort-menu {
  left: 0 !important;
  right: auto !important;
  width: min(430px, calc(100vw - 48px)) !important;
  min-width: 0 !important;
  max-width: none !important;
  padding: 12px !important;
  border-radius: 16px !important;
}

/* Sous-libellé actif des boutons Trier / Grouper du calendrier */
.tool-btn small { color: var(--t3); font-weight: 500; font-size: 11.5px; }
.tool-btn small:empty { display: none; }
