/* ---------- Thème clair – Sénégal ---------- */
:root{
  /* Palette Sénégal */
  --sn-green: #00853b;
  --sn-yellow:#fcd116;
  --sn-red:   #e31b23;

  /* Thème clair */
  --bg: #f8faf7;
  --panel: #ffffff;
  --panel-2: #f7f8fb;
  --text: #0f172a;
  --muted: #475569;
  --border: #e5e7eb;
  --shadow: 0 8px 24px rgba(0,0,0,.08);
  --radius: 14px;

  /* Accents */
  --brand: var(--sn-green);
  --brand-2: #2cab60;

  /* Alerts */
  --ok-bg:#e9f8ef; --ok:#066e31; 
  --ko-bg:#fdecec; --ko:#b42318;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background: var(--bg);
  color:var(--text);
  font:16px/1.55 system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, "Noto Sans", "Liberation Sans", sans-serif;
}

.container{max-width:1100px;margin:32px auto;padding:0 16px}

/* En-tête */
.header{
  display:flex;align-items:center;justify-content:space-between;
  margin:8px 0 18px 0; position: relative;
}
.header::after{
  content:""; position:absolute; left:0; right:0; bottom:-10px; height:4px;
  background: linear-gradient(90deg, var(--sn-green) 0 33.33%, var(--sn-yellow) 33.33% 66.66%, var(--sn-red) 66.66% 100%);
  border-radius: 999px;
}
.brand{font-weight:800;letter-spacing:.2px;font-size:22px}
.actions a,.actions button{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 14px;border-radius:12px;text-decoration:none;border:1px solid var(--border);
  background: var(--panel); color:var(--text);
  box-shadow: var(--shadow);
}
.actions a:hover{transform:translateY(-1px)}

/* Cartes / panneaux */
.card{
  background:
    radial-gradient(800px 500px at 0% -20%, rgba(0,133,59,.08), transparent),
    radial-gradient(800px 500px at 120% 20%, rgba(252,209,22,.10), transparent),
    var(--panel);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}

/* Alerts */
.alert{padding:12px 14px;border-radius:12px;margin:12px 0;border:1px solid transparent}
.alert.ok{background:var(--ok-bg); color:var(--ok); border-color:rgba(6,110,49,.25)}
.alert.ko{background:var(--ko-bg); color:var(--ko); border-color:rgba(180,35,24,.25)}

/* Formulaires */
form.form{display:grid;gap:14px;padding:18px}
label span{display:block;margin-bottom:6px;color:var(--muted);font-size:14px}
input[type="file"], select, textarea{
  width:100%; padding:12px 12px; border-radius:12px;
  border:1px solid var(--border); background:var(--panel-2); color:var(--text);
}
textarea{min-height:110px;resize:vertical}
.btn{
  padding:12px 16px;border-radius:12px;border:1px solid var(--border);
  background:linear-gradient(180deg, var(--brand), var(--brand-2));
  color:white; font-weight:700; cursor:pointer;
  box-shadow: var(--shadow);
}
.btn:hover{filter:brightness(1.03); transform:translateY(-1px)}
.btn.danger{
  background: linear-gradient(180deg, #ff5a5f, var(--sn-red));
  color: #fff;
}

/* Table */
.table-wrap{overflow:auto;border-radius:var(--radius);border:1px solid var(--border)}
table{width:100%;border-collapse:collapse;background:var(--panel)}
th,td{padding:12px 14px;border-bottom:1px solid var(--border);vertical-align:top}
th{position:sticky;top:0;background:var(--panel-2);text-align:left;font-weight:700;color:#2f3b52}
tbody tr:hover{background:#f6f7fb}
.badge{
  display:inline-block;padding:4px 8px;border-radius:999px;
  background:rgba(252,209,22,.18);
  border:1px solid rgba(252,209,22,.45);
  color:#1f2937;font-size:12px;font-weight:600;
}

/* Helpers */
.muted{color:var(--muted)}
.right{display:flex;gap:10px}
.comment{max-width:420px;white-space:pre-wrap;word-wrap:break-word}
.center{max-width:420px;margin:12vh auto}

/* Responsive */
@media (max-width:720px){
  .header{flex-direction:column;gap:10px;align-items:flex-start}
}