/* app/room-chrome.css — habillage de la surface ROOM (chrome + layout).
   Partageable par toute page hôte qui monte un simulateur (démo, future page room).
   RÈGLE : aucune couleur/forme en dur — tout vient des variables --vr-* que la
   couche app pose sur .vr-room depuis le thème résolu (resolveRoomTheme). Les
   variables sont SCOPÉES à .vr-room : la cascade tenant ne fuit pas hors de la room. */

/* Conteneur de la room : carte à coins arrondis, encadrement fin. */
.vr-room {
  font-family: var(--vr-font-body);
  color: var(--vr-on-surface); /* encre : s'inverse en mode sombre */
  background: var(--vr-surface);
  border: var(--vr-border-thin) solid var(--vr-border);
  border-radius: var(--vr-radius-card);
  overflow: hidden;
}

/* Header : bande structure (bleu nuit), fente logo + titre. */
.vr-chrome-header {
  display: flex; align-items: center; gap: 14px;
  padding: 16px 20px;
  background: var(--vr-structure);
  color: var(--vr-on-structure); /* bande sombre dans les 2 modes -> encre claire stable */
}
.vr-logo { display: block; height: 26px; width: auto; }
/* Marque blanche : emplacement « Votre logo » assumé (donnée brand.logoPlaceholder). */
.vr-logo-placeholder {
  display: inline-flex; align-items: center; height: 26px; padding: 0 12px;
  border: var(--vr-border-thin) dashed var(--vr-on-structure);
  border-radius: var(--vr-radius-control);
  color: var(--vr-on-structure); opacity: .75;
  font-size: 12px; font-weight: 600; letter-spacing: .3px;
}
.vr-logo-default svg { display: block; height: 26px; width: auto; }
.vr-chrome-title {
  font-family: var(--vr-font-title);
  font-weight: 800; font-size: 18px; letter-spacing: -.2px;
  color: var(--vr-on-structure);
}

/* Corps : fond clair, respiration. */
.vr-room-body { padding: 20px; background: var(--vr-surface); }

/* Entrées et sorties : cartouches arrondis à encadrements fins. */
.vr-inputs {
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px;
  padding: 18px; margin-bottom: 18px;
  border: var(--vr-border-thin) solid var(--vr-border);
  border-radius: var(--vr-radius-card);
  background: var(--vr-surface);
}
.vr-outputs { display: flex; flex-direction: column; gap: 16px; }

/* Hypothèses avancées : entrées repliées par défaut (curation d'audience).
   Pleine largeur dans la grille .vr-inputs ; mêmes cartouches à l'intérieur. */
.vr-advanced {
  grid-column: 1 / -1;
  border-top: var(--vr-border-thin) solid var(--vr-border);
  padding-top: 12px;
}
.vr-advanced-title {
  cursor: pointer; font-size: 12px; font-weight: 600;
  text-transform: uppercase; letter-spacing: .5px;
  color: var(--vr-text-muted);
}
.vr-advanced-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px;
  margin-top: 16px;
}
.vr-group-title {
  font-size: 12px; text-transform: uppercase; letter-spacing: .5px;
  color: var(--vr-text-muted); margin: 0 0 10px;
}
.vr-group-body { display: flex; gap: 12px; flex-wrap: wrap; }
.vr-output {
  flex: 1; min-width: 160px; padding: 14px;
  border: var(--vr-border-thin) solid var(--vr-border);
  border-radius: var(--vr-radius-card);
  background: var(--vr-surface);
}
.vr-output svg { width: 100%; height: auto; display: block; }

/* Carte KPI : gros chiffre tabulaire + label discret (charte §5). */
.vr-kpi-value {
  font-family: var(--vr-font-kpi);
  font-variant-numeric: var(--vr-font-numeric);
  font-size: 30px; font-weight: 800; line-height: 1; letter-spacing: -1px;
}
.vr-kpi-label {
  font-size: 11px; font-weight: 600; text-transform: uppercase;
  letter-spacing: .5px; margin-top: 5px; color: var(--vr-text-muted);
}

/* Widgets d'entrée : structure/forme seulement ; couleurs via variables. */
.vr-slider { display: flex; flex-direction: column; gap: 8px; font-size: 13px; }
.vr-slider-row { display: flex; justify-content: space-between; font-weight: 600; }
.vr-slider input[type=range] { width: 100%; accent-color: var(--vr-accent-action); }
.vr-number, .vr-select, .vr-stepper { display: flex; flex-direction: column; gap: 8px; font-size: 13px; font-weight: 600; }
.vr-number-field { display: flex; align-items: center; gap: 8px; }
.vr-number input {
  flex: 1; border: var(--vr-border-thin) solid var(--vr-border);
  border-radius: var(--vr-radius-control); padding: 8px 10px; font: inherit; font-size: 15px; font-weight: 700;
  background: var(--vr-surface); color: var(--vr-on-surface); /* s'inversent par mode */
}
.vr-number-unit { font-size: 12px; color: var(--vr-text-muted); }
.vr-stepper-ctrl {
  display: flex; align-items: center; width: fit-content; overflow: hidden;
  border: var(--vr-border-thin) solid var(--vr-border); border-radius: var(--vr-radius-control);
  background: var(--vr-surface);
}
.vr-stepper-btn { width: 40px; height: 40px; border: 0; background: transparent; font-size: 20px; font-weight: 700; cursor: pointer; color: var(--vr-accent-action); }
.vr-stepper-val { width: 72px; text-align: center; border: 0; font: inherit; font-size: 16px; font-weight: 700; background: transparent; color: var(--vr-on-surface); }
.vr-select select {
  border: var(--vr-border-thin) solid var(--vr-border);
  border-radius: var(--vr-radius-control); padding: 8px 10px; font: inherit;
  background: var(--vr-surface); color: var(--vr-on-surface);
}
.vr-toggle {
  display: flex; align-items: center; gap: 12px;
  min-height: 40px; /* équilibre vertical face aux sliders du même cartouche */
  font-size: 14px; font-weight: 600;
  accent-color: var(--vr-accent-action);
}
.vr-toggle-input { width: 22px; height: 22px; flex-shrink: 0; margin: 0; cursor: pointer; accent-color: var(--vr-accent-action); }
.vr-toggle-label { cursor: pointer; }

/* Pied : bande structure, badge d'attribution ValueRoom (distinct du logo). */
.vr-chrome-footer {
  padding: 12px 20px;
  background: var(--vr-structure);
  color: var(--vr-text-muted);
  font-size: 12px;
}
.vr-badge-link { color: var(--vr-on-structure); text-decoration: none; }
.vr-badge-link:hover { text-decoration: underline; }

/* ── Mode présentation (« passage de tablette ») ──────────────────────────────
   Plein écran, tactile. Hérite des variables --vr-* du thème room (light/dark +
   marque tenant) posées sur l'overlay -> aucune couleur réintroduite. */
.vr-present {
  position: fixed; inset: 0; z-index: 9999; overflow: auto;
  display: flex; flex-direction: column;
  background: var(--vr-surface); color: var(--vr-on-surface);
  font-family: var(--vr-font-body);
}
.vr-present-bar {
  background: var(--vr-structure); color: var(--vr-on-structure);
  padding: 12px 20px; display: flex; justify-content: flex-end;
}
.vr-present-quit {
  background: var(--vr-accent-action); color: #fff; border: 0;
  border-radius: var(--vr-radius-control); padding: 12px 24px;
  font-size: 16px; font-weight: 700; cursor: pointer;
}
.vr-present-cursors {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: 22px;
  padding: 28px; width: 100%; max-width: 960px; margin: 0 auto;
}
.vr-present-cursor {
  border: var(--vr-border-thin) solid var(--vr-border);
  border-radius: var(--vr-radius-card); padding: 20px 22px; font-size: 18px;
}
.vr-present-cursor .vr-slider-row { font-size: 19px; }
.vr-present-cursor input[type=range] { width: 100%; height: 36px; accent-color: var(--vr-accent-action); }
.vr-present-cursor .vr-stepper-ctrl { border-color: var(--vr-border); }
.vr-present-cursor .vr-stepper-btn { width: 54px; height: 54px; font-size: 26px; }
.vr-present-cursor .vr-stepper-val { width: 90px; font-size: 22px; color: var(--vr-on-surface); }
.vr-present-outputs {
  display: flex; flex-direction: column; gap: 18px;
  padding: 4px 28px 36px; width: 100%; max-width: 1000px; margin: 0 auto;
}
.vr-present-outputs .vr-kpi-value { font-size: 46px; }      /* chiffre client, lecture à distance */
.vr-present-outputs .vr-group-body { gap: 16px; }
