/* ══════════════════════════════════════════════════════════════════════
   Donna · Match Inversé — styles
   S'appuie sur les tokens de tc.css
   ══════════════════════════════════════════════════════════════════════ */

/* ─── Mock page bien (fond) ─── */
.rm-sp-wrap{
  position:relative;
  width:100%; height:100%;
  background:var(--bg);
  overflow:hidden;
}
.rm-mock-page{
  padding:32px 48px;
  filter:saturate(.7);
  opacity:.7;
}

.rm-mock-page h1{
  font-family:'Plus Jakarta Sans', var(--font);
  font-size:24px; font-weight:700; margin:0 0 4px;
  letter-spacing:-.02em;
}
.rm-mock-meta{ font-size:13px; color:var(--text-dim); margin-bottom:20px; }

.rm-mock-photo{
  height:180px;
  background:linear-gradient(135deg, var(--s2), var(--s3));
  border-radius:var(--radius-lg);
  border:1px solid var(--border);
}
.rm-mock-info{
  display:flex; flex-direction:column; gap:8px;
  padding:14px 18px;
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--radius-lg);
}
.rm-mock-stat{
  display:flex; justify-content:space-between;
  font-size:12px; color:var(--text-dim);
}
.rm-mock-stat b{ color:var(--text); font-weight:600; }

.rm-sp-overlay{
  position:absolute; inset:0;
  background:rgba(20,22,31,.18);
  backdrop-filter:blur(2px);
}
:root[data-theme="noir"] .rm-sp-overlay{ background:rgba(0,0,0,.45); }

/* ─── Sidepanel ─── */
.rm-sp{
  position:absolute; top:0; right:0; bottom:0;
  width:680px; max-width:62%;
  background:var(--bg);
  border-left:1px solid var(--border);
  box-shadow:-8px 0 24px rgba(20,22,31,.08);
  display:flex; flex-direction:column;
  overflow:hidden;
}
:root[data-theme="noir"] .rm-sp{ box-shadow:-8px 0 24px rgba(0,0,0,.6); }

/* ─── Header ─── */
.rm-head{
  display:flex; justify-content:space-between; align-items:flex-start;
  padding:18px 22px 16px;
  background:var(--surface);
  border-bottom:1px solid var(--border);
  flex-shrink:0;
}
.rm-head-l{ flex:1; min-width:0; }
.rm-crumb{
  font-size:10.5px; font-weight:700; letter-spacing:.4px;
  color:var(--muted); margin-bottom:5px;
  display:inline-flex; align-items:center; gap:6px;
}
.rm-crumb svg{ color:var(--accent); }
.rm-head h2{
  font-family:'Plus Jakarta Sans', var(--font);
  font-size:20px; font-weight:700; letter-spacing:-.02em;
  margin:0 0 4px; color:var(--text);
}
.rm-sub{
  font-size:12.5px; color:var(--text-dim);
  display:inline-flex; align-items:center; gap:8px;
}

.rm-close{
  width:28px; height:28px;
  display:grid; place-items:center;
  border-radius:var(--radius);
  background:transparent; border:1px solid var(--border);
  color:var(--text-dim);
  transition:all .12s;
}
.rm-close:hover{ background:var(--s2); color:var(--text); border-color:var(--border-hi); }

.dot-sep{
  display:inline-block; width:3px; height:3px;
  border-radius:50%; background:var(--border-hi);
  vertical-align:middle;
}

/* ─── Form critères ─── */
.rm-form-row{
  padding:12px 22px 14px;
  background:var(--surface);
  border-bottom:1px solid var(--border);
  flex-shrink:0;
}
.rm-form{
  display:grid;
  grid-template-columns: 1.1fr 1fr .7fr 1.1fr;
  gap:10px 10px;
  align-items:end;
}
.rm-form .rm-field-toggle{ grid-column: 1 / -1; padding-bottom:0; padding-top:2px; }
.rm-form-dense{ gap:8px; }

.rm-field{ display:flex; flex-direction:column; gap:4px; min-width:0; }
.rm-field label{
  font-size:10.5px; font-weight:600; letter-spacing:.02em;
  text-transform:uppercase;
  color:var(--muted);
}
.rm-field input[type="number"],
.rm-field select{
  width:100%;
  padding:7px 9px;
  font-size:13px; font-weight:500;
  font-variant-numeric:tabular-nums;
  background:var(--bg); border:1px solid var(--border);
  border-radius:var(--radius);
  color:var(--text);
  font-family:inherit;
  transition:border-color .12s;
}
.rm-field input:focus,
.rm-field select:focus{
  outline:none; border-color:var(--accent);
}
.rm-input-grp{
  position:relative;
}
.rm-input-grp input{ padding-right:30px; }
.rm-suffix{
  position:absolute; right:10px; top:50%; transform:translateY(-50%);
  font-size:11.5px; color:var(--muted);
  pointer-events:none;
}

.rm-field-toggle{ flex-direction:row; gap:14px; align-items:center; padding-bottom:6px; }
.rm-tg{
  display:inline-flex; align-items:center; gap:5px;
  font-size:12px; color:var(--text-dim); cursor:pointer;
}
.rm-tg input{
  margin:0; accent-color:var(--accent);
  width:13px; height:13px;
}

/* ─── Summary bar (Direction A) ─── */
.rm-summary{
  display:flex; align-items:center; gap:18px;
  padding:11px 22px;
  background:var(--bg);
  border-bottom:1px solid var(--border);
  flex-shrink:0;
}
.rm-summary-stat{
  display:flex; align-items:baseline; gap:6px;
}
.rm-summary-stat .big{
  font-family:'Plus Jakarta Sans', var(--font);
  font-size:20px; font-weight:700; color:var(--text);
  font-variant-numeric:tabular-nums;
}
.rm-summary-stat:first-child .big{ color:var(--chaud); }
.rm-summary-stat:nth-child(2) .big{ color:var(--tiede); }
.rm-summary-stat .lbl{
  font-size:11.5px; color:var(--muted); font-weight:500;
}
.rm-summary-actions{ margin-left:auto; display:flex; gap:6px; }

/* ─── Banner (Direction B) ─── */

/* ─── Boutons ─── */
.rm-btn-primary{
  background:var(--text); color:var(--bg);
  padding:7px 14px; border-radius:var(--radius);
  font-size:12.5px; font-weight:600;
  transition:background .12s;
}
.rm-btn-primary:hover{ background:var(--text-dim); }
.rm-btn-ghost{
  background:var(--surface); color:var(--text-dim);
  padding:6px 11px; border-radius:var(--radius);
  font-size:12px; font-weight:500;
  border:1px solid var(--border);
  display:inline-flex; align-items:center; gap:5px;
  transition:all .12s;
}
.rm-btn-ghost:hover{ color:var(--text); border-color:var(--border-hi); background:var(--s2); }
.rm-icon-btn{
  width:22px; height:22px;
  display:grid; place-items:center;
  background:transparent; border:1px solid transparent;
  border-radius:var(--radius-sm);
  color:var(--text-dim);
  transition:all .12s;
}
.rm-icon-btn:hover{ background:var(--s2); color:var(--text); border-color:var(--border); }
.rm-icon-btn.active{
  background:color-mix(in srgb, var(--green) 13%, transparent);
  color:var(--green); border-color:color-mix(in srgb, var(--green) 30%, transparent);
}

/* ─── Avatar ─── */
.rm-avatar{
  border-radius:50%;
  display:grid; place-items:center;
  color:#fff; font-weight:700;
  font-family:'Plus Jakarta Sans', var(--font);
  flex-shrink:0;
}

/* ─── Match pill ─── */
.rm-match{
  font-family:'Plus Jakarta Sans', var(--font);
  font-size:12.5px; font-weight:700;
  font-variant-numeric:tabular-nums;
  padding:3px 7px;
  border-radius:var(--radius);
  display:inline-flex; align-items:baseline; gap:1px;
  letter-spacing:-.02em;
  margin-top:1px;
}
.rm-match .pct{ font-size:9.5px; opacity:.6; font-weight:500; margin-left:1px; }
.rm-match[data-tone="hot"]{
  background:color-mix(in srgb, var(--chaud) 13%, transparent);
  color:var(--chaud);
}
.rm-match[data-tone="warm"]{
  background:color-mix(in srgb, var(--tiede) 14%, transparent);
  color:var(--tiede);
}
.rm-match[data-tone="cold"]{
  background:var(--s2);
  color:var(--text-dim);
}
.rm-match[data-tone="cold-low"]{
  background:var(--s2);
  color:var(--muted);
}

/* ─── Tag ─── */
.rm-tag{
  font-size:9.5px; font-weight:600; letter-spacing:.02em;
  padding:1px 6px; border-radius:3px;
  background:var(--s2); color:var(--text-dim);
  border:1px solid var(--border);
  margin-left:5px;
}
.rm-tag-done{
  background:color-mix(in srgb, var(--green) 13%, transparent);
  color:var(--green);
  border-color:color-mix(in srgb, var(--green) 25%, transparent);
}

/* ─── Critère chips ─── */
.rm-chips{
  display:flex; flex-wrap:wrap; gap:4px;
  margin-top:5px;
}
.rm-chip{
  display:inline-flex; align-items:center; gap:3px;
  padding:1px 6px 1px 4px;
  font-size:10px; font-weight:500;
  border-radius:3px;
  border:1px solid var(--border);
  background:var(--surface);
  color:var(--text-dim);
}
.rm-chip-ic{
  width:11px; height:11px; border-radius:50%;
  display:grid; place-items:center;
  background:var(--s3);
  color:var(--muted);
}
.rm-chip-ic svg{ width:7px; height:7px; }
.rm-chip[data-state="ok"]{
  border-color:color-mix(in srgb, var(--green) 25%, transparent);
  background:color-mix(in srgb, var(--green) 8%, var(--surface));
  color:var(--text);
}
.rm-chip[data-state="ok"] .rm-chip-ic{ background:var(--green); color:#fff; }
.rm-chip[data-state="tiede"]{
  border-color:color-mix(in srgb, var(--tiede) 25%, transparent);
  background:color-mix(in srgb, var(--tiede) 8%, var(--surface));
  color:var(--text);
}
.rm-chip[data-state="tiede"] .rm-chip-ic{ background:var(--tiede); color:#fff; }
.rm-chip[data-state="no"]{
  border-color:var(--border);
  background:var(--surface);
  color:var(--muted);
  text-decoration:line-through;
  text-decoration-color:var(--border-hi);
}
.rm-chip[data-state="no"] .rm-chip-ic{ background:var(--s3); color:var(--muted); }

/* ═════════ Direction A : list rows ═════════ */
.rm-list{
  flex:1; overflow-y:auto;
  background:var(--bg);
}
.rm-row{
  display:grid;
  grid-template-columns:22px 28px 1fr auto auto;
  align-items:flex-start; gap:10px;
  padding:9px 22px;
  background:var(--surface);
  border-bottom:1px solid var(--border);
  transition:background .1s;
}
.rm-row .rm-row-actions{
  margin-top:1px;
  align-self:center;
  display:flex; gap:2px;
  opacity:0; transition:opacity .12s;
}
.rm-row:hover .rm-row-actions{ opacity:1; }
.rm-row:hover{ background:color-mix(in srgb, var(--s2) 60%, var(--surface)); }
.rm-row[data-tier="hot"]{
  border-left:2px solid var(--chaud);
  padding-left:20px;
}
.rm-row[data-tier="warm"]{
  border-left:2px solid var(--tiede);
  padding-left:20px;
}
.rm-row[data-tier="cold"]{
  border-left:2px solid var(--border-hi);
  padding-left:20px;
}
.rm-row-rank{
  font-family:'Plus Jakarta Sans', var(--font);
  font-size:11.5px; font-weight:600; color:var(--muted);
  margin-top:5px;
  font-variant-numeric:tabular-nums;
}
.rm-row-main{ min-width:0; flex:1; padding-top:1px; }
.rm-row-name{
  font-size:12.5px; font-weight:600; color:var(--text);
  margin-bottom:1px;
  display:flex; align-items:center; flex-wrap:wrap;
}
.rm-row-meta{
  font-size:10.5px; color:var(--muted);
  display:flex; align-items:center; gap:5px; flex-wrap:wrap;
  line-height:1.35;
}
.rm-row-actions{
  display:flex; gap:3px;
  margin-top:4px;
}

/* ─── Footer (commun) ─── */
.rm-foot{
  padding:12px 22px;
  background:var(--surface);
  border-top:1px solid var(--border);
  display:flex; justify-content:space-between; align-items:center;
  flex-shrink:0;
}
.rm-foot-l{
  font-size:12px; color:var(--text-dim);
}
.rm-foot-r{ display:flex; gap:8px; }

/* ═════════ Direction B : cards ═════════ */

.rm-card-score .big{
  font-family:'Plus Jakarta Sans', var(--font);
  font-size:28px; font-weight:700; line-height:1;
  letter-spacing:-.025em;
  color:var(--text);
}
.rm-card[data-tier="hot"] .rm-card-score .big{ color:var(--chaud); }
.rm-card[data-tier="warm"] .rm-card-score .big{ color:var(--tiede); }
.rm-card-score .lbl{
  font-size:9.5px; color:var(--muted); margin-top:1px;
  letter-spacing:.05em; text-transform:uppercase; font-weight:600;
}

/* ═════════ Direction C : grid ═════════ */

.rm-grid-name .n{
  font-size:13px; font-weight:600; color:var(--text);
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.rm-grid-name .m{
  font-size:10.5px; color:var(--muted);
}

/* Disable theme toggle outside frame */

