/* ================================================================
   LINKEVENT by LSCS — espace-prestataire.css  v1.1
   Espace prestataire : auth, dashboard, services, galerie,
   profil, demandes, messagerie, paramètres.
   Inclut les styles de layout compte (account-grid, sidebar,
   hero) en autonome — ne dépend pas de client.css côté layout.
   ================================================================ */

.badge-verified,
.badge-pending {
    display: inline-block;
    font-size: 12px;
    padding: 3px 8px;
    border-radius: 6px;
    font-weight: 600;
    line-height: 1;
    white-space: nowrap;
}

.badge-verified {
    background: #16a34a;
    color: #ffffff !important;
}

.badge-pending {
    background: #f59e0b;
    color: #ffffff !important;
}

/* ================================================================
   0. LAYOUT COMPTE — autonome (ne dépend pas de client.css)
   ================================================================ */

/* Hero section */
.account-hero {
  background: var(--surface, #EFF6FF);
  border-bottom: 1px solid var(--border, #BFDBFE);
  padding: 36px 0;
}

.account-hero-card {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
}

.account-hero-card h1 {
  font-family: var(--font-title, 'Cormorant Garamond', serif);
  font-size: clamp(1.7rem, 3.5vw, 2.6rem);
  font-weight: 700;
  color: var(--text, #0F172A);
  margin: 6px 0 8px;
}

.account-hero-card > div > p,
.account-hero-main > p {
  font-size: 15px;
  color: var(--text-s, #475569);
  margin: 0;
  max-width: 560px;
  line-height: 1.7;
}

.account-hero-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  flex-shrink: 0;
}

/* Grid sidebar + contenu */
.account-section { padding: 40px 0 64px; }

.account-grid {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 28px;
  align-items: start;
}

/* Sidebar */
.account-sidebar {
  position: sticky;
  top: calc(var(--header-h, 80px) + 20px);
}

.account-sidebar .account-panel {
  overflow: visible;
  padding: 18px 16px 14px;
}

.account-sidebar .account-panel h3 {
  font-family: var(--font-body, 'DM Sans', sans-serif);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-t, #94A3B8);
  margin: 0 0 10px;
  padding: 0 4px;
}

.account-menu {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.account-menu a {
  display: block;
  padding: 9px 12px;
  border-radius: var(--r-sm, 10px);
  font-size: 14px;
  font-weight: 500;
  color: var(--text-s, #475569);
  text-decoration: none;
  transition: background 0.14s, color 0.14s;
}

.account-menu a:hover {
  background: var(--surface-2, #DBEAFE);
  color: var(--primary, #1E3A5F);
}

.account-menu a.active {
  background: var(--primary, #1E3A5F);
  color: #fff;
  font-weight: 600;
}

/* Panels */
.account-panel {
  background: var(--white, #fff);
  border: 1px solid var(--border, #BFDBFE);
  border-radius: var(--r-lg, 20px);
  overflow: hidden;
  box-shadow: 0 8px 20px rgba(30,58,95,0.06);
}

.panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 18px 24px;
  border-bottom: 1px solid var(--border, #BFDBFE);
  background: var(--bg, #F8FAFC);
}

.panel-head h2 {
  font-family: var(--font-body, 'DM Sans', sans-serif);
  font-size: 15px;
  font-weight: 700;
  color: var(--text, #0F172A);
  margin: 0;
}

.account-content {
  display: flex;
  flex-direction: column;
  gap: 20px;
  min-width: 0;
}

/* Responsive layout */
@media (max-width: 960px) {
  .account-grid { grid-template-columns: 1fr; }
  .account-sidebar { position: static; }
  .account-sidebar .account-panel { padding-bottom: 8px; }
  .account-menu { flex-direction: row; flex-wrap: wrap; gap: 4px; }
  .account-menu a { padding: 7px 12px; font-size: 13px; }
}

@media (max-width: 768px) {
  .account-hero-card { flex-direction: column; }
}



/* ================================================================
   1. AUTH PRESTATAIRE — connexion / inscription
   Hérite de .auth-page / .auth-card / .auth-form définis
   dans client.css. Éléments spécifiques + surcharges de contexte.
   ================================================================ */

/*
 * Quand auth-wrapper / auth-card sont dans account-content
 * (modifier-service, ajouter-service), on annule le centrage
 * et on les transforme en panels pleine largeur.
 */
.account-content .auth-wrapper {
  display: block;
  max-width: none;
  padding: 0;
}

.account-content .auth-card,
.account-content .auth-card-large {
  max-width: none;
  padding: 0;
  border: none;
  border-radius: 0;
  box-shadow: none;
  background: transparent;
}

/* Sections internes → panel visuel */
.account-content .auth-card-section {
  background: var(--white, #fff);
  border: 1px solid var(--border, #BFDBFE);
  border-radius: var(--r-lg, 20px);
  padding: 22px 24px;
  margin-bottom: 20px;
  box-shadow: 0 8px 20px rgba(30,58,95,0.06);
}

.account-content .auth-card-section > h2,
.account-content .auth-card-section > h3 {
  font-size: 16px;
  font-weight: 700;
  color: var(--text, #0F172A);
  margin-bottom: 10px;
}

/* Formulaire principal hors auth-card-section → panel */
.account-content .auth-card > form.auth-form {
  background: var(--white, #fff);
  border: 1px solid var(--border, #BFDBFE);
  border-radius: var(--r-lg, 20px);
  box-shadow: 0 8px 20px rgba(30,58,95,0.06);
  padding: 22px 24px;
  margin-top: 4px;
}


/* Switch Connexion / Inscription */
.auth-switch-box {
  display: flex;
  gap: 4px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-pill, 999px);
  padding: 4px;
  margin-bottom: 22px;
}

.auth-switch-link {
  flex: 1;
  text-align: center;
  padding: 8px 14px;
  border-radius: var(--r-pill, 999px);
  font-size: 13px;
  font-weight: 600;
  color: var(--text-s);
  text-decoration: none;
  transition: background 0.15s, color 0.15s;
}

.auth-switch-link.active {
  background: var(--primary);
  color: #fff;
}

.auth-switch-link:not(.active):hover {
  background: var(--surface-2, #DBEAFE);
  color: var(--primary);
}

/* Grande carte auth pour l'inscription (nombreux champs) */
.auth-card-large {
  max-width: 680px;
}

.auth-card-section { /* utilisé comme modificateur */ }

/* Grille 2 colonnes dans les formulaires auth */
.auth-form .form-row,
.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

/* Mot de passe oublié — lien sous le champ */
.form-forgot {
  display: block;
  text-align: right;
  font-size: 13px;
  color: var(--primary-m);
  text-decoration: none;
  margin-top: 4px;
  transition: color 0.14s;
}
.form-forgot:hover { color: var(--primary); text-decoration: underline; }

/* Jauge de force mot de passe */
.password-wrapper {
  position: relative;
  display: flex;
  align-items: center;
}

.password-wrapper input { padding-right: 44px; }

.password-toggle {
  position: absolute;
  right: 12px;
  background: none;
  border: none;
  cursor: pointer;
  font-size: 16px;
  opacity: 0.5;
  transition: opacity 0.14s;
  padding: 0; line-height: 1;
}
.password-toggle:hover { opacity: 1; }

.password-strength {
  display: flex;
  gap: 4px;
  margin-top: 6px;
  height: 4px;
}

.strength-bar {
  flex: 1;
  border-radius: var(--r-pill);
  background: var(--border);
  transition: background 0.2s;
}
.strength-bar.weak   { background: var(--danger, #991B1B); }
.strength-bar.medium { background: #F59E0B; }
.strength-bar.strong { background: var(--success, #065F46); }

.strength-label {
  display: block;
  font-size: 11px;
  font-weight: 600;
  color: var(--text-t);
  margin-top: 4px;
}


/* ================================================================
   2. FORMULAIRES PRESTATAIRE — profil, service, paramètres
   ================================================================ */

/* auth-form ET account-form partagent les mêmes styles de champs */
.account-form,
.auth-form {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 22px 24px;
}

.account-form .form-group,
.auth-form .form-group {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.account-form .form-group label,
.auth-form .form-group label,
.form-group label {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-s, #475569);
}

.account-form .form-group input,
.account-form .form-group select,
.account-form .form-group textarea,
.auth-form .form-group input,
.auth-form .form-group select,
.auth-form .form-group textarea {
  width: 100%;
  background: var(--bg, #F8FAFC);
  border: 1.5px solid var(--border-gray, #CBD5E1);
  border-radius: var(--r-sm, 10px);
  font-family: var(--font-body, 'DM Sans', sans-serif);
  font-size: 15px;
  color: var(--text, #0F172A);
  outline: none;
  transition: border-color 0.14s, box-shadow 0.14s;
  padding: 0 14px;
  height: 46px;
  appearance: none;
}

.account-form .form-group textarea,
.auth-form .form-group textarea {
  height: auto;
  min-height: 110px;
  padding: 12px 14px;
  resize: vertical;
  line-height: 1.65;
}

.account-form .form-group select,
.auth-form .form-group select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2394A3B8' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 38px;
  cursor: pointer;
}

.account-form .form-group input:focus,
.account-form .form-group select:focus,
.account-form .form-group textarea:focus,
.auth-form .form-group input:focus,
.auth-form .form-group select:focus,
.auth-form .form-group textarea:focus {
  border-color: var(--primary-m, #3B6CB0);
  box-shadow: 0 0 0 3px rgba(59,108,176,0.12);
  background: var(--white, #fff);
}

.account-form .form-group small,
.auth-form .form-group small {
  font-size: 12px;
  color: var(--text-t, #94A3B8);
  line-height: 1.5;
}

/* file input */
.account-form .form-group input[type="file"],
.auth-form .form-group input[type="file"] {
  height: auto;
  padding: 10px 14px;
  cursor: pointer;
  font-size: 13px;
}

/* Grille 2 colonnes dans les formulaires */
.auth-form .form-row,
.account-form .form-row,
.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

/* Checkbox inline */
.checkbox-group {
  flex-direction: row;
  align-items: center;
  gap: 10px;
  cursor: pointer;
}

.checkbox-inline {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  font-weight: 500;
  color: var(--text-s, #475569);
  cursor: pointer;
}

.checkbox-inline input[type="checkbox"] {
  width: 18px; height: 18px;
  accent-color: var(--primary, #1E3A5F);
  cursor: pointer;
  flex-shrink: 0;
}

/* Form actions */
.form-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  padding-top: 8px;
  border-top: 1px solid var(--border, #BFDBFE);
  margin-top: 4px;
}

.form-actions-inline {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}




/* ================================================================
   3. LOGO PRESTATAIRE — modifier-profil
   ================================================================ */
.logo-manager {
  display: flex;
  align-items: flex-start;
  gap: 20px;
  flex-wrap: wrap;
  padding: 16px 0;
}

.logo-preview-block {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}

.logo-preview-box {
  width: 90px; height: 90px;
  border-radius: var(--r-md, 14px);
  border: 2px solid var(--border);
  overflow: hidden;
  background: var(--surface);
  display: flex;
  align-items: center;
  justify-content: center;
}

.logo-preview-box.logo-preview-empty {
  border-style: dashed;
  color: var(--text-t);
  font-size: 12px;
  text-align: center;
  padding: 8px;
}

.logo-preview-image {
  width: 100%; height: 100%;
  object-fit: cover;
}

.logo-manager-actions {
  flex: 1;
  min-width: 200px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.logo-delete-check {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--danger, #991B1B);
  cursor: pointer;
}

.logo-delete-check input[type="checkbox"] {
  accent-color: var(--danger);
}

.logo-help {
  font-size: 12px;
  color: var(--text-t);
  line-height: 1.5;
}


/* ================================================================
   4. PHOTOS SERVICE — ajouter-service / modifier-service
   ================================================================ */
.service-photo-manager-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  padding: 12px 0;
}

.service-photo-manager-item {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.service-photo-preview-box {
  width: 100%; aspect-ratio: 4/3;
  border-radius: var(--r-sm, 10px);
  overflow: hidden;
  border: 1px solid var(--border);
  background: var(--surface);
}

.service-photo-preview-image {
  width: 100%; height: 100%;
  object-fit: cover;
}

.service-photo-delete-form button {
  width: 100%;
  font-size: 12px;
  height: 34px;
  padding: 0 10px;
}


/* ================================================================
   5. DASHBOARD — espace-prestataire.php
   ================================================================ */

/* Hero du dashboard prestataire */
.account-hero-main {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.hero-meta {
  font-size: 13px;
  color: var(--text-t);
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 6px;
}

.hero-meta span {
  display: flex;
  align-items: center;
  gap: 5px;
}

/* Complétude profil */
.profile-progress {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg, 20px);
  padding: 18px 22px;
  box-shadow: var(--shadow-s);
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.profile-progress-bar {
  flex: 1;
  min-width: 180px;
  height: 8px;
  background: var(--surface);
  border-radius: var(--r-pill);
  overflow: hidden;
  border: 1px solid var(--border);
}

.profile-progress-bar span {
  display: block;
  height: 100%;
  background: linear-gradient(to right, var(--primary-m), var(--primary));
  border-radius: var(--r-pill);
  transition: width 0.5s ease;
}

.completion-badge {
  display: inline-flex;
  align-items: center;
  padding: 5px 14px;
  border-radius: var(--r-pill);
  font-size: 13px;
  font-weight: 700;
  background: var(--surface-2, #DBEAFE);
  color: var(--primary);
  flex-shrink: 0;
}

/* Cards stats dashboard */
.account-cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}

.dashboard-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-md, 14px);
  padding: 18px 16px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  box-shadow: var(--shadow-s);
  transition: transform 0.16s;
}

.dashboard-card:hover { transform: translateY(-2px); }

.dashboard-card .card-kicker {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-t);
}

.dashboard-card strong {
  font-family: var(--font-title);
  font-size: 2.2rem;
  font-weight: 700;
  color: var(--primary);
  line-height: 1;
}

.dashboard-card p {
  font-size: 12px;
  color: var(--text-t);
  margin: 0;
  line-height: 1.4;
}

.card-kicker {
  display: block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-t);
  margin-bottom: 3px;
}

/* Highlight panel (compte en attente, etc.) */
.account-panel-highlight {
  border-color: var(--primary-m, #3B6CB0);
  box-shadow: 0 0 0 1px var(--primary-m), var(--shadow-s);
}

/* Panel intro / actions */
.panel-intro {
  font-size: 14px;
  color: var(--text-s);
  line-height: 1.65;
  padding: 0 22px 14px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 0;
}

.panel-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 16px 22px;
  border-top: 1px solid var(--border);
  flex-wrap: wrap;
}

/* Liste dashboard (demandes récentes, services récents) */
.dashboard-list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.dashboard-list-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 14px 22px;
  border-bottom: 1px solid var(--border);
  transition: background 0.12s;
}

.dashboard-list-item:last-child { border-bottom: none; }
.dashboard-list-item:hover { background: #fafcff; }

.dashboard-list-item strong {
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  display: block;
  margin-bottom: 2px;
}

.dashboard-list-item span {
  font-size: 12px;
  color: var(--text-t);
}

/* Actions rapides */
.quick-actions-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  padding: 18px;
}

.quick-action-card {
  display: flex;
  flex-direction: column;
  gap: 5px;
  padding: 16px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md, 14px);
  text-decoration: none;
  transition: background 0.15s, border-color 0.15s, transform 0.15s;
  cursor: pointer;
}

.quick-action-card:hover {
  background: var(--surface-2, #DBEAFE);
  border-color: var(--border-s, #93C5FD);
  transform: translateY(-2px);
}

.quick-action-icon { font-size: 1.4rem; line-height: 1; margin-bottom: 4px; }

.quick-action-label,
.quick-action-card strong {
  font-size: 14px;
  font-weight: 600;
  color: var(--primary);
  display: block;
}

.quick-action-card p {
  font-size: 12px;
  color: var(--text-t);
  line-height: 1.4;
  margin: 0;
}

/* Éléments manquants dans profil */
.missing-items {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 14px 22px;
}

.missing-items li {
  font-size: 13px;
  color: var(--text-s);
  list-style: none;
  display: flex;
  align-items: center;
  gap: 8px;
}

.missing-items li::before {
  content: '·';
  color: var(--border-s);
  font-weight: 700;
}

/* Prochaines étapes */
.next-steps {
  display: flex;
  flex-direction: column;
  gap: 0;
  padding: 4px 22px;
}

.next-steps .step-line {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 14px 0;
  border-bottom: 1px solid var(--border);
}
.next-steps .step-line:last-child { border-bottom: none; }

.next-steps .step-dot {
  width: 12px; height: 12px;
  border-radius: 50%;
  background: var(--primary-m);
  border: 2px solid var(--primary-l, #DBEAFE);
  flex-shrink: 0;
  margin-top: 4px;
}

.next-steps .step-line > div strong {
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  display: block;
  margin-bottom: 3px;
}

.next-steps .step-line > div p {
  font-size: 13px;
  color: var(--text-s);
  line-height: 1.6;
  margin: 0;
}

/* Galerie preview dans dashboard */
.gallery-preview-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  padding: 14px 22px;
}

.gallery-preview-card {
  aspect-ratio: 1;
  border-radius: var(--r-sm, 10px);
  overflow: hidden;
  border: 1px solid var(--border);
  background: var(--surface);
  position: relative;
}

.gallery-preview-card img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 0.2s;
}

.gallery-preview-card:hover img { transform: scale(1.05); }

.gallery-preview-card.more {
  background: var(--primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  font-weight: 700;
  color: #fff;
  text-decoration: none;
}

.gallery-link {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 13px;
  font-weight: 600;
  color: var(--primary-m);
  text-decoration: none;
  transition: color 0.14s;
}

.gallery-link:hover { color: var(--primary); }


/* ================================================================
   6. SERVICES — mes-services.php
   ================================================================ */
.services-list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.service-card {
  padding: 18px 22px;
  border-bottom: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  gap: 10px;
  transition: background 0.12s;
}

.service-card:last-child { border-bottom: none; }
.service-card:hover { background: #fafcff; }

.service-card-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.service-card-top h3 {
  font-size: 16px;
  font-weight: 700;
  color: var(--text);
  margin: 0 0 4px;
}

.service-meta {
  font-size: 13px;
  color: var(--text-t);
  margin: 0;
}

.service-text {
  font-size: 14px;
  color: var(--text-s);
  line-height: 1.65;
  margin: 0;
}

.service-infos-row {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.service-pill {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 14px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-sm, 10px);
  font-size: 13px;
}

.service-pill span {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-t);
}

.service-pill strong {
  font-weight: 600;
  color: var(--text);
}


/* ================================================================
   7. GALERIE — galerie.php
   ================================================================ */
.gallery-manager-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  padding: 18px;
}

.gallery-manager-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md, 14px);
  overflow: hidden;
  transition: transform 0.18s, box-shadow 0.18s;
}

.gallery-manager-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow, 0 16px 40px rgba(30,58,95,0.08));
}

.gallery-manager-image-wrap {
  width: 100%; aspect-ratio: 4/3;
  overflow: hidden;
  background: var(--surface-2);
}

.gallery-manager-image {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 0.22s;
}

.gallery-manager-card:hover .gallery-manager-image { transform: scale(1.04); }

.gallery-manager-body {
  padding: 12px 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}

.gallery-alt-text {
  font-size: 12px;
  color: var(--text-t);
  margin: 0;
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.gallery-alt-text strong { color: var(--text-s); }


/* ================================================================
   8. MA VITRINE — aperçu prestataire
   ================================================================ */
.vitrine-preview-section {
  background: var(--surface);
  border-top: 1px solid var(--border);
  padding: 40px 0 60px;
}

.presentation-block {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg, 20px);
  overflow: hidden;
  margin-bottom: 20px;
  box-shadow: var(--shadow-s);
}

.presentation-item {
  padding: 16px 22px;
  border-bottom: 1px solid var(--border);
  font-size: 14px;
  color: var(--text-s);
  line-height: 1.7;
}

.presentation-item:last-child { border-bottom: none; }

.offer-category {
  display: inline-block;
  padding: 3px 10px;
  border-radius: var(--r-pill);
  background: var(--surface-2, #DBEAFE);
  color: var(--primary);
  font-size: 12px;
  font-weight: 600;
  margin-bottom: 6px;
}

.offer-details-section {
  padding: 14px 22px;
  border-top: 1px solid var(--border);
  font-size: 14px;
  color: var(--text-s);
  line-height: 1.65;
}

.offer-link {
  text-decoration: none;
  color: var(--primary-m);
  font-weight: 600;
  font-size: 13px;
  transition: color 0.14s;
}
.offer-link:hover { color: var(--primary); }

.offer-toggle-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 6px 14px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-pill);
  font-size: 13px;
  font-weight: 600;
  color: var(--primary-m);
  cursor: pointer;
  transition: background 0.14s;
}
.offer-toggle-btn:hover { background: var(--surface-2); }


/* ================================================================
   9. DEMANDE DETAIL — demande.php prestataire
   ================================================================ */
.demande-page {
  min-height: 70vh;
  background: var(--bg);
}

.demande-container {
  max-width: 1100px;
  margin: 0 auto;
  padding: 28px 24px 60px;
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 22px;
  align-items: start;
}

.demande-topbar {
  max-width: 1100px;
  margin: 0 auto;
  padding: 20px 24px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
}

.demande-breadcrumb {
  font-size: 13px;
  color: var(--text-t);
  display: flex;
  align-items: center;
  gap: 8px;
}

.demande-breadcrumb a {
  color: var(--primary-m);
  text-decoration: none;
  font-weight: 600;
}

.demande-breadcrumb a:hover { text-decoration: underline; }

.demande-back {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 600;
  color: var(--primary-m);
  text-decoration: none;
  transition: color 0.14s;
}
.demande-back:hover { color: var(--primary); }

.demande-main { display: flex; flex-direction: column; gap: 18px; }
.demande-sidebar { display: flex; flex-direction: column; gap: 16px; position: sticky; top: calc(var(--header-h, 80px) + 20px); }

/* Cards dédiées demande */
.d-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg, 20px);
  overflow: hidden;
  box-shadow: var(--shadow-s);
}

.d-card.d-hero {
  border-color: var(--primary-m);
  box-shadow: 0 0 0 1px var(--primary-m), var(--shadow-s);
}

.d-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 16px 22px;
  border-bottom: 1px solid var(--border);
  background: var(--bg);
  flex-wrap: wrap;
}

.d-card-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0;
}

.d-card-title-icon {
  font-size: 1.1rem;
  opacity: 0.8;
}

.d-card-body { padding: 18px 22px; }

/* Hero demande */
.d-hero-inner {
  padding: 22px 22px 18px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.d-hero-id {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-t);
}

.d-hero-objet {
  font-family: var(--font-title);
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--text);
  margin: 4px 0;
  line-height: 1.2;
}

.d-hero-badge {
  display: inline-flex;
  align-items: center;
  padding: 4px 12px;
  border-radius: var(--r-pill);
  font-size: 12px;
  font-weight: 600;
  background: var(--surface-2, #DBEAFE);
  color: var(--primary);
}

.d-hero-meta {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  font-size: 13px;
  color: var(--text-t);
}

/* Info grid dans demande */
.d-info-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
}

.d-info-item {
  padding: 12px 18px;
  border-bottom: 1px solid var(--border);
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.d-info-item:nth-child(2n)        { border-right: none; }
.d-info-item:nth-last-child(-n+2) { border-bottom: none; }

.d-info-label {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-t);
}

.d-info-value {
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
}

/* Message client */
.d-message {
  background: var(--surface);
  border-radius: var(--r-sm, 10px);
  padding: 14px 16px;
  font-size: 14px;
  color: var(--text-s);
  line-height: 1.7;
  white-space: pre-wrap;
}

/* Textarea note prestataire */
.d-textarea {
  width: 100%;
  background: var(--bg);
  border: 1.5px solid var(--border-gray, #CBD5E1);
  border-radius: var(--r-sm, 10px);
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--text);
  padding: 12px 14px;
  min-height: 110px;
  resize: vertical;
  outline: none;
  line-height: 1.65;
  transition: border-color 0.14s, box-shadow 0.14s;
}
.d-textarea:focus {
  border-color: var(--primary-m);
  box-shadow: 0 0 0 3px rgba(59,108,176,0.12);
  background: var(--white);
}

/* Gestion statut */
.d-statut-grid {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 14px 18px;
}

.d-statut-btn {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 11px 14px;
  border: 1.5px solid var(--border);
  border-radius: var(--r-sm, 10px);
  background: var(--white);
  font-size: 14px;
  font-weight: 500;
  color: var(--text-s);
  cursor: pointer;
  text-align: left;
  width: 100%;
  transition: background 0.14s, border-color 0.14s;
}

.d-statut-btn:hover { background: var(--surface); border-color: var(--border-s); }

.d-statut-btn.active {
  border-color: var(--primary);
  background: var(--surface-2, #DBEAFE);
  color: var(--primary);
  font-weight: 600;
}

.d-statut-dot {
  width: 10px; height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}

/* CTA messagerie */
.d-msg-cta {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px;
  text-decoration: none;
  transition: background 0.14s;
  border-radius: var(--r-sm);
  margin: 8px 8px 0;
  background: var(--surface);
  border: 1px solid var(--border);
}

.d-msg-cta:hover { background: var(--surface-2); border-color: var(--border-s); }

.d-msg-cta-icon {
  font-size: 1.4rem;
  line-height: 1;
  flex-shrink: 0;
}

.d-msg-cta strong {
  display: block;
  font-size: 14px;
  font-weight: 600;
  color: var(--primary);
  margin-bottom: 2px;
}

.d-msg-cta span {
  font-size: 12px;
  color: var(--text-t);
}

/* Infos prestatation traitée */
.d-traitee-info {
  padding: 14px 18px;
  font-size: 13px;
  color: var(--success, #065F46);
  background: var(--success-l, #D1FAE5);
  border-radius: var(--r-sm);
  margin: 8px;
}

/* Alertes inline demande */
.d-alert {
  padding: 12px 16px;
  border-radius: var(--r-sm, 10px);
  font-size: 14px;
  margin: 8px;
  border-left: 3px solid transparent;
}

.d-alert-success {
  background: var(--success-l, #D1FAE5);
  color: #022C22;
  border-left-color: #10B981;
}

.d-alert-error {
  background: var(--danger-l, #FEE2E2);
  color: #4C0519;
  border-left-color: #E11D48;
}

/* Boutons inline demande */
.d-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 0 18px;
  height: 40px;
  border-radius: var(--r-md, 14px);
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  border: none;
  text-decoration: none;
  transition: opacity 0.15s, transform 0.15s;
  white-space: nowrap;
}

.d-btn:hover { opacity: 0.88; transform: translateY(-1px); }

.d-btn-primary { background: var(--primary); color: #fff; }
.d-btn-outline {
  background: transparent;
  color: var(--primary);
  border: 1.5px solid var(--primary);
}
.d-btn-outline:hover { background: var(--surface-2); opacity: 1; }

.d-btn-sm { height: 34px; font-size: 13px; padding: 0 14px; }

/* Info grid standard (hérité de client.css — redéfini ici pour sécurité) */
.info-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
}

.info-item {
  padding: 13px 22px;
  border-bottom: 1px solid var(--border);
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.info-item:nth-child(2n)        { border-right: none; }
.info-item:nth-last-child(-n+2) { border-bottom: none; }

.info-item span {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-t);
}

.info-item strong {
  font-size: 15px;
  font-weight: 600;
  color: var(--text);
}

.info-item a { color: var(--primary-m); text-decoration: none; }
.info-item a:hover { color: var(--primary); }


/* ================================================================
   10. PARAMÈTRES — zone sensible
   ================================================================ */
.danger-zone-box {
  padding: 18px 22px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.danger-zone-box p {
  font-size: 14px;
  color: var(--text-s);
  line-height: 1.65;
  margin: 0;
}

.danger-zone-box strong { color: var(--text); }


/* ================================================================
   11. MESSAGERIE PRESTATAIRE — messages.php restructuré
   ================================================================ */
/* Réutilise le layout account-page + msg-panel de client.css */
/* Classes msg-* déjà définies dans client.css section 25       */

/* Si messages.php utilise encore l'ancienne structure wrapper */
.presta-wrapper {
  display: flex;
  min-height: calc(100vh - var(--header-h, 80px));
}

.presta-main {
  flex: 1; min-width: 0;
  padding: 28px 32px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.presta-page-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

.presta-page-title {
  font-family: var(--font-title);
  font-size: 1.8rem;
  font-weight: 700;
  color: var(--text);
  margin: 0;
}

/* Statuts demandes */
.status-badge {
  display: inline-flex;
  align-items: center;
  padding: 4px 12px;
  border-radius: var(--r-pill, 999px);
  font-size: 12px;
  font-weight: 600;
  white-space: nowrap;
}

.status-pending   { background: var(--surface-2, #DBEAFE);  color: var(--primary, #1E3A5F); }
.status-neutral   { background: var(--neutral-l, #F1F5F9);  color: var(--neutral, #334155); }
.status-active    { background: var(--success-l, #D1FAE5);  color: var(--success, #065F46); }
.status-suspended { background: var(--danger-l, #FEE2E2);   color: var(--danger, #991B1B); }
.status-warning   { background: var(--warn-l, #FEF3C7);     color: var(--warn, #92400E); }

/* Alertes (redéfinition sécurisée, hérite de client.css) */
.alert {
  padding: 12px 16px;
  border-radius: var(--r-sm, 10px);
  font-size: 14px;
  line-height: 1.6;
  margin-bottom: 14px;
  border-left: 3px solid transparent;
}
.alert ul { margin: 0; padding-left: 18px; list-style: disc; }

.alert-success { background: var(--success-l); color: #022C22;  border-left-color: #10B981; }
.alert-error   { background: var(--danger-l);  color: #4C0519;  border-left-color: #E11D48; }
.alert-danger  { background: var(--danger-l);  color: #4C0519;  border-left-color: #E11D48; }
.alert-warning { background: var(--warn-l);    color: #451a03;  border-left-color: #F59E0B; }
.alert-info    { background: var(--surface-2); color: var(--primary-d); border-left-color: var(--primary-m); }

/* Empty state */
.empty-state-box {
  text-align: center;
  padding: 48px 24px;
  background: var(--surface);
}

.empty-state-box strong {
  display: block;
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 8px;
  font-family: var(--font-title);
}

.empty-state-box p {
  font-size: 14px;
  color: var(--text-t);
  max-width: 380px;
  margin: 0 auto 16px;
  line-height: 1.65;
}

/* Demandes : filtres + liste (réutilisation des classes client) */
.demandes-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 16px 22px;
  border-bottom: 1px solid var(--border);
}

.demandes-filter-pill {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 6px 14px;
  border-radius: var(--r-pill, 999px);
  border: 1.5px solid var(--border-gray, #CBD5E1);
  background: var(--white);
  font-size: 13px;
  font-weight: 500;
  color: var(--text-s);
  text-decoration: none;
  transition: background 0.14s, border-color 0.14s, color 0.14s;
}

.demandes-filter-pill:hover {
  background: var(--surface);
  border-color: var(--border-s, #93C5FD);
  color: var(--primary);
}

.demandes-filter-pill.active {
  background: var(--primary);
  border-color: var(--primary);
  color: #fff;
  font-weight: 600;
}

.demandes-filter-pill span {
  min-width: 18px; height: 18px;
  padding: 0 4px;
  background: rgba(0,0,0,0.10);
  border-radius: var(--r-pill);
  font-size: 10px; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
}

.demandes-filter-pill.active span { background: rgba(255,255,255,0.25); }

/* Demande cards prestataire */
.demandes-list { display: flex; flex-direction: column; gap: 0; }

.demande-card {
  padding: 20px 24px;
  border-bottom: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: background 0.12s;
}

.demande-card:last-child { border-bottom: none; }
.demande-card:hover { background: #fafcff; }

.demande-card-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.demande-card-head h3 {
  font-family: var(--font-body);
  font-size: 16px;
  font-weight: 700;
  color: var(--text);
  margin: 4px 0 0;
}

.demande-meta-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
}

.demande-meta-grid .info-item:nth-child(3n)        { border-right: none; }
.demande-meta-grid .info-item:nth-last-child(-n+3) { border-bottom: none; }

.demande-message-box {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-sm, 10px);
  padding: 12px 16px;
}

.demande-message-box > span {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-t);
  display: block;
  margin-bottom: 6px;
}

.demande-message-box p {
  font-size: 14px;
  color: var(--text-s);
  line-height: 1.7;
  margin: 0;
}

.demande-card-actions { display: flex; gap: 10px; flex-wrap: wrap; }


/* ================================================================
   12. RESPONSIVE
   ================================================================ */
@media (max-width: 1100px) {
  .account-cards         { grid-template-columns: repeat(2, 1fr); }
  .gallery-preview-grid  { grid-template-columns: repeat(3, 1fr); }
  .demande-container     { grid-template-columns: 1fr; }
  .demande-sidebar       { position: static; }
}

@media (max-width: 960px) {
  .account-grid          { grid-template-columns: 1fr; }
  .account-sidebar       { position: static; }
  .account-menu          { flex-direction: row; flex-wrap: wrap; gap: 4px; }
  .account-menu a        { padding: 7px 12px; font-size: 13px; }
  .gallery-manager-grid  { grid-template-columns: repeat(2, 1fr); }
  .demande-meta-grid     { grid-template-columns: 1fr 1fr; }
  .demande-meta-grid .info-item:nth-child(2n)        { border-right: none; }
  .demande-meta-grid .info-item:nth-last-child(-n+2) { border-bottom: none; }
  .d-info-grid           { grid-template-columns: 1fr; }
  .d-info-item           { border-right: none !important; }
}

@media (max-width: 768px) {
  .auth-form .form-row,
  .form-row              { grid-template-columns: 1fr; }
  .auth-card-large       { max-width: 100%; padding: 24px 18px; }
  .account-cards         { grid-template-columns: 1fr 1fr; }
  .quick-actions-grid    { grid-template-columns: 1fr; }
  .gallery-preview-grid  { grid-template-columns: repeat(2, 1fr); }
  .service-photo-manager-grid { grid-template-columns: repeat(2, 1fr); }
  .info-grid             { grid-template-columns: 1fr; }
  .info-item             { border-right: none !important; border-bottom: 1px solid var(--border) !important; }
  .info-item:last-child  { border-bottom: none !important; }
}

@media (max-width: 560px) {
  .account-cards        { grid-template-columns: 1fr; }
  .gallery-manager-grid { grid-template-columns: 1fr; }
  .demande-meta-grid    { grid-template-columns: 1fr; }
  .demande-meta-grid .info-item { border-right: none !important; }
  .service-photo-manager-grid { grid-template-columns: 1fr; }
}