/* ═══════════════════════════════════════════════════════════════════
   IMMO AFRICA TOPOREG — app.css
   ═══════════════════════════════════════════════════════════════════ */

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

:root {
  --bg:        #ffffff;
  --bg2:       #f5f5f5;
  --bg3:       #f0f0f0;
  --txt:       #111111;
  --txt2:      #555555;
  --txt3:      #888888;
  --border:    #cccccc;
  --border2:   #dddddd;
  --border3:   #e5e5e5;
  --red:       #cc0000;
  --red-dark:  #aa0000;
  --red-light: #fff5f5;
  --red-tag-bg:#FCEBEB;
  --red-tag-tx:#A32D2D;
  --red-tag-br:#F7C1C1;
  --blue-tag-bg:#E6F1FB;
  --blue-tag-tx:#185FA5;
  --blue-tag-br:#B5D4F4;
  --amber-tag-bg:#FAEEDA;
  --amber-tag-tx:#854F0B;
  --amber-tag-br:#FAC775;
  --green-bg:  #E1F5EE;
  --green-tx:  #0F6E56;
  --green-br:  #9FE1CB;
  --shadow:    0 2px 8px rgba(0,0,0,0.06);
  --shadow-lg: 0 4px 24px rgba(0,0,0,0.08);
  --radius:    12px;
  --radius-sm: 8px;
  --font: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --mono: 'SF Mono', 'Fira Code', monospace;
}

body { font-family: var(--font); background: var(--bg3); min-height: 100vh; color: var(--txt); }
#toporeg-root { min-height: 100vh; }

/* ── LOGIN ──────────────────────────────────────────────────────────── */
.login-wrap {
  min-height: 100vh; display: flex; align-items: center;
  justify-content: center; padding: 24px 16px; background: var(--bg3);
}
.login-box {
  background: var(--bg); border: 0.5px solid #e0e0e0;
  border-top: 2px solid var(--red); border-radius: var(--radius);
  padding: 36px 32px; width: 100%; max-width: 400px; box-shadow: var(--shadow-lg);
}
.login-logo { display: flex; align-items: center; gap: 12px; margin-bottom: 28px; justify-content: center; }
.login-logo img { width: 52px; height: 52px; object-fit: contain; }
.login-logo-text .t1 { font-size: 18px; font-weight: 500; color: var(--txt); letter-spacing: .5px; }
.login-logo-text .t1 span { color: var(--red); }
.login-logo-text .t2 { font-size: 11px; color: var(--txt3); letter-spacing: 1px; text-transform: uppercase; }
.login-title { font-size: 15px; color: var(--txt2); margin-bottom: 24px; text-align: center; }
.lfield { margin-bottom: 16px; }
.lfield label { display: block; font-size: 12px; color: var(--txt2); margin-bottom: 6px; }
.lfield input {
  width: 100%; background: var(--bg2); border: 0.5px solid var(--border2);
  border-radius: var(--radius-sm); padding: 10px 14px; font-size: 14px;
  color: var(--txt); outline: none; font-family: var(--font);
}
.lfield input:focus { border-color: var(--red); box-shadow: 0 0 0 2px rgba(204,0,0,.15); }
.login-btn {
  width: 100%; background: var(--red); color: #fff; border: none;
  border-radius: var(--radius-sm); padding: 11px; font-size: 15px;
  font-weight: 500; cursor: pointer; margin-top: 8px; transition: background .15s;
}
.login-btn:hover { background: var(--red-dark); }
.login-err { font-size: 13px; color: #e24b4a; text-align: center; margin-top: 12px; min-height: 20px; }

/* ── HEADER ─────────────────────────────────────────────────────────── */
.app-header {
  background: var(--bg); border-bottom: 2px solid var(--red);
  padding: 12px 24px; display: flex; align-items: center; justify-content: space-between;
  position: sticky; top: 0; z-index: 100; box-shadow: var(--shadow);
}
.logo { display: flex; align-items: center; gap: 12px; }
.logo img { width: 44px; height: 44px; object-fit: contain; }
.logo-title { font-size: 16px; font-weight: 500; color: var(--txt); letter-spacing: .5px; }
.logo-title span { color: var(--red); }
.logo-sub { font-size: 11px; color: var(--txt3); letter-spacing: 1px; text-transform: uppercase; }
.header-right { display: flex; align-items: center; gap: 10px; }
.user-badge {
  font-size: 13px; color: var(--txt2); padding: 5px 10px;
  background: var(--bg2); border-radius: 6px; border: 0.5px solid var(--border2);
}
.user-badge b { color: var(--txt); }
.role-admin { color: var(--red); }
.role-agent-ecriture { color: #6B3FA0; }
.role-agent { color: var(--green-tx); }
.btn-logout {
  padding: 6px 12px; font-size: 13px; border: 0.5px solid var(--border2);
  border-radius: 6px; background: transparent; color: var(--txt2); cursor: pointer; transition: all .15s;
}
.btn-logout:hover { border-color: var(--red); color: var(--red); }
.btn-add {
  display: flex; align-items: center; gap: 6px; background: var(--red); color: #fff;
  border: none; border-radius: var(--radius-sm); padding: 8px 16px;
  font-size: 14px; font-weight: 500; cursor: pointer; transition: background .15s;
}
.btn-add:hover { background: var(--red-dark); }

/* ── CONTAINER ──────────────────────────────────────────────────────── */
.container { max-width: 1100px; margin: 0 auto; padding: 24px 16px; }

/* ── TABS ───────────────────────────────────────────────────────────── */
.tabs {
  display: flex; gap: 2px; margin-bottom: 24px; background: var(--bg2);
  border-radius: var(--radius-sm); padding: 3px; width: fit-content;
}
.tab {
  padding: 7px 18px; font-size: 14px; border-radius: 6px; border: none;
  background: transparent; color: var(--txt2); cursor: pointer; transition: all .15s;
  font-family: var(--font);
}
.tab.active {
  background: var(--bg); color: var(--txt); font-weight: 500; border: 0.5px solid var(--border3);
}

/* ── STATS ──────────────────────────────────────────────────────────── */
.stats-row { display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; margin-bottom: 24px; }
.stat-card {
  background: var(--bg); border: 0.5px solid var(--border3); border-top: 2px solid var(--red);
  border-radius: var(--radius); padding: 16px;
}
.stat-label { font-size: 12px; color: var(--txt2); margin-bottom: 4px; }
.stat-val { font-size: 24px; font-weight: 500; color: var(--txt); }

/* ── BARRE DE RECHERCHE ─────────────────────────────────────────────── */
.search-bar {
  background: var(--bg); border: 0.5px solid var(--border3); border-radius: var(--radius);
  padding: 16px 20px; margin-bottom: 20px; display: flex; flex-wrap: wrap; gap: 12px; align-items: flex-end;
}
.sg { display: flex; flex-direction: column; gap: 4px; flex: 1; min-width: 120px; }
.sg label { font-size: 12px; color: var(--txt2); }
.sg input {
  border: 0.5px solid var(--border2); border-radius: var(--radius-sm);
  padding: 7px 10px; font-size: 14px; background: var(--bg2); color: var(--txt); outline: none;
  font-family: var(--font);
}
.sg input:focus { border-color: var(--red); box-shadow: 0 0 0 2px rgba(204,0,0,.1); }
.btn-reset {
  padding: 7px 14px; font-size: 13px; border: 0.5px solid var(--border2);
  border-radius: var(--radius-sm); background: transparent; color: var(--txt2);
  cursor: pointer; white-space: nowrap; font-family: var(--font);
}
.btn-reset:hover { background: var(--bg2); color: var(--txt); }

/* ── GRILLE DE CARTES ───────────────────────────────────────────────── */
.grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px,1fr)); gap: 16px; }
.card {
  background: var(--bg); border: 0.5px solid var(--border3); border-radius: var(--radius);
  overflow: hidden; cursor: pointer; transition: border-color .15s, box-shadow .15s;
}
.card:hover { border-color: var(--red); box-shadow: 0 4px 16px rgba(204,0,0,.08); }
.card-img {
  width: 100%; height: 148px; background: var(--bg2); display: flex;
  align-items: center; justify-content: center; overflow: hidden;
  border-bottom: 0.5px solid var(--border3);
}
.card-img img { width: 100%; height: 100%; object-fit: cover; }
.no-img { display: flex; flex-direction: column; align-items: center; gap: 6px; }
.no-img svg { opacity: .2; }
.no-img span { font-size: 12px; color: var(--txt3); }
.card-body { padding: 14px 16px; }
.card-name { font-size: 15px; font-weight: 500; color: var(--txt); margin-bottom: 3px; }
.card-contact { font-size: 12px; color: var(--txt2); margin-bottom: 3px; }
.card-tags { display: flex; flex-wrap: wrap; gap: 5px; margin-top: 8px; }
.tag { font-size: 11px; padding: 3px 8px; border-radius: 20px; border: 0.5px solid; }
.tag-red    { background: var(--red-tag-bg);   color: var(--red-tag-tx);   border-color: var(--red-tag-br); }
.tag-blue   { background: var(--blue-tag-bg);  color: var(--blue-tag-tx);  border-color: var(--blue-tag-br); }
.tag-amber  { background: var(--amber-tag-bg); color: var(--amber-tag-tx); border-color: var(--amber-tag-br); }
.card-date { font-size: 12px; color: var(--txt2); margin-top: 6px; }
.card-footer {
  padding: 10px 16px; border-top: 0.5px solid var(--border3);
  display: flex; justify-content: flex-end; gap: 8px;
}
.btn-sm {
  font-size: 12px; padding: 5px 10px; border: 0.5px solid var(--border2);
  border-radius: 6px; background: transparent; color: var(--txt2);
  cursor: pointer; transition: all .15s; font-family: var(--font);
}
.btn-sm:hover { background: var(--bg2); color: var(--txt); }
.btn-sm.danger:hover { background: var(--red-tag-bg); color: var(--red-tag-tx); border-color: var(--red-tag-br); }
.btn-sm.primary { background: var(--red); color: #fff; border-color: var(--red); }
.btn-sm.primary:hover { background: var(--red-dark); }
.empty-state { grid-column: 1/-1; padding: 60px 20px; text-align: center; color: var(--txt2); }
.empty-state svg { opacity: .2; margin: 0 auto; display: block; }
.empty-state p { font-size: 14px; margin-top: 12px; }

/* ── TABLE UTILISATEURS ─────────────────────────────────────────────── */
.users-panel { background: var(--bg); border: 0.5px solid var(--border3); border-radius: var(--radius); overflow: hidden; }
.users-header {
  padding: 16px 20px; border-bottom: 0.5px solid var(--border3);
  display: flex; align-items: center; justify-content: space-between;
}
.users-header h3 { font-size: 15px; font-weight: 500; color: var(--txt); }
.users-table { width: 100%; border-collapse: collapse; }
.users-table th {
  font-size: 12px; color: var(--txt2); padding: 10px 16px; text-align: left;
  border-bottom: 0.5px solid var(--border3); background: var(--bg2);
}
.users-table td {
  font-size: 14px; color: var(--txt); padding: 12px 16px;
  border-bottom: 0.5px solid var(--border3);
}
.users-table tr:last-child td { border-bottom: none; }
.role-pill { display: inline-block; font-size: 11px; padding: 3px 9px; border-radius: 20px; }
.role-pill.admin          { background: var(--red-tag-bg); color: var(--red-tag-tx); border: 0.5px solid var(--red-tag-br); }
.role-pill.agent_ecriture { background: #F0E9F9; color: #6B3FA0; border: 0.5px solid #C9A8E5; }
.role-pill.agent          { background: var(--green-bg); color: var(--green-tx); border: 0.5px solid var(--green-br); }

/* ── OVERLAYS / MODALS ──────────────────────────────────────────────── */
.overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,.5); z-index: 200;
  display: none; align-items: flex-start; justify-content: center;
  padding: 30px 16px; overflow-y: auto;
}
.overlay.open { display: flex; }
.modal {
  background: var(--bg); border-radius: var(--radius); border: 0.5px solid var(--border3);
  border-top: 2px solid var(--red); width: 100%; max-width: 560px; padding: 24px; position: relative;
}
.modal-large { max-width: 680px; }
.modal-title { font-size: 17px; font-weight: 500; color: var(--txt); margin-bottom: 6px; }
.sec-label {
  font-size: 11px; font-weight: 500; letter-spacing: 1px; color: var(--red);
  text-transform: uppercase; margin: 16px 0 10px;
  padding-bottom: 6px; border-bottom: 0.5px solid var(--border3);
}
.field { margin-bottom: 12px; }
.field label { display: block; font-size: 13px; color: var(--txt2); margin-bottom: 5px; }
.field input, .field textarea, .field select {
  width: 100%; border: 0.5px solid var(--border2); border-radius: var(--radius-sm);
  padding: 9px 12px; font-size: 14px; background: var(--bg2);
  color: var(--txt); outline: none; font-family: var(--font);
}
.field input:focus, .field textarea:focus, .field select:focus {
  border-color: var(--red); box-shadow: 0 0 0 2px rgba(204,0,0,.1);
}
.field textarea { min-height: 70px; resize: vertical; }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.upload-zone {
  border: 1.5px dashed var(--border2); border-radius: var(--radius-sm);
  padding: 18px; text-align: center; cursor: pointer; background: var(--bg2); transition: all .15s;
}
.upload-zone:hover { border-color: var(--red); }
.upload-zone.has-file { border-color: var(--red); background: var(--red-light); }
.upload-zone input { display: none; }
.upload-zone p { font-size: 13px; color: var(--txt2); margin-top: 6px; }
.modal-actions { display: flex; justify-content: flex-end; gap: 10px; margin-top: 20px; }
.btn-cancel {
  padding: 9px 18px; font-size: 14px; border: 0.5px solid var(--border2);
  border-radius: var(--radius-sm); background: transparent; color: var(--txt2); cursor: pointer;
  font-family: var(--font);
}
.btn-save {
  padding: 9px 18px; font-size: 14px; font-weight: 500; background: var(--red);
  color: #fff; border: none; border-radius: var(--radius-sm); cursor: pointer;
  font-family: var(--font); transition: background .15s;
}
.btn-save:hover { background: var(--red-dark); }
.btn-save:disabled { opacity: .6; cursor: not-allowed; }
.close-btn {
  position: absolute; top: 16px; right: 16px; width: 28px; height: 28px;
  border: 0.5px solid var(--border3); border-radius: 50%; background: transparent;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  color: var(--txt2); font-size: 18px; line-height: 1; font-family: var(--font);
}
.close-btn:hover { background: var(--bg2); }
.info-box {
  background: var(--bg2); border: 0.5px solid var(--border3); border-radius: var(--radius-sm);
  padding: 12px 14px; font-size: 13px; color: var(--txt2); margin-bottom: 16px;
}

/* ── PIÈCES ─────────────────────────────────────────────────────────── */
.pieces-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(190px,1fr)); gap: 8px; }
.piece-check {
  display: flex; align-items: center; gap: 8px; padding: 8px 10px;
  border: 0.5px solid var(--border2); border-radius: var(--radius-sm); cursor: pointer;
  background: var(--bg2); transition: all .15s; font-size: 13px; color: var(--txt);
}
.piece-check:hover { border-color: var(--red); background: var(--red-light); }
.piece-check input[type=checkbox] { accent-color: var(--red); width: 15px; height: 15px; cursor: pointer; }
.piece-check input[type=checkbox]:checked + span { color: var(--red); font-weight: 500; }
.piece-check:has(input:checked) { border-color: var(--red); background: var(--red-light); }

/* ── DOCUMENTS ANNEXES ──────────────────────────────────────────────── */
.docs-upload-zone {
  border: 1.5px dashed var(--border2); border-radius: var(--radius-sm);
  padding: 16px; text-align: center; cursor: pointer; background: var(--bg2);
  transition: all .15s; margin-bottom: 10px;
}
.docs-upload-zone:hover { border-color: var(--red); }
.docs-upload-zone input { display: none; }
.docs-upload-zone p { font-size: 13px; color: var(--txt2); margin-top: 6px; }
.docs-list-form { display: flex; flex-direction: column; gap: 6px; }
.doc-item-form {
  display: flex; align-items: center; gap: 8px; padding: 8px 10px;
  background: var(--bg2); border: 0.5px solid var(--border2); border-radius: var(--radius-sm);
  font-size: 13px;
}
.doc-item-form .doc-name { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.doc-item-form .doc-size { font-size: 11px; color: var(--txt3); white-space: nowrap; }
.doc-item-form .btn-remove-doc { background: none; border: none; cursor: pointer; color: var(--txt3); font-size: 16px; padding: 0 4px; }
.doc-item-form .btn-remove-doc:hover { color: var(--red); }
.doc-icon { width: 20px; height: 20px; flex-shrink: 0; }

/* ── VUE DÉTAIL ─────────────────────────────────────────────────────── */
.view-img {
  width: 100%; max-height: 280px; object-fit: contain; border-radius: var(--radius-sm);
  border: 0.5px solid var(--border3); margin-bottom: 16px;
}
.view-sec { margin-bottom: 14px; padding-bottom: 14px; border-bottom: 0.5px solid var(--border3); }
.view-sec:last-of-type { border-bottom: none; }
.view-sec-title {
  font-size: 11px; font-weight: 500; letter-spacing: 1px; color: var(--red);
  text-transform: uppercase; margin-bottom: 10px;
}
.detail-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px 20px; }
.d-label { font-size: 12px; color: var(--txt2); margin-bottom: 2px; }
.d-val { font-size: 14px; font-weight: 500; color: var(--txt); }

/* ── DOCS LISTE VUE DÉTAIL ──────────────────────────────────────────── */
.docs-list { display: flex; flex-direction: column; gap: 8px; margin-top: 8px; }
.doc-item {
  display: flex; align-items: center; gap: 10px; padding: 10px 12px;
  background: var(--bg2); border: 0.5px solid var(--border2); border-radius: var(--radius-sm);
}
.doc-item a { font-size: 13px; color: var(--red); text-decoration: none; flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.doc-item a:hover { text-decoration: underline; }
.doc-item .doc-meta { font-size: 11px; color: var(--txt3); white-space: nowrap; }
.doc-item .btn-del-doc { background: none; border: none; cursor: pointer; color: var(--txt3); font-size: 14px; }
.doc-item .btn-del-doc:hover { color: var(--red); }

/* ── TOAST NOTIFICATION ─────────────────────────────────────────────── */
#toast {
  position: fixed; bottom: 24px; right: 24px; background: #222; color: #fff;
  padding: 12px 20px; border-radius: var(--radius-sm); font-size: 14px;
  z-index: 9999; opacity: 0; transform: translateY(10px);
  transition: opacity .25s, transform .25s; pointer-events: none; max-width: 320px;
}
#toast.show { opacity: 1; transform: translateY(0); }
#toast.success { background: #0F6E56; }
#toast.error   { background: #cc0000; }

/* ── LOADER ─────────────────────────────────────────────────────────── */
.loader-overlay {
  position: fixed; inset: 0; background: rgba(255,255,255,.7); z-index: 9000;
  display: flex; align-items: center; justify-content: center;
}
.spinner {
  width: 36px; height: 36px; border: 3px solid var(--border2);
  border-top-color: var(--red); border-radius: 50%; animation: spin .7s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ── BADGE PIÈCES ───────────────────────────────────────────────────── */
.piece-tag {
  display: inline-block; font-size: 12px; padding: 4px 10px; border-radius: 20px;
  background: var(--red-tag-bg); color: var(--red-tag-tx); border: 0.5px solid var(--red-tag-br);
}
.piece-tag::before { content: '✓ '; }

/* ── RESPONSIVE ─────────────────────────────────────────────────────── */
@media (max-width: 640px) {
  .app-header { padding: 10px 14px; }
  .logo-sub { display: none; }
  .stats-row { grid-template-columns: 1fr 1fr; }
  .field-row { grid-template-columns: 1fr; }
  .detail-grid { grid-template-columns: 1fr; }
  .btn-add span { display: none; }
  .pieces-grid { grid-template-columns: 1fr 1fr; }
}
