/*
 * MSE BENIN — Feuille de style principale
 * Couleurs : Teal #0F6E56 | Blanc #FFFFFF | Ardoise #546E7A
 */

/* ─── VARIABLES ───────────────────────────────────────────────────────────── */
:root {
    --mse-teal:       #0F6E56;
    --mse-teal-light: #1D9E75;
    --mse-teal-pale:  #E1F5EE;
    --mse-slate:      #546E7A;
    --mse-slate-light:#90A4AE;
    --mse-orange:     #D85A30;
    --mse-white:      #FFFFFF;
    --mse-bg:         #F5F7F6;
    --mse-border:     #D0E4DD;
    --mse-shadow:     0 2px 8px rgba(15,110,86,.10);
    --mse-radius:     10px;
    --mse-font:       'Segoe UI', Arial, sans-serif;
}

/* ─── BASE ─────────────────────────────────────────────────────────────────── */
.mse-container { font-family: var(--mse-font); color: #2d3a35; }

/* ─── CARTES ───────────────────────────────────────────────────────────────── */
.mse-card {
    background: var(--mse-white);
    border-radius: var(--mse-radius);
    border: 1px solid var(--mse-border);
    padding: 24px;
    box-shadow: var(--mse-shadow);
}
.mse-card h3 {
    color: var(--mse-teal);
    margin: 0 0 16px;
    font-size: 1.05em;
    border-bottom: 2px solid var(--mse-teal-pale);
    padding-bottom: 8px;
}

/* ─── DASHBOARD GRID ────────────────────────────────────────────────────────── */
.mse-dashboard-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(340px, 1fr));
    gap: 20px;
    margin-top: 20px;
}
.mse-card-full { grid-column: 1 / -1; }

/* ─── BARRE DE BIENVENUE ─────────────────────────────────────────────────────── */
.mse-welcome-bar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: linear-gradient(135deg, var(--mse-teal), var(--mse-teal-light));
    color: #fff;
    padding: 20px 24px;
    border-radius: var(--mse-radius);
    margin-bottom: 4px;
}
.mse-welcome-bar h2 { margin: 0 0 4px; font-size: 1.3em; }
.mse-welcome-bar p  { margin: 0; opacity: 0.9; font-size: 0.9em; }

/* ─── BADGES ────────────────────────────────────────────────────────────────── */
.badge-ok   { background:#E1F5EE; color:#0F6E56; padding:2px 8px; border-radius:20px; font-size:.8em; font-weight:600; }
.badge-warn { background:#FEF3E2; color:#BA7517; padding:2px 8px; border-radius:20px; font-size:.8em; font-weight:600; }
.badge-actif    { background:#E1F5EE; color:#0F6E56; padding:2px 8px; border-radius:12px; font-size:.8em; }
.badge-confirme { background:#E1F5EE; color:#0F6E56; padding:2px 8px; border-radius:12px; font-size:.8em; }
.badge-en_attente { background:#FEF3E2; color:#BA7517; padding:2px 8px; border-radius:12px; font-size:.8em; }
.badge-echoue   { background:#FCEAEA; color:#A32D2D; padding:2px 8px; border-radius:12px; font-size:.8em; }

/* ─── CARTE DIGITALE ─────────────────────────────────────────────────────────── */
.mse-carte-digitale {
    background: linear-gradient(135deg, #0F6E56 0%, #085041 100%);
    border-radius: 12px;
    color: #fff;
    padding: 20px;
    min-height: 160px;
    position: relative;
    overflow: hidden;
}
.mse-carte-digitale::after {
    content: '';
    position: absolute;
    top: -40px; right: -40px;
    width: 130px; height: 130px;
    border-radius: 50%;
    background: rgba(255,255,255,.06);
}
.mse-carte-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
}
.mse-carte-logo   { font-weight: 700; font-size: 1.1em; letter-spacing: 1px; }
.mse-carte-forfait { background:rgba(255,255,255,.2); padding:3px 10px; border-radius:20px; font-size:.8em; }
.mse-carte-num    { font-size: 1.3em; font-weight: 700; letter-spacing: 2px; margin-bottom: 6px; }
.mse-carte-nom    { font-size: .95em; text-transform: uppercase; letter-spacing: 1px; }
.mse-carte-ville  { font-size: .8em; opacity: .8; margin-top: 2px; }
.mse-carte-footer {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    margin-top: 16px;
}
.mse-carte-statut.ok   { background:rgba(255,255,255,.2); color:#fff; padding:3px 10px; border-radius:20px; font-size:.8em; }
.mse-carte-statut.warn { background:rgba(216,90,48,.4);   color:#fff; padding:3px 10px; border-radius:20px; font-size:.8em; }

/* ─── BARRE DE PROGRESSION ───────────────────────────────────────────────────── */
.mse-progress-label { display:flex; justify-content:space-between; font-size:.85em; margin-bottom:6px; color:var(--mse-slate); }
.mse-progress-bar-wrap {
    height: 12px; background: #E1F5EE; border-radius: 6px; overflow: hidden; margin-bottom: 8px;
}
.mse-progress-bar { height: 100%; border-radius: 6px; transition: width .5s ease; }
.mse-reste   { font-size:.9em; color:var(--mse-slate); }
.mse-alerte  { color: var(--mse-orange); font-size:.85em; margin-top:6px; }

/* ─── FORMULAIRE ─────────────────────────────────────────────────────────────── */
.mse-progress {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0;
    margin-bottom: 32px;
    flex-wrap: wrap;
    gap: 4px;
}
.mse-step {
    display: flex; align-items: center; gap: 8px;
    color: var(--mse-slate-light); font-size: .85em;
}
.mse-step.active { color: var(--mse-teal); font-weight: 600; }
.mse-step.done   { color: var(--mse-teal-light); }
.mse-step-num {
    width: 28px; height: 28px; border-radius: 50%;
    background: var(--mse-slate-light); color: #fff;
    display: flex; align-items: center; justify-content: center;
    font-size: .8em; font-weight: 700; flex-shrink: 0;
}
.mse-step.active .mse-step-num { background: var(--mse-teal); }
.mse-step.done   .mse-step-num { background: var(--mse-teal-light); }
.mse-step-line { width: 40px; height: 2px; background: var(--mse-border); }

.mse-field { display:flex; flex-direction:column; gap:6px; }
.mse-field label { font-size:.85em; font-weight:600; color:var(--mse-slate); }
.mse-field input, .mse-field select, .mse-field textarea {
    padding: 10px 14px;
    border: 1px solid var(--mse-border);
    border-radius: 8px;
    font-size: 1em;
    outline: none;
    transition: border-color .2s;
}
.mse-field input:focus, .mse-field select:focus {
    border-color: var(--mse-teal);
    box-shadow: 0 0 0 3px rgba(15,110,86,.12);
}
.req { color: var(--mse-orange); }
.mse-grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.mse-col-2  { grid-column: 1 / -1; }

/* ─── FORFAITS ───────────────────────────────────────────────────────────────── */
.mse-forfaits { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.mse-forfait-card {
    border: 2px solid var(--mse-border);
    border-radius: 12px; padding:20px; cursor:pointer;
    transition: all .2s;
}
.mse-forfait-card:hover  { border-color: var(--mse-teal); transform: translateY(-2px); }
.mse-forfait-card.selected { border-color: var(--mse-teal); background: var(--mse-teal-pale); }
.mse-forfait-badge  { font-weight:700; color:var(--mse-teal); font-size:1.1em; margin-bottom:6px; }
.mse-badge-premium  { color:#0C447C; }
.mse-forfait-plafond{ font-size:.8em; color:var(--mse-slate); margin-bottom:10px; }
.mse-forfait-card ul { padding-left:16px; font-size:.85em; color:var(--mse-slate); }
.mse-prix { font-weight:700; color:var(--mse-teal); margin-top:10px; }
.mse-radio-group { display:flex; gap:20px; flex-wrap:wrap; }
.mse-radio-group label { cursor:pointer; font-size:.9em; }

/* ─── ZONE UPLOAD ────────────────────────────────────────────────────────────── */
.mse-upload-zone {
    border: 2px dashed var(--mse-border); border-radius: 8px; padding:20px;
    text-align:center; cursor:pointer; color:var(--mse-slate); font-size:.9em;
    transition: border-color .2s;
}
.mse-upload-zone:hover { border-color: var(--mse-teal); background: var(--mse-teal-pale); }

/* ─── BOUTONS ────────────────────────────────────────────────────────────────── */
.mse-btn {
    padding: 11px 24px; border-radius: 8px; font-size:1em; font-weight:600;
    cursor:pointer; border:none; transition:all .2s; display:inline-flex;
    align-items:center; gap:8px;
}
.mse-btn-primary { background:var(--mse-teal); color:#fff; }
.mse-btn-primary:hover { background:var(--mse-teal-light); }
.mse-btn-next    { background:var(--mse-teal); color:#fff; }
.mse-btn-next:hover { background:var(--mse-teal-light); }
.mse-btn-back    { background:var(--mse-bg); color:var(--mse-slate); border:1px solid var(--mse-border); }
.mse-btn-outline { background:transparent; color:var(--mse-teal); border:2px solid var(--mse-teal); }
.mse-btn-outline:hover { background:var(--mse-teal-pale); }
.mse-btn-lg  { padding:14px 32px; font-size:1.05em; }
.mse-btn-sm  { padding:7px 14px; font-size:.85em; }
.mse-btn-group { display:flex; gap:12px; margin-top:20px; }

/* ─── MESSAGES ───────────────────────────────────────────────────────────────── */
.mse-messages { padding:12px 16px; border-radius:8px; margin:12px 0; font-size:.9em; }
.mse-error    { background:#FCEAEA; color:#A32D2D; border-left:4px solid #A32D2D; }
.mse-success  { background:#E1F5EE; color:#0F6E56; border-left:4px solid #0F6E56; }

/* ─── RÉCAP ──────────────────────────────────────────────────────────────────── */
.mse-recap-box {
    background:var(--mse-teal-pale); border-left:4px solid var(--mse-teal);
    padding:16px; border-radius:0 8px 8px 0; margin:16px 0;
}
.mse-recap-box h4 { margin:0 0 8px; color:var(--mse-teal); }
.mse-recap-box p  { margin:4px 0; font-size:.9em; }

/* ─── TABLEAU ────────────────────────────────────────────────────────────────── */
.mse-table { width:100%; border-collapse:collapse; font-size:.87em; }
.mse-table th { background:var(--mse-teal-pale); color:var(--mse-teal); padding:10px; text-align:left; font-weight:600; }
.mse-table td { padding:9px 10px; border-bottom:1px solid var(--mse-border); }
.mse-table tr:last-child td { border-bottom:none; }

/* ─── VÉRIFICATION PARTENAIRE ────────────────────────────────────────────────── */
.mse-verif-result { padding:16px; border-radius:8px; font-size:.9em; }
.mse-eligible   { background:#E1F5EE; border:1px solid #1D9E75; }
.mse-ineligible { background:#FCEAEA; border:1px solid #D85A30; }
.mse-verif-header { font-weight:700; font-size:1em; margin-bottom:8px; }
.mse-verif-detail p { margin:3px 0; }

/* ─── INFO BOX ───────────────────────────────────────────────────────────────── */
.mse-info-box { background:var(--mse-teal-pale); padding:12px 16px; border-radius:8px; font-size:.9em; }
.mse-info-box p { margin:4px 0; }

/* ─── BÉNÉFICIAIRES ──────────────────────────────────────────────────────────── */
.mse-beneficiaires-liste { list-style:none; padding:0; margin:0; }
.mse-beneficiaires-liste li {
    display:flex; align-items:center; gap:10px;
    padding:8px 0; border-bottom:1px solid var(--mse-border);
    font-size:.9em;
}
.mse-lien-badge { background:var(--mse-teal); color:#fff; padding:2px 8px; border-radius:12px; font-size:.75em; text-transform:capitalize; flex-shrink:0; }
.mse-ddn { color:var(--mse-slate-light); font-size:.8em; margin-left:auto; }

/* ─── STAT PILLS ─────────────────────────────────────────────────────────────── */
.mse-stat-pill { background:var(--mse-bg); border:1px solid var(--mse-border); padding:8px 14px; border-radius:20px; font-size:.85em; }
.mse-stat-pill.ok   { background:var(--mse-teal-pale); border-color:var(--mse-teal-light); color:var(--mse-teal); }
.mse-stat-pill.warn { background:#FEF3E2; border-color:#BA7517; color:#BA7517; }
.mse-calc-result { padding:10px 14px; background:var(--mse-teal-pale); border-radius:8px; font-weight:700; color:var(--mse-teal); }

/* ─── RESPONSIVE ─────────────────────────────────────────────────────────────── */
@media (max-width: 640px) {
    .mse-grid-2    { grid-template-columns: 1fr; }
    .mse-forfaits  { grid-template-columns: 1fr; }
    .mse-dashboard-grid { grid-template-columns: 1fr; }
    .mse-welcome-bar { flex-direction:column; gap:12px; text-align:center; }
    .mse-btn-group { flex-direction:column; }
}

/* ─── SECTION PANIERS DE SOINS ─────────────────────────────────────────────── */
.mse-paniers-section { padding: 40px 0; }
.mse-paniers-intro   { text-align:center; margin-bottom:32px; }
.mse-paniers-intro h2{ color:var(--mse-teal); font-size:1.8em; margin-bottom:10px; }
.mse-paniers-intro p { color:var(--mse-slate); max-width:600px; margin:0 auto 20px; }

/* Onglets */
.mse-paniers-tabs    { display:flex; justify-content:center; gap:8px; flex-wrap:wrap; }
.mse-tab {
    padding:9px 20px; border-radius:24px; border:2px solid var(--mse-border);
    background:transparent; cursor:pointer; font-size:.9em; font-weight:600;
    color:var(--mse-slate); transition:all .2s;
}
.mse-tab:hover  { border-color:var(--mse-teal); color:var(--mse-teal); }
.mse-tab.active { background:var(--mse-teal); border-color:var(--mse-teal); color:#fff; }

/* Grille paniers */
.mse-paniers-grid {
    display:grid;
    grid-template-columns:repeat(auto-fit, minmax(270px, 1fr));
    gap:20px; margin-top:24px;
}

/* Carte panier */
.mse-panier-card {
    background:var(--mse-white); border:1px solid var(--mse-border);
    border-radius:14px; padding:24px 20px; position:relative;
    display:flex; flex-direction:column; gap:14px;
    box-shadow:var(--mse-shadow); transition:transform .2s, box-shadow .2s;
}
.mse-panier-card:hover { transform:translateY(-4px); box-shadow:0 8px 24px rgba(15,110,86,.15); }
.mse-panier-featured {
    border:2px solid var(--mse-teal);
    box-shadow:0 4px 20px rgba(15,110,86,.2);
}
.mse-panier-badge {
    position:absolute; top:-12px; left:50%; transform:translateX(-50%);
    background:var(--mse-teal); color:#fff; font-size:.75em; font-weight:700;
    padding:4px 14px; border-radius:20px; white-space:nowrap;
}

.mse-panier-top      { text-align:center; }
.mse-panier-icone    { font-size:2em; margin-bottom:6px; }
.mse-panier-nom      { font-size:1.2em; font-weight:700; color:var(--mse-teal); }
.mse-panier-cible    { font-size:.78em; color:var(--mse-slate-light); margin-top:2px; }

.mse-panier-prix     { text-align:center; }
.mse-panier-montant  { font-size:2em; font-weight:700; color:var(--mse-teal); }
.mse-panier-devise   { font-size:.85em; color:var(--mse-slate); }

/* Méta infos */
.mse-panier-meta     { display:grid; grid-template-columns:1fr 1fr; gap:8px; }
.mse-panier-meta-item{
    background:var(--mse-bg); border-radius:8px; padding:8px 10px; text-align:center;
}
.mse-meta-label      { display:block; font-size:.7em; color:var(--mse-slate-light); margin-bottom:2px; }
.mse-meta-val        { font-size:.85em; font-weight:700; color:var(--mse-teal); }
.mse-taux-70         { color:#BA7517 !important; }
.mse-taux-80         { color:#185FA5 !important; }
.mse-taux-90         { color:#0F6E56 !important; }

/* Soins couverts */
.mse-panier-soins    { flex:1; }
.mse-soins-titre     { font-size:.8em; font-weight:700; color:var(--mse-slate); text-transform:uppercase;
                        letter-spacing:.5px; margin-bottom:8px; }
.mse-panier-soins ul { list-style:none; padding:0; margin:0; }
.mse-panier-soins li { display:flex; align-items:flex-start; gap:6px; font-size:.82em;
                        padding:4px 0; border-bottom:1px solid var(--mse-border); }
.mse-panier-soins li:last-child { border-bottom:none; }
.mse-soin-check      { color:var(--mse-teal); flex-shrink:0; font-size:.9em; }
.mse-soin-nom        { flex:1; color:var(--mse-slate); }
.mse-soin-plafond    { font-size:.75em; color:var(--mse-slate-light); text-align:right;
                        flex-shrink:0; max-width:100px; }
.mse-plus            { color:var(--mse-teal) !important; font-style:italic; }

.mse-panier-frais    { text-align:center; font-size:.8em; color:var(--mse-slate-light); }
.mse-btn-panier      { text-align:center; text-decoration:none; width:100%; box-sizing:border-box;
                        justify-content:center; }

/* Règles */
.mse-regles-big      { padding:24px; }
.mse-regles-big h3   { color:var(--mse-teal); margin:0 0 16px; }
.mse-regles-big ul   { list-style:none; padding:0; margin:0; }
.mse-regles-big li   { padding:8px 0; border-bottom:1px solid var(--mse-border); font-size:.9em; }
.mse-regles-big li:last-child { border-bottom:none; }

/* Calcul box */
.mse-calcul-box {
    background:var(--mse-teal-pale); border:1px solid var(--mse-teal);
    border-radius:10px; padding:20px; margin-top:20px;
}
.mse-calcul-box h4   { margin:0 0 12px; color:var(--mse-teal); }
.mse-calcul-grid     { display:grid; grid-template-columns:auto auto; gap:6px 20px;
                        align-items:center; font-size:.9em; }
.mse-calcul-grid .mse-total { font-size:1em; font-weight:700; color:var(--mse-teal);
                               border-top:1px solid var(--mse-teal); padding-top:8px; margin-top:4px; }
.mse-badge-count     { background:var(--mse-teal); color:#fff; padding:1px 7px;
                        border-radius:12px; font-size:.75em; margin-left:4px; }

/* Tableau règles générales */
.mse-carence-tableau { margin-top:24px; }
.mse-carence-tableau h4 { color:var(--mse-teal); margin-bottom:12px; }
.mse-table-scroll    { overflow-x:auto; }
.mse-table-paniers   { min-width:480px; }
.mse-regles-box ul   { padding-left:0; list-style:none; }
.mse-regles-box li   { padding:5px 0; font-size:.9em; }

/* Responsive */
@media (max-width:768px) {
    .mse-paniers-grid { grid-template-columns:1fr; }
    .mse-panier-meta  { grid-template-columns:1fr 1fr; }
}
