/* ================================================================
   ONCFC CAMEROUN — CSS v9 | Fidèle au thème Modins (oncfc.cm)
   Polices : Raleway (700/800) + Open Sans (400/600)
   Couleurs: navy #1a2d5a | orange #f15a24 | white #fff | bg #f5f5f5
   ================================================================ */
:root {
  --navy:      #1a2d5a;
  --navy-dk:   #0f1e3d;
  --navy-lt:   #243672;
  --orange:    #f15a24;
  --orange-lt: #f47a4a;
  --orange-pale:#fff1ec;
  --white:     #ffffff;
  --bg:        #f5f5f5;
  --gray-100:  #f0f0f0;
  --gray-200:  #e0e0e0;
  --gray-400:  #aaaaaa;
  --gray-600:  #666666;
  --gray-800:  #333333;
  --dark:      #111111;
  --sh-sm: 0 2px 8px rgba(0,0,0,.08);
  --sh:    0 4px 20px rgba(0,0,0,.10);
  --sh-lg: 0 12px 40px rgba(0,0,0,.15);
  --r:     6px;
  --r-sm:  4px;
  --r-lg:  12px;
  --tr:    all .25s ease;
  --nav-h: 80px;
  --fh:    'Raleway', 'Segoe UI', sans-serif;
  --fb:    'Open Sans', 'Segoe UI', sans-serif;
}

/* RESET */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--fb);color:var(--gray-800);background:#fff;overflow-x:hidden;line-height:1.7}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
ul,ol{list-style:none}
button{cursor:pointer;border:none;outline:none;font-family:inherit;background:none}
input,select,textarea{font-family:inherit;font-size:inherit}

/* TYPO — Raleway pour tout ce qui est titre */
h1,h2,h3,h4,h5{font-family:var(--fh);line-height:1.2;color:var(--navy)}
h1{font-size:clamp(1.8rem,4vw,2.8rem);font-weight:800}
h2{font-size:clamp(1.5rem,3vw,2rem);font-weight:700}
h3{font-size:clamp(1rem,2vw,1.3rem);font-weight:700}
h4{font-size:1rem;font-weight:700}
p{color:var(--gray-600);line-height:1.8;font-size:.95rem}

/* LAYOUT */
.container{max-width:1200px;margin:0 auto;padding:0 15px}
.section{padding:100px 0}
.section-alt{background:var(--bg)}

/* SECTION HEADERS — style exact Modins */
.section-label{font-family:var(--fh);font-size:.72rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--orange);display:block;margin-bottom:.6rem}
.section-title{color:var(--navy);margin-bottom:.8rem;font-weight:800}
.section-sub{color:var(--gray-600);font-size:.92rem;margin-bottom:1.5rem}
.divider-bar{width:50px;height:3px;background:var(--orange);margin-bottom:2rem;border-radius:2px}
.divider-bar.center{margin-left:auto;margin-right:auto}
.section-header{margin-bottom:50px}
.section-header.center{text-align:center}

/* BUTTONS — style Modins */
.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.85rem 2.2rem;border-radius:var(--r-sm);font-family:var(--fh);font-size:.82rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;transition:var(--tr);white-space:nowrap;cursor:pointer}
.btn-orange{background:var(--orange);color:#fff;border:2px solid var(--orange)}
.btn-orange:hover{background:var(--orange-lt);border-color:var(--orange-lt);box-shadow:0 6px 18px rgba(241,90,36,.35)}
.btn-navy{background:var(--navy);color:#fff;border:2px solid var(--navy)}
.btn-navy:hover{background:var(--navy-lt);border-color:var(--navy-lt)}
.btn-outline-white{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.6)}
.btn-outline-white:hover{background:rgba(255,255,255,.15);border-color:#fff}
.btn-outline-navy{background:transparent;color:var(--navy);border:2px solid var(--navy)}
.btn-outline-navy:hover{background:var(--navy);color:#fff}
.btn-sm{padding:.45rem 1.1rem;font-size:.75rem}
.btn-lg{padding:.85rem 2.2rem;font-size:.88rem}

/* BADGES */
.badge{display:inline-block;padding:.18rem .55rem;border-radius:3px;font-size:.68rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;font-family:var(--fh)}
.badge-orange{background:var(--orange);color:#fff}
.badge-navy{background:var(--navy);color:#fff}
.badge-light{background:var(--gray-100);color:var(--gray-600)}

/* CARDS */
.card{background:#fff;border-radius:var(--r);box-shadow:var(--sh);overflow:hidden;transition:var(--tr)}
.card:hover{box-shadow:var(--sh-lg);transform:translateY(-3px)}
.card-body{padding:1.5rem}

/* FORMS */
.form-group{margin-bottom:1.1rem}
.form-label{display:block;font-size:.8rem;font-weight:600;color:var(--gray-800);margin-bottom:.35rem;font-family:var(--fh)}
.form-control{width:100%;padding:.7rem 1rem;border:1px solid var(--gray-200);border-radius:var(--r-sm);font-size:.9rem;transition:var(--tr);background:#fff;color:var(--dark);font-family:var(--fb)}
.form-control:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 3px rgba(241,90,36,.1)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
textarea.form-control{resize:vertical;min-height:120px}

/* GRIDS */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:30px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:30px}

/* ALERTS */
.alert{padding:.85rem 1.1rem;border-radius:var(--r-sm);font-size:.9rem;margin-bottom:1rem;border-left:3px solid}
.alert-success{background:#e8f5e9;color:#1b5e20;border-color:#4caf50}
.alert-error{background:var(--orange-pale);color:#7f1d1d;border-color:var(--orange)}

/* TABLE */
.table-wrap{overflow-x:auto;border-radius:var(--r);box-shadow:var(--sh-sm)}
.data-table{width:100%;font-size:.85rem;border-collapse:collapse}
.data-table thead tr{background:var(--navy);color:#fff}
.data-table th{padding:.75rem 1rem;text-align:left;font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;font-family:var(--fh)}
.data-table td{padding:.75rem 1rem;border-bottom:1px solid var(--gray-100);vertical-align:middle}
.data-table tbody tr:hover td{background:var(--bg)}
.data-table tbody tr:last-child td{border-bottom:none}

/* PAGINATION */
.pagination{display:flex;align-items:center;gap:.3rem;justify-content:center;margin-top:40px;flex-wrap:wrap}
.page-btn{min-width:38px;height:38px;padding:0 .6rem;border-radius:var(--r-sm);font-size:.85rem;font-weight:700;color:var(--navy);transition:var(--tr);display:flex;align-items:center;justify-content:center;font-family:var(--fh);border:1px solid var(--gray-200)}
.page-btn:hover{background:var(--orange);color:#fff;border-color:var(--orange)}
.page-btn.active{background:var(--navy);color:#fff;border-color:var(--navy)}
.page-btn.disabled{opacity:.35;pointer-events:none}

/* ═══ TOPBAR ═══ */
.topbar{background:var(--navy);color:rgba(255,255,255,.8);font-size:.8rem;padding:.5rem 0;border-bottom:none}
.topbar-inner{display:flex;justify-content:space-between;align-items:center}
.topbar-item{display:flex;align-items:center;gap:.4rem;margin-right:1.5rem;font-family:var(--fb)}
.topbar-item svg{width:13px;height:13px;stroke:var(--orange);fill:none;stroke-width:2;stroke-linecap:round;flex-shrink:0}
.topbar-left{display:flex;align-items:center}
.topbar-right{display:flex;align-items:center;gap:1rem}
.topbar-right a{color:rgba(255,255,255,.7);transition:var(--tr);font-size:.78rem}
.topbar-right a:hover{color:var(--orange)}
.lang-sw{display:flex;gap:.3rem}
.lang-btn{font-size:.72rem;font-weight:700;padding:.1rem .42rem;border-radius:3px;color:rgba(255,255,255,.5);cursor:pointer;border:1px solid transparent;font-family:var(--fh);letter-spacing:.05em}
.lang-btn.active,.lang-btn:hover{background:var(--orange);color:#fff;border-color:var(--orange)}

/* ═══ NAVBAR — style Modins exact ═══ */
.site-nav{background:#fff;position:sticky;top:0;z-index:900;box-shadow:0 2px 10px rgba(0,0,0,.08);border-bottom:3px solid var(--orange)}
.nav-inner{height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;gap:1rem}
.site-logo img{height:55px;width:auto}
.nav-menu{display:flex;align-items:center}
.nav-item{position:relative}
/* Raleway uppercase bold comme le thème */
.nav-link{display:flex;align-items:center;gap:.18rem;padding:.5rem .85rem;font-family:var(--fh);font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--navy);transition:var(--tr);white-space:nowrap;border-bottom:3px solid transparent}
.nav-link:hover,.nav-link.active{color:var(--orange);border-bottom-color:var(--orange)}
.nav-caret{font-size:.5rem;opacity:.5;transition:transform .2s;pointer-events:none}
.nav-item.open .nav-caret{transform:rotate(180deg)}

/* Dropdown */
.nav-dropdown{position:absolute;top:calc(100% + 3px);left:0;min-width:230px;background:#fff;border-top:3px solid var(--orange);box-shadow:0 8px 25px rgba(0,0,0,.12);padding:.5rem 0;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .18s,transform .18s,visibility .18s;transform:translateY(-8px);z-index:500}
.nav-item.open .nav-dropdown{opacity:1;visibility:visible;pointer-events:auto;transform:translateY(0)}
.nav-dropdown a{display:block;padding:.6rem 1.2rem;font-family:var(--fh);font-size:.75rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--navy);transition:var(--tr);border-left:3px solid transparent}
.nav-dropdown a:hover{color:var(--orange);border-left-color:var(--orange);background:var(--bg);padding-left:1.5rem}
.nav-actions{display:flex;align-items:center;gap:.5rem}
.hamburger{display:none;flex-direction:column;gap:5px;padding:6px;cursor:pointer}
.hamburger span{width:22px;height:2.5px;background:var(--navy);border-radius:2px;transition:var(--tr);display:block}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* Mobile menu */
.mobile-menu{display:none;position:fixed;inset:0;top:var(--nav-h);background:#fff;z-index:800;overflow-y:auto;border-top:3px solid var(--orange)}
.mobile-menu.open{display:block}
.mob-link{display:flex;justify-content:space-between;align-items:center;padding:.85rem 1.5rem;border-bottom:1px solid var(--gray-100);font-family:var(--fh);font-size:.8rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--navy);cursor:pointer}
.mob-link a{flex:1;color:inherit}
.mob-link:hover{color:var(--orange)}
.mob-toggle{font-size:.7rem;color:var(--gray-400);width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--gray-100);transition:var(--tr)}
.mob-toggle.open{transform:rotate(180deg);background:var(--orange);color:#fff}
.mob-sub{display:none;background:var(--bg)}
.mob-sub.open{display:block}
.mob-sub a{display:block;padding:.6rem 2rem;font-family:var(--fh);font-size:.75rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--navy);border-bottom:1px solid var(--gray-200)}
.mob-sub a:hover{color:var(--orange)}
.mob-actions{padding:1.2rem 1.5rem;display:flex;gap:.8rem}

/* ═══ TICKER ═══ */
.ticker-wrap{background:var(--navy-dk);overflow:hidden;padding:.45rem 0}
.ticker-track{display:flex;align-items:center;white-space:nowrap;animation:ticker 60s linear infinite}
.ticker-track:hover{animation-play-state:paused}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.ticker-item{display:inline-flex;align-items:center;gap:.5rem;padding:0 2rem;font-size:.78rem;color:rgba(255,255,255,.8);font-family:var(--fb)}
.ticker-sep{color:rgba(255,255,255,.25);padding:0 .3rem}
.ticker-pill{background:var(--orange);color:#fff;padding:.06rem .45rem;border-radius:2px;font-weight:700;font-size:.65rem;letter-spacing:.08em;font-family:var(--fh)}

/* ═══ PAGE HEADER ═══ */
.page-header{background:linear-gradient(135deg,var(--navy-dk) 0%,var(--navy) 60%,var(--navy-lt) 100%);color:#fff;padding:60px 0 70px;position:relative;overflow:hidden}
.page-header::after{content:'';position:absolute;bottom:0;left:0;right:0;height:4px;background:var(--orange)}
.page-header h1{color:#fff;margin-bottom:.6rem;font-size:clamp(1.8rem,4vw,2.5rem)}
.page-header p{color:rgba(255,255,255,.75);font-size:.95rem;max-width:560px}
.breadcrumb{display:flex;align-items:center;gap:.4rem;font-size:.8rem;margin-top:1.2rem;flex-wrap:wrap;font-family:var(--fh);letter-spacing:.03em}
.breadcrumb a{color:rgba(255,255,255,.55);transition:var(--tr)}
.breadcrumb a:hover{color:var(--orange)}
.breadcrumb .sep{color:rgba(255,255,255,.25);font-size:.6rem}
.breadcrumb .current{color:var(--orange)}

/* ═══ HERO SWIPER — plein écran comme Modins ═══ */
.hero{position:relative;height:100vh;min-height:580px;max-height:820px;overflow:hidden;background:var(--navy)}
.hero-slides{position:relative;width:100%;height:100%}
.hero-slide{position:absolute;inset:0;display:flex;align-items:center;opacity:0;transition:opacity .9s ease;pointer-events:none;z-index:0}
.hero-slide.active{opacity:1;pointer-events:auto;z-index:1}
.hero-slide-bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform 8s ease}
.hero-slide.active .hero-slide-bg{transform:scale(1.06)}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(15,30,61,.85) 0%,rgba(15,30,61,.5) 50%,rgba(15,30,61,.2) 100%)}
.hero-content-wrap{position:relative;z-index:2;width:100%}
/* Texte slide aligné à gauche comme Modins */
.hero-text{max-width:620px}
.hero-label{font-family:var(--fh);font-size:.72rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--orange);display:inline-block;margin-bottom:1.2rem;padding:.3rem .8rem;border:1px solid rgba(241,90,36,.4);border-radius:3px}
.hero h1{color:#fff;font-size:clamp(2rem,5vw,3.2rem);font-weight:800;line-height:1.1;margin-bottom:1.2rem}
.hero h1 span{color:var(--orange)}
.hero-desc{color:rgba(255,255,255,.75);font-size:1.1rem;line-height:1.8;margin-bottom:2.2rem;max-width:500px;font-family:var(--fb)}
.hero-btns{display:flex;gap:1rem;flex-wrap:wrap}
/* Contrôles carousel */
.hero-controls{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:.6rem;z-index:10}
.hero-dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.4);cursor:pointer;transition:var(--tr);border:none;padding:0}
.hero-dot.active{background:var(--orange);width:28px;border-radius:5px}
.hero-arrow{position:absolute;top:50%;z-index:10;transform:translateY(-50%);width:50px;height:50px;border-radius:50%;background:rgba(255,255,255,.12);border:2px solid rgba(255,255,255,.3);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--tr);font-size:1.3rem;line-height:1}
.hero-arrow:hover{background:var(--orange);border-color:var(--orange)}
.hero-arrow.prev{left:2rem}
.hero-arrow.next{right:2rem}

/* ═══ NEWS CARDS — style exact Modins ═══ */
/* Badge date en haut à gauche de l'image: "17
Sep" */
.news-card{background:#fff;border-radius:var(--r);overflow:hidden;box-shadow:var(--sh);transition:var(--tr)}
.news-card:hover{box-shadow:var(--sh-lg);transform:translateY(-3px)}
.news-card-img{position:relative;height:270px;overflow:hidden;background:var(--navy)}
.news-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.news-card:hover .news-card-img img{transform:scale(1.05)}
/* Badge date style Modins: carré orange en bas à gauche */
.news-date-badge{position:absolute;bottom:0;left:0;background:var(--orange);color:#fff;padding:.4rem .7rem;text-align:center;min-width:52px;font-family:var(--fh)}
.news-date-badge .day{font-size:1.3rem;font-weight:800;line-height:1;display:block}
.news-date-badge .month{font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;display:block}
.news-card-body{padding:1.3rem}
.news-meta{font-size:.75rem;color:var(--gray-400);margin-bottom:.6rem;font-family:var(--fh)}
.news-card-title{font-family:var(--fh);font-size:1rem;font-weight:700;color:var(--navy);line-height:1.3;margin-bottom:.8rem;transition:var(--tr)}
.news-card-title:hover{color:var(--orange)}
.news-read-more{display:inline-flex;align-items:center;gap:.3rem;color:var(--orange);font-size:.8rem;font-weight:700;font-family:var(--fh);letter-spacing:.04em;text-transform:uppercase;transition:var(--tr)}
.news-read-more:hover{gap:.5rem}

/* ═══ GOV CARDS ═══ */
.gov-card{background:#fff;border-radius:var(--r);box-shadow:var(--sh);overflow:hidden;text-align:center;transition:var(--tr)}
.gov-card:hover{transform:translateY(-3px);box-shadow:var(--sh-lg)}
.gov-card-photo{height:260px;position:relative;overflow:hidden;background:linear-gradient(135deg,var(--navy-dk),var(--navy));display:flex;align-items:center;justify-content:center;cursor:pointer}
.gov-card-photo img{width:160px;height:160px;border-radius:50%;object-fit:cover;border:4px solid rgba(255,255,255,.35);position:relative;z-index:2;transition:transform .35s}
.gov-card-photo:hover img{transform:scale(1.08)}
.gov-card-overlay{position:absolute;inset:0;background:rgba(26,45,90,0);transition:.3s;z-index:3;display:flex;align-items:center;justify-content:center;pointer-events:none}
.gov-card-photo:hover .gov-card-overlay{background:rgba(26,45,90,.55)}
.gov-card-overlay-icon{opacity:0;transition:.3s;color:#fff;font-size:2rem}
.gov-card-photo:hover .gov-card-overlay-icon{opacity:1}
.gov-card-body{padding:1.2rem 1rem}
.gov-card-name{font-family:var(--fh);font-size:.95rem;color:var(--navy);font-weight:700;margin-bottom:.3rem}
.gov-badge{display:inline-block;background:var(--orange);color:#fff;font-size:.68rem;font-weight:700;padding:.18rem .55rem;border-radius:3px;font-family:var(--fh);letter-spacing:.03em;text-transform:uppercase}

/* ═══ TABLEAU ANNUAIRE ═══ */
.tableau-agrement{font-family:monospace;font-size:.72rem;background:rgba(26,45,90,.08);color:var(--navy);padding:.12rem .5rem;border-radius:3px;white-space:nowrap;font-weight:700}

/* ═══ FOOTER — bleu marine comme oncfc.cm ═══ */
.site-footer{background:var(--navy);color:rgba(255,255,255,.65)}
/* FOOTER */
.footer-top-bar{background:var(--orange);padding:.65rem 0;text-align:center;font-family:var(--fh);font-size:.76rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#fff}
.site-footer{background:var(--navy);color:rgba(255,255,255,.65)}
.footer-grid{display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;gap:40px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer-brand img{height:42px;filter:brightness(0) invert(1);opacity:.88;margin-bottom:.9rem;display:block}
.footer-desc{font-size:.84rem;color:rgba(255,255,255,.48);line-height:1.8;margin-bottom:1.1rem}
/* Infos contact dans le footer */
.footer-contact-info{font-size:.81rem;color:rgba(255,255,255,.42);line-height:1.85}
.footer-contact-info span{display:flex;align-items:flex-start;gap:.45rem;margin-bottom:.32rem}
.footer-contact-info svg{
  width:13px;height:13px;min-width:13px;
  stroke:var(--orange);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;
  flex-shrink:0;margin-top:2px
}
/* Icônes sociales — taille fixe et proportionnée */
.social-row{display:flex;gap:.4rem;margin-top:1rem;flex-wrap:wrap}
.social-btn{
  width:32px;height:32px;
  border-radius:var(--r-sm);
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  display:inline-flex;align-items:center;justify-content:center;
  transition:var(--tr);text-decoration:none;flex-shrink:0
}
.social-btn svg{
  width:14px;height:14px;min-width:14px;max-width:14px;
  stroke:rgba(255,255,255,.65);fill:none;
  stroke-width:2;stroke-linecap:round;stroke-linejoin:round;
  display:block;flex-shrink:0
}
.social-btn:hover{background:var(--orange);border-color:var(--orange)}
.social-btn:hover svg{stroke:#fff}
/* Colonnes footer */
.footer-col h4{font-family:var(--fh);font-size:.86rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.88);margin-bottom:1.1rem;padding-bottom:.55rem;border-bottom:2px solid var(--orange)}
.footer-col a{display:block;font-family:var(--fh);font-size:.74rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:rgba(255,255,255,.42);margin-bottom:.52rem;transition:var(--tr)}
.footer-col a:hover{color:var(--orange);padding-left:.3rem}
.footer-bottom{padding:1.4rem 0;display:flex;justify-content:space-between;align-items:center;font-size:.76rem;font-family:var(--fh);font-weight:600;letter-spacing:.04em;flex-wrap:wrap;gap:.5rem;color:rgba(255,255,255,.45)}
.footer-legal{display:flex;gap:1.4rem}
.footer-legal a{color:rgba(255,255,255,.28);transition:var(--tr);font-family:var(--fh);font-size:.74rem}
.footer-legal a:hover{color:var(--orange)}
.footer-legal{display:flex;gap:1.5rem}
.footer-legal a{color:rgba(255,255,255,.3);transition:var(--tr);font-size:.75rem;font-family:var(--fh)}
.footer-legal a:hover{color:var(--orange)}

/* ═══ ADMIN ═══ */
body.admin-page{background:#f0f2f5}
.admin-wrapper{display:flex;min-height:100vh}
.admin-sidebar{width:235px;background:#1a1f2e;color:rgba(255,255,255,.72);position:fixed;top:0;left:0;bottom:0;overflow-y:auto;z-index:100;display:flex;flex-direction:column;transition:transform .22s ease}
.admin-sidebar-logo{padding:1.2rem;border-bottom:1px solid rgba(255,255,255,.07);background:var(--navy)}
.admin-sidebar-logo img{height:34px;filter:brightness(0) invert(1);opacity:.8}
.admin-sidebar-logo strong{font-size:.82rem;color:#fff;font-family:var(--fh);display:block;margin-top:.35rem}
.admin-sidebar-logo span{font-size:.68rem;color:rgba(255,255,255,.4)}
.admin-nav-sect{font-size:.6rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.22);padding:1rem 1.1rem .22rem;font-family:var(--fh)}
.admin-nav-link{display:flex;align-items:center;gap:.65rem;padding:.65rem 1.1rem;font-size:.82rem;color:rgba(255,255,255,.55);transition:var(--tr);border-left:3px solid transparent;font-family:var(--fh);font-weight:600;text-transform:uppercase;letter-spacing:.03em}
.admin-nav-link:hover,.admin-nav-link.active{background:rgba(255,255,255,.06);color:#fff;border-left-color:var(--orange)}
.admin-nav-icon{width:16px;text-align:center;font-size:.9rem}
.admin-nav-badge{margin-left:auto;background:var(--orange);color:#fff;font-size:.6rem;font-weight:700;padding:.1rem .4rem;border-radius:50px}
.admin-main{margin-left:235px;flex:1;background:#f0f2f5;min-height:100vh;display:flex;flex-direction:column}
.admin-topbar{background:#fff;border-bottom:1px solid var(--gray-200);padding:0 1.8rem;height:58px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50;border-top:3px solid var(--orange)}
.admin-topbar-title{font-size:.95rem;font-weight:700;color:var(--navy);font-family:var(--fh);text-transform:uppercase;letter-spacing:.04em}
.admin-user{display:flex;align-items:center;gap:.65rem;font-size:.83rem;color:var(--gray-600);font-family:var(--fb)}
.admin-content{padding:1.8rem;flex:1}
.admin-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.8rem}
.stat-widget{background:#fff;border-radius:var(--r);padding:1.3rem;box-shadow:var(--sh-sm);border-top:3px solid var(--navy)}
.stat-widget.orange{border-top-color:var(--orange)}
.sw-num{font-family:var(--fh);font-size:2rem;font-weight:800;color:var(--navy);line-height:1}
.stat-widget.orange .sw-num{color:var(--orange)}
.sw-label{font-size:.78rem;color:var(--gray-600);margin-top:.2rem;font-family:var(--fh);font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.admin-card{background:#fff;border-radius:var(--r);box-shadow:var(--sh-sm);overflow:hidden;margin-bottom:1.4rem}
.admin-card-header{padding:.9rem 1.3rem;border-bottom:1px solid var(--gray-100);display:flex;justify-content:space-between;align-items:center}
.admin-card-header h3{font-size:.88rem;font-weight:700;color:var(--navy);font-family:var(--fh);text-transform:uppercase;letter-spacing:.04em}
.admin-card-body{padding:1.3rem}
.table-actions{display:flex;gap:.28rem}
.filters-bar{background:#fff;border-radius:var(--r);padding:1rem 1.2rem;box-shadow:var(--sh-sm);margin-bottom:1.4rem;display:flex;gap:.9rem;flex-wrap:wrap;align-items:flex-end}
.filter-group label{display:block;font-size:.72rem;font-weight:700;color:var(--gray-800);margin-bottom:.28rem;font-family:var(--fh);text-transform:uppercase;letter-spacing:.04em}
.msg-item{padding:.85rem 1.2rem;border-bottom:1px solid var(--gray-100);transition:var(--tr);cursor:pointer}
.msg-item:hover{background:var(--bg)}
.msg-item.unread{background:rgba(241,90,36,.04);border-left:3px solid var(--orange)}

/* TOP BUTTON */
#topUpBtn{position:fixed;bottom:2rem;right:2rem;z-index:800;width:46px;height:46px;border-radius:50%;background:var(--orange);color:#fff;border:none;cursor:pointer;box-shadow:0 4px 16px rgba(241,90,36,.4);display:flex;align-items:center;justify-content:center;opacity:0;transform:translateY(12px);transition:opacity .3s,transform .3s,background .2s;pointer-events:none}
#topUpBtn.visible{opacity:1;transform:translateY(0);pointer-events:auto}
#topUpBtn:hover{background:var(--orange-lt);transform:translateY(-2px)}
#topUpBtn svg{width:18px;height:18px;stroke:#fff;fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}

/* UTILITIES */
.text-center{text-align:center}.hidden{display:none!important}
.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}
.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}
.flex-center{display:flex;align-items:center;justify-content:center}

/* ANIMATIONS */
@keyframes fadeInUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.fade-up{animation:fadeInUp .5s ease forwards;opacity:0}

/* RESPONSIVE */
@media(max-width:1100px){
  .grid-4{grid-template-columns:repeat(3,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .admin-stats-row{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:900px){
  .nav-menu,.nav-actions>.btn-navy{display:none}
  .hamburger{display:flex}
  .hero{height:70vh}
  .admin-sidebar{transform:translateX(-100%)}
  .admin-sidebar.open{transform:translateX(0)}
  .admin-main{margin-left:0}
}
@media(max-width:700px){
  .container{padding:0 15px}.section{padding:60px 0}
  .grid-2,.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}
  .form-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:2rem}
  .footer-bottom{flex-direction:column;text-align:center}
  .admin-stats-row{grid-template-columns:1fr 1fr}
}
@media(max-width:480px){
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .topbar-left .topbar-item:nth-child(n+2){display:none}
  .hero-arrow{display:none}
}

/* ═══════════════════════════════════════════════════════
   IMAGES EN DUR — Headers pages internes
   Source: oncfc.cm (images migrées en local)
═══════════════════════════════════════════════════════ */

/* Tous les page-header ont un fond navy par défaut */
.page-header {
  background: linear-gradient(135deg,var(--navy-dk) 0%,var(--navy) 60%,var(--navy-lt) 100%);
  color:#fff; padding:60px 0 70px; position:relative; overflow:hidden;
}
/* Overlay semi-transparent sur les images de fond */
.page-header::before {
  content:''; position:absolute; inset:0;
  background: linear-gradient(135deg,rgba(15,30,61,.88) 0%,rgba(26,45,90,.75) 100%);
  z-index:0;
}
.page-header::after {
  content:''; position:absolute; bottom:0; left:0; right:0;
  height:4px; background:var(--orange); z-index:2;
}
.page-header .container { position:relative; z-index:1; }
.page-header h1 { color:#fff; margin-bottom:.6rem; }
.page-header p  { color:rgba(255,255,255,.75); font-size:.95rem; max-width:560px; }

/* Image en dur — Histoire */
.page-header.ph-histoire {
  background-image: url('../images/headers/header-histoire.jpg');
  background-size:cover; background-position:center;
}
/* Image en dur — Mission */
.page-header.ph-mission {
  background-image: url('../images/headers/header-mission.jpg');
  background-size:cover; background-position:center;
}
/* Image en dur — Gouvernance */
.page-header.ph-gouvernance {
  background-image: url('../images/headers/header-gouvernance.jpg');
  background-size:cover; background-position:center top;
}
/* Image en dur — Annuaire / Team */
.page-header.ph-annuaire {
  background-image: url('../images/headers/header-annuaire.jpg');
  background-size:cover; background-position:center;
}
/* Image en dur — Galerie */
.page-header.ph-galerie {
  background-image: url('../images/headers/header-galerie.jpg');
  background-size:cover; background-position:center;
}
/* Image en dur — Actualités */
.page-header.ph-actualites {
  background-image: url('../images/headers/header-actualites.jpg');
  background-size:cover; background-position:center;
}
/* Image en dur — Contact */
.page-header.ph-contact {
  background-image: url('../images/headers/header-contact.jpg');
  background-size:cover; background-position:center;
}
/* Image en dur — Fonctionnement / Textes / Autres */
.page-header.ph-profession {
  background-image: url('../images/headers/header-profession.jpg');
  background-size:cover; background-position:center;
}

/* ═══════════════════════════════════════════════════════
   SECTION "BIENVENUE À L'ONCFC" — images about en dur
═══════════════════════════════════════════════════════ */
.about-img-1 {
  border-radius:var(--r); overflow:hidden; height:280px;
  background-color: var(--navy);
  background-image: url('../images/about-1.png');
  background-size: cover; background-position:center;
}
.about-img-2 {
  border-radius:var(--r); overflow:hidden; height:280px; margin-top:30px;
  background-color: var(--navy-lt);
  background-image: url('../images/about-2.png');
  background-size: cover; background-position:center;
}

/* ═══════════════════════════════════════════════════════
   SECTION "CE QUE NOUS FAISONS" — fond en dur
═══════════════════════════════════════════════════════ */
.section-actions {
  background-color: var(--navy);
  background-image: url('../images/bg-actions.jpg');
  background-size: cover; background-position:center;
  position:relative;
}
.section-actions::before {
  content:''; position:absolute; inset:0;
  background: rgba(15,30,61,.88);
}
.section-actions .container { position:relative; z-index:1; }

/* Cartes actions */
.action-card {
  text-align:center; padding:3.5rem 2rem;
  border:1px solid rgba(255,255,255,.12);
  border-top:3px solid var(--orange);
  border-radius:var(--r); transition:var(--tr);
  background:rgba(255,255,255,.04);
}
.action-card:hover { background:rgba(255,255,255,.09); }
.action-card h3 { color:#fff; font-family:var(--fh); font-size:1.65rem; font-weight:800; margin-bottom:1.2rem; }
.action-card p  { color:rgba(255,255,255,.65); font-size:1.05rem; line-height:1.8; margin:0; }

/* ═══════════════════════════════════════════════════════
   HERO CAROUSEL — images en dur (slides)
═══════════════════════════════════════════════════════ */
.hero-slide-1 .hero-slide-bg {
  background-image: url('../images/slides/slide1.png');
  background-color: var(--navy);
}
.hero-slide-2 .hero-slide-bg {
  background-image: url('../images/slides/slide2.png');
  background-color: var(--navy-lt);
}
.hero-slide-3 .hero-slide-bg {
  background-image: url('../images/slides/slide3.png');
  background-color: var(--navy-dk);
}
