/* ===================================================
   PROCURATIONS.CSS — Module Procurations bancaires
   Préfixe : .pr-  (aucun conflit avec .ck- ou .apf-)
   =================================================== */

/* ─── PAGE ──────────────────────────────────────────── */
.page-procurations {
  background: var(--cream, #F5F1EB);
  min-height: 100vh;
}

.page-procurations .brand-link {
  text-decoration: none;
  display: flex;
  flex-direction: column;
}

.nav-badge--proc {
  display: inline-flex;
  align-items: center;
  padding: 4px 14px;
  background: rgba(201, 169, 110, 0.13);
  border: 1px solid rgba(201, 169, 110, 0.38);
  border-radius: 20px;
  font-size: 11px;
  font-weight: 600;
  color: var(--gold, #C9A96E);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

/* ─── MAIN ──────────────────────────────────────────── */
.pr-main {
  padding: 3rem 0 5rem;
}

/* ─── PAGE HEADER ───────────────────────────────────── */
.pr-page-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1.5rem;
  margin-bottom: 2.5rem;
  flex-wrap: wrap;
}

.pr-page-title {
  font-family: var(--font-serif, 'Playfair Display', Georgia, serif);
  font-size: 2rem;
  font-weight: 700;
  color: var(--navy, #0A1628);
  margin: 0 0 0.3rem;
  line-height: 1.15;
}

.pr-page-subtitle {
  font-size: 0.875rem;
  color: var(--text-secondary, #4A4540);
  margin: 0;
}

.pr-header-actions {
  display: flex;
  gap: 0.75rem;
  align-items: center;
  flex-wrap: wrap;
}

/* ─── BUTTONS ───────────────────────────────────────── */
.pr-btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.65rem 1.3rem;
  background: var(--navy, #0A1628);
  color: #fff;
  border: none;
  border-radius: 6px;
  font-size: 13px;
  font-weight: 600;
  font-family: var(--font-sans, 'Inter', sans-serif);
  cursor: pointer;
  transition: background 0.18s, opacity 0.18s;
  letter-spacing: 0.015em;
  white-space: nowrap;
}
.pr-btn-primary:hover   { background: #0F2040; }
.pr-btn-primary:disabled { opacity: 0.5; cursor: not-allowed; }

.pr-btn-secondary {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.6rem 1.1rem;
  background: #fff;
  color: var(--text-primary, #1C1A17);
  border: 1px solid var(--border, #D8D3CC);
  border-radius: 6px;
  font-size: 13px;
  font-weight: 500;
  font-family: var(--font-sans, 'Inter', sans-serif);
  cursor: pointer;
  transition: border-color 0.18s, background 0.18s;
  text-decoration: none;
  white-space: nowrap;
}
.pr-btn-secondary:hover { border-color: var(--navy, #0A1628); background: #f8f7f5; }

.pr-btn-import   { position: relative; }
.pr-hidden-input {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
  width: 100%;
  height: 100%;
}

/* ─── STATUS BAR ────────────────────────────────────── */
.pr-status {
  padding: 10px 16px;
  border-radius: 6px;
  font-size: 13px;
  font-family: var(--font-sans, 'Inter', sans-serif);
  margin-bottom: 1.25rem;
  line-height: 1.5;
}
.pr-status--info    { background: #EBF2FC; color: #1a4a8a; border: 1px solid #b8d0f0; }
.pr-status--success { background: var(--success-bg, #EAF4EE); color: var(--success, #2D6A4F); border: 1px solid #aacfbb; }
.pr-status--error   { background: var(--error-bg, #F9ECEC);   color: var(--error, #8B2020);   border: 1px solid #edb8b8; }
.pr-hidden { display: none !important; }

/* ─── FORM LAYOUT ───────────────────────────────────── */
.pr-form { display: flex; flex-direction: column; gap: 1.5rem; }

.pr-section {
  background: #fff;
  border: 1px solid var(--border-light, #E8E4DE);
  border-radius: 10px;
  padding: 1.75rem 2rem;
}

/* ─── SECTION TITLE ─────────────────────────────────── */
.pr-section-title {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  font-family: var(--font-serif, 'Playfair Display', Georgia, serif);
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--navy, #0A1628);
  margin: 0 0 1.5rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--border-light, #E8E4DE);
  line-height: 1.2;
}

.pr-section-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 26px;
  background: var(--navy, #0A1628);
  color: var(--gold, #C9A96E);
  border-radius: 50%;
  font-size: 10px;
  font-weight: 700;
  font-family: var(--font-sans, 'Inter', sans-serif);
  flex-shrink: 0;
}

.pr-section-hint {
  font-size: 12.5px;
  color: var(--text-muted, #7A7570);
  margin: -0.75rem 0 1.25rem;
  font-style: italic;
}

/* ─── FORM FIELDS ───────────────────────────────────── */
.pr-form-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 1rem;
}

.pr-form-group         { display: flex; flex-direction: column; gap: 0.35rem; }
.pr-form-group--sm     { flex: 0 0 155px; min-width: 120px; }

.pr-form-label {
  font-size: 11.5px;
  font-weight: 600;
  color: var(--text-secondary, #4A4540);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.pr-form-input,
.pr-form-select {
  padding: 0.52rem 0.75rem;
  border: 1px solid var(--border, #D8D3CC);
  border-radius: 5px;
  font-size: 13.5px;
  font-family: var(--font-sans, 'Inter', sans-serif);
  color: var(--text-primary, #1C1A17);
  background: #fff;
  transition: border-color 0.18s, box-shadow 0.18s;
  outline: none;
  width: 100%;
  box-sizing: border-box;
}
.pr-form-input:focus,
.pr-form-select:focus {
  border-color: var(--navy, #0A1628);
  box-shadow: 0 0 0 3px rgba(10,22,40,0.07);
}

/* ─── BORROWERS COUNT TOGGLE ────────────────────────── */
.pr-borrowers-count-wrap { margin-bottom: 1.25rem; }

.pr-toggle-group {
  display: inline-flex;
  border: 1px solid var(--border, #D8D3CC);
  border-radius: 6px;
  overflow: hidden;
  margin-top: 0.25rem;
}

.pr-toggle {
  padding: 0.48rem 1.2rem;
  background: #fff;
  border: none;
  font-size: 13px;
  font-family: var(--font-sans, 'Inter', sans-serif);
  font-weight: 500;
  color: var(--text-secondary, #4A4540);
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
}
.pr-toggle + .pr-toggle { border-left: 1px solid var(--border, #D8D3CC); }
.pr-toggle--active      { background: var(--navy, #0A1628); color: #fff; }

/* ─── BORROWER BLOCKS ───────────────────────────────── */
.pr-borrower-block {
  margin-top: 1.5rem;
  padding-top: 1.25rem;
  border-top: 1px dashed var(--border-light, #E8E4DE);
}
.pr-borrower-block--hidden { display: none !important; }

.pr-borrower-title {
  font-size: 11.5px;
  font-weight: 700;
  color: var(--gold-muted, #8B7240);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin: 0 0 1rem;
}

/* ─── BANKS GRID ────────────────────────────────────── */
.pr-banks-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(148px, 1fr));
  gap: 0.75rem;
  margin-top: 0.25rem;
}

.pr-bank-card { position: relative; cursor: pointer; }
.pr-bank-card input[type="checkbox"] {
  position: absolute; opacity: 0; width: 0; height: 0;
}

.pr-bank-card-inner {
  display: flex;
  flex-direction: column;
  gap: 0.22rem;
  padding: 1rem 1.2rem;
  border: 2px solid var(--border, #D8D3CC);
  border-radius: 8px;
  background: #fff;
  transition: border-color 0.18s, background 0.18s, box-shadow 0.18s;
  user-select: none;
}
.pr-bank-card:hover .pr-bank-card-inner { border-color: var(--navy-border, #1A2F50); }
.pr-bank-card input:checked ~ .pr-bank-card-inner {
  border-color: var(--navy, #0A1628);
  background: rgba(10,22,40,0.035);
  box-shadow: 0 0 0 3px rgba(10,22,40,0.06);
}

.pr-bank-name    { font-size: 13px; font-weight: 600; color: var(--text-primary, #1C1A17); }
.pr-bank-name-he { font-size: 10.5px; color: var(--text-muted, #7A7570); direction: rtl; }

/* ─── OPTIONS GRID ──────────────────────────────────── */
.pr-options-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 0.75rem;
}

.pr-option-item {
  display: flex;
  align-items: flex-start;
  gap: 0.7rem;
  padding: 0.9rem 1rem;
  border: 1px solid var(--border-light, #E8E4DE);
  border-radius: 8px;
  cursor: pointer;
  transition: border-color 0.18s, background 0.15s;
}
.pr-option-item:hover { border-color: var(--border, #D8D3CC); background: #faf9f7; }
.pr-option-item input[type="checkbox"] {
  margin-top: 2px;
  flex-shrink: 0;
  accent-color: var(--navy, #0A1628);
  width: 15px;
  height: 15px;
}

.pr-option-content  { display: flex; flex-direction: column; gap: 0.18rem; }
.pr-option-title    { font-size: 13px; font-weight: 600; color: var(--text-primary, #1C1A17); }
.pr-option-desc     { font-size: 11.5px; color: var(--text-muted, #7A7570); line-height: 1.4; }

/* ─── RESPONSIVE ────────────────────────────────────── */
@media (max-width: 640px) {
  .pr-page-header { flex-direction: column; }
  .pr-header-actions { width: 100%; }
  .pr-btn-primary, .pr-btn-secondary { flex: 1; justify-content: center; }
  .pr-section { padding: 1.25rem 1rem; }
  .pr-form-row { grid-template-columns: 1fr; }
  .pr-form-group--sm { flex: none; }
  .pr-banks-grid { grid-template-columns: 1fr 1fr; }
}
