/* ================================================================
   MSN Hors Cote — Public Stylesheet
   ================================================================ */
:root{
  --msn-gold:#c8a84b;
  --msn-gold-light:#f5d98a;
  --msn-dark:#1a1a2e;
  --msn-dark2:#16213e;
  --msn-blue:#0f3460;
  --msn-white:#ffffff;
  --msn-bg:#f8f6f0;
  --msn-border:#e0d8c0;
  --msn-text:#333;
  --msn-text-muted:#777;
  --msn-success:#2ecc71;
  --msn-warning:#f39c12;
  --msn-danger:#e74c3c;
  --msn-radius:10px;
  --msn-shadow:0 4px 24px rgba(0,0,0,.08);
  --msn-font:'Inter',system-ui,-apple-system,sans-serif;
}
*{box-sizing:border-box}
.msn-section-title{font-size:1.8rem;font-weight:700;color:var(--msn-dark);margin-bottom:1.5rem;position:relative;padding-bottom:.5rem}
.msn-section-title::after{content:'';display:block;width:60px;height:3px;background:var(--msn-gold);position:absolute;bottom:0;left:0;border-radius:2px}

/* ── Boutons ── */
.msn-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 22px;border-radius:6px;font-weight:600;font-size:.9rem;text-decoration:none;cursor:pointer;border:none;transition:all .2s;font-family:var(--msn-font)}
.msn-btn-primary{background:linear-gradient(135deg,var(--msn-gold),var(--msn-gold-light));color:var(--msn-dark)}
.msn-btn-primary:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 4px 12px rgba(200,168,75,.4);color:var(--msn-dark)}
.msn-btn-ghost{background:transparent;border:2px solid var(--msn-gold);color:var(--msn-gold)}
.msn-btn-ghost:hover{background:var(--msn-gold);color:var(--msn-dark)}
.msn-btn-secondary{background:var(--msn-dark);color:#fff}
.msn-btn-secondary:hover{background:var(--msn-dark2)}
.msn-btn-sm{padding:6px 14px;font-size:.8rem}

/* ── Inputs ── */
.msn-input{width:100%;padding:10px 14px;border:1.5px solid var(--msn-border);border-radius:6px;font-size:.9rem;font-family:var(--msn-font);transition:border-color .2s;background:#fff}
.msn-input:focus{outline:none;border-color:var(--msn-gold);box-shadow:0 0 0 3px rgba(200,168,75,.15)}
.msn-select{padding:10px 14px;border:1.5px solid var(--msn-border);border-radius:6px;font-size:.9rem;background:#fff;cursor:pointer}

/* ── Badges ── */
.msn-badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:.75rem;font-weight:600}
.msn-badge-success,.msn-badge-validee,.msn-badge-achat{background:#d4edda;color:#155724}
.msn-badge-warning,.msn-badge-en_attente{background:#fff3cd;color:#856404}
.msn-badge-danger,.msn-badge-annulee{background:#f8d7da;color:#721c24}
.msn-badge-info,.msn-badge-transfert{background:#d1ecf1;color:#0c5460}

/* ── Progress bar ── */
.msn-progress-bar-wrap{margin:10px 0}
.msn-progress-bar-label{display:flex;justify-content:space-between;font-size:.8rem;color:var(--msn-text-muted);margin-bottom:4px}
.msn-progress-bar{height:8px;background:#e9ecef;border-radius:4px;overflow:hidden}
.msn-progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--msn-gold),var(--msn-gold-light));border-radius:4px;transition:width .6s ease}

/* ── Tables ── */
.msn-table{width:100%;border-collapse:collapse;font-size:.9rem}
.msn-table th{background:var(--msn-dark);color:#fff;padding:12px 16px;text-align:left;font-weight:600}
.msn-table td{padding:12px 16px;border-bottom:1px solid var(--msn-border)}
.msn-table tr:hover td{background:var(--msn-bg)}
.msn-positive{color:var(--msn-success);font-weight:600}
.msn-negative{color:var(--msn-danger);font-weight:600}

/* ── Empty state ── */
.msn-empty{text-align:center;padding:40px 20px;color:var(--msn-text-muted);font-size:1rem}
.msn-empty a{color:var(--msn-gold);text-decoration:none;font-weight:600}

/* ── Login wall ── */
.msn-login-wall{text-align:center;padding:60px 20px;background:var(--msn-bg);border-radius:var(--msn-radius);border:2px dashed var(--msn-border)}
.msn-login-icon{font-size:3rem;margin-bottom:1rem}

/* ════════════════════════════════════════════════
   MARKETPLACE
════════════════════════════════════════════════ */
.msn-marketplace-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:15px;margin-bottom:25px}
.msn-filters{display:flex;gap:10px;flex-wrap:wrap}
.msn-entreprises-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}
.msn-ent-card{background:#fff;border-radius:var(--msn-radius);box-shadow:var(--msn-shadow);overflow:hidden;transition:transform .2s,box-shadow .2s}
.msn-ent-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,.12)}
.msn-ent-card-img{height:180px;background-size:cover;background-position:center;background-color:var(--msn-dark)}
.msn-ent-card-img--placeholder{display:flex;align-items:center;justify-content:center;font-size:4rem;background:linear-gradient(135deg,var(--msn-dark),var(--msn-blue))}
.msn-ent-card-body{padding:20px}
.msn-ent-card-title{font-size:1.1rem;font-weight:700;color:var(--msn-dark);margin-bottom:4px}
.msn-ent-card-activite{font-size:.85rem;color:var(--msn-text-muted);margin-bottom:12px}
.msn-ent-card-meta{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin:12px 0}
.msn-meta-item{text-align:center}
.msn-meta-label{display:block;font-size:.7rem;color:var(--msn-text-muted);text-transform:uppercase;letter-spacing:.5px}
.msn-meta-item strong{font-size:.9rem;color:var(--msn-dark)}
.msn-ent-card-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.msn-buy-form{display:flex;gap:8px;flex:1}
.msn-buy-form .msn-nb-actions{max-width:80px}

/* ════════════════════════════════════════════════
   DASHBOARD
════════════════════════════════════════════════ */
.msn-dashboard{max-width:1200px;margin:0 auto;padding:20px 0}
.msn-dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:25px;flex-wrap:wrap;gap:10px}
.msn-dashboard-header h2{font-size:1.6rem;color:var(--msn-dark);font-weight:700}
.msn-subtitle{color:var(--msn-text-muted);margin-top:4px}
.msn-dashboard-date{color:var(--msn-text-muted);font-size:.9rem;padding:8px 16px;background:var(--msn-bg);border-radius:20px}
.msn-stats-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;margin-bottom:25px}
.msn-stat-card{background:#fff;border-radius:var(--msn-radius);padding:20px;box-shadow:var(--msn-shadow);text-align:center;border-top:3px solid var(--msn-border)}
.msn-stat-primary{border-top-color:var(--msn-gold);background:linear-gradient(135deg,var(--msn-dark),var(--msn-blue));color:#fff}
.msn-stat-primary .msn-stat-value,.msn-stat-primary .msn-stat-label{color:#fff}
.msn-stat-icon{font-size:1.8rem;margin-bottom:8px}
.msn-stat-value{font-size:1.6rem;font-weight:700;color:var(--msn-dark)}
.msn-stat-label{font-size:.8rem;color:var(--msn-text-muted);text-transform:uppercase;letter-spacing:.5px;margin-top:2px}
.msn-dashboard-grid{display:grid;grid-template-columns:3fr 2fr;gap:20px;margin-bottom:20px}
@media(max-width:768px){.msn-dashboard-grid{grid-template-columns:1fr}}
.msn-dashboard-section{background:#fff;border-radius:var(--msn-radius);padding:24px;box-shadow:var(--msn-shadow)}
.msn-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.msn-section-header h3{font-size:1rem;font-weight:700;color:var(--msn-dark);margin:0}
.msn-link{color:var(--msn-gold);text-decoration:none;font-size:.85rem;font-weight:600}
.msn-dashboard-links{display:flex;gap:12px;flex-wrap:wrap;margin-top:20px}
.msn-quick-link{display:flex;align-items:center;gap:8px;padding:12px 20px;background:#fff;border-radius:var(--msn-radius);box-shadow:var(--msn-shadow);color:var(--msn-dark);text-decoration:none;font-weight:600;font-size:.9rem;transition:all .2s}
.msn-quick-link:hover{background:var(--msn-dark);color:var(--msn-gold-light)}

/* ── Notifications ── */
.msn-notif-list{list-style:none;padding:0;margin:0}
.msn-notif-item{padding:12px 0;border-bottom:1px solid var(--msn-border)}
.msn-notif-item:last-child{border-bottom:none}
.msn-notif-unread{background:rgba(200,168,75,.05);padding:12px;border-radius:6px;margin:-12px 0 0}
.msn-notif-titre{font-weight:600;font-size:.9rem;color:var(--msn-dark)}
.msn-notif-msg{font-size:.85rem;color:var(--msn-text-muted);margin-top:2px}
.msn-notif-date{font-size:.75rem;color:#bbb;margin-top:4px}

/* ── Certificats ── */
.msn-certificats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}
.msn-cert-card{background:#fff;border-radius:var(--msn-radius);box-shadow:var(--msn-shadow);overflow:hidden;border:2px solid var(--msn-border)}
.msn-cert-card-header{background:linear-gradient(135deg,var(--msn-dark),var(--msn-blue));padding:20px;display:flex;justify-content:space-between;align-items:center}
.msn-cert-badge{background:var(--msn-gold);color:var(--msn-dark);font-weight:700;font-size:.7rem;letter-spacing:2px;padding:4px 10px;border-radius:3px}
.msn-cert-numero{color:rgba(255,255,255,.7);font-size:.75rem;font-family:monospace}
.msn-cert-card-body{padding:20px}
.msn-cert-field{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--msn-border);font-size:.9rem}
.msn-cert-field:last-child{border-bottom:none}
.msn-cert-field label{color:var(--msn-text-muted)}
.msn-cert-field strong{color:var(--msn-dark)}
.msn-cert-card-footer{padding:16px 20px;background:var(--msn-bg);display:flex;gap:8px}

/* ── Marché secondaire ── */
.msn-marche-desc{color:var(--msn-text-muted);margin-bottom:20px}
.msn-offres-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}
.msn-offre-card{background:#fff;border-radius:var(--msn-radius);box-shadow:var(--msn-shadow);padding:24px}
.msn-offre-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.msn-offre-card-header h3{font-size:1rem;font-weight:700;margin:0;color:var(--msn-dark)}
.msn-offre-field{display:flex;justify-content:space-between;padding:6px 0;font-size:.85rem;border-bottom:1px solid var(--msn-border)}
.msn-offre-notes{font-size:.8rem;color:var(--msn-text-muted);margin:10px 0;font-style:italic}

/* ── Fiche entreprise ── */
.msn-fiche-hero{position:relative;margin-bottom:30px;border-radius:var(--msn-radius);overflow:hidden;background:var(--msn-dark)}
.msn-fiche-banner{height:280px;background-size:cover;background-position:center;opacity:.5}
.msn-fiche-hero-content{position:absolute;bottom:0;left:0;right:0;padding:30px;color:#fff}
.msn-fiche-hero-content h1{font-size:2rem;font-weight:700;margin:0 0 4px}
.msn-fiche-activite{color:var(--msn-gold-light);font-size:1rem;margin-bottom:12px}
.msn-fiche-meta-row{display:flex;gap:20px;flex-wrap:wrap;font-size:.9rem}
.msn-fiche-meta-row span{color:rgba(255,255,255,.7)}
.msn-fiche-meta-row strong{color:#fff}
.msn-fiche-grid{display:grid;grid-template-columns:3fr 1fr;gap:30px;align-items:start}
@media(max-width:900px){.msn-fiche-grid{grid-template-columns:1fr}}
.msn-fiche-section{background:#fff;border-radius:var(--msn-radius);padding:25px;box-shadow:var(--msn-shadow);margin-bottom:20px}
.msn-fiche-section h3{font-size:1.1rem;font-weight:700;color:var(--msn-dark);margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid var(--msn-border)}
.msn-fiche-video{border-radius:8px;overflow:hidden;margin-top:12px}
.msn-invest-box{background:var(--msn-dark);border-radius:var(--msn-radius);padding:24px;color:#fff;position:sticky;top:20px}
.msn-invest-box-title{font-size:1rem;font-weight:700;color:var(--msn-gold-light);margin-bottom:16px}
.msn-invest-stats{display:flex;justify-content:space-between;margin-bottom:12px}
.msn-invest-stat{text-align:center}
.msn-invest-stat span{display:block;font-size:1.4rem;font-weight:700;color:var(--msn-gold-light)}
.msn-invest-stat label{font-size:.75rem;color:rgba(255,255,255,.6);text-transform:uppercase}
.msn-invest-prix{text-align:center;font-size:1.3rem;font-weight:700;color:var(--msn-gold-light);margin:16px 0}
.msn-invest-form label{display:block;font-size:.8rem;color:rgba(255,255,255,.7);margin-bottom:4px}
.msn-invest-form .msn-input{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.2);color:#fff;margin-bottom:10px}
.msn-invest-total{text-align:center;font-size:.9rem;color:rgba(255,255,255,.7);margin-bottom:12px}
.msn-total-val{color:var(--msn-gold-light);font-size:1rem}

/* ── Contrats ── */
.msn-contrats-list{display:flex;flex-direction:column;gap:12px}
.msn-contrat-item{background:#fff;border-radius:8px;padding:16px 20px;display:flex;align-items:center;gap:16px;box-shadow:var(--msn-shadow)}
.msn-contrat-icon{font-size:1.8rem}
.msn-contrat-info{flex:1}
.msn-contrat-info strong{display:block;font-size:1rem;color:var(--msn-dark)}
.msn-contrat-date{font-size:.8rem;color:var(--msn-text-muted);margin-top:2px}

/* ── Modal ── */
.msn-modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.6);z-index:9999;align-items:center;justify-content:center}
.msn-modal.is-open{display:flex}
.msn-modal-content{background:#fff;border-radius:var(--msn-radius);padding:30px;max-width:480px;width:90%;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.msn-modal-content h3{margin-bottom:20px;font-size:1.2rem;color:var(--msn-dark)}
.msn-modal-footer{display:flex;gap:10px;margin-top:16px}

/* ── Confirmation checkout ── */
.msn-confirmation-notice{background:linear-gradient(135deg,var(--msn-dark),var(--msn-blue));color:#fff;border-radius:var(--msn-radius);padding:30px;text-align:center;margin:20px 0}
.msn-confirmation-notice h3{color:var(--msn-gold-light);margin-bottom:10px}

/* ── Espace entreprise ── */
.msn-ent-dashboard .msn-stats-row{margin-bottom:20px}

@media(max-width:600px){
  .msn-entreprises-grid,.msn-certificats-grid,.msn-offres-grid{grid-template-columns:1fr}
  .msn-stats-row{grid-template-columns:1fr 1fr}
  .msn-fiche-hero-content h1{font-size:1.4rem}
  .msn-table{font-size:.8rem}
  .msn-table th,.msn-table td{padding:8px}
}
