/* INFJ Surveillants 2026 — Charte Graphique Officielle */
:root {
    --primary:#1E8B3E;--primary-light:#27A84D;--primary-dark:#0F5C28;--primary-deep:#083D1A;
    --secondary:#C9A84C;--secondary-light:#E8C96A;--secondary-dark:#A8882E;
    --accent:#E05A1E;--accent-light:#F07035;
    --success:#1E8B3E;--warning:#C9A84C;--danger:#E05A1E;--info:#27A84D;
    --white:#FFFFFF;--ivory:#F5F2EC;--light:#EEF4EE;
    --gray-100:#E8F0E8;--gray-200:#D0E4D0;--gray-400:#8FAF8F;
    --gray-600:#4A6B4A;--gray-800:#1A3A1A;
    --text:#1A3A1A;--text-light:#4A6B4A;--border:#B8D4B8;
    --shadow:0 2px 20px rgba(15,92,40,0.12);--shadow-md:0 4px 30px rgba(15,92,40,0.20);
    --radius:8px;--radius-lg:16px;
    --font:'Segoe UI','Arial',sans-serif;--font-serif:Georgia,'Times New Roman',serif;
    --transition:all 0.25s ease;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font);color:var(--text);background:var(--light);line-height:1.6;min-height:100vh;display:flex;flex-direction:column}
a{color:var(--primary);text-decoration:none;transition:var(--transition)}
a:hover{color:var(--primary-light)}
img{max-width:100%;height:auto}
ul{list-style:none}
.container{max-width:1200px;margin:0 auto;padding:0 20px}

/* Bande tricolore CI */
.tricolore-bar{height:5px;background:linear-gradient(to right,#F77F00 0%,#F77F00 33.33%,#FFFFFF 33.33%,#FFFFFF 66.66%,#009A44 66.66%,#009A44 100%);width:100%}

/* Header */
.main-header{background:var(--white);box-shadow:var(--shadow-md);position:sticky;top:0;z-index:1000}
.header-top{background:linear-gradient(135deg,var(--primary-deep) 0%,var(--primary-dark) 60%,var(--primary) 100%);padding:12px 0;border-bottom:3px solid var(--secondary);position:relative;overflow:hidden}
.header-top::before{content:'⚖';position:absolute;right:60px;top:50%;transform:translateY(-50%);font-size:8rem;color:rgba(201,168,76,0.05);pointer-events:none}
.header-top .container{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.header-armoiries img{height:65px;width:auto;filter:drop-shadow(0 2px 4px rgba(0,0,0,0.3))}
.header-separator{width:2px;height:55px;background:linear-gradient(to bottom,transparent,var(--secondary),transparent);flex-shrink:0}
.header-brand a{display:flex;align-items:center;gap:12px}
.logo-img{height:55px;width:auto;filter:drop-shadow(0 2px 4px rgba(0,0,0,0.2))}
.logo-text-fallback{flex-direction:column;color:var(--white)}
.logo-acronym{font-size:2rem;font-weight:900;letter-spacing:4px;color:var(--secondary);font-family:var(--font-serif)}
.logo-subtitle{font-size:0.7rem;color:rgba(255,255,255,0.75)}
.header-info{flex:1;color:var(--white)}
.header-info h1{font-size:1.25rem;font-weight:700;color:var(--secondary);font-family:var(--font-serif);text-shadow:0 1px 3px rgba(0,0,0,0.3)}
.header-info p{font-size:0.82rem;opacity:0.8}
.header-contact{display:flex;gap:18px;margin-top:4px;font-size:0.78rem;opacity:0.65;flex-wrap:wrap}
.header-contact span{display:flex;align-items:center;gap:5px}

/* Nav */
.main-nav{background:var(--primary-dark);border-top:1px solid rgba(201,168,76,0.2)}
.main-nav .container{display:flex;align-items:center;justify-content:space-between}
.nav-menu{display:flex;list-style:none}
.nav-menu li a{display:flex;align-items:center;gap:7px;padding:13px 18px;color:rgba(255,255,255,0.80);font-size:0.88rem;font-weight:500;transition:var(--transition);border-bottom:3px solid transparent}
.nav-menu li a:hover,.nav-menu li a.active{color:var(--secondary);background:rgba(201,168,76,0.08);border-bottom-color:var(--secondary)}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:10px}
.nav-toggle span{display:block;width:25px;height:3px;background:var(--white);border-radius:2px;transition:var(--transition)}

/* Hero */
.hero{background:linear-gradient(135deg,var(--primary-deep) 0%,var(--primary-dark) 50%,var(--primary) 100%);color:var(--white);padding:70px 0 50px;text-align:center;position:relative;overflow:hidden}
.hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:4px;background:linear-gradient(to right,var(--secondary-dark),var(--secondary),var(--secondary-light),var(--secondary))}
.hero-content{position:relative;z-index:1}
.hero h2{font-size:2.2rem;font-weight:800;margin-bottom:12px;font-family:var(--font-serif);text-shadow:0 2px 8px rgba(0,0,0,0.3)}
.hero p{font-size:1.05rem;opacity:0.9;max-width:650px;margin:0 auto 24px}
.hero-badges{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin-bottom:20px}
.hero-badge{background:rgba(201,168,76,0.15);border:1px solid rgba(201,168,76,0.4);border-radius:50px;padding:6px 18px;font-size:0.83rem;color:var(--secondary-light)}

/* Boutons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:11px 22px;border-radius:var(--radius);font-size:0.92rem;font-weight:600;cursor:pointer;border:2px solid transparent;transition:var(--transition);text-decoration:none;white-space:nowrap}
.btn-primary{background:var(--primary);color:var(--white);border-color:var(--primary)}
.btn-primary:hover{background:var(--primary-light);border-color:var(--primary-light);color:var(--white);transform:translateY(-1px)}
.btn-secondary{background:var(--secondary);color:var(--primary-deep);border-color:var(--secondary);font-weight:700}
.btn-secondary:hover{background:var(--secondary-light);color:var(--primary-deep);transform:translateY(-1px)}
.btn-success{background:var(--success);color:var(--white);border-color:var(--success)}
.btn-success:hover{background:var(--primary-light);transform:translateY(-1px)}
.btn-danger{background:var(--danger);color:var(--white);border-color:var(--danger)}
.btn-danger:hover{background:#c04010;transform:translateY(-1px)}
.btn-outline{background:transparent;color:var(--primary);border-color:var(--primary)}
.btn-outline:hover{background:var(--primary);color:var(--white)}
.btn-white{background:var(--white);color:var(--primary-dark);border-color:var(--white)}
.btn-white:hover{background:var(--ivory)}
.btn-lg{padding:15px 30px;font-size:1.05rem}
.btn-sm{padding:7px 14px;font-size:0.82rem}
.btn-block{width:100%;justify-content:center}

/* CTA Accueil */
.cta-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px;padding:50px 0}
.cta-card{background:var(--white);border-radius:var(--radius-lg);padding:34px 24px;text-align:center;box-shadow:var(--shadow);transition:var(--transition);border:2px solid transparent;border-top:4px solid var(--primary);cursor:pointer;text-decoration:none;color:var(--text);display:flex;flex-direction:column;align-items:center;gap:12px}
.cta-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-md);border-color:var(--secondary);border-top-color:var(--secondary);color:var(--text)}
.cta-card .cta-icon{width:70px;height:70px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.9rem;margin-bottom:4px}
.cta-card .cta-icon.green{background:rgba(30,139,62,0.10);color:var(--primary)}
.cta-card .cta-icon.gold{background:rgba(201,168,76,0.15);color:var(--secondary-dark)}
.cta-card .cta-icon.orange{background:rgba(224,90,30,0.12);color:var(--accent)}
.cta-card .cta-icon.dark{background:rgba(8,61,26,0.10);color:var(--primary-dark)}
.cta-card h3{font-size:1.1rem;font-weight:700;color:var(--primary-dark);font-family:var(--font-serif)}
.cta-card p{font-size:0.85rem;color:var(--text-light)}

/* Formulaires */
.form-container{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:40px;margin:30px 0;border-top:4px solid var(--secondary)}
.form-section{border:1px solid var(--border);border-radius:var(--radius);margin-bottom:28px;overflow:hidden}
.form-section-title{background:linear-gradient(135deg,var(--primary-dark),var(--primary));color:var(--white);padding:13px 20px;font-size:0.95rem;font-weight:600;display:flex;align-items:center;gap:10px;border-left:4px solid var(--secondary)}
.form-section-body{padding:22px;background:var(--white)}
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.form-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.col-span-2{grid-column:span 2}.col-span-3{grid-column:span 3}
.form-group{display:flex;flex-direction:column;gap:5px}
.form-group label{font-size:0.85rem;font-weight:600;color:var(--primary-dark)}
.form-group label .required{color:var(--danger);margin-left:3px}
.form-control{padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--radius);font-size:0.92rem;font-family:var(--font);color:var(--text);background:var(--white);transition:var(--transition);width:100%}
.form-control:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(30,139,62,0.12);background:#fafffa}
.form-control.is-invalid{border-color:var(--danger)}
.form-control.is-valid{border-color:var(--success)}
select.form-control{cursor:pointer}
textarea.form-control{resize:vertical;min-height:88px}
.form-hint{font-size:0.76rem;color:var(--text-light);margin-top:3px}
.invalid-feedback{color:var(--danger);font-size:0.78rem}

/* Upload */
.upload-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:24px;text-align:center;cursor:pointer;transition:var(--transition);background:var(--gray-100)}
.upload-zone:hover,.upload-zone.drag-over{border-color:var(--primary);background:rgba(30,139,62,0.04)}
.upload-zone input[type="file"]{display:none}
.upload-zone .upload-icon{font-size:2rem;color:var(--primary);margin-bottom:8px}
.upload-zone p{font-size:0.82rem;color:var(--text-light)}
.upload-preview{margin-top:10px;max-width:120px;max-height:120px;border-radius:var(--radius);object-fit:cover;border:2px solid var(--primary);display:none}

/* Alertes */
.alert{padding:13px 18px;border-radius:var(--radius);margin-bottom:16px;font-size:0.88rem;display:flex;align-items:flex-start;gap:10px}
.alert-success{background:#d8f0de;color:#0F5C28;border-left:4px solid var(--success)}
.alert-danger{background:#fce8df;color:#8B2500;border-left:4px solid var(--danger)}
.alert-warning{background:#faf3dc;color:#7A5C00;border-left:4px solid var(--warning)}
.alert-info{background:#d8f0de;color:#0F5C28;border-left:4px solid var(--info)}

/* Cartes */
.card{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden;margin-bottom:24px;border:1px solid var(--gray-200)}
.card-header{background:linear-gradient(135deg,var(--primary-dark),var(--primary));color:var(--white);padding:14px 22px;font-size:0.95rem;font-weight:600;display:flex;align-items:center;justify-content:space-between;border-bottom:2px solid var(--secondary)}
.card-body{padding:22px}

/* Tableaux */
.table-responsive{overflow-x:auto}
.table{width:100%;border-collapse:collapse;font-size:0.86rem}
.table th,.table td{padding:11px 13px;border-bottom:1px solid var(--border);text-align:left;vertical-align:middle}
.table th{background:linear-gradient(135deg,var(--primary-dark),var(--primary));color:var(--white);font-weight:600;white-space:nowrap}
.table th:first-child{border-left:3px solid var(--secondary)}
.table tbody tr:hover{background:rgba(30,139,62,0.04)}
.table-striped tbody tr:nth-child(even){background:var(--gray-100)}

/* Badges */
.badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:50px;font-size:0.76rem;font-weight:600}
.badge-success{background:#d8f0de;color:#0F5C28}
.badge-warning{background:#faf3dc;color:#7A5C00}
.badge-danger{background:#fce8df;color:#8B2500}
.badge-info{background:#d8f0de;color:#0F5C28}
.badge-secondary{background:var(--gray-200);color:var(--gray-800)}
.badge-primary{background:rgba(30,139,62,0.12);color:var(--primary-dark)}

/* Stats */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:20px;margin-bottom:28px}
.stat-card{background:var(--white);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);display:flex;align-items:center;gap:16px;border-left:4px solid var(--primary);border-top:2px solid var(--gray-200);transition:var(--transition)}
.stat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.stat-card.success{border-left-color:var(--success)}
.stat-card.warning{border-left-color:var(--warning)}
.stat-card.danger{border-left-color:var(--danger)}
.stat-icon{font-size:2rem;opacity:0.7}
.stat-info .stat-value{font-size:1.9rem;font-weight:800;color:var(--primary-dark);font-family:var(--font-serif)}
.stat-info .stat-label{font-size:0.8rem;color:var(--text-light)}

/* Info Section */
.info-section{padding:50px 0}
.info-section h2{color:var(--primary-dark);margin-bottom:30px;font-size:1.7rem;text-align:center;font-family:var(--font-serif)}
.info-section h2::after{content:'';display:block;width:80px;height:3px;background:linear-gradient(to right,var(--secondary),var(--accent));margin:10px auto 0;border-radius:2px}
.conditions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:22px}
.condition-card{background:var(--white);border-radius:var(--radius);padding:26px 20px;box-shadow:var(--shadow);border-top:4px solid var(--secondary);text-align:center;transition:var(--transition)}
.condition-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);border-top-color:var(--primary)}
.condition-card i{font-size:2.2rem;color:var(--secondary-dark);margin-bottom:12px}
.condition-card h4{color:var(--primary-dark);margin-bottom:8px;font-size:0.98rem;font-family:var(--font-serif)}
.condition-card p{font-size:0.84rem;color:var(--text-light)}

/* Page titre */
.page-title{background:linear-gradient(135deg,var(--primary-deep) 0%,var(--primary-dark) 60%,var(--primary) 100%);color:var(--white);padding:32px 0 26px;text-align:center;border-bottom:3px solid var(--secondary)}
.page-title h1{font-size:1.7rem;margin-bottom:6px;font-family:var(--font-serif)}
.page-title p{opacity:0.8;font-size:0.92rem}

/* Dossier */
.dossier-grid{display:grid;grid-template-columns:200px 1fr;gap:28px;align-items:start}
.candidat-photo{width:180px;height:200px;object-fit:cover;border-radius:var(--radius);border:3px solid var(--secondary);box-shadow:var(--shadow)}
.candidat-photo-placeholder{width:180px;height:200px;background:var(--gray-100);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:4rem;color:var(--gray-400);border:3px solid var(--border)}
.info-list{list-style:none}
.info-list li{display:flex;gap:10px;padding:9px 0;border-bottom:1px solid var(--border);font-size:0.88rem}
.info-list li:last-child{border-bottom:none}
.info-list .label{font-weight:600;color:var(--primary-dark);min-width:180px}

/* Numéro inscription */
.numero-inscription{background:linear-gradient(135deg,var(--primary-dark),var(--primary));color:var(--white);padding:12px 20px;border-radius:var(--radius);font-size:1.1rem;font-weight:700;letter-spacing:2px;text-align:center;margin-bottom:14px;display:inline-block;border:2px solid var(--secondary);font-family:'Courier New',monospace}

/* Admin Layout */
.admin-layout{display:grid;grid-template-columns:255px 1fr;min-height:100vh}
.admin-sidebar{background:linear-gradient(180deg,var(--primary-deep) 0%,var(--primary-dark) 100%);color:var(--white);position:sticky;top:0;height:100vh;overflow-y:auto;border-right:2px solid rgba(201,168,76,0.2)}
.sidebar-header{background:rgba(0,0,0,0.2);padding:18px 16px;border-bottom:2px solid var(--secondary);text-align:center}
.sidebar-header .sidebar-logo{height:50px;width:auto;margin-bottom:8px;filter:drop-shadow(0 1px 3px rgba(0,0,0,0.3))}
.sidebar-header h3{color:var(--secondary);font-size:0.9rem;font-family:var(--font-serif)}
.sidebar-header p{font-size:0.74rem;opacity:0.65;margin-top:3px}
.sidebar-nav{padding:10px 0}
.sidebar-nav a{display:flex;align-items:center;gap:11px;padding:12px 18px;color:rgba(255,255,255,0.72);font-size:0.87rem;transition:var(--transition);border-left:3px solid transparent}
.sidebar-nav a:hover,.sidebar-nav a.active{background:rgba(201,168,76,0.10);color:var(--secondary);border-left-color:var(--secondary)}
.sidebar-nav .nav-section{font-size:0.68rem;text-transform:uppercase;letter-spacing:1.5px;color:rgba(201,168,76,0.4);padding:14px 18px 5px}
.admin-main{background:var(--light);padding:28px;overflow-y:auto}
.admin-topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:26px;flex-wrap:wrap;gap:12px;padding-bottom:16px;border-bottom:2px solid var(--gray-200)}
.admin-topbar h1{font-size:1.4rem;color:var(--primary-dark);font-family:var(--font-serif);display:flex;align-items:center;gap:10px}
.filters-bar{background:var(--white);padding:16px 20px;border-radius:var(--radius);box-shadow:var(--shadow);display:flex;gap:14px;flex-wrap:wrap;margin-bottom:18px;align-items:flex-end;border-left:4px solid var(--secondary)}
.filters-bar .form-group{flex:1;min-width:155px}

/* Steps */
.steps-indicator{display:flex;justify-content:center;gap:0;margin-bottom:34px;overflow-x:auto;padding:4px}
.step-item{display:flex;align-items:center;gap:8px;padding:10px 16px;font-size:0.83rem;color:var(--text-light);position:relative}
.step-item::after{content:'';position:absolute;right:-12px;top:50%;transform:translateY(-50%);border:7px solid transparent;border-left-color:var(--gray-200);z-index:1}
.step-item:last-child::after{display:none}
.step-num{width:30px;height:30px;border-radius:50%;background:var(--gray-200);color:var(--text-light);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:0.88rem;flex-shrink:0}
.step-item.active .step-num{background:var(--primary);color:var(--white)}
.step-item.done .step-num{background:var(--secondary);color:var(--primary-dark)}
.step-item.active{color:var(--primary-dark);font-weight:600}

/* Footer */
.main-footer{background:linear-gradient(180deg,var(--primary-deep) 0%,#030F08 100%);color:rgba(255,255,255,0.70);padding:40px 0 0;margin-top:auto;border-top:3px solid var(--secondary)}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:30px;padding-bottom:28px}
.footer-col h4{color:var(--secondary);margin-bottom:13px;display:flex;align-items:center;gap:8px;font-family:var(--font-serif);font-size:0.95rem}
.footer-col ul li{margin-bottom:7px;font-size:0.85rem}
.footer-col ul li a{color:rgba(255,255,255,0.60)}
.footer-col ul li a:hover{color:var(--secondary)}
.footer-col p{font-size:0.85rem}
.footer-col li{display:flex;align-items:center;gap:8px}
.footer-bottom{border-top:1px solid rgba(201,168,76,0.15);padding:14px 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;font-size:0.80rem}
.footer-admin-link a{color:rgba(255,255,255,0.30);font-size:0.78rem}
.footer-admin-link a:hover{color:var(--secondary)}

/* Utilitaires */
.text-center{text-align:center}.text-right{text-align:right}.text-primary{color:var(--primary)}.text-muted{color:var(--text-light)}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.text-warning{color:var(--warning)}
.mt-0{margin-top:0}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mt-4{margin-top:32px}
.mb-0{margin-bottom:0}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}
.d-flex{display:flex}.align-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:12px}.w-100{width:100%}.hidden{display:none!important}
.spinner{width:40px;height:40px;border:4px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%;animation:spin 0.8s linear infinite;margin:20px auto}
@keyframes spin{to{transform:rotate(360deg)}}

/* Responsive */
@media(max-width:992px){.admin-layout{grid-template-columns:1fr}.admin-sidebar{height:auto;position:relative}.dossier-grid{grid-template-columns:1fr}.form-grid,.form-grid-3{grid-template-columns:1fr}.col-span-2,.col-span-3{grid-column:span 1}}
@media(max-width:768px){.nav-toggle{display:flex}.nav-menu{display:none;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:var(--primary-dark);z-index:999;box-shadow:0 8px 20px rgba(0,0,0,0.25)}.nav-menu.open{display:flex}.hero h2{font-size:1.55rem}.cta-buttons{grid-template-columns:1fr 1fr}.header-contact{display:none}.header-separator{display:none}.form-container{padding:20px}.footer-bottom{flex-direction:column;text-align:center}.admin-topbar{flex-direction:column}.filters-bar{flex-direction:column}}
@media(max-width:480px){.cta-buttons{grid-template-columns:1fr}.hero{padding:40px 0 28px}.stats-grid{grid-template-columns:1fr 1fr}.header-armoiries{display:none}}
@media print{.main-header,.main-nav,.main-footer,.btn,.no-print{display:none!important}body{background:white}.card{box-shadow:none;border:1px solid #ccc}}
