/**
 * components.css — Composants UI George V3 Client
 * Boutons, inputs, cartes, tags, badges, tables, pagination, empty-states…
 */

/* ══════════════════════════════════════════════════════════════════════════
   BOUTONS
══════════════════════════════════════════════════════════════════════════ */
.btn-primary {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-4);
  background: var(--a);
  color: #fff;
  font-weight: var(--weight-medium);
  border-radius: var(--radius);
  transition: background var(--tr-fast), opacity var(--tr-fast);
}
.btn-primary:hover:not(:disabled) { background: var(--a-dark); }
.btn-primary:disabled { opacity: 0.45; cursor: not-allowed; }

.btn-ghost {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-3);
  color: var(--fg-2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  transition: background var(--tr-fast), color var(--tr-fast);
}
.btn-ghost:hover:not(:disabled) { background: var(--bg-4); color: var(--fg); }
.btn-ghost:disabled { opacity: 0.45; cursor: not-allowed; }

.btn-full  { width: 100%; justify-content: center; }
.btn-sm    { padding: var(--sp-1) var(--sp-3); font-size: var(--text-sm); }
.btn-xs    { padding: 2px var(--sp-2); font-size: var(--text-xs); }

/* ══════════════════════════════════════════════════════════════════════════
   INPUTS
══════════════════════════════════════════════════════════════════════════ */
.input {
  width: 100%;
  padding: var(--sp-2) var(--sp-3);
  background: var(--bg-3);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  color: var(--fg);
  transition: border-color var(--tr-fast);
}
.input:focus { border-color: var(--a); outline: none; }
.input::placeholder { color: var(--fg-3); }
.input:disabled { opacity: 0.5; cursor: not-allowed; }

textarea.input { resize: vertical; min-height: 80px; }

.form-label {
  display: flex;
  flex-direction: column;
  gap: var(--sp-1);
  font-size: var(--text-sm);
  color: var(--fg-2);
  font-weight: var(--weight-medium);
}

.toggle-label {
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
}

/* ══════════════════════════════════════════════════════════════════════════
   CARTES
══════════════════════════════════════════════════════════════════════════ */
.card {
  background: var(--bg-3);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--sp-4);
  box-shadow: var(--shadow-sm);
}

/* ══════════════════════════════════════════════════════════════════════════
   TAGS & BADGES
══════════════════════════════════════════════════════════════════════════ */
.tag {
  display: inline-block;
  padding: 2px var(--sp-2);
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  background: var(--bg-4);
  color: var(--fg-2);
}
.tag--green  { background: #052e16; color: var(--ok); }
.tag--blue   { background: #0c1a2e; color: var(--info); }
.tag--orange { background: #2d1a04; color: #fb923c; }
.tag--yellow { background: #2d2004; color: var(--warn); }
.tag--red    { background: #2d0808; color: var(--err); }
.tag--grey   { background: var(--bg-4); color: var(--fg-3); }

.badge {
  display: inline-block;
  padding: 1px var(--sp-2);
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
}
.badge--l1 { background: #052e16; color: var(--ok); }
.badge--l2 { background: #0c1a2e; color: var(--info); }
.badge--l3 { background: #2d1a04; color: #fb923c; }

/* ══════════════════════════════════════════════════════════════════════════
   TABLEAUX
══════════════════════════════════════════════════════════════════════════ */
.data-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
}
.data-table th {
  text-align: left;
  padding: var(--sp-2) var(--sp-3);
  color: var(--fg-2);
  font-weight: var(--weight-medium);
  border-bottom: 1px solid var(--border);
  background: var(--bg-3);
  position: sticky;
  top: 0;
}
.data-table td {
  padding: var(--sp-2) var(--sp-3);
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
}
.data-table tr:hover td { background: var(--bg-4); }
.td-name { font-weight: var(--weight-medium); color: var(--fg); }
.td-mono { font-family: var(--font-mono); font-size: var(--text-xs); color: var(--fg-2); }

/* ══════════════════════════════════════════════════════════════════════════
   PAGINATION
══════════════════════════════════════════════════════════════════════════ */
.pager {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-3) 0;
  justify-content: flex-end;
}
.pager-info { font-size: var(--text-sm); color: var(--fg-2); }

/* ══════════════════════════════════════════════════════════════════════════
   EMPTY STATE
══════════════════════════════════════════════════════════════════════════ */
.empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--sp-3);
  padding: var(--sp-8) var(--sp-4);
  color: var(--fg-3);
  text-align: center;
}
.empty-state-icon { font-size: 2.5rem; opacity: 0.5; }
.empty-state-title { font-size: var(--text-lg); font-weight: var(--weight-medium); color: var(--fg-2); }
.empty-state-sub { font-size: var(--text-sm); }

/* ══════════════════════════════════════════════════════════════════════════
   LOADING
══════════════════════════════════════════════════════════════════════════ */
.loading-spinner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--sp-3);
  padding: var(--sp-8);
}
.spinner {
  width: 32px; height: 32px;
  border: 3px solid var(--border);
  border-top-color: var(--a);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ══════════════════════════════════════════════════════════════════════════
   ERROR
══════════════════════════════════════════════════════════════════════════ */
.error-banner {
  padding: var(--sp-3) var(--sp-4);
  background: #2d0808;
  border: 1px solid var(--err);
  border-radius: var(--radius);
  color: #fca5a5;
  font-size: var(--text-sm);
}

/* ══════════════════════════════════════════════════════════════════════════
   TABS
══════════════════════════════════════════════════════════════════════════ */
.tab-bar {
  display: flex;
  gap: var(--sp-1);
  border-bottom: 1px solid var(--border);
  padding-bottom: 0;
  margin-bottom: var(--sp-4);
  overflow-x: auto;
}
.tab-btn {
  padding: var(--sp-2) var(--sp-4);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  color: var(--fg-2);
  border-bottom: 2px solid transparent;
  transition: color var(--tr-fast), border-color var(--tr-fast);
  white-space: nowrap;
}
.tab-btn:hover { color: var(--fg); }
.tab-btn--active { color: var(--a); border-bottom-color: var(--a); }

.tab-content { padding: 0; }

/* ══════════════════════════════════════════════════════════════════════════
   HEX AVATAR
══════════════════════════════════════════════════════════════════════════ */
.hex-avatar {
  width: 36px; height: 36px;
  border-radius: var(--radius);
  background: var(--a);
  color: #fff;
  font-weight: var(--weight-bold);
  font-size: var(--text-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

/* ══════════════════════════════════════════════════════════════════════════
   SEARCH BAR
══════════════════════════════════════════════════════════════════════════ */
.search-bar {
  display: flex;
  gap: var(--sp-2);
  margin-bottom: var(--sp-4);
}
.search-bar .input { flex: 1; }

/* ══════════════════════════════════════════════════════════════════════════
   SETTINGS
══════════════════════════════════════════════════════════════════════════ */
.settings-form {
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
  max-width: 560px;
}
.settings-actions {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding-top: var(--sp-2);
}
.save-ok { color: var(--ok); font-size: var(--text-sm); }
.settings-readonly {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  font-size: var(--text-sm);
  color: var(--fg-2);
}
.settings-note {
  font-size: var(--text-xs);
  color: var(--fg-3);
  font-style: italic;
}

/* ══════════════════════════════════════════════════════════════════════════
   GROUP C — DETAIL PANELS
══════════════════════════════════════════════════════════════════════════ */
.detail-panel {
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
  padding: var(--sp-2) 0;
}
.detail-header {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  flex-wrap: wrap;
}
.detail-title {
  font-size: var(--text-lg);
  font-weight: var(--weight-semibold);
  color: var(--fg);
  flex: 1;
}
.detail-meta {
  display: flex;
  flex-direction: column;
  gap: var(--sp-1);
  font-size: var(--text-sm);
  color: var(--fg-2);
  padding: var(--sp-3) var(--sp-4);
  background: var(--bg-3);
  border: 1px solid var(--border);
  border-radius: var(--radius);
}
.detail-meta p { margin: 0; }
.detail-section {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
.section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.section-title {
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  color: var(--fg-2);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* ══════════════════════════════════════════════════════════════════════════
   GROUP C — ACTIVITÉS
══════════════════════════════════════════════════════════════════════════ */
.activity-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}
.activity-item {
  display: flex;
  align-items: baseline;
  gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-3);
  background: var(--bg-3);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  font-size: var(--text-sm);
  flex-wrap: wrap;
}
.activity-type { flex-shrink: 0; }
.activity-subject { font-weight: var(--weight-medium); color: var(--fg); flex: 1; }
.activity-notes { color: var(--fg-2); font-size: var(--text-xs); }
.activity-date { color: var(--fg-3); font-size: var(--text-xs); margin-left: auto; }

/* ══════════════════════════════════════════════════════════════════════════
   GROUP C — FORMULAIRES (panel-form)
══════════════════════════════════════════════════════════════════════════ */
.panel-form {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  max-width: 640px;
}
.form-title {
  font-size: var(--text-base);
  font-weight: var(--weight-semibold);
  color: var(--fg);
  margin: 0 0 var(--sp-1);
}
.form-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--sp-3);
}
.form-actions {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  padding-top: var(--sp-2);
}
.field-error {
  font-size: var(--text-xs);
  color: var(--err);
  margin: 0;
}

/* ══════════════════════════════════════════════════════════════════════════
   GROUP C — LIGNES DE DOCUMENT
══════════════════════════════════════════════════════════════════════════ */
.doc-lines {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: var(--sp-3);
  background: var(--bg-3);
}
.doc-lines-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: var(--text-sm);
  color: var(--fg-2);
  margin-bottom: var(--sp-1);
}
.doc-line {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  flex-wrap: wrap;
}
.doc-line .input { flex: 1; min-width: 120px; }
.input--narrow { max-width: 90px; min-width: 70px; flex: 0 0 auto; }
.data-table--compact td,
.data-table--compact th { padding: var(--sp-1) var(--sp-2); font-size: var(--text-xs); }

/* ══════════════════════════════════════════════════════════════════════════
   GROUP C — ACTIONS DOCUMENT
══════════════════════════════════════════════════════════════════════════ */
.doc-actions {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  flex-wrap: wrap;
  padding: var(--sp-3) 0;
  border-top: 1px solid var(--border);
}

/* ══════════════════════════════════════════════════════════════════════════
   GROUP C — CHAÎNE LINKED_TO
══════════════════════════════════════════════════════════════════════════ */
.linked-chain {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  flex-wrap: wrap;
  font-size: var(--text-xs);
  padding: var(--sp-2) var(--sp-3);
  background: var(--bg-3);
  border: 1px solid var(--border);
  border-radius: var(--radius);
}
.linked-chain-label { color: var(--fg-3); font-weight: var(--weight-medium); }
.linked-chain-item  { display: flex; align-items: center; gap: var(--sp-1); }
.linked-chain-arrow { color: var(--fg-3); }
.linked-chain-num   { color: var(--fg-2); font-family: var(--font-mono); }

/* ══════════════════════════════════════════════════════════════════════════
   GROUP C — SIREN LOOKUP
══════════════════════════════════════════════════════════════════════════ */
.siren-lookup {
  display: flex;
  flex-direction: column;
  gap: var(--sp-1);
}
.siren-form {
  display: flex;
  gap: var(--sp-2);
}
.siren-form .input { max-width: 200px; }

/* ══════════════════════════════════════════════════════════════════════════
   GROUP C — TABLE ROWS CLIQUABLES
══════════════════════════════════════════════════════════════════════════ */
.row-clickable { cursor: pointer; }
.row-clickable:hover td { background: var(--bg-4); }

/* ══════════════════════════════════════════════════════════════════════════
   GROUP C — TOOLBAR ONGLET
══════════════════════════════════════════════════════════════════════════ */
.tab-toolbar {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  margin-bottom: var(--sp-3);
}
