@layer components {
  /* Stay-info card preview on Prep — shows actual filled values. */
  .prep-stay-info-card {
    background: var(--paper-warm);
    margin-bottom: 22px;
  }
  .prep-stay-info-preview {
    display: flex;
    gap: 14px;
    align-items: flex-start;
    flex-wrap: wrap;
    margin-top: 4px;
  }
  .prep-stay-info-avatar {
    width: 44px; height: 44px;
    border-radius: 50%;
    background: var(--paper-edge);
    border: 2px solid var(--paper);
    display: flex; align-items: center; justify-content: center;
    font-size: 12px;
    letter-spacing: 0.08em;
    color: var(--ink-soft);
    font-weight: var(--weight-semibold);
    flex-shrink: 0;
    box-shadow: 0 1px 2px rgba(0,0,0,0.08);
  }
  .prep-stay-info-preview-body { flex: 1; min-width: 0; }
  .prep-stay-info-name {
    font-family: var(--display);
    font-style: normal;
    font-size: 18px;
    color: var(--ink);
    line-height: 1.2;
    margin-bottom: 4px;
  }
  .prep-stay-info-line {
    font-size: 12.5px;
    color: var(--ink-soft);
    line-height: 1.45;
  }
  .prep-stay-info-line.muted {
    color: var(--ink-faint);
    font-style: italic;
    margin-top: 2px;
  }

  /* ── Stay-info modal layout ── */
  .stay-info-modal { margin-top: 8px; }

  /* ── Profile section: read mode by default; Edit flips to form. ── */
  .stay-info-profile {
    background: rgba(0,0,0,0.045);
    border-radius: 6px;
    padding: 16px 18px;
    margin-bottom: 22px;
  }

  .stay-info-profile-summary {
    display: flex;
    align-items: center;
    gap: 14px;
  }
  .stay-info-profile-edit {
    appearance: none;
    -webkit-appearance: none;
    border: none;
    background: transparent;
    cursor: pointer;
    font: inherit;
    font-size: 11px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--ink-soft);
    padding: 6px 4px;
    transition: color 0.12s ease;
  }
  .stay-info-profile-edit:hover { color: var(--ink); }
  .stay-info-profile-edit:focus { outline: none; }
  .stay-info-profile-avatar {
    width: 44px; height: 44px;
    border-radius: 50%;
    background: var(--paper);
    border: 1.5px solid rgba(0,0,0,0.10);
    display: flex; align-items: center; justify-content: center;
    font-size: 13px;
    letter-spacing: 0.08em;
    color: var(--ink-soft);
    font-weight: var(--weight-semibold);
    flex-shrink: 0;
  }
  .stay-info-profile-summary-body { flex: 1; min-width: 0; }
  .stay-info-profile-name {
    font-family: var(--display);
    font-style: normal;
    font-size: 18px;
    color: var(--ink);
    line-height: 1.2;
  }
  .stay-info-profile-line {
    font-size: 12.5px;
    color: var(--ink-soft);
    margin-top: 2px;
  }

  .stay-info-profile-form { display: none; }
  .stay-info-profile.expanded .stay-info-profile-summary { display: none; }
  .stay-info-profile.expanded .stay-info-profile-form { display: block; }

  /* Quiet inline notice — surfaces missing-profile fields. Plain
     muted text, no bg, sits beneath the summary card content. */
  .stay-info-profile-missing {
    margin: 12px 0 0;
    padding: 10px 0 0;
    border-top: 1px solid rgba(0, 0, 0, 0.08);
    color: var(--ink-soft);
    font-size: 12.5px;
    font-style: italic;
    line-height: 1.4;
  }

  /* ── Other sections ── */
  .stay-info-section { margin-top: 22px; }
  .stay-info-section:first-child { margin-top: 0; }
  .stay-info-section-title {
    font-size: 11px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--ink-faint);
    margin-bottom: 10px;
    font-weight: var(--weight-bold);
  }
  .stay-info-section-help {
    font-size: 12px;
    color: var(--ink-soft);
    font-style: italic;
    margin: -4px 0 12px;
    line-height: 1.5;
  }

  /* Companions */
  .stay-info-companions {
    list-style: none;
    margin: 0 0 10px;
    padding: 0;
    font-size: 14px;
    color: var(--ink);
  }
  .stay-info-companions li { padding: 6px 0; border-bottom: 1px solid rgba(0,0,0,0.06); }
  .stay-info-companions.hidden { display: none; }

  .companions-form {
    margin-top: 14px;
    padding: 16px 16px 14px;
    border: 1px solid rgba(0,0,0,0.18);
    border-radius: 6px;
    background: rgba(0,0,0,0.02);
  }
  .companions-form.hidden { display: none; }
  .companions-form .nom-field { margin-bottom: 12px; }
  .companions-form .nom-field:last-of-type { margin-bottom: 14px; }
  .companions-form-actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    margin-top: 6px;
  }

@media (max-width: 768px) {
    .stay-info-profile { padding: 14px 14px; }
    .stay-info-profile-name { font-size: 16px; }
  }
}
