/* ============================================================
   PLATEFORME NAISSANCES SN – CSS v2
   Palette : vert sénégalais #009639, rouge #E31837, or #FDEF42
   ============================================================ */
:root{
  --vert:#009639;--vert-d:#006628;--vert-l:#e8f7ed;
  --rouge:#E31837;--rouge-d:#b8132c;
  --or:#FDEF42;--or-d:#d4bc00;
  --bleu:#0077b6;--violet:#6a0572;
  --dark:#1a2332;--text:#2c3e50;--muted:#6c757d;
  --border:#dee2e6;--bg:#f4f6f9;--white:#fff;
  --sb-w:250px;--topbar-h:58px;
  --sh-sm:0 2px 8px rgba(0,0,0,.06);
  --sh:0 4px 16px rgba(0,0,0,.1);
  --sh-lg:0 8px 32px rgba(0,0,0,.14);
  --r:10px;--r-lg:14px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{font-size:14.5px}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--text);min-height:100vh}
a{color:var(--vert);text-decoration:none}a:hover{color:var(--vert-d)}
h1,h2,h3,h4,h5{font-weight:700;line-height:1.25}

/* ── Sidebar ─────────────────────────────────────────────────*/
.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sb-w);background:var(--dark);display:flex;flex-direction:column;z-index:1000;overflow-y:auto;transition:transform .25s ease}
.sb-logo{padding:1rem 1.1rem;border-bottom:1px solid rgba(255,255,255,.07);display:flex}
.sb-logo a{display:flex;align-items:center;gap:.65rem;text-decoration:none}
.sb-icon{width:36px;height:36px;background:var(--vert);border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.sb-logo b{color:white;font-size:.85rem;display:block;line-height:1.2}
.sb-logo small{color:rgba(255,255,255,.4);font-size:.65rem;display:block}
.sb-user{padding:.85rem 1.1rem;border-bottom:1px solid rgba(255,255,255,.07);display:flex;align-items:center;gap:.6rem}
.sb-av{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:white;font-weight:700;font-size:.85rem;flex-shrink:0}
.sb-name{color:white;font-size:.82rem;font-weight:600}
.sb-role{font-size:.63rem;padding:.1rem .45rem;border-radius:20px;color:white;display:inline-block;margin-top:.15rem}
.sb-nav{flex:1;padding:.5rem 0}
.nav-sect{color:rgba(255,255,255,.28);font-size:.6rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:.85rem 1.1rem .25rem}
.nav-link{display:flex;align-items:center;gap:.65rem;padding:.55rem 1.1rem;color:rgba(255,255,255,.62);font-size:.81rem;border-left:3px solid transparent;transition:all .15s;text-decoration:none}
.nav-link i{width:15px;text-align:center;font-size:.82rem;opacity:.75}
.nav-link span{flex:1}
.nav-link:hover,.nav-link.active{color:white;background:rgba(255,255,255,.06);border-left-color:var(--vert)}
.nav-link.active{font-weight:600}
.nav-badge{background:var(--rouge);color:white;font-size:.6rem;padding:.1rem .4rem;border-radius:10px;font-weight:700}
.sb-foot{padding:.85rem 1.1rem;border-top:1px solid rgba(255,255,255,.07)}
.sb-logout{display:flex;align-items:center;gap:.55rem;color:rgba(255,255,255,.45);font-size:.8rem}
.sb-logout:hover{color:white}

/* ── Layout principal ────────────────────────────────────────*/
.main-wrap{margin-left:var(--sb-w);min-height:100vh;display:flex;flex-direction:column}
.topbar{height:var(--topbar-h);background:white;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:.75rem;padding:0 1.5rem;position:sticky;top:0;z-index:800;box-shadow:var(--sh-sm)}
.topbar-title{font-size:1rem;font-weight:700;color:var(--dark)}
.topbar-bread{font-size:.75rem;color:var(--muted);margin-top:.1rem}
.topbar-btn{width:32px;height:32px;border-radius:50%;border:1px solid var(--border);background:white;display:flex;align-items:center;justify-content:center;color:var(--muted);cursor:pointer;text-decoration:none;position:relative}
.topbar-btn:hover{background:var(--vert-l);color:var(--vert);border-color:var(--vert)}
.notif-dot{position:absolute;top:4px;right:4px;width:7px;height:7px;background:var(--rouge);border-radius:50%;border:2px solid white}
.content{padding:1.5rem;flex:1}

/* ── Cards ────────────────────────────────────────────────── */
.card{background:white;border-radius:var(--r-lg);border:1px solid var(--border);box-shadow:var(--sh-sm);overflow:hidden}
.card-hd{padding:1rem 1.25rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:.75rem}
.card-hd h4{font-size:.92rem;color:var(--dark);display:flex;align-items:center;gap:.5rem}
.card-hd h4 i{color:var(--vert)}
.card-bd{padding:1.25rem}

/* ── Stats cards ─────────────────────────────────────────── */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:1rem;margin-bottom:1.5rem}
.stat-card{background:white;border-radius:var(--r-lg);padding:1.1rem 1.25rem;border:1px solid var(--border);box-shadow:var(--sh-sm);display:flex;align-items:center;gap:.85rem;position:relative;overflow:hidden;transition:transform .15s,box-shadow .15s}
.stat-card:hover{transform:translateY(-2px);box-shadow:var(--sh)}
.stat-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px}
.stat-card.green::before{background:var(--vert)}
.stat-card.blue::before{background:var(--bleu)}
.stat-card.red::before{background:var(--rouge)}
.stat-card.purple::before{background:var(--violet)}
.stat-card.gold::before{background:var(--or-d)}
.stat-icon{width:44px;height:44px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}
.stat-icon.green{background:var(--vert-l);color:var(--vert)}
.stat-icon.blue{background:#e3f2fd;color:var(--bleu)}
.stat-icon.red{background:#fde8ec;color:var(--rouge)}
.stat-icon.purple{background:#f3e5f5;color:var(--violet)}
.stat-icon.gold{background:#fff9c4;color:var(--or-d)}
.stat-val{font-size:1.6rem;font-weight:900;color:var(--dark);line-height:1}
.stat-lbl{font-size:.72rem;color:var(--muted);margin-top:.2rem}

/* ── Tableau ─────────────────────────────────────────────── */
.tbl-wrap{overflow-x:auto}
table.tbl{width:100%;border-collapse:collapse;font-size:.83rem}
table.tbl thead th{background:var(--vert-l);color:var(--vert-d);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:.75rem .9rem;border-bottom:2px solid rgba(0,102,40,.15);white-space:nowrap}
table.tbl tbody tr{border-bottom:1px solid var(--border)}
table.tbl tbody tr:hover{background:rgba(0,150,57,.03)}
table.tbl tbody td{padding:.7rem .9rem;vertical-align:middle}
table.tbl tfoot td{background:var(--vert-l);font-weight:700;padding:.7rem .9rem;font-size:.82rem}

/* ── Formulaires ─────────────────────────────────────────── */
.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}
.fg{margin-bottom:1rem}
.fg label{display:block;font-size:.78rem;font-weight:600;color:var(--text);margin-bottom:.35rem}
.fg label .req{color:var(--rouge)}
.fc{width:100%;padding:.58rem .85rem;border:1.5px solid var(--border);border-radius:var(--r);font-size:.88rem;color:var(--text);background:white;font-family:inherit;transition:border .2s,box-shadow .2s}
.fc:focus{border-color:var(--vert);outline:none;box-shadow:0 0 0 3px rgba(0,150,57,.1)}
.fc.invalid{border-color:var(--rouge)}
.ft{font-size:.72rem;color:var(--muted);margin-top:.25rem}
select.fc{cursor:pointer}
textarea.fc{resize:vertical;min-height:90px}

/* ── Boutons ─────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.55rem 1.1rem;border-radius:var(--r);font-size:.85rem;font-weight:600;border:none;cursor:pointer;transition:all .15s;font-family:inherit;text-decoration:none;white-space:nowrap}
.btn-primary{background:var(--vert);color:white}.btn-primary:hover{background:var(--vert-d);color:white}
.btn-danger{background:var(--rouge);color:white}.btn-danger:hover{background:var(--rouge-d);color:white}
.btn-secondary{background:#e9ecef;color:var(--text)}.btn-secondary:hover{background:#dee2e6}
.btn-outline{background:transparent;border:1.5px solid var(--vert);color:var(--vert)}.btn-outline:hover{background:var(--vert);color:white}
.btn-sm{padding:.38rem .75rem;font-size:.78rem}
.btn-lg{padding:.75rem 1.6rem;font-size:.95rem}
.btn-block{width:100%;justify-content:center}
.btn:disabled{opacity:.6;cursor:not-allowed}

/* ── Badges ──────────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;gap:.25rem;padding:.18rem .55rem;border-radius:20px;font-size:.7rem;font-weight:700}
.bg-success,.badge-success{background:var(--vert-l);color:var(--vert-d)}
.bg-danger,.badge-danger{background:#fde8ec;color:var(--rouge-d)}
.bg-warning,.badge-warning{background:#fff9c4;color:#7a5800}
.text-dark{color:var(--dark)!important}
.bg-info,.badge-info{background:#e3f2fd;color:#0d47a1}
.badge-secondary{background:#e9ecef;color:#495057}
.badge-purple{background:#f3e5f5;color:#4a0072}

/* ── Alertes ─────────────────────────────────────────────── */
.alert{padding:.85rem 1.1rem;border-radius:var(--r);font-size:.86rem;display:flex;align-items:flex-start;gap:.65rem;margin-bottom:1rem}
.alert-success{background:var(--vert-l);color:var(--vert-d);border-left:4px solid var(--vert)}
.alert-danger,.alert-error{background:#fde8ec;color:var(--rouge-d);border-left:4px solid var(--rouge)}
.alert-warning{background:#fff9c4;color:#7a5800;border-left:4px solid var(--or-d)}
.alert-info{background:#e3f2fd;color:#0d47a1;border-left:4px solid #0d47a1}

/* ── Filtres bar ─────────────────────────────────────────── */
.filter-bar{background:white;border-radius:var(--r-lg);padding:1rem 1.25rem;margin-bottom:1.25rem;box-shadow:var(--sh-sm);border:1px solid var(--border)}
.filter-bar form{display:flex;gap:.75rem;flex-wrap:wrap;align-items:flex-end}
.filter-group{display:flex;flex-direction:column;gap:.28rem}
.filter-group label{font-size:.67rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}

/* ── Page header ─────────────────────────────────────────── */
.page-hd{margin-bottom:1.5rem}
.page-hd h2{font-size:1.3rem;color:var(--dark);margin-bottom:.2rem}
.page-hd p{color:var(--muted);font-size:.85rem}

/* ── Graphique container ─────────────────────────────────── */
.chart-wrap{position:relative;height:280px}

/* ── Pagination ──────────────────────────────────────────── */
.pagination{display:flex;gap:.35rem;justify-content:center;padding:.75rem 0}
.pagination a,.pagination span{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--r);border:1px solid var(--border);font-size:.82rem;color:var(--text)}
.pagination a:hover{background:var(--vert-l);border-color:var(--vert);color:var(--vert)}
.pagination .active{background:var(--vert);color:white;border-color:var(--vert)}

/* ── Numéro certificat ───────────────────────────────────── */
.cert-num{display:inline-flex;align-items:center;gap:.4rem;background:var(--vert-l);border:1.5px solid var(--vert);color:var(--vert-d);padding:.3rem .85rem;border-radius:6px;font-family:monospace;font-weight:700;font-size:.85rem;letter-spacing:.05em}

/* ── Row / Col ───────────────────────────────────────────── */
.row{display:flex;flex-wrap:wrap;gap:1.25rem;margin-bottom:1.25rem}
.col-4{flex:1 1 calc(33.3% - .83rem);min-width:220px}
.col-6{flex:1 1 calc(50% - .625rem);min-width:260px}
.col-8{flex:1 1 calc(66.6% - .625rem);min-width:300px}
.col-12{flex:1 1 100%}

/* ── Modal ───────────────────────────────────────────────── */
.modal-bg{position:fixed;inset:0;background:rgba(26,35,50,.6);display:flex;align-items:center;justify-content:center;z-index:2000;padding:1rem;backdrop-filter:blur(3px)}
.modal{background:white;border-radius:var(--r-lg);max-width:580px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--sh-lg);animation:fadeIn .25s ease}
.modal-hd{padding:1.1rem 1.25rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.modal-bd{padding:1.25rem}
.modal-ft{padding:.9rem 1.25rem;border-top:1px solid var(--border);display:flex;gap:.65rem;justify-content:flex-end}

@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ── Responsive ──────────────────────────────────────────── */
@media(max-width:1024px){
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0)}
  .main-wrap{margin-left:0}
}
@media(max-width:768px){
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .form-row{grid-template-columns:1fr}
  .col-4,.col-6,.col-8{flex:1 1 100%}
  .content{padding:1rem}
  .row{gap:.85rem}
}
@media(max-width:480px){
  .stats-grid{grid-template-columns:1fr}
  .topbar{padding:0 .9rem}
}

/* ── Impression ──────────────────────────────────────────── */
@media print{
  .sidebar,.topbar,.filter-bar,.btn,.pagination,.no-print{display:none!important}
  .main-wrap{margin-left:0!important}
  .content{padding:0!important}
}

/* ── Page connexion ──────────────────────────────────────── */
.login-page{min-height:100vh;display:grid;grid-template-columns:1.1fr 1fr}
.login-left{background:linear-gradient(145deg,var(--vert-d) 0%,var(--dark) 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;position:relative;overflow:hidden}
.login-left::after{content:'';position:absolute;bottom:0;left:0;right:0;height:5px;background:linear-gradient(90deg,var(--vert) 33.3%,var(--or) 33.3% 66.6%,var(--rouge) 66.6%)}
.login-right{display:flex;align-items:center;justify-content:center;padding:2rem;background:white}
.login-card{width:100%;max-width:400px}
@media(max-width:900px){.login-page{grid-template-columns:1fr}.login-left{display:none}}
