/* =============================================================================
   N2M SÉCURITÉ — Portail Client 3 rôles (P19)
   ============================================================================= */
/* Tableau de bord toujours visible : on neutralise l'animation reveal au scroll
   (le portail n'a pas de hero avant la section → le reveal restait à mi-opacité). */
.n2m-section.n2m-portal { opacity: 1 !important; transform: none !important; }
.n2m-portal { min-height: 60vh; }

/* ── Login ─────────────────────────────────────────────────────────────── */
.n2m-portal-login { display: flex; justify-content: center; padding: 20px 0; }
.n2m-portal-login__card { width: 100%; max-width: 440px; background: var(--n2m-surface); border: 1px solid var(--n2m-hairline); border-radius: 16px; padding: 38px 34px; }
.n2m-portal-login__head { text-align: center; margin-bottom: 24px; }
.n2m-portal-login__ic { font-size: 40px; }
.n2m-portal-login__head h1 { font-family: 'Barlow Condensed', sans-serif; font-size: 30px; color:var(--n2m-white); margin: 10px 0 8px; }
.n2m-portal-login__head p { font-size: 14px; color:var(--text-muted); line-height: 1.6; margin: 0; }
.n2m-portal-login__err { background: rgba(239,68,68,.12); border: 1px solid rgba(239,68,68,.4); color: #ff8585; border-radius: 9px; padding: 11px 14px; font-size: 13.5px; margin-bottom: 16px; }
.n2m-portal-login__form .n2m-form-group { margin-bottom: 16px; }
.n2m-portal-login__remember { display: flex; align-items: center; gap: 8px; font-size: 13.5px; color:var(--text-secondary); margin-bottom: 18px; cursor: pointer; }
.n2m-portal-login__foot { text-align: center; margin: 16px 0 0; font-size: 13px; color:var(--text-muted); display: flex; gap: 8px; justify-content: center; flex-wrap: wrap; }
.n2m-portal-login__foot a { color: #F5C200; text-decoration: none; }

/* ── En-tête connecté ──────────────────────────────────────────────────── */
.n2m-portal-head { display: flex; justify-content: space-between; align-items: flex-end; gap: 16px; flex-wrap: wrap; margin-bottom: 26px; padding-bottom: 18px; border-bottom: 1px solid var(--n2m-hairline); }
.n2m-portal-head__hi h1 { font-family: 'Barlow Condensed', sans-serif; font-size: 30px; color:var(--n2m-white); margin: 0; }
.n2m-portal-head__hi p { color:var(--text-muted); margin: 4px 0 0; font-size: 14px; }
.n2m-portal-head__meta { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.n2m-portal-head__role { background: #F5C200; color: #050508; font-weight: 700; font-size: 12px; padding: 5px 13px; border-radius: 999px; text-transform: uppercase; letter-spacing: .4px; }
.n2m-portal-head__date { color:var(--text-muted); font-size: 13px; text-transform: capitalize; }
.n2m-portal-head__logout { color:var(--text-secondary); font-size: 13.5px; text-decoration: none; border: 1px solid rgba(255,255,255,.16); padding: 7px 14px; border-radius: 8px; }
.n2m-portal-head__logout:hover { border-color: #EF4444; color: #ff8585; }

.n2m-portal-empty { text-align: center; padding: 60px 20px; color:var(--text-muted); }
.n2m-portal-empty span { font-size: 46px; display: block; margin-bottom: 14px; }
.n2m-portal-empty h2 { color:var(--n2m-white); font-family: 'Barlow Condensed', sans-serif; font-size: 26px; margin: 0 0 10px; }

/* ── KPIs ──────────────────────────────────────────────────────────────── */
.n2m-portal-kpis { display: grid; grid-template-columns: repeat(5, 1fr); gap: 14px; margin-bottom: 24px; }
.n2m-portal-kpi { background: var(--n2m-surface); border: 1px solid var(--n2m-hairline); border-left: 4px solid #94A3B8; border-radius: 12px; padding: 16px 14px; text-align: center; }
.n2m-portal-kpi__ic { font-size: 22px; display: block; }
.n2m-portal-kpi__val { display: block; font-size: 28px; font-weight: 800; color:var(--n2m-white); line-height: 1.1; margin: 4px 0 2px; }
.n2m-portal-kpi__lab { font-size: 12px; color:var(--text-muted); }
.n2m-portal-kpi--vert{border-left-color:#10B981}.n2m-portal-kpi--rouge{border-left-color:#EF4444}.n2m-portal-kpi--bleu{border-left-color:#0EA5E9}.n2m-portal-kpi--orange{border-left-color:#F97316}.n2m-portal-kpi--or{border-left-color:#F5C200}

.n2m-portal-sites { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 20px; }
.n2m-portal-sites__lab { color:var(--text-muted); font-size: 13px; }
.n2m-portal-site-chip { background: rgba(245,194,0,.12); color: #F5C200; border: 1px solid rgba(245,194,0,.3); padding: 4px 12px; border-radius: 999px; font-size: 12.5px; font-weight: 600; }

/* ── Grille + panneaux ─────────────────────────────────────────────────── */
.n2m-portal-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; align-items: start; }
.n2m-portal-col { display: flex; flex-direction: column; gap: 20px; }
.n2m-portal-panel { background: var(--n2m-surface); border: 1px solid var(--n2m-hairline); border-radius: 14px; padding: 18px 20px; }
.n2m-portal-panel__h { display: flex; justify-content: space-between; align-items: center; margin-bottom: 12px; }
.n2m-portal-panel__h h2 { font-family: 'Barlow Condensed', sans-serif; font-size: 18px; color:var(--n2m-white); margin: 0; }
.n2m-portal-add { background: rgba(245,194,0,.14); border: 1px solid rgba(245,194,0,.4); color: #F5C200; font-size: 12.5px; font-weight: 600; padding: 5px 12px; border-radius: 8px; cursor: pointer; }
.n2m-portal-add:hover { background: #F5C200; color: #050508; }

.n2m-portal-row { display: flex; align-items: center; gap: 12px; padding: 11px 0; border-bottom: 1px solid var(--n2m-surface); text-decoration: none; }
.n2m-portal-row:last-child { border-bottom: 0; }
.n2m-portal-row__main { flex: 1; min-width: 0; }
.n2m-portal-row__main strong { display: block; font-size: 13.5px; color:var(--n2m-white); }
.n2m-portal-row__main span { font-size: 12px; color:var(--text-muted); }
.n2m-portal-row__meta { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.n2m-pb { display: inline-block; padding: 3px 9px; border-radius: 999px; font-size: 11px; font-weight: 600; color:var(--n2m-white); }
.n2m-portal-dl { font-size: 12px; color: #F5C200; text-decoration: none; white-space: nowrap; }
.n2m-portal-empty-line { color:var(--text-muted); font-size: 13.5px; font-style: italic; padding: 10px 0; margin: 0; }

/* ── Formulaires intervention / réclamation ────────────────────────────── */
.n2m-portal-form[hidden] { display: none; }
.n2m-portal-form { display: flex; flex-direction: column; gap: 9px; background: rgba(0,0,0,.2); border: 1px solid var(--n2m-hairline); border-radius: 10px; padding: 14px; margin-bottom: 14px; }
.n2m-portal-form .n2m-input, .n2m-portal-form .n2m-select, .n2m-portal-form .n2m-textarea { font-size: 13.5px; padding: 10px 12px; }
.n2m-portal-submit { align-self: flex-start; }
.n2m-portal-feedback { font-size: 12.5px; margin: 0; }
.n2m-portal-feedback.error { color: #ff8585; }
.n2m-portal-feedback.ok { color: #34d399; }
.n2m-portal-submit .sp { display: none; width: 14px; height: 14px; margin-left: 7px; border: 2px solid rgba(5,5,8,.3); border-top-color: #050508; border-radius: 50%; animation: n2mPortalSpin .7s linear infinite; vertical-align: middle; }
.n2m-portal-submit.is-loading .tx { opacity: .55; }
.n2m-portal-submit.is-loading .sp { display: inline-block; }
@keyframes n2mPortalSpin { to { transform: rotate(360deg); } }

.n2m-portal-panel--contact h2 { font-size: 16px; margin-bottom: 12px; }
.n2m-portal-contact { display: block; color:var(--n2m-white); text-decoration: none; padding: 9px 0; border-bottom: 1px solid var(--n2m-surface); font-size: 14px; }
.n2m-portal-contact small { color:var(--text-muted); }

/* ── Liens admin ───────────────────────────────────────────────────────── */
.n2m-portal-admin-links { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-bottom: 24px; }
.n2m-portal-link { display: flex; flex-direction: column; gap: 2px; background: var(--n2m-surface); border: 1px solid var(--n2m-hairline); border-radius: 12px; padding: 16px; text-decoration: none; transition: .2s; }
.n2m-portal-link:hover { border-color: #F5C200; transform: translateY(-2px); }
.n2m-portal-link strong { color:var(--n2m-white); font-size: 15px; }
.n2m-portal-link span { color:var(--text-muted); font-size: 12.5px; }

@media (max-width: 900px) {
    .n2m-portal-kpis { grid-template-columns: repeat(2, 1fr); }
    .n2m-portal-grid { grid-template-columns: 1fr; }
    .n2m-portal-admin-links { grid-template-columns: 1fr 1fr; }
    .n2m-portal-head { align-items: flex-start; }
}
