/**
 * FIRPCAM — Design Institutionnel Original
 * Bleu #003087 | Or #C9A84C | Ivoire #F5F0E8
 */
:root {
    --bleu-institutionnel: #003087;
    --or-antique: #C9A84C;
    --ivoire: #F5F0E8;
    --anthracite: #2C2C2C;
    --blanc-pur: #FFFFFF;
    --gris-clair: #F8F8F8;
    --or-hover: #B8962A;
    --bleu-clair: #0047AB;
    --bleu-fonce: #002060;
    --rouge-alerte: #C0392B;
    --vert-validation: #27AE60;
    --bleu-transparent: rgba(0,48,135,0.12);
    --or-transparent: rgba(201,168,76,0.15);

    /* Compat */
    --color-accent: var(--or-antique);
    --color-dark: var(--bleu-institutionnel);
    --color-dark2: var(--bleu-fonce);
    --color-dark3: #001540;
    --color-bg: var(--blanc-pur);
    --color-white: var(--blanc-pur);
    --color-gray: var(--gris-clair);
    --color-gray2: var(--ivoire);
    --color-text: var(--anthracite);
    --color-heading: var(--anthracite);
    --color-silver: #999;
    --color-border: #E0E0E0;
    --vert-principal: var(--vert-validation);
    --vert-clair: #E8F5E9;
    --rouge-erreur: var(--rouge-alerte);
    --bleu-info: var(--bleu-clair);
    --jaune-warning: #F39C12;
    --texte-noir: var(--anthracite);
    --texte-gris: #555;
    --texte-light: #666;
    --texte-muted: #999;

    --font-titres: 'Cormorant Garamond', Georgia, serif;
    --font-sous-titres: 'Playfair Display', Georgia, serif;
    --font-corps: 'Lato', 'Open Sans', Arial, sans-serif;
    --font-officiel: Georgia, 'Times New Roman', serif;
    --font-chiffres: 'Montserrat', Arial, sans-serif;
    --title-font: var(--font-titres);
    --text-font: var(--font-corps);
    --font-principale: var(--font-corps);
    --font-alt: var(--font-chiffres);
    --font-display: var(--font-titres);
    --font-body: var(--font-corps);

    --fs-h1: 2.8rem; --fs-h2: 2.2rem; --fs-h3: 1.6rem; --fs-h4: 1.3rem;
    --fs-body: 1rem; --fs-small: 0.875rem; --fs-xs: 0.75rem;

    --spacing-xs: 0.5rem; --spacing-sm: 1rem; --spacing-md: 1.5rem;
    --spacing-lg: 2.5rem; --spacing-xl: 4rem; --spacing-xxl: 6rem;
    --max-width: 1200px; --max-width-narrow: 900px;

    --shadow-sm: 0 2px 8px rgba(0,48,135,0.08);
    --shadow-md: 0 4px 20px rgba(0,48,135,0.12);
    --shadow-lg: 0 8px 40px rgba(0,48,135,0.16);
    --shadow-card: 0 2px 12px rgba(0,0,0,0.08);
    --shadow-card-hover: 0 8px 30px rgba(0,48,135,0.15);

    --radius-sm: 4px; --radius-md: 8px; --radius-lg: 12px;
    --radius-xl: 20px; --radius-2xl: 24px; --radius-full: 50px;
    --radius-btn: 4px;

    --transition: all 0.3s ease; --transition-fast: all 0.15s ease;
}

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { font-size: 16px; scroll-behavior: smooth; -webkit-font-smoothing: antialiased; }

body {
    font-family: var(--font-corps); font-size: var(--fs-body); font-weight: 400;
    line-height: 1.7; color: var(--anthracite); background: var(--blanc-pur);
    min-height: 100vh; display: flex; flex-direction: column;
}

img { max-width: 100%; height: auto; display: block; }
a { color: var(--bleu-clair); text-decoration: none; transition: var(--transition); }
a:hover { color: var(--bleu-institutionnel); text-decoration: underline; }
ul, ol { list-style: none; }
table { border-collapse: collapse; width: 100%; }
input, textarea, select, button { font-family: inherit; font-size: inherit; }

h1, h2 { font-family: var(--font-titres); font-weight: 700; color: var(--bleu-institutionnel); line-height: 1.2; }
h3, h4 { font-family: var(--font-sous-titres); font-weight: 600; color: var(--bleu-institutionnel); line-height: 1.3; }
h5, h6 { font-family: var(--font-corps); font-weight: 600; color: var(--anthracite); }
h1 { font-size: var(--fs-h1); margin-bottom: var(--spacing-md); }
h2 { font-size: var(--fs-h2); margin-bottom: var(--spacing-md); }
h3 { font-size: var(--fs-h3); margin-bottom: var(--spacing-sm); }
h4 { font-size: var(--fs-h4); margin-bottom: var(--spacing-sm); }
p { margin-bottom: var(--spacing-sm); }
strong { font-weight: 700; }
main { flex: 1; }

.container { width: 100%; max-width: var(--max-width); margin: 0 auto; padding: 0 var(--spacing-md); }
.container-narrow { max-width: var(--max-width-narrow); margin: 0 auto; padding: 0 var(--spacing-md); }

.section { padding: var(--spacing-xl) 0; }
.section-ivoire { background: var(--ivoire); }
.section-gris { background: var(--gris-clair); }
.section-bleu, .section-dark { background: var(--bleu-institutionnel); color: var(--blanc-pur); }
.section-bleu h1,.section-bleu h2,.section-bleu h3,.section-bleu h4,.section-dark h2 { color: var(--blanc-pur); }
.section-bleu a,.section-dark a { color: var(--or-antique); }
.section-white { background: var(--blanc-pur); }

.section-title { text-align: center; margin-bottom: var(--spacing-lg); }
.section-title h2 { position: relative; display: inline-block; padding-bottom: var(--spacing-sm); }
.section-title h2::after { content: ''; position: absolute; bottom: 0; left: 50%; transform: translateX(-50%); width: 80px; height: 3px; background: var(--or-antique); }
.section-title p { color: #666; font-size: 1.1rem; max-width: 700px; margin: var(--spacing-sm) auto 0; }
.section-title .sub { display: inline-flex; align-items: center; gap: 8px; font-size: var(--fs-xs); font-weight: 600; color: var(--bleu-institutionnel); text-transform: uppercase; letter-spacing: 2px; margin-bottom: 12px; }
.section-title .sub .line { width: 30px; height: 3px; background: var(--or-antique); border-radius: 2px; }

/* Boutons */
.btn { display: inline-block; padding: 12px 32px; font-family: var(--font-corps); font-size: var(--fs-body); font-weight: 600; text-align: center; text-decoration: none; border: 2px solid transparent; border-radius: var(--radius-sm); cursor: pointer; transition: var(--transition); letter-spacing: 0.5px; }
.btn:hover { transform: translateY(-2px); text-decoration: none; }
.btn-primary { background: var(--or-antique); color: var(--blanc-pur); border-color: var(--or-antique); }
.btn-primary:hover { background: var(--or-hover); border-color: var(--or-hover); color: var(--blanc-pur); box-shadow: var(--shadow-md); }
.btn-secondary { background: var(--bleu-institutionnel); color: var(--blanc-pur); border-color: var(--bleu-institutionnel); }
.btn-secondary:hover { background: var(--bleu-fonce); border-color: var(--bleu-fonce); color: var(--blanc-pur); box-shadow: var(--shadow-md); }
.btn-outline { background: transparent; color: var(--or-antique); border-color: var(--or-antique); }
.btn-outline:hover { background: var(--or-antique); color: var(--blanc-pur); }
.btn-outline-white { background: transparent; color: var(--blanc-pur); border-color: var(--blanc-pur); }
.btn-outline-white:hover { background: var(--blanc-pur); color: var(--bleu-institutionnel); }
.btn-or { background: var(--or-antique); color: var(--blanc-pur); border-color: var(--or-antique); }
.btn-danger { background: var(--rouge-alerte); color: var(--blanc-pur); border-color: var(--rouge-alerte); }
.btn-sm { padding: 8px 20px; font-size: var(--fs-small); }
.btn-lg { padding: 16px 40px; font-size: 1.1rem; }

/* Cartes */
.card { background: var(--blanc-pur); border-radius: var(--radius-md); box-shadow: var(--shadow-card); overflow: hidden; transition: var(--transition); }
.card:hover { box-shadow: var(--shadow-md); transform: translateY(-4px); }
.card-body { padding: var(--spacing-md); }
.card-or { border-top: 4px solid var(--or-antique); }

/* Grilles */
.grid { display: grid; gap: var(--spacing-md); }
.grid-2 { grid-template-columns: repeat(2,1fr); }
.grid-3 { grid-template-columns: repeat(3,1fr); }
.grid-4 { grid-template-columns: repeat(4,1fr); }

/* Badges */
.badge { display: inline-block; padding: 4px 12px; font-size: var(--fs-xs); font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; border-radius: var(--radius-xl); }
.badge-success { background: #E8F5E9; color: var(--vert-validation); }
.badge-warning { background: #FFF8E1; color: #F57F17; }
.badge-danger { background: #FFEBEE; color: var(--rouge-alerte); }
.badge-info { background: #E3F2FD; color: var(--bleu-clair); }
.badge-or { background: var(--or-transparent); color: var(--or-hover); }

/* Formulaires */
.form-group { margin-bottom: var(--spacing-md); }
.form-group label { display: block; margin-bottom: 6px; font-weight: 600; color: var(--anthracite); font-size: var(--fs-small); }
.form-control { width: 100%; padding: 12px 16px; font-size: var(--fs-body); color: var(--anthracite); background: var(--blanc-pur); border: 2px solid #D0D0D0; border-radius: var(--radius-sm); transition: var(--transition); }
.form-control:focus { outline: none; border-color: var(--bleu-institutionnel); box-shadow: 0 0 0 3px rgba(0,48,135,0.15); }
.form-control::placeholder { color: #999; }
textarea.form-control { min-height: 120px; resize: vertical; }
select.form-control { appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%232C2C2C' stroke-width='1.5' fill='none'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 16px center; padding-right: 40px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--spacing-md); }
.form-actions { display: flex; gap: var(--spacing-sm); justify-content: flex-end; margin-top: var(--spacing-md); padding-top: var(--spacing-md); border-top: 1px solid #E0E0E0; }

/* Alertes */
.alert { padding: var(--spacing-sm) var(--spacing-md); border-radius: var(--radius-sm); margin-bottom: var(--spacing-md); border-left: 4px solid var(--or-antique); }
.alert-success { background: #E8F5E9; color: #1B5E20; border-left-color: var(--vert-validation); }
.alert-danger { background: #FFEBEE; color: #B71C1C; border-left-color: var(--rouge-alerte); }
.alert-warning { background: #FFF8E1; color: #E65100; border-left-color: #FF9800; }
.alert-info { background: #E3F2FD; color: var(--bleu-institutionnel); border-left-color: var(--bleu-clair); }

/* Tableaux */
.table-wrapper { overflow-x: auto; }
.table th { background: var(--bleu-institutionnel); color: var(--blanc-pur); font-family: var(--font-corps); font-weight: 600; font-size: var(--fs-small); text-transform: uppercase; letter-spacing: 0.5px; padding: 14px 16px; text-align: left; }
.table td { padding: 12px 16px; border-bottom: 1px solid #E0E0E0; vertical-align: middle; }
.table tbody tr:hover { background: var(--gris-clair); }

/* Stats */
.stat-number { font-family: var(--font-chiffres); font-size: 3rem; font-weight: 700; color: var(--or-antique); line-height: 1; }
.stat-label { font-size: var(--fs-small); color: #666; text-transform: uppercase; letter-spacing: 1px; margin-top: var(--spacing-xs); }

/* Info box */
.info-box { background: var(--ivoire); border-left: 4px solid var(--or-antique); padding: var(--spacing-md); border-radius: 0 var(--radius-md) var(--radius-md) 0; margin: var(--spacing-md) 0; }
.info-box h4 { color: var(--bleu-institutionnel); margin-bottom: var(--spacing-xs); }
.info-box-bleu { background: var(--bleu-transparent); border-left-color: var(--bleu-institutionnel); }

/* Utilitaires */
.text-center{text-align:center}.text-or{color:var(--or-antique)}.text-bleu{color:var(--bleu-institutionnel)}.text-vert{color:var(--vert-validation)}.text-muted{color:#888}
.mt-0{margin-top:0}.mt-1{margin-top:var(--spacing-sm)}.mt-2{margin-top:var(--spacing-md)}.mt-3{margin-top:var(--spacing-lg)}
.mb-0{margin-bottom:0}.mb-1{margin-bottom:var(--spacing-sm)}.mb-2{margin-bottom:var(--spacing-md)}.mb-3{margin-bottom:var(--spacing-lg)}
.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}
.gap-1{gap:var(--spacing-sm)}.gap-2{gap:var(--spacing-md)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
.separator{border:none;border-top:2px solid var(--or-antique);margin:var(--spacing-lg) 0}
.separator-light{border:none;border-top:1px solid #E0E0E0;margin:var(--spacing-md) 0}
.section-404{text-align:center;padding:var(--spacing-xxl) 0}
.section-404 h1{font-size:6rem;color:var(--or-antique)}
.section-404 p{font-size:1.2rem;color:#666;margin-bottom:var(--spacing-lg)}
