/* VFC-MLC — Design complet refait (riche, impactant) */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap');

:root{
  --blue-900:#0f172a;
  --blue-800:#1e3a8a;
  --blue-700:#1e40af;
  --blue-600:#2563eb;
  --cyan-500:#0ea5e9;
  --cyan-400:#22d3ee;
  --slate-900:#0f172a;
  --slate-800:#1e293b;
  --slate-600:#475569;
  --slate-500:#64748b;
  --slate-400:#94a3b8;
  --slate-200:#e2e8f0;
  --white:#ffffff;
  --bg:#f8fafc;
  --bg-dark:#0f172a;

  --radius-lg:20px;
  --radius-md:14px;
  --radius-sm:10px;
  --shadow-card:0 4px 24px rgba(15,23,42,.08), 0 1px 3px rgba(15,23,42,.06);
  --shadow-card-hover:0 20px 50px rgba(15,23,42,.12), 0 4px 12px rgba(15,23,42,.08);
  --shadow-btn:0 8px 24px rgba(14,165,233,.35);
  --container:1200px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:'Plus Jakarta Sans',ui-sans-serif,system-ui,sans-serif;
  color:var(--slate-800);
  background:var(--white);
  line-height:1.6;
  font-weight:500;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}

.container{
  width:min(var(--container),calc(100% - 48px));
  margin-inline:auto;
}

/* ========== HEADER ========== */
.site-header{
  position:sticky;
  top:0;
  z-index:100;
  background:rgba(15,23,42,.95);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(255,255,255,.08);
  box-shadow:0 4px 24px rgba(0,0,0,.12);
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  padding:4px 0;
}
.brand{
  display:flex;
  align-items:center;
  gap:16px;
  flex-shrink:0;
  background:transparent;
}
.brand img{
  width:360px;
  height:auto;
  max-height:70px;
  min-width:220px;
  object-fit:contain;
  object-position:left center;
  flex-shrink:0;
  background:transparent !important;
}
.brand > div{
  display:none;
}

.nav{
  display:flex;
  align-items:center;
  gap:4px;
  flex-wrap:nowrap;
}
.nav a{
  position:relative;
  padding:10px 16px;
  border-radius:10px;
  font-weight:700;
  font-size:.95rem;
  color:rgba(255,255,255,.85);
  transition:color .2s,background .2s;
  white-space:nowrap;
}
.nav a:hover{color:#fff;background:rgba(255,255,255,.08)}
.nav a[aria-current="page"]{
  color:#fff;
  background:rgba(14,165,233,.25);
}
.nav a[aria-current="page"]::after{
  content:"";
  position:absolute;
  left:16px;right:16px;
  bottom:6px;
  height:2px;
  border-radius:2px;
  background:var(--cyan-400);
}

.header-cta .btn{
  font-weight:700;
  padding:12px 24px;
  background:linear-gradient(135deg,var(--cyan-500),#38bdf8);
  color:#0f172a;
  border:none;
  box-shadow:var(--shadow-btn);
}
.header-cta .btn:hover{transform:translateY(-1px);box-shadow:0 12px 32px rgba(14,165,233,.4)}

.nav-toggle{
  display:none;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.2);
  color:#fff;
  border-radius:10px;
  padding:10px 14px;
  font-weight:800;
  cursor:pointer;
}

/* ========== HERO (dark, full impact) ========== */
.hero{
  position:relative;
  background:linear-gradient(135deg, #0f172a 0%, #1e3a8a 45%, #1e40af 100%);
  min-height:85vh;
  display:flex;
  align-items:center;
  overflow:hidden;
}
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(ellipse 80% 50% at 20% 50%, rgba(14,165,233,.25) 0%, transparent 50%),
    radial-gradient(ellipse 60% 40% at 80% 80%, rgba(30,64,175,.4) 0%, transparent 50%);
  pointer-events:none;
}
.hero-inner{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:1.1fr .9fr;
  align-items:center;
  gap:48px;
  padding:80px 0 100px;
}
.hero .hero-text h1{
  margin:0 0 20px;
  font-size:clamp(2.8rem, 5vw, 4.2rem);
  font-weight:800;
  line-height:1.05;
  letter-spacing:-.03em;
  color:#fff;
}
.hero .hero-text .pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 16px;
  border-radius:999px;
  background:rgba(14,165,233,.2);
  border:1px solid rgba(14,165,233,.4);
  color:var(--cyan-400);
  font-weight:700;
  font-size:.9rem;
  margin-bottom:20px;
}
.hero .hero-text p{
  margin:0 0 28px;
  max-width:520px;
  font-size:1.15rem;
  line-height:1.65;
  color:rgba(255,255,255,.88);
  font-weight:500;
}
.hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  align-items:center;
}
.hero .btn-primary{
  padding:16px 32px;
  font-size:1.05rem;
  font-weight:700;
  background:linear-gradient(135deg,var(--cyan-500),#38bdf8);
  color:#0f172a;
  border:none;
  border-radius:12px;
  box-shadow:var(--shadow-btn);
  transition:transform .2s,box-shadow .2s;
}
.hero .btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 36px rgba(14,165,233,.45)}
.hero .btn-soft{
  padding:16px 28px;
  font-size:1rem;
  font-weight:700;
  background:rgba(255,255,255,.12);
  color:#fff;
  border:2px solid rgba(255,255,255,.3);
  border-radius:12px;
  backdrop-filter:blur(8px);
}
.hero .btn-soft:hover{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.5)}
.hero .breadcrumbs{color:rgba(255,255,255,.7)}
.hero .breadcrumbs a{color:var(--cyan-400)}
.hero .breadcrumbs a:hover{color:#fff}

.hero-media{
  position:relative;
  border-radius:24px;
  overflow:hidden;
  box-shadow:0 32px 80px rgba(0,0,0,.35), 0 0 0 1px rgba(255,255,255,.1);
}
.hero-media img{
  width:100%;
  height:100%;
  min-height:400px;
  object-fit:cover;
}
.hero-media .caption{
  position:absolute;
  bottom:0;
  left:0;
  right:0;
  padding:24px 28px;
  background:linear-gradient(transparent,rgba(15,23,42,.92));
  color:#fff;
  font-weight:700;
  font-size:1rem;
}

.login-panel-wrap{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:auto;
}
.login-panel-wrap .card{
  box-shadow:0 32px 80px rgba(0,0,0,.35), 0 0 0 1px rgba(255,255,255,.1);
}

/* ========== PAGE BANNER (pages internes, alternatif au hero) ========== */
.page-banner{
  position:relative;
  background:linear-gradient(135deg, #0f172a 0%, #1e3a8a 50%, #1e40af 100%);
  padding:64px 0 80px;
  overflow:hidden;
}
.page-banner::before{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(ellipse 70% 60% at 50% 30%, rgba(14,165,233,.2) 0%, transparent 60%);
  pointer-events:none;
}
.page-banner-inner{
  position:relative;
  z-index:1;
  text-align:center;
  max-width:720px;
  margin:0 auto;
}
.page-banner .pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 16px;
  border-radius:999px;
  background:rgba(14,165,233,.2);
  border:1px solid rgba(14,165,233,.4);
  color:var(--cyan-400);
  font-weight:700;
  font-size:.9rem;
  margin-bottom:20px;
}
.page-banner h1{
  margin:0 0 16px;
  font-size:clamp(2rem, 4vw, 3rem);
  font-weight:800;
  line-height:1.1;
  letter-spacing:-.02em;
  color:#fff;
}
.page-banner p{
  margin:0;
  font-size:1.1rem;
  line-height:1.6;
  color:rgba(255,255,255,.85);
}
.page-banner .breadcrumbs{
  margin-bottom:16px;
  font-size:.9rem;
  color:rgba(255,255,255,.7);
}
.page-banner .breadcrumbs a{color:var(--cyan-400)}
.page-banner .breadcrumbs a:hover{color:#fff}

/* ========== STATS STRIP ========== */
.stats-strip{
  background:var(--blue-900);
  padding:32px 0;
  margin-top:-1px;
  border-top:1px solid rgba(255,255,255,.08);
}
.stats-strip .container{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:24px;
  text-align:center;
}
.stat-item strong{
  display:block;
  font-size:2.2rem;
  font-weight:800;
  color:var(--cyan-400);
  letter-spacing:-.02em;
  margin-bottom:4px;
}
.stat-item span{
  font-size:.95rem;
  color:rgba(255,255,255,.75);
  font-weight:600;
}

/* ========== SECTIONS ========== */
section{
  padding:90px 0;
}
.section-head{
  margin-bottom:40px;
}
.section-head h2{
  margin:0 0 12px;
  font-size:clamp(1.9rem, 3vw, 2.5rem);
  font-weight:800;
  letter-spacing:-.02em;
  color:var(--slate-900);
}
.section-head p{
  margin:0;
  max-width:600px;
  font-size:1.1rem;
  color:var(--slate-600);
  font-weight:500;
}

/* ========== CARDS ========== */
.grid{display:grid;gap:24px}
.grid.cols-4{grid-template-columns:repeat(4,1fr)}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.grid.cols-2{grid-template-columns:repeat(2,1fr)}

.card{
  background:#fff;
  border:1px solid var(--slate-200);
  border-radius:var(--radius-lg);
  padding:28px;
  box-shadow:var(--shadow-card);
  transition:transform .25s,box-shadow .25s,border-color .25s;
  position:relative;
  overflow:hidden;
}
.card::before{
  content:"";
  position:absolute;
  top:0;left:0;right:0;
  height:4px;
  background:linear-gradient(90deg,var(--blue-700),var(--cyan-500));
  opacity:0;
  transition:opacity .25s;
}
.card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-card-hover);
  border-color:rgba(14,165,233,.3);
}
.card:hover::before{opacity:1}
.card h3{margin:0 0 10px;font-size:1.15rem;font-weight:800;color:var(--slate-900)}
.card p{margin:0;color:var(--slate-600);font-size:.98rem;line-height:1.55}

.icon{
  width:52px;
  height:52px;
  border-radius:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg,rgba(30,64,175,.15),rgba(14,165,233,.15));
  border:1px solid rgba(14,165,233,.25);
  color:var(--blue-700);
  font-weight:900;
  font-size:1.25rem;
  margin-bottom:16px;
}

.card-media{
  border-radius:var(--radius-md);
  overflow:hidden;
  margin-bottom:20px;
  border:1px solid var(--slate-200);
}
.card-media img{
  width:100%;
  height:200px;
  object-fit:cover;
}

.tag{
  display:inline-flex;
  padding:6px 12px;
  border-radius:8px;
  background:rgba(30,64,175,.08);
  color:var(--blue-700);
  font-weight:700;
  font-size:.85rem;
}

/* ========== BUTTONS ========== */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:14px 26px;
  border-radius:12px;
  font-weight:700;
  font-size:1rem;
  transition:transform .2s,box-shadow .2s;
  cursor:pointer;
  border:2px solid transparent;
}
.btn:active{transform:translateY(0)}
.btn-primary{
  background:linear-gradient(135deg,var(--cyan-500),#38bdf8);
  color:#0f172a;
  box-shadow:var(--shadow-btn);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(14,165,233,.4)}
.btn-outline{
  background:#fff;
  color:var(--blue-700);
  border-color:var(--blue-700);
}
.btn-outline:hover{background:var(--blue-700);color:#fff;border-color:var(--blue-700)}
.btn-soft{
  background:rgba(30,64,175,.08);
  color:var(--blue-700);
  border-color:rgba(30,64,175,.2);
}
.btn-soft:hover{background:rgba(30,64,175,.15);border-color:var(--blue-700)}
.btn-sm{padding:8px 16px;font-size:.9rem}
.btn-danger{
  background:rgba(220,38,38,.1);
  color:#b91c1c;
  border-color:rgba(220,38,38,.3);
}
.btn-danger:hover{background:rgba(220,38,38,.2);border-color:#b91c1c}

.admin-badge{
  display:inline-flex;
  padding:6px 12px;
  border-radius:8px;
  background:rgba(14,165,233,.2);
  color:var(--cyan-400);
  font-weight:700;
  font-size:.85rem;
  margin-right:8px;
}
.badge{
  display:inline-flex;
  padding:4px 10px;
  border-radius:6px;
  font-size:.8rem;
  font-weight:700;
}
.badge-ok{background:rgba(34,197,94,.15);color:#15803d}
.badge-off{background:rgba(100,116,139,.2);color:var(--slate-600)}

.admin-form .form-row{display:flex;gap:20px;flex-wrap:wrap;margin-bottom:20px}
.admin-form label{display:block;font-weight:600;margin-bottom:6px;font-size:.95rem}
.admin-form input,.admin-form textarea{width:100%;padding:12px 14px;border-radius:10px;border:2px solid var(--slate-200);font-size:1rem}
.admin-form input:focus,.admin-form textarea:focus{outline:none;border-color:var(--cyan-500)}
.admin-form .checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-weight:500}
.admin-form .checkbox-label input{width:auto}

.offres-list{display:flex;flex-direction:column;gap:16px}
.offre-card{padding:24px}
.loading-msg,.empty-msg,.err-msg{color:var(--slate-600);font-style:italic}
.err-msg{color:#b91c1c;font-style:normal}
.offre-publique{padding:24px;min-height:200px;display:flex;flex-direction:column;overflow:hidden}
.offre-publique .btn{margin-top:auto;align-self:flex-start}
.offre-publique-link{
  display:block;
  text-decoration:none;
  color:inherit;
  flex:1;
  min-width:0;
}
.offre-publique-link:hover{color:inherit}
.offre-publique-link:hover .offre-publique-cta{color:var(--cyan-500);text-decoration:underline}
.offre-publique-img{
  margin:-24px -24px 16px -24px;
  overflow:hidden;
  border-radius:20px 20px 0 0;
}
.offre-publique-img img{
  width:100%;
  height:180px;
  object-fit:cover;
}
.offre-publique-cta{
  display:inline-block;
  margin-top:8px;
  font-weight:700;
  font-size:.95rem;
  color:var(--blue-600);
  transition:color .2s;
}

/* ========== OFFRE DÉTAIL ========== */
.offre-detail-layout{
  display:grid;
  grid-template-columns:1fr 340px;
  gap:32px;
  align-items:start;
}
.offre-detail-card{padding:0;overflow:hidden}
.offre-detail-image{
  width:100%;
  max-height:320px;
  overflow:hidden;
  border-radius:var(--radius-lg) var(--radius-lg) 0 0;
}
.offre-detail-image img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.offre-detail-body{padding:28px}
.offre-detail-date{
  margin-bottom:20px;
  padding:12px 16px;
  background:rgba(14,165,233,.08);
  border-radius:var(--radius-sm);
  color:var(--slate-700);
  font-size:1rem;
}
.offre-detail-text{
  line-height:1.7;
  color:var(--slate-700);
  white-space:pre-wrap;
}
.offre-detail-text p{margin:0 0 12px}
.offre-detail-sidebar .card{padding:24px}
.page-banner-desc{font-size:1rem;opacity:.9}
@media(max-width:900px){
  .offre-detail-layout{grid-template-columns:1fr}
  .offre-detail-sidebar{order:-1}
}

.toast{
  position:fixed;
  bottom:24px;
  right:24px;
  z-index:9999;
  padding:16px 24px;
  border-radius:12px;
  font-weight:600;
  font-size:1rem;
  box-shadow:0 8px 32px rgba(0,0,0,.2);
  animation:toast-in .3s ease;
}
.toast-success{background:linear-gradient(135deg,#059669,#10b981);color:#fff}
.toast-error{background:linear-gradient(135deg,#dc2626,#ef4444);color:#fff}
@keyframes toast-in{
  from{opacity:0;transform:translateY(12px)}
  to{opacity:1;transform:translateY(0)}
}

.link{font-weight:700;color:var(--cyan-500);text-decoration:underline;text-underline-offset:4px}
.link:hover{color:var(--blue-700)}

/* ========== SECTION BACKGROUNDS ========== */
.soft{
  background:linear-gradient(180deg,#f1f5f9 0%,#fff 100%);
  border-top:1px solid var(--slate-200);
  border-bottom:1px solid var(--slate-200);
}
.cool{
  background:linear-gradient(180deg,#eff6ff 0%,#f8fafc 100%);
  border-top:1px solid rgba(30,64,175,.1);
}
.dark{
  background:linear-gradient(135deg,#0f172a 0%,#1e3a8a 100%);
  color:rgba(255,255,255,.9);
}
.dark .section-head h2{color:#fff}
.dark .section-head p{color:rgba(255,255,255,.8)}
.dark .card{
  background:rgba(255,255,255,.06);
  border-color:rgba(255,255,255,.12);
}
.dark .card:hover{border-color:rgba(14,165,233,.5)}
.dark .card h3{color:#fff}
.dark .card p{color:rgba(255,255,255,.8)}

/* ========== PROJECT CARDS ========== */
.project-card{
  padding:0;
  overflow:hidden;
}
.project-card .media{
  position:relative;
  aspect-ratio:16/10;
  overflow:hidden;
}
.project-card .media img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .4s;
}
.project-card:hover .media img{transform:scale(1.06)}
.project-card .media::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,transparent 50%,rgba(15,23,42,.85) 100%);
  pointer-events:none;
}
.project-card .content{
  padding:24px;
}
.project-card .content h3{
  font-size:1.2rem;
  margin-bottom:8px;
}
.project-card .actions{margin-top:16px}
.project-card .btn-outline{border-radius:0}

/* ========== KPIs ========== */
.kpis{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
}
.kpi{
  background:#fff;
  border:2px solid var(--slate-200);
  border-radius:var(--radius-lg);
  padding:28px;
  text-align:center;
  box-shadow:var(--shadow-card);
  transition:transform .2s,border-color .2s;
}
.kpi:hover{
  transform:translateY(-2px);
  border-color:var(--cyan-500);
}
.kpi strong{
  display:block;
  font-size:2rem;
  font-weight:800;
  color:var(--blue-700);
  letter-spacing:-.02em;
  margin-bottom:4px;
}
.kpi span{color:var(--slate-600);font-weight:600}

/* ========== SPLIT ========== */
.split{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:40px;
  align-items:start;
}

/* ========== FORMS ========== */
form{display:flex;flex-direction:column;gap:14px}
label{font-weight:700;color:var(--slate-900);font-size:.95rem}
input,select,textarea{
  width:100%;
  padding:14px 18px;
  border-radius:12px;
  border:2px solid var(--slate-200);
  background:#fff;
  font:inherit;
  font-size:1rem;
  color:var(--slate-800);
  transition:border-color .2s,box-shadow .2s;
}
textarea{min-height:140px;resize:vertical}
input:focus,select:focus,textarea:focus{
  outline:none;
  border-color:var(--cyan-500);
  box-shadow:0 0 0 4px rgba(14,165,233,.15);
}
.form-card{padding:32px}
.form-note{margin:0 0 20px;color:var(--slate-600);font-size:1rem}

/* ========== FOOTER ========== */
.site-footer{
  background:var(--blue-900);
  color:#fff;
  border-top:4px solid var(--cyan-500);
  padding:0;
}
.footer-inner{
  padding:56px 0 40px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:40px 80px;
}
.site-footer h3{
  margin:0 0 16px;
  font-size:1.1rem;
  font-weight:800;
  color:#fff;
  letter-spacing:-.01em;
}
.site-footer p,.site-footer a{
  margin:0;
  color:rgba(255,255,255,.8);
  font-weight:500;
  font-size:1rem;
}
.site-footer a:hover{color:var(--cyan-400)}
.footer-inner > div:first-child:has(p){display:none}
.footer-links{
  display:flex;
  flex-direction:row;
  flex-wrap:wrap;
  gap:24px 40px;
  align-items:center;
}
.footer-contact .footer-contact-list{
  display:flex;
  flex-direction:column;
  gap:12px;
  align-items:flex-start;
}
.footer-contact .footer-contact-list a{
  display:inline-flex;
  align-items:center;
  gap:12px;
  padding:10px 14px;
  border-radius:10px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1);
  transition:background .2s,border-color .2s;
  min-width:0;
}
.footer-contact .footer-contact-list a:hover{
  background:rgba(255,255,255,.1);
  border-color:rgba(14,165,233,.4);
}
.footer-contact .footer-icon{
  font-size:.75rem;
  font-weight:800;
  color:var(--cyan-400);
  text-transform:uppercase;
  min-width:32px;
}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.12);
  padding:20px 0;
  color:rgba(255,255,255,.6);
  font-weight:500;
  font-size:.95rem;
}
.footer-bottom-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
}
.footer-connexion{
  font-size:.85rem;
  opacity:.75;
  transition:opacity .2s;
}
.footer-connexion:hover{opacity:1}

/* ========== BREADCRUMBS ========== */
.breadcrumbs{
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
  color:var(--slate-500);
  font-weight:600;
  margin-bottom:16px;
}
.breadcrumbs a{color:var(--cyan-500)}
.breadcrumbs a:hover{text-decoration:underline}

/* ========== GALLERY ========== */
.gallery{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
.gallery .tile{
  border-radius:var(--radius-lg);
  overflow:hidden;
  border:2px solid var(--slate-200);
  box-shadow:var(--shadow-card);
  transition:transform .25s,box-shadow .25s,border-color .25s;
}
.gallery .tile:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-card-hover);
  border-color:var(--cyan-500);
}
.gallery img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3}

/* ========== CAROUSEL ========== */
.carousel-wrap{position:relative;margin-top:20px}
.carousel{position:relative;overflow:hidden;border-radius:var(--radius-lg);box-shadow:var(--shadow-card);background:var(--slate-900)}
.carousel-track{display:flex;transition:transform .4s ease-out}
.carousel-slide{flex:0 0 100%;min-width:0;cursor:pointer;position:relative}
.carousel-slide img{width:100%;height:auto;max-height:500px;object-fit:contain;display:block;transition:opacity .2s}
.carousel-slide:hover img{opacity:.95}
.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:2;width:48px;height:48px;border:0;border-radius:50%;background:rgba(255,255,255,.9);color:var(--slate-800);font-size:28px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s;box-shadow:0 2px 12px rgba(0,0,0,.15)}
.carousel-btn:hover{background:var(--white);color:var(--cyan-600)}
.carousel-prev{left:12px}
.carousel-next{right:12px}
.carousel-dots{display:flex;justify-content:center;gap:10px;margin-top:16px;flex-wrap:wrap}
.carousel-dots button{width:10px;height:10px;border-radius:50%;border:0;background:var(--slate-300);cursor:pointer;transition:background .2s,transform .2s}
.carousel-dots button:hover,.carousel-dots button.active{background:var(--cyan-500);transform:scale(1.2)}
.carousel-hint{text-align:center;font-size:.9rem;color:var(--slate-500);margin-top:10px}

/* ========== LIGHTBOX ========== */
.lightbox{position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.92);display:flex;align-items:center;justify-content:center;padding:60px;opacity:0;visibility:hidden;transition:opacity .25s,visibility .25s}
.lightbox[aria-hidden="false"]{opacity:1;visibility:visible}
.lightbox img{max-width:100%;max-height:calc(100vh - 80px);object-fit:contain}
.lightbox-close{position:absolute;top:20px;right:20px;width:48px;height:48px;border:0;border-radius:50%;background:rgba(255,255,255,.15);color:var(--white);font-size:32px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}
.lightbox-close:hover{background:rgba(255,255,255,.25)}
.lightbox-prev,.lightbox-next{position:absolute;top:50%;transform:translateY(-50%);width:56px;height:56px;border:0;border-radius:50%;background:rgba(255,255,255,.15);color:var(--white);font-size:36px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}
.lightbox-prev:hover,.lightbox-next:hover{background:rgba(255,255,255,.25)}
.lightbox-prev{left:20px}
.lightbox-next{right:20px}

/* ========== RESPONSIVE ========== */
@media (max-width: 1024px){
  .hero-inner{grid-template-columns:1fr;gap:40px;padding:60px 0 80px}
  .hero-media{min-height:380px}
  .hero .hero-text{order:1}
  .hero .hero-media{order:0}
  .hero .login-panel-wrap{order:0}
  .stats-strip .container{grid-template-columns:repeat(2,1fr)}
  .grid.cols-4{grid-template-columns:repeat(2,1fr)}
  .kpis{grid-template-columns:repeat(2,1fr)}
  .footer-inner{grid-template-columns:1fr 1fr}
}
@media (max-width: 768px){
  .container{width:min(var(--container),calc(100% - 32px));padding:0 16px}
  section{padding:48px 0}
  .section-head{margin-bottom:28px}
  .section-head h2{font-size:1.6rem}
  .section-head p{font-size:1rem}
  .hero{min-height:auto}
  .page-banner{padding:36px 0 48px}
  .page-banner h1{font-size:1.65rem}
  .page-banner p{font-size:1rem}
  .hero-inner{padding:36px 0 48px;gap:28px}
  .hero .hero-text h1{font-size:1.85rem}
  .hero .hero-text p{font-size:1rem;margin-bottom:20px}
  .hero-media{min-height:240px}
  .hero-media img{min-height:240px}
  .hero-media .caption{padding:16px 20px;font-size:.95rem}
  .hero-actions{flex-direction:column;align-items:stretch;gap:10px}
  .hero .btn-primary,.hero .btn-soft{width:100%;justify-content:center;padding:14px 24px}
  .stats-strip .container{grid-template-columns:1fr;gap:16px}
  .stats-strip{padding:24px 0}
  .stat-item strong{font-size:1.8rem}
  .stat-item span{font-size:.9rem}
  .card{padding:20px}
  .card h3{font-size:1.05rem}
  .card p{font-size:.95rem}
  .card-media img{height:160px}
  .grid{gap:16px}
  .header-cta{display:none}
  .header-inner{padding:8px 0;gap:12px}
  .brand img{width:min(200px,50vw);min-width:140px;max-height:56px}
  .nav-toggle{display:inline-flex;min-width:44px;min-height:44px}
  .nav{
    display:none;
    position:absolute;
    top:100%;
    left:0;
    right:0;
    background:var(--blue-900);
    padding:12px;
    flex-direction:column;
    border-bottom:1px solid rgba(255,255,255,.1);
  }
  .nav.is-open{display:flex}
  .nav a{padding:14px 16px;min-height:48px;display:flex;align-items:center;border-radius:10px}
  .header-inner{position:relative}
  .split{grid-template-columns:1fr;gap:24px}
  .dark .split > div:last-child{display:flex;flex-direction:column;gap:10px}
  .dark .split .btn{width:100%;justify-content:center}
  .grid.cols-3,.grid.cols-2,.grid.cols-4{grid-template-columns:1fr}
  .form-card{padding:20px}
  input,select,textarea{padding:12px 14px;font-size:16px}
  input[type="file"]{padding:10px;min-height:44px}
  .btn{padding:14px 20px;min-height:48px;font-size:1rem}
  .gallery{grid-template-columns:1fr}
  .carousel-btn{width:44px;height:44px;font-size:24px;min-width:44px;min-height:44px}
  .carousel-prev{left:8px}
  .carousel-next{right:8px}
  .carousel-slide img{max-height:280px}
  .lightbox{padding:16px}
  .lightbox-close,.lightbox-prev,.lightbox-next{width:48px;height:48px;min-width:48px;min-height:48px}
  .lightbox-prev{left:12px}
  .lightbox-next{right:12px}
  .footer-inner{grid-template-columns:1fr;gap:28px;padding:40px 0 32px}
  .footer-links{flex-direction:column;align-items:flex-start;gap:12px}
  .footer-contact .footer-contact-list a{width:100%;min-height:48px;box-sizing:border-box}
  .footer-bottom{padding:16px 0}
  .footer-bottom-inner{flex-direction:column;text-align:center;gap:8px}
  .kpis{grid-template-columns:1fr}
  .kpi{padding:20px}
  .kpi strong{font-size:1.6rem}
  .project-card .content{padding:18px}
  .offre-detail-body{padding:20px}
  .offre-publique{padding:18px;min-height:180px}
}
@media (max-width: 480px){
  .container{width:calc(100% - 24px);padding:0 12px}
  section{padding:36px 0}
  .section-head h2{font-size:1.4rem}
  .page-banner{padding:28px 0 36px}
  .page-banner h1{font-size:1.45rem}
  .hero-inner{padding:28px 0 40px}
  .hero .hero-text h1{font-size:1.6rem}
  .hero-media{min-height:200px}
  .hero-media img{min-height:200px}
  .brand img{width:min(180px,70vw);min-width:120px;max-height:50px}
  .card{padding:16px}
  .stats-strip{padding:20px 0}
  .form-card{padding:16px}
}
