/* ═══════════════════════════════════════════════════════════════════════════
   123webimmo – Styles partagés (variables, reset, utilitaires)
   ═══════════════════════════════════════════════════════════════════════════ */

:root {
  /* Charte 123webimmo */
  --orange:        #F47C20;
  --orange-light:  #FFF0E3;
  --orange-dark:   #D96A10;
  --blue:          #1F3D7A;
  --blue-mid:      #2A52A3;
  --blue-light:    #E8EDF7;
  --blue-pale:     #F0F4FB;

  /* Neutres */
  --white:         #FFFFFF;
  --bg:            #F7F8FC;
  --border:        #E2E8F0;
  --border-dark:   #C8D3E8;
  --text-dark:     #1A2340;
  --text-mid:      #3D4F72;
  --text-soft:     #6B7A99;
  --text-light:    #9AAAC2;

  /* Statuts */
  --green:         #10B981;
  --green-light:   #D1FAE5;
  --yellow:        #F59E0B;
  --yellow-light:  #FEF3C7;
  --red:           #EF4444;
  --red-light:     #FEE2E2;

  /* UI */
  --radius-sm:     6px;
  --radius-md:     12px;
  --radius-lg:     18px;
  --radius-xl:     24px;
  --shadow-sm:     0 1px 4px rgba(31,61,122,.08);
  --shadow-md:     0 4px 16px rgba(31,61,122,.12);
  --shadow-lg:     0 8px 32px rgba(31,61,122,.16);
  --transition:    .22s cubic-bezier(.4,0,.2,1);

  /* Typo */
  --font:          'Inter', system-ui, sans-serif;
}

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

html { font-size: 16px; scroll-behavior: smooth; }

body {
  font-family: var(--font);
  background: var(--bg);
  color: var(--text-dark);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

/* ─── Boutons partagés ──────────────────────────────────────────────────── */
.btn-primary {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  background: var(--orange);
  color: var(--white);
  border: none;
  border-radius: var(--radius-sm);
  padding: .65rem 1.4rem;
  font-size: .92rem;
  font-weight: 600;
  font-family: var(--font);
  cursor: pointer;
  transition: background var(--transition), transform var(--transition), box-shadow var(--transition);
  text-decoration: none;
}
.btn-primary:hover { background: var(--orange-dark); box-shadow: 0 4px 14px rgba(244,124,32,.35); transform: translateY(-1px); }
.btn-primary:active { transform: translateY(0); }

.btn-secondary {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  background: var(--white);
  color: var(--blue);
  border: 1.5px solid var(--border-dark);
  border-radius: var(--radius-sm);
  padding: .6rem 1.3rem;
  font-size: .92rem;
  font-weight: 600;
  font-family: var(--font);
  cursor: pointer;
  transition: all var(--transition);
  text-decoration: none;
}
.btn-secondary:hover { background: var(--blue-light); border-color: var(--blue-mid); }

.btn-icon {
  background: none;
  border: none;
  cursor: pointer;
  color: var(--text-soft);
  font-size: 1.1rem;
  padding: .4rem;
  border-radius: var(--radius-sm);
  transition: color var(--transition), background var(--transition);
}
.btn-icon:hover { color: var(--blue); background: var(--blue-light); }

.btn-full { width: 100%; justify-content: center; }

/* ─── Logo 123webimmo ──────────────────────────────────────────────────── */
.logo-badge {
  background: var(--orange);
  color: var(--white);
  font-weight: 800;
  font-size: 1.3rem;
  border-radius: var(--radius-sm);
  width: 48px; height: 48px;
  display: flex; align-items: center; justify-content: center;
  letter-spacing: -1px;
  flex-shrink: 0;
}
.logo-text {
  color: var(--blue);
  font-weight: 700;
  font-size: 1.4rem;
  letter-spacing: -.5px;
}
.logo-dot { color: var(--text-soft); font-weight: 400; }

.logo-badge-sm {
  background: var(--orange);
  color: var(--white);
  font-weight: 800;
  font-size: .85rem;
  border-radius: 6px;
  width: 34px; height: 34px;
  display: flex; align-items: center; justify-content: center;
  letter-spacing: -1px;
  flex-shrink: 0;
}
.logo-text-sm {
  color: var(--blue);
  font-weight: 700;
  font-size: 1rem;
}
.logo-dot-sm { color: var(--text-soft); font-weight: 400; }

/* ─── Badges & pills ──────────────────────────────────────────────────── */
.badge {
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  padding: .25rem .7rem;
  border-radius: 99px;
  font-size: .75rem;
  font-weight: 600;
}
.badge-orange  { background: var(--orange-light); color: var(--orange-dark); }
.badge-blue    { background: var(--blue-light);   color: var(--blue); }
.badge-green   { background: var(--green-light);  color: var(--green); }
.badge-yellow  { background: var(--yellow-light); color: var(--yellow); }
.badge-red     { background: var(--red-light);    color: var(--red); }
.badge-grey    { background: var(--border);       color: var(--text-soft); }

/* ─── Progress bar ────────────────────────────────────────────────────── */
.progress-bar-wrap {
  background: var(--border);
  border-radius: 99px;
  height: 8px;
  overflow: hidden;
  width: 100%;
}
.progress-bar-fill {
  height: 100%;
  border-radius: 99px;
  background: linear-gradient(90deg, var(--orange), var(--orange-dark));
  transition: width .6s ease;
}
.progress-bar-fill.completed { background: linear-gradient(90deg, var(--green), #059669); }

/* ─── États vides ────────────────────────────────────────────────────── */
.empty-state {
  text-align: center;
  padding: 4rem 2rem;
  color: var(--text-light);
}
.empty-state i { font-size: 3rem; margin-bottom: 1rem; display: block; }
.empty-state p { font-size: 1rem; }
.empty-state a { color: var(--orange); text-decoration: none; font-weight: 600; }

/* ─── Modal ──────────────────────────────────────────────────────────── */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(20, 30, 60, .55);
  backdrop-filter: blur(4px);
  z-index: 9000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.5rem;
  animation: fadeIn .2s ease;
}
.modal-card {
  background: var(--white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  max-width: 680px;
  width: 100%;
  max-height: 90vh;
  overflow-y: auto;
  animation: slideUp .25s ease;
}

@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes slideUp { from { opacity: 0; transform: translateY(24px); } to { opacity: 1; transform: translateY(0); } }

/* ─── Scrollbar custom ────────────────────────────────────────────────── */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: var(--border-dark); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--text-light); }

/* ─── Utilitaires ────────────────────────────────────────────────────── */
.hidden { display: none !important; }
.text-orange { color: var(--orange); }
.text-blue   { color: var(--blue); }
.text-green  { color: var(--green); }
.text-soft   { color: var(--text-soft); }
.fw-600 { font-weight: 600; }
.fw-700 { font-weight: 700; }
