/* COMPONENTS CSS v2 — Mobile First */
.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:var(--radius-sm);font-size:14px;font-weight:500;cursor:pointer;transition:all 0.2s;border:none;font-family:inherit;text-decoration:none;white-space:nowrap;}
.btn-primary{background:var(--primary);color:#fff;}
.btn-primary:hover{background:var(--primary-light);color:#fff;}
.btn-secondary{background:var(--bg-gray);color:var(--text);border:1px solid var(--border);}
.btn-secondary:hover{background:var(--border);}
.btn-success{background:#1a7a4a;color:#fff;}
.btn-success:hover{background:#15623c;color:#fff;}
.btn-danger{background:var(--red);color:#fff;}
.btn-danger:hover{background:#a93226;color:#fff;}
.btn-warning{background:var(--orange);color:#fff;}
.btn-sm{padding:5px 12px;font-size:12px;}
.btn-lg{padding:12px 28px;font-size:15px;}
.btn-block{width:100%;justify-content:center;}

.form-group{margin-bottom:18px;}
.form-label{display:block;margin-bottom:6px;font-size:14px;font-weight:600;color:var(--text);}
.form-label .req{color:var(--red);}
.form-control{width:100%;padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;transition:border-color 0.2s;outline:none;background:#fff;color:var(--text);}
.form-control:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(26,92,56,.12);}
.form-control:disabled{background:var(--bg-gray);opacity:.7;}
.form-help{font-size:12px;color:var(--text-muted);margin-top:4px;}
.form-error{font-size:12px;color:var(--red);margin-top:4px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;}

.card{background:#fff;border-radius:var(--radius-lg);padding:22px;box-shadow:var(--shadow-sm);border:1px solid var(--border);}
.card-header{padding-bottom:14px;border-bottom:1px solid var(--border);margin-bottom:18px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;}
.card-title{font-size:16px;font-weight:700;color:var(--primary);}

.alert{padding:13px 16px;border-radius:var(--radius-sm);font-size:14px;margin-bottom:16px;display:flex;align-items:flex-start;gap:10px;line-height:1.5;}
.alert-success{background:#e8f5ee;color:#1a5c38;border-left:4px solid var(--primary);}
.alert-danger{background:var(--red-light);color:var(--red);border-left:4px solid var(--red);}
.alert-warning{background:#fff8e8;color:#865500;border-left:4px solid var(--orange);}
.alert-info{background:var(--primary-xlight);color:var(--primary);border-left:4px solid var(--primary);}

.badge{padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;display:inline-block;}
.badge-success{background:#e8f5ee;color:#1a5c38;}
.badge-danger{background:var(--red-light);color:var(--red);}
.badge-warning{background:#fff8e8;color:#865500;}
.badge-info{background:var(--primary-xlight);color:var(--primary);}

.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;}
.stat-card{background:#fff;border-radius:var(--radius-lg);padding:18px;border:1px solid var(--border);box-shadow:var(--shadow-sm);}
.stat-card-icon{font-size:26px;margin-bottom:8px;}
.stat-card-value{font-size:26px;font-weight:800;color:var(--primary);}
.stat-card-label{font-size:12px;color:var(--text-muted);margin-top:4px;}

.table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border);}
table{width:100%;border-collapse:collapse;}
th{background:var(--primary-xlight);padding:11px 14px;text-align:left;font-size:11px;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:.4px;border-bottom:1px solid var(--border);white-space:nowrap;}
td{padding:12px 14px;font-size:14px;border-bottom:1px solid var(--border);}
tr:last-child td{border-bottom:none;}
tr:hover td{background:var(--bg-gray);}

.upload-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:24px;text-align:center;cursor:pointer;transition:all 0.2s;background:var(--bg-gray);}
.upload-zone:hover{border-color:var(--primary);background:var(--primary-xlight);}

.countdown-big{display:flex;gap:12px;justify-content:center;margin:16px 0;flex-wrap:wrap;}
.countdown-unit{text-align:center;background:var(--primary);color:#fff;padding:14px 18px;border-radius:var(--radius);min-width:65px;}
.countdown-unit .val{font-size:28px;font-weight:700;line-height:1;}
.countdown-unit .lbl{font-size:10px;opacity:.8;margin-top:4px;}

/* ===== MOBILE RESPONSIVE ===== */
@media(max-width:1024px){.form-row-3{grid-template-columns:1fr 1fr;}}
@media(max-width:768px){
  .form-row,.form-row-3{grid-template-columns:1fr;}
  .stats-grid{grid-template-columns:repeat(2,1fr);}
  .card{padding:16px;}
  /* Table responsive */
  .resp-table .table-wrap{border:none;}
  .resp-table table,.resp-table thead,.resp-table tbody,.resp-table th,.resp-table td,.resp-table tr{display:block;}
  .resp-table thead tr{position:absolute;top:-9999px;left:-9999px;}
  .resp-table tr{border:1px solid var(--border);border-radius:var(--radius);margin-bottom:10px;padding:12px;}
  .resp-table td{border:none;padding:6px 0;font-size:13px;display:flex;gap:8px;}
  .resp-table td::before{content:attr(data-label);font-weight:600;font-size:11px;color:var(--text-muted);min-width:80px;text-transform:uppercase;}
  .resp-table tr:hover td{background:transparent;}
}
@media(max-width:480px){
  .stats-grid{grid-template-columns:repeat(2,1fr);}
  .card{padding:14px;border-radius:var(--radius);}
  .btn-lg{padding:11px 18px;font-size:14px;}
  .annonce-card{padding:14px;}
  .annonce-title{font-size:13px;}
  .type-card{padding:14px 10px;}
  .type-card-count{font-size:22px;}
  .type-card-name{font-size:11px;}
  .hero h1{font-size:22px !important;}
  .hero-sub{font-size:14px !important;}
  .hero-badge{font-size:11px;padding:5px 12px;}
  .search-bar input{padding:9px 12px;font-size:14px;}
  .search-bar button{padding:9px 18px;font-size:13px;}
  .stat-item{padding:12px 8px;}
  .stat-number{font-size:20px;}
  .stat-label{font-size:10px;}
  .sidebar-nav a{padding:10px 10px;font-size:13px;}
  .dashboard-layout{padding:12px;gap:12px;}
  .footer-bottom .footer-container{grid-template-columns:1fr;gap:6px;text-align:center;}
}
@media(max-width:360px){
  .types-grid-4x4{grid-template-columns:repeat(2,1fr);gap:8px;}
  .nav-logo-text strong{font-size:14px;}
  .btn-accent,.btn-outline-nav{padding:6px 12px;font-size:12px;}
}
@media(hover:none){
  .annonce-card:hover,.type-card:hover,.secteur-card:hover{transform:none;}
}
@media print{
  .navbar,.bandeau-wrap,.footer,.btn,.sidebar{display:none!important;}
  .dashboard-layout{grid-template-columns:1fr!important;}
  .card{box-shadow:none!important;}
}

/* RTL */
[dir="rtl"] .alert{border-left:none;border-right:4px solid;}
[dir="rtl"] .sidebar-nav a.active{border-left:none;border-right:3px solid var(--primary);}
[dir="rtl"] th,[dir="rtl"] td{text-align:right;}
[dir="rtl"] .search-bar select{border-left:none;border-right:1.5px solid var(--border);}

/* ============================================================
   COMPOSANTS v21 — Améliorations UX
   ============================================================ */

/* Badges améliorés */
.badge-blue   { background:var(--blue);  color:#fff; }
.badge-purple { background:#7c3aed;      color:#fff; }

/* Bouton loading */
.btn.loading { opacity:.7; pointer-events:none; }
.btn.loading::after { content:'...'; margin-left:4px; }

/* Stats card améliorée */
.stat-card {
  background:#fff;
  border-radius:var(--radius-lg);
  padding:18px 20px;
  border:1px solid var(--border);
  box-shadow:var(--shadow-sm);
  display:flex;
  flex-direction:column;
  gap:6px;
  transition:all .2s;
  border-left:4px solid var(--primary);
}
.stat-card:hover { box-shadow:var(--shadow); transform:translateY(-1px); }
.stat-card-icon { font-size:26px; }
.stat-card-value { font-size:28px; font-weight:800; color:var(--primary); line-height:1.1; }
.stat-card-label { font-size:12px; color:var(--text-muted); font-weight:500; text-transform:uppercase; letter-spacing:.4px; }

/* Alert améliorée */
.alert { padding:14px 18px; border-radius:var(--radius); font-size:14px; border-left:4px solid; margin-bottom:16px; }
.alert-success { background:#e8f5ee; border-color:var(--green); color:#0d5229; }
.alert-danger  { background:#fdf0ef; border-color:var(--red); color:#7b1d1d; }
.alert-warning { background:#fff8e8; border-color:var(--orange); color:#7a4700; }
.alert-info    { background:#e8f4fb; border-color:var(--blue); color:#0d3d5c; }

/* Annonce card grid layout */
.annonces-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(340px,1fr));
  gap:16px;
}
.annonce-card {
  background:#fff;
  border-radius:var(--radius-lg);
  border:1px solid var(--border);
  padding:18px;
  display:flex;
  flex-direction:column;
  gap:10px;
  transition:all .2s;
  box-shadow:var(--shadow-sm);
}
.annonce-card:hover { box-shadow:var(--shadow); border-color:var(--primary); transform:translateY(-1px); }
.annonce-card-header { display:flex; align-items:center; justify-content:space-between; }
.annonce-badge { padding:3px 10px; border-radius:10px; font-size:11px; font-weight:700; color:#fff; }
.annonce-fav { background:none; border:none; cursor:pointer; font-size:18px; color:var(--text-muted); transition:.15s; padding:2px 6px; border-radius:6px; }
.annonce-fav:hover { color:var(--red); background:#fdf0ef; }
.annonce-fav.active { color:var(--red); }
.annonce-title { font-size:15px; font-weight:700; color:var(--text); text-decoration:none; line-height:1.45; }
.annonce-title:hover { color:var(--primary); }
.annonce-meta { display:flex; flex-wrap:wrap; gap:6px; margin-top:2px; }
.annonce-meta-item { font-size:12px; color:var(--text-muted); display:flex; align-items:center; gap:3px; }
.annonce-countdown { font-size:13px; font-weight:600; padding:6px 12px; border-radius:8px; text-align:center; margin-top:4px; }
.annonce-countdown.green  { background:#e8f5ee; color:var(--green); }
.annonce-countdown.orange { background:#fff8e8; color:var(--orange); }
.annonce-countdown.red    { background:#fdf0ef; color:var(--red); }
.annonce-countdown.grey   { background:var(--bg-light); color:var(--text-muted); }
.annonce-actions { display:flex; gap:8px; margin-top:auto; padding-top:10px; border-top:1px solid var(--border); }
.annonce-actions .btn { flex:1; justify-content:center; font-size:12px; padding:7px 10px; }

/* Notification badge */
.notif-badge {
  background:var(--red);
  color:#fff;
  font-size:10px;
  font-weight:700;
  padding:1px 5px;
  border-radius:10px;
  margin-left:2px;
  vertical-align:top;
  margin-top:-2px;
  display:inline-block;
}

/* Form improvements */
.form-control:focus { outline:none; border-color:var(--primary); box-shadow:0 0 0 3px rgba(26,92,56,.12); }
.form-label { font-size:13px; font-weight:600; color:var(--text); margin-bottom:5px; display:block; }
.form-hint  { font-size:11px; color:var(--text-muted); margin-top:3px; }
.form-group { display:flex; flex-direction:column; margin-bottom:0; }

/* Annonces sidebar layout fix */
.annonces-layout {
  display:grid;
  grid-template-columns:240px 1fr;
  gap:20px;
  align-items:start;
}
.annonces-sidebar { position:sticky; top:88px; }

/* Password strength */
.pwd-strength { height:4px; border-radius:2px; margin-top:6px; transition:.3s; }
.pwd-strength.weak   { background:var(--red);    width:33%; }
.pwd-strength.medium { background:var(--orange); width:66%; }
.pwd-strength.strong { background:var(--green);  width:100%; }

/* Print styles */
@media print {
  .navbar, .sidebar, footer, .btn, .nav-actions { display:none !important; }
  .dashboard-layout { grid-template-columns:1fr; }
  .card { box-shadow:none; border:1px solid #ddd; }
}

/* Mobile full-width */
@media(max-width:768px) {
  .annonces-grid { grid-template-columns:1fr; }
  .annonces-layout { grid-template-columns:1fr; }
  .annonces-sidebar { position:static; }
  .stat-card-value { font-size:22px; }
}
