/* ============================================================
   Back-office Anwar — styles partagés
   Palette : reprend les variables du site public (riad marocain)
   Ton : sobre, professionnel, espacé, accessible
   ============================================================ */

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

:root{
  --rose:#C47560;--rose-light:#F5DFD5;--rose-dark:#8B3A2D;
  --gold:#E0B659;--gold-light:#FAE9C0;--gold-dark:#9C7025;
  --blue:#5B8AA3;--blue-light:#DCE6ED;--blue-dark:#2D5160;
  --teal:#6FA5A2;--teal-light:#DCEAE8;--teal-dark:#3E736F;
  --magenta:#C55B8B;--magenta-light:#F2DAE5;
  --cream:#FDF6E8;--sand:#F3E9D2;
  --dark:#3A2820;--gray:#8A7565;--border:#E5D9BF;--white:#fff;
  --bg:#F7F2E8;
  --danger:#C0392B;--danger-light:#FBE9E7;
  --success:#3E736F;--success-light:#DCEAE8;
  --radius:14px;--radius-sm:8px;--radius-lg:20px;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Inter','Tajawal',system-ui,-apple-system,sans-serif;
  --shadow:0 12px 32px rgba(60,40,20,.08),0 2px 6px rgba(60,40,20,.06);
  --shadow-lg:0 24px 60px rgba(60,40,20,.12),0 4px 12px rgba(60,40,20,.06);
}

html,body{height:100%}
body{
  font-family:var(--sans);
  color:var(--dark);
  background:var(--bg);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}

a{color:var(--rose-dark);text-decoration:none}
a:hover{text-decoration:underline}

/* =============== Layout général =============== */

.auth-shell{
  min-height:100vh;
  display:grid;
  place-items:center;
  padding:24px;
  background:
    radial-gradient(ellipse 70% 50% at 50% 0%, rgba(224,182,89,.14) 0%, transparent 60%),
    linear-gradient(165deg, #F7F2E8 0%, #EDE5D2 100%);
}

.auth-card{
  width:100%;
  max-width:440px;
  background:var(--white);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);
  padding:40px 36px;
  position:relative;
  overflow:hidden;
}
.auth-card::before{
  content:"";
  position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--gold) 0%,var(--rose) 50%,var(--teal) 100%);
}

.auth-logo{
  display:flex;
  justify-content:center;
  margin-bottom:18px;
}
.auth-logo img{
  height:48px;
  width:auto;
}

.auth-title{
  font-family:var(--serif);
  font-size:28px;
  font-weight:600;
  color:var(--rose-dark);
  text-align:center;
  margin-bottom:6px;
  font-style:italic;
}
.auth-subtitle{
  text-align:center;
  font-size:13px;
  color:var(--gray);
  margin-bottom:28px;
}

/* =============== Dashboard layout =============== */

.app-header{
  background:var(--white);
  border-bottom:1px solid var(--border);
  padding:14px 28px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  position:sticky;top:0;z-index:10;
  box-shadow:0 1px 3px rgba(60,40,20,.04);
}
.app-brand{
  display:flex;align-items:center;gap:10px;
  font-family:var(--serif);font-size:20px;color:var(--rose-dark);font-weight:600;
}
.app-brand img{height:32px;width:auto}

.app-nav{display:flex;gap:6px;align-items:center}
.app-nav a{
  font-size:14px;
  color:var(--dark);
  padding:8px 14px;
  border-radius:8px;
  transition:background .15s;
}
.app-nav a:hover{background:var(--sand);text-decoration:none}
.app-nav a.active{background:var(--rose-light);color:var(--rose-dark);font-weight:600}

.user-chip{
  display:flex;align-items:center;gap:10px;
  padding:6px 12px 6px 6px;
  background:var(--sand);
  border-radius:999px;
  font-size:13px;
}
.user-chip .avatar{
  width:28px;height:28px;border-radius:50%;
  background:linear-gradient(135deg,var(--rose) 0%,var(--gold) 100%);
  color:var(--white);display:grid;place-items:center;
  font-weight:700;font-size:12px;
}

.app-main{
  max-width:1080px;
  margin:0 auto;
  padding:32px 28px 60px;
}
.page-title{
  font-family:var(--serif);
  font-size:32px;
  color:var(--rose-dark);
  font-weight:600;
  margin-bottom:6px;
}
.page-subtitle{color:var(--gray);font-size:14px;margin-bottom:28px}

.card{
  background:var(--white);
  border-radius:var(--radius);
  border:1px solid var(--border);
  box-shadow:var(--shadow);
  padding:28px;
  margin-bottom:22px;
}
.card h2{
  font-family:var(--serif);
  font-size:22px;
  color:var(--rose-dark);
  font-weight:600;
  margin-bottom:6px;
}
.card .card-hint{color:var(--gray);font-size:13.5px;margin-bottom:18px}

/* =============== Form elements =============== */

.field{margin-bottom:16px}
.field label{
  display:block;
  font-size:13px;
  font-weight:600;
  color:var(--dark);
  margin-bottom:6px;
}
.field input[type=text],
.field input[type=email],
.field input[type=password],
.field input[type=tel]{
  width:100%;
  padding:11px 14px;
  font-size:15px;
  font-family:inherit;
  color:var(--dark);
  background:var(--white);
  border:1.5px solid var(--border);
  border-radius:var(--radius-sm);
  transition:border-color .15s,box-shadow .15s;
}
.field input:focus{
  outline:none;
  border-color:var(--rose);
  box-shadow:0 0 0 3px rgba(196,117,96,.15);
}
.field .field-hint{
  font-size:12px;color:var(--gray);margin-top:5px;
}

.field-pwd{position:relative}
.field-pwd input{padding-right:46px}
.toggle-pwd{
  position:absolute;right:8px;top:50%;transform:translateY(-50%);
  background:transparent;border:none;
  width:34px;height:34px;border-radius:6px;
  cursor:pointer;color:var(--gray);
  display:grid;place-items:center;
}
.toggle-pwd:hover{background:var(--sand);color:var(--dark)}

.pwd-strength{
  margin-top:8px;font-size:12px;
}
.pwd-strength ul{list-style:none;display:flex;flex-wrap:wrap;gap:6px 14px}
.pwd-strength li{display:flex;align-items:center;gap:5px;color:var(--gray)}
.pwd-strength li.ok{color:var(--success)}
.pwd-strength li::before{
  content:"○";font-weight:700;
}
.pwd-strength li.ok::before{content:"✓"}

/* =============== Buttons =============== */

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:12px 22px;
  font-size:15px;font-weight:600;font-family:inherit;
  border:none;border-radius:var(--radius-sm);
  cursor:pointer;
  transition:transform .1s,box-shadow .15s,background .15s;
  text-decoration:none;
}
.btn:active{transform:translateY(1px)}

.btn-primary{
  background:linear-gradient(135deg,var(--rose) 0%,var(--rose-dark) 100%);
  color:var(--white);
  box-shadow:0 4px 14px rgba(139,58,45,.25);
}
.btn-primary:hover{box-shadow:0 6px 20px rgba(139,58,45,.35);text-decoration:none}
.btn-primary:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}

.btn-ghost{
  background:transparent;
  color:var(--rose-dark);
  border:1.5px solid var(--border);
}
.btn-ghost:hover{background:var(--sand);text-decoration:none}

.btn-danger{
  background:var(--danger);
  color:var(--white);
}
.btn-danger:hover{background:#9b2a1f}

.btn-block{width:100%}

.btn-link{
  background:none;border:none;
  color:var(--rose-dark);
  font-size:13.5px;
  cursor:pointer;
  padding:4px 0;
  font-family:inherit;
}
.btn-link:hover{text-decoration:underline}

/* =============== Messages =============== */

.alert{
  padding:12px 14px;
  border-radius:var(--radius-sm);
  font-size:13.5px;
  margin-bottom:18px;
  display:flex;align-items:flex-start;gap:10px;
  line-height:1.5;
}
.alert-error{background:var(--danger-light);color:var(--danger);border:1px solid #f5b5ad}
.alert-success{background:var(--success-light);color:var(--success-dark, var(--success));border:1px solid #b4d4d0}
.alert-info{background:var(--blue-light);color:var(--blue-dark);border:1px solid #b8cad6}

/* =============== Footer auth =============== */

.auth-footer{
  text-align:center;
  margin-top:22px;
  padding-top:18px;
  border-top:1px solid var(--border);
  font-size:13px;color:var(--gray);
}

/* =============== MFA =============== */

.mfa-qr{
  display:flex;justify-content:center;
  padding:18px;
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  margin-bottom:14px;
}
.mfa-qr svg{max-width:200px;height:auto}

.mfa-secret{
  font-family:'Courier New',monospace;
  background:var(--sand);
  padding:10px 14px;
  border-radius:6px;
  font-size:13px;
  letter-spacing:1px;
  text-align:center;
  user-select:all;
  word-break:break-all;
  margin-bottom:14px;
}

.totp-input{
  font-family:'Courier New',monospace !important;
  letter-spacing:8px !important;
  text-align:center;
  font-size:22px !important;
  font-weight:600;
}

/* =============== Status badges =============== */

.badge{
  display:inline-flex;align-items:center;gap:5px;
  padding:3px 10px;
  border-radius:999px;
  font-size:12px;font-weight:600;
}
.badge-on{background:var(--success-light);color:var(--success)}
.badge-off{background:var(--sand);color:var(--gray)}

/* =============== Loader =============== */

.spinner{
  display:inline-block;
  width:16px;height:16px;
  border:2.5px solid currentColor;
  border-right-color:transparent;
  border-radius:50%;
  animation:spin .7s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}

/* =============== Status / Danger badges =============== */

.badge-status-new       {background:var(--rose-light);color:var(--rose-dark)}
.badge-status-reviewed  {background:var(--gold-light);color:var(--gold-dark)}
.badge-status-contacted {background:var(--blue-light);color:var(--blue-dark)}
.badge-status-closed    {background:var(--sand);color:var(--gray)}

.badge-danger-high {background:#FBE9E7;color:#C0392B;border:1px solid #f5b5ad}
.badge-danger-mid  {background:#FAE9C0;color:#9C7025}
.badge-danger-low  {background:var(--success-light);color:var(--success)}

/* =============== Small buttons =============== */

.btn-small{padding:8px 14px;font-size:13.5px}

/* =============== Tabs (statut) =============== */

.tabs{
  display:flex;flex-wrap:wrap;gap:4px;
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:5px;
  margin-bottom:16px;
  box-shadow:var(--shadow);
}
.tab{
  background:transparent;border:none;cursor:pointer;
  font-family:inherit;font-size:14px;font-weight:500;color:var(--dark);
  padding:9px 16px;border-radius:8px;
  display:inline-flex;align-items:center;gap:8px;
  transition:background .15s,color .15s;
}
.tab:hover{background:var(--sand)}
.tab.active{background:var(--rose-light);color:var(--rose-dark);font-weight:600}
.tab-count{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:22px;height:20px;padding:0 6px;
  background:var(--bg);
  border-radius:999px;
  font-size:12px;font-weight:600;color:var(--gray);
}
.tab.active .tab-count{background:var(--white);color:var(--rose-dark)}

/* =============== Filtres =============== */

.filters{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(170px,1fr));
  gap:12px 16px;
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:18px 20px;
  margin-bottom:18px;
  box-shadow:var(--shadow);
}
.filter-field{display:flex;flex-direction:column}
.filter-field label{
  font-size:11px;font-weight:600;color:var(--gray);
  text-transform:uppercase;letter-spacing:.5px;
  margin-bottom:5px;
}
.filter-field input[type=search],
.filter-field input[type=date],
.filter-field select{
  width:100%;
  padding:9px 12px;
  font-size:14px;font-family:inherit;color:var(--dark);
  background:var(--white);
  border:1.5px solid var(--border);
  border-radius:var(--radius-sm);
  transition:border-color .15s,box-shadow .15s;
}
.filter-field input:focus,
.filter-field select:focus{
  outline:none;border-color:var(--rose);
  box-shadow:0 0 0 3px rgba(196,117,96,.15);
}
.filter-actions{display:flex;align-items:flex-end}

/* =============== Tableau =============== */

.table-wrap{
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  overflow:hidden;
}

.data-table{
  width:100%;
  border-collapse:collapse;
  font-size:14px;
}
.data-table thead th{
  text-align:left;
  font-size:12px;font-weight:600;
  color:var(--gray);
  text-transform:uppercase;letter-spacing:.5px;
  padding:14px 18px;
  background:var(--bg);
  border-bottom:1px solid var(--border);
}
.data-table tbody td{
  padding:14px 18px;
  border-bottom:1px solid var(--border);
  vertical-align:top;
}
.data-table tbody tr:last-child td{border-bottom:none}
.data-table tbody tr{
  cursor:pointer;
  transition:background .12s;
}
.data-table tbody tr:hover{background:#FBF6EA}
.data-table tbody tr:focus-visible{
  outline:2px solid var(--rose);outline-offset:-2px;
  background:#FBF6EA;
}

.cell-date{font-weight:600;color:var(--dark)}
.cell-id{font-size:11px;color:var(--gray);font-family:'Courier New',monospace;margin-top:2px}
.cell-preview{
  color:var(--dark);line-height:1.45;
  display:-webkit-box;
  -webkit-line-clamp:2;-webkit-box-orient:vertical;
  overflow:hidden;
}
.cell-empty{
  text-align:center;
  color:var(--gray);
  padding:36px 18px !important;
  font-style:italic;
}

/* =============== Pagination =============== */

.pagination{
  display:flex;justify-content:space-between;align-items:center;
  padding:12px 18px;
  background:var(--bg);
  border-top:1px solid var(--border);
  font-size:13px;
}
.pagination-info{color:var(--gray)}
.pagination-buttons{display:flex;gap:8px}

/* =============== Vue detail =============== */

.app-main-narrow{max-width:920px}

.back-link-wrap{margin-bottom:14px}
.back-link{
  display:inline-flex;align-items:center;
  font-size:13.5px;color:var(--rose-dark);
  padding:6px 0;
}
.back-link:hover{text-decoration:underline}

.loading-block{
  text-align:center;color:var(--gray);
  padding:60px 20px;font-style:italic;
}

.detail-header{
  display:flex;justify-content:space-between;align-items:flex-start;
  gap:16px;flex-wrap:wrap;
  margin-bottom:16px;
}
.detail-actions{
  display:flex;align-items:center;gap:10px;
  padding-top:6px;
}
.status-select{
  padding:9px 14px;font-size:14px;font-family:inherit;font-weight:600;
  background:var(--white);
  border:1.5px solid var(--border);
  border-radius:var(--radius-sm);
  color:var(--dark);cursor:pointer;
  min-width:200px;
}
.status-select:focus{
  outline:none;border-color:var(--rose);
  box-shadow:0 0 0 3px rgba(196,117,96,.15);
}
.status-saved{
  font-size:13px;color:var(--success);font-weight:600;
}

.danger-banner{
  background:#FBE9E7;
  border:1px solid #f5b5ad;
  border-left:4px solid var(--danger);
  color:var(--danger);
  padding:14px 18px;
  border-radius:var(--radius-sm);
  font-size:14px;
  margin-bottom:18px;
}

.meta-grid{
  display:grid;
  grid-template-columns:200px 1fr;
  gap:10px 18px;
  font-size:14px;
}
.meta-label{
  color:var(--gray);
  font-size:12.5px;font-weight:600;
  text-transform:uppercase;letter-spacing:.5px;
  padding-top:3px;
}
.meta-value{color:var(--dark);line-height:1.5}
.meta-empty{color:var(--gray);font-style:italic}

.chip{
  display:inline-block;
  background:var(--sand);
  color:var(--dark);
  font-size:12.5px;
  padding:3px 10px;
  border-radius:999px;
  margin:2px 4px 2px 0;
}

.long-text{
  background:var(--bg);
  padding:14px 16px;
  border-radius:var(--radius-sm);
  font-size:14.5px;
  line-height:1.65;
  color:var(--dark);
  white-space:pre-wrap;
  border-left:3px solid var(--gold);
}

.mono{
  font-family:'Courier New',monospace;
  font-size:12px;color:var(--gray);
}

.sr-only{
  position:absolute;width:1px;height:1px;
  padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);
  white-space:nowrap;border:0;
}

/* =============== Notes internes =============== */

.notes-list{margin-bottom:18px}
.notes-empty{
  color:var(--gray);font-size:13.5px;font-style:italic;
  padding:8px 0;
}

.note-item{
  background:var(--bg);
  border-left:3px solid var(--teal);
  border-radius:var(--radius-sm);
  padding:12px 14px;
  margin-bottom:10px;
}
.note-meta{
  display:flex;justify-content:space-between;align-items:center;
  font-size:12px;color:var(--gray);
  margin-bottom:6px;
}
.note-author{font-weight:600;color:var(--teal-dark)}
.note-body{
  font-size:14px;line-height:1.55;color:var(--dark);
}

.note-form textarea{
  width:100%;
  padding:11px 14px;
  font-size:14.5px;font-family:inherit;color:var(--dark);
  background:var(--white);
  border:1.5px solid var(--border);
  border-radius:var(--radius-sm);
  resize:vertical;min-height:80px;
  transition:border-color .15s,box-shadow .15s;
}
.note-form textarea:focus{
  outline:none;border-color:var(--rose);
  box-shadow:0 0 0 3px rgba(196,117,96,.15);
}
.note-form-actions{
  display:flex;align-items:center;gap:12px;
  margin-top:10px;
}
.note-saved{font-size:13px;color:var(--success);font-weight:600}

/* =============== Responsive =============== */

@media (max-width:760px){
  .meta-grid{grid-template-columns:1fr;gap:4px 0}
  .meta-label{padding-top:8px}
  .meta-value{padding-bottom:6px;border-bottom:1px solid var(--border)}
  .meta-grid > *:last-child{border-bottom:none}
  .detail-header{flex-direction:column}
  .detail-actions{padding-top:0}
  .status-select{min-width:0;width:100%}
  .data-table thead{display:none}
  .data-table tbody td{
    display:block;border:none;padding:6px 16px;
  }
  .data-table tbody tr{
    display:block;border-bottom:1px solid var(--border);
    padding:14px 0;
  }
}

@media (max-width:600px){
  .auth-card{padding:32px 22px}
  .auth-title{font-size:24px}
  .app-header{padding:12px 16px;flex-wrap:wrap;gap:10px}
  .app-nav a{padding:6px 10px;font-size:13px}
  .app-main{padding:22px 16px 40px}
  .card{padding:20px 18px}
  .page-title{font-size:26px}
  .filters{padding:14px 16px}
  .tabs{padding:4px}
  .tab{padding:8px 12px;font-size:13px}
}
