/* =========================================================
   NADCI — Plateforme Placement & Formation
   Palette : Bleu (#003B7A / #0057B7) + Jaune (#FFC72C)
   ========================================================= */

:root{
    --blue-900:#001F4D;
    --blue-800:#003B7A;
    --blue-600:#0057B7;
    --blue-100:#E6F0FA;
    --blue-50:#F4F8FD;
    --yellow:#FFC72C;
    --yellow-dark:#F5A623;
    --yellow-50:#FFF9E5;
    --dark:#1A2238;
    --gray-700:#374151;
    --gray-500:#6B7280;
    --gray-300:#D1D5DB;
    --gray-100:#F3F4F6;
    --gray-50:#FAFAFC;
    --white:#FFFFFF;
    --shadow-sm:0 2px 8px rgba(15,23,42,.06);
    --shadow:0 12px 30px rgba(15,23,42,.08);
    --shadow-lg:0 24px 60px rgba(15,23,42,.12);
    --radius:14px;
    --radius-lg:22px;
    --transition:.3s cubic-bezier(.4,0,.2,1);
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
    font-family:'Inter','Poppins',system-ui,sans-serif;
    color:var(--dark);
    line-height:1.6;
    background:#F1EEEEDB;
    -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;transition:var(--transition);}
button{font-family:inherit;cursor:pointer;border:none;background:none;}
ul{list-style:none;}

.container{
    width:100%;
    max-width:1240px;
    margin:0 auto;
    padding:0 24px;
}

/* ============ TYPO ============ */
h1,h2,h3,h4,h5{font-family:'Poppins',sans-serif;font-weight:700;line-height:1.2;color:var(--dark);}
h1{font-size:clamp(2.2rem,4.5vw,3.6rem);font-weight:800;letter-spacing:-.02em;}
h2{font-size:clamp(1.8rem,3.2vw,2.6rem);letter-spacing:-.01em;}
h3{font-size:1.4rem;}
h4{font-size:1.1rem;}
.hl{color:var(--blue-600);}
.hl-y{color:var(--yellow-dark);}

/* ============ BUTTONS ============ */
.btn{
    display:inline-flex;align-items:center;justify-content:center;gap:8px;
    padding:13px 26px;
    border-radius:10px;
    font-weight:600;
    font-size:.95rem;
    transition:var(--transition);
    cursor:pointer;
    white-space:nowrap;
    border:2px solid transparent;
}
.btn-primary{background:var(--blue-800);color:var(--white);}
.btn-primary:hover{background:var(--blue-900);transform:translateY(-2px);box-shadow:0 10px 25px rgba(0,59,122,.3);}
.btn-yellow{background:var(--yellow);color:var(--blue-900);}
.btn-yellow:hover{background:var(--yellow-dark);transform:translateY(-2px);box-shadow:0 10px 25px rgba(255,199,44,.45);}
.btn-dark{background:var(--dark);color:var(--white);}
.btn-dark:hover{background:#000;transform:translateY(-2px);}
.btn-outline{background:transparent;border-color:var(--blue-800);color:var(--blue-800);}
.btn-outline:hover{background:var(--blue-800);color:var(--white);}
.btn-outline-dark{background:transparent;border-color:var(--gray-300);color:var(--dark);}
.btn-outline-dark:hover{background:var(--blue-800);border-color:var(--blue-800);color:var(--white);}
.btn-block{width:100%;}

/* ============ TOPBAR ============ */
.topbar{
    background:var(--blue-900);
    color:rgba(255,255,255,.9);
    font-size:.85rem;
    padding:8px 0;
}
.topbar-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;}
.topbar-left{display:flex;gap:24px;flex-wrap:wrap;}
.topbar-left span{display:inline-flex;align-items:center;gap:6px;}
.topbar-right{display:flex;align-items:center;gap:12px;}
.topbar-right a{color:rgba(255,255,255,.85);}
.topbar-right a:hover{color:var(--yellow);}
.sep{opacity:.4;}
.topbar-cta{background:var(--yellow);color:var(--blue-900) !important;padding:4px 14px;border-radius:6px;font-weight:600;}
.topbar-cta:hover{background:var(--white);}

/* ============ HEADER ============ */
.header{
    background:var(--white);
    box-shadow:var(--shadow-sm);
    position:sticky;top:0;z-index:1000;
    transition:var(--transition);
}
.header.scrolled{box-shadow:var(--shadow);}
.header-inner{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:16px;padding:14px 0;position:relative;min-height:78px;}

.logo{display:flex;flex-direction:row;align-items:center;gap:10px;}
.logo-mark{flex-shrink:0;}
/* Logo du HEADER uniquement : sorti du flux pour pouvoir l'agrandir sans toucher la hauteur du header ni la position du menu. */
.header .logo{position:absolute;left:0;top:50%;transform:translateY(-50%);z-index:2;}
.header .logo-mark{width:auto;height:56px;}    /* ← change SEULEMENT cette valeur pour grossir/réduire le logo du header */
.logo-text{display:flex;flex-direction:column;align-items:flex-start;text-align:left;line-height:1;}
.logo-name{font-family:'Poppins';font-weight:800;font-size:1.35rem;color:var(--blue-800);letter-spacing:-.02em;}
.logo-tag{font-size:.60rem;color:var(--gray-500);font-weight:500;margin-top:3px;letter-spacing:.04em;text-transform:uppercase;}

.nav{display:flex;gap:2px;flex-wrap:nowrap;justify-self:center;grid-column:2;}
.nav a{
    padding:8px 10px;
    border-radius:8px;
    font-weight:500;
    color:var(--gray-700);
    font-size:.88rem;
    position:relative;
    white-space:nowrap;
}
.nav a:hover{color:var(--blue-800);background:var(--blue-50);}
.nav a.active{color:var(--blue-800);}

/* Dropdown Compte */
.nav-dropdown{position:relative;}
.nav-trigger{
    display:inline-flex;align-items:center;gap:4px;
    padding:8px 10px;border-radius:8px;
    font-weight:500;color:var(--gray-700);font-size:.88rem;
    cursor:pointer;white-space:nowrap;
}
.nav-trigger::before{
    content:"";display:inline-block;
    width:8px;height:8px;border-radius:50%;
    background:var(--yellow);margin-right:4px;
}
.nav-dropdown:hover .nav-trigger{color:var(--blue-800);background:var(--blue-50);}
.nav-dropdown:hover .nav-trigger svg{transform:rotate(180deg);}
.nav-trigger svg{transition:var(--transition);}
.nav-menu{
    position:absolute;
    top:calc(100% + 12px);right:0;
    width:320px;
    background:var(--white);
    border-radius:14px;
    box-shadow:var(--shadow-lg);
    padding:10px;
    opacity:0;visibility:hidden;
    transform:translateY(-10px);
    transition:var(--transition);
    z-index:100;
    border:1px solid var(--gray-100);
}
.nav-menu::before{
    content:"";position:absolute;
    top:-6px;right:30px;
    width:12px;height:12px;
    background:var(--white);
    transform:rotate(45deg);
    border-left:1px solid var(--gray-100);
    border-top:1px solid var(--gray-100);
}
.nav-dropdown:hover .nav-menu{opacity:1;visibility:visible;transform:translateY(0);}
.nav-item{
    display:flex !important;align-items:center;gap:12px;
    padding:10px !important;
    border-radius:10px;
    background:transparent !important;
}
.nav-item:hover{background:var(--blue-50) !important;}
.ni-icon{
    width:42px;height:42px;border-radius:10px;
    display:flex;align-items:center;justify-content:center;
    flex-shrink:0;
}
.nav-item strong{display:block;font-size:.95rem;color:var(--dark);font-weight:600;}
.nav-item span{font-size:.78rem;color:var(--gray-500);}
.nav-menu-foot{
    border-top:1px solid var(--gray-100);
    margin-top:8px;padding:12px 10px 6px;
    display:flex;gap:10px;
}
.nav-menu-foot a{
    flex:1;text-align:center;
    padding:10px !important;border-radius:8px;
    font-size:.85rem !important;font-weight:600 !important;
}
.nav-menu-foot a:first-child{background:var(--blue-50) !important;color:var(--blue-800) !important;}
.nav-menu-foot a:last-child{background:var(--yellow) !important;color:var(--blue-900) !important;}

.header-cta{display:flex;gap:8px;justify-self:end;grid-column:3;}
.header-cta .btn{padding:9px 16px;font-size:.84rem;}

.burger{display:none;flex-direction:column;gap:5px;padding:8px;}
.burger span{width:26px;height:2px;background:var(--dark);transition:var(--transition);}

/* ============ HERO ============ */
.hero{
    position:relative;
    background-image:
        linear-gradient(135deg,rgba(10,22,40,.78) 0%,rgba(0,59,122,.65) 60%,rgba(0,59,122,.55) 100%),
        url('../img/hero-team.jpg');
    background-size:cover;
    background-position:center;
    background-attachment:fixed;
    overflow:hidden;
    padding:120px 0 110px;
    color:var(--white);
}
.hero-bg{
    position:absolute;
    top:-200px;right:-200px;
    width:700px;height:700px;
    background:radial-gradient(circle,rgba(255,199,44,.18),transparent 70%);
    border-radius:50%;
    z-index:0;
    pointer-events:none;
}
.hero-bg::after{
    content:"";position:absolute;
    bottom:-400px;left:-400px;
    width:600px;height:600px;
    background:radial-gradient(circle,rgba(0,87,183,.25),transparent 70%);
    border-radius:50%;
}
.hero h1{color:var(--white);}
.hero h1 .hl{color:var(--yellow);}
.hero h1 .hl-y{color:var(--yellow);}
.hero h1 .hl::after,.hero h1 .hl-y::after{background:rgba(255,199,44,.25);}
.hero-tags{color:rgba(255,255,255,.8);}
.hero-tags a{
    background:rgba(255,255,255,.12);
    border-color:rgba(255,255,255,.2);
    color:var(--white);
    backdrop-filter:blur(8px);
}
.hero-tags a:hover{background:var(--yellow);color:var(--blue-900);border-color:var(--yellow);}
.hero-inner{
    display:flex;
    flex-direction:column;
    align-items:center;
    gap:36px;
    position:relative;
    z-index:1;
    text-align:center;
}
.hero-content{
    max-width:880px;
    width:100%;
}
.hero-badge{
    display:inline-flex;align-items:center;gap:8px;
    background:var(--white);
    color:var(--blue-800);
    padding:8px 16px;
    border-radius:100px;
    font-size:.85rem;
    font-weight:600;
    box-shadow:var(--shadow-sm);
    margin-bottom:24px;
}
.hero-badge .dot{
    width:8px;height:8px;border-radius:50%;
    background:var(--yellow);
    box-shadow:0 0 0 4px rgba(255,199,44,.25);
    animation:pulse 1.6s infinite;
}
@keyframes pulse{
    0%,100%{box-shadow:0 0 0 4px rgba(255,199,44,.25);}
    50%{box-shadow:0 0 0 8px rgba(255,199,44,.05);}
}

.hero-content h1{margin-bottom:22px;letter-spacing:-.025em;}
.hero-content h1 .hl,
.hero-content h1 .hl-y{
    position:relative;display:inline-block;
}
.hero-content h1 .hl::after{
    content:"";position:absolute;
    left:0;right:0;bottom:6px;height:10px;
    background:rgba(0,87,183,.18);
    z-index:-1;border-radius:4px;
}
.hero-content h1 .hl-y::after{
    content:"";position:absolute;
    left:0;right:0;bottom:6px;height:10px;
    background:rgba(255,199,44,.45);
    z-index:-1;border-radius:4px;
}
.hero-sub{
    font-size:1.15rem;color:var(--gray-700);
    margin:0 auto 30px;max-width:660px;
    line-height:1.65;
}

/* mini-stats removed */

.search-wrap{
    position:relative;
    background:var(--white);
    padding:14px;
    border-radius:18px;
    box-shadow:0 25px 60px rgba(0,59,122,.18), 0 8px 20px rgba(0,59,122,.08);
    border:2px solid var(--yellow);
    width:100%;
}
.search-wrap::before{
    content:"";
    position:absolute;
    inset:-2px;
    border-radius:18px;
    background:linear-gradient(135deg,var(--yellow),var(--blue-600));
    z-index:-1;
    opacity:.4;
    filter:blur(20px);
}
.search-label{
    position:absolute;
    top:-14px;left:24px;
    background:var(--blue-800);
    color:var(--white);
    padding:5px 14px;
    border-radius:100px;
    font-size:.78rem;
    font-weight:700;
    letter-spacing:.05em;
    text-transform:uppercase;
    display:inline-flex;align-items:center;gap:6px;
    box-shadow:0 6px 14px rgba(0,59,122,.3);
}
.search-bar{
    background:var(--white);
    border-radius:14px;
    display:flex;
    align-items:stretch;
    gap:0;
    flex-wrap:wrap;
}
.search-field{
    flex:1;min-width:200px;
    display:flex;flex-direction:column;
    padding:10px 18px;
    background:var(--white);
    border-radius:10px;
    transition:var(--transition);
}
.search-field:hover{background:var(--blue-50);}
.search-field label{
    font-size:.72rem;font-weight:700;
    color:var(--blue-800);
    text-transform:uppercase;
    letter-spacing:.08em;
    margin-bottom:4px;
}
.sf-input{
    display:flex;align-items:center;gap:10px;
}
.sf-input svg{color:var(--yellow-dark);flex-shrink:0;}
.search-field input,
.search-field select{
    flex:1;border:none;background:transparent;
    padding:6px 0;
    font-size:1rem;color:var(--dark);
    font-family:inherit;font-weight:500;
    outline:none;
    width:100%;
}
.search-field input::placeholder{color:#9CA3AF;}
.search-field select{cursor:pointer;}
.search-divider{
    width:1px;background:var(--gray-100);
    margin:8px 0;
}
.search-btn{
    padding:0 28px;
    border-radius:12px;
    margin:6px;
    font-size:1rem;
    font-weight:700;
    box-shadow:0 8px 20px rgba(255,199,44,.45);
    min-height:60px;
}
.search-btn:hover{
    box-shadow:0 12px 28px rgba(255,199,44,.6);
}

@media (max-width:640px){
    .search-bar{flex-direction:column;}
    .search-divider{width:auto;height:1px;margin:0 16px;}
    .search-btn{margin:6px;width:calc(100% - 12px);min-height:54px;}
}

.hero-tags{display:flex;flex-wrap:wrap;gap:8px;align-items:center;justify-content:center;font-size:.88rem;color:var(--gray-500);}
.hero-tags a{
    background:var(--white);
    padding:5px 12px;
    border-radius:100px;
    color:var(--blue-800);
    font-weight:500;
    border:1px solid var(--blue-100);
}
.hero-tags a:hover{background:var(--blue-800);color:var(--white);border-color:var(--blue-800);}

/* hero visual (removed) */

/* ============ OFFRES DISPONIBLES ============ */
.offers-section{
    background:linear-gradient(180deg,var(--white) 0%,var(--blue-50) 100%);
    padding-top:70px;
}
.offers-head{
    display:flex;justify-content:space-between;align-items:flex-end;
    flex-wrap:wrap;gap:20px;
    margin-bottom:30px;
}
.offers-head .eyebrow{margin-bottom:14px;}
.offers-head h2{margin-bottom:8px;}
.offers-head p{color:var(--gray-500);}
.offers-all{padding:12px 22px;font-size:.9rem;}

.offers-tabs{margin-bottom:30px;justify-content:flex-start;}
.offers-tabs .tab span{font-weight:400;opacity:.7;margin-left:4px;}

.offers-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:20px;
}

.offer-card{
    background:var(--white);
    border-radius:16px;
    padding:22px;
    border:1px solid var(--gray-100);
    transition:var(--transition);
    position:relative;
    display:flex;flex-direction:column;
}
.offer-card.hide{display:none;}
.offer-card::before{
    content:"";position:absolute;
    inset:0;border-radius:16px;
    border:2px solid transparent;
    transition:var(--transition);
    pointer-events:none;
}
.offer-card:hover{
    transform:translateY(-6px);
    box-shadow:var(--shadow-lg);
}
.offer-card:hover::before{border-color:var(--yellow);}

.offer-top{
    display:flex;justify-content:space-between;align-items:center;
    margin-bottom:14px;
}
.offer-logo{
    width:48px;height:48px;
    border-radius:12px;
    display:flex;align-items:center;justify-content:center;
    color:var(--white);
    font-family:'Poppins';font-weight:700;font-size:.95rem;
    letter-spacing:.05em;
}
.offer-urgent{
    align-self:flex-start;
    background:linear-gradient(135deg,#FF5A5F 0%,#DC2626 100%);
    color:#fff;
    padding:5px 13px 5px 11px;border-radius:30px;
    font-size:.68rem;font-weight:800;
    text-transform:uppercase;letter-spacing:.06em;
    display:inline-flex;align-items:center;gap:6px;
    margin-bottom:12px;
    box-shadow:0 4px 12px rgba(220,38,38,.32);
}
.offer-urgent::before{
    content:"";width:7px;height:7px;border-radius:50%;
    background:#fff;flex-shrink:0;
    animation:pulse-red 1.5s infinite;
}
@keyframes pulse-red{
    0%{box-shadow:0 0 0 0 rgba(255,255,255,.75);}
    70%{box-shadow:0 0 0 6px rgba(255,255,255,0);}
    100%{box-shadow:0 0 0 0 rgba(255,255,255,0);}
}

.offer-cat{
    display:inline-block;
    background:var(--blue-50);color:var(--blue-800);
    padding:3px 10px;border-radius:6px;
    font-size:.72rem;font-weight:600;
    margin-bottom:10px;
    text-transform:uppercase;letter-spacing:.04em;
}
.offer-card h4{
    font-size:1.05rem;line-height:1.35;margin-bottom:6px;
    min-height:2.7em;
}
.offer-company{
    color:var(--gray-500);font-size:.85rem;font-weight:500;
    margin-bottom:14px;
}
.offer-meta{
    display:flex;flex-direction:column;gap:7px;
    margin-bottom:18px;
    padding:14px;
    background:var(--gray-50);
    border-radius:10px;
    flex:1;
}
.offer-meta li{
    display:flex;align-items:center;gap:8px;
    font-size:.8rem;color:var(--gray-700);
}
.offer-meta svg{color:var(--blue-600);flex-shrink:0;}

.offer-foot{
    display:flex;justify-content:space-between;align-items:center;
    padding-top:14px;
    border-top:1px dashed var(--gray-100);
    gap:10px;
}
.offer-salary{
    font-family:'Poppins';
    font-weight:700;font-size:.85rem;
    color:var(--dark);
}
.offer-btn{
    background:var(--blue-800);color:var(--white);
    padding:8px 16px;border-radius:8px;
    font-weight:600;font-size:.82rem;
    transition:var(--transition);
    white-space:nowrap;
}
.offer-btn:hover{
    background:var(--yellow);color:var(--blue-900);
    transform:translateX(2px);
}

.offers-bottom{
    margin-top:40px;
    background:linear-gradient(135deg,var(--blue-800),var(--blue-600));
    color:var(--white);
    padding:26px 36px;
    border-radius:16px;
    display:flex;justify-content:space-between;align-items:center;
    flex-wrap:wrap;gap:20px;
    box-shadow:0 20px 40px rgba(0,59,122,.2);
}
.offers-counter strong{
    display:block;
    font-family:'Poppins';font-size:2.2rem;font-weight:800;
    color:var(--yellow);line-height:1;margin-bottom:4px;
}
.offers-counter span{opacity:.9;font-size:.95rem;}
.offers-bottom .btn{background:var(--yellow);color:var(--blue-900);}
.offers-bottom .btn:hover{background:var(--white);}

@media (max-width:1024px){
    .offers-grid{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:768px){
    .offers-grid{grid-template-columns:1fr;}
    .offers-head{flex-direction:column;align-items:flex-start;}
    .offers-bottom{flex-direction:column;text-align:center;}
}

/* ============ SECTIONS GENERIC ============ */
.section{padding:90px 0;}
.section-alt{background:transparent;}
.section-dark{background:var(--blue-900);color:var(--white);}
.section-dark h2{color:var(--white);}

.section-head{text-align:center;max-width:680px;margin:0 auto 60px;}
.section-head.light h2{color:var(--white);}
.eyebrow{
    display:inline-block;
    text-transform:uppercase;
    letter-spacing:.15em;
    font-size:.78rem;
    font-weight:700;
    color:var(--blue-600);
    margin-bottom:14px;
    padding:5px 14px;
    background:var(--blue-100);
    border-radius:100px;
}
.eyebrow.yellow{background:rgba(255,199,44,.18);color:var(--yellow);}
.section-head p{color:var(--gray-500);font-size:1.05rem;margin-top:16px;}
.section-cta{text-align:center;margin-top:50px;}

/* ============ SERVICES ============ */
.services-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:24px;
}
.service-card{
    background:var(--white);
    padding:36px 30px;
    border-radius:var(--radius-lg);
    border:1px solid var(--gray-100);
    transition:var(--transition);
    position:relative;
    overflow:hidden;
}
.service-card::before{
    content:"";position:absolute;
    top:0;left:0;right:0;height:4px;
    background:linear-gradient(90deg,var(--blue-600),var(--yellow));
    transform:scaleX(0);transform-origin:left;
    transition:var(--transition);
}
.service-card:hover{
    transform:translateY(-8px);
    box-shadow:var(--shadow-lg);
    border-color:transparent;
}
.service-card:hover::before{transform:scaleX(1);}
.service-card.highlight{
    background:linear-gradient(135deg,var(--blue-800),var(--blue-600));
    color:var(--white);
    border:none;
}
.service-card.highlight h3,
.service-card.highlight p{color:var(--white);}
.service-card.highlight .sc-icon{background:rgba(255,255,255,.15);color:var(--yellow);}
.service-card.highlight .sc-link{color:var(--yellow);}
.sc-badge{
    position:absolute;top:18px;right:18px;
    background:var(--yellow);color:var(--blue-900);
    padding:4px 12px;border-radius:100px;
    font-size:.72rem;font-weight:700;
    text-transform:uppercase;letter-spacing:.05em;
}
.sc-icon{
    width:64px;height:64px;
    background:var(--blue-100);
    color:var(--blue-800);
    border-radius:16px;
    display:flex;align-items:center;justify-content:center;
    margin-bottom:22px;
}
.service-card h3{margin-bottom:10px;}
.service-card p{color:var(--gray-500);margin-bottom:18px;font-size:.95rem;}
.sc-link{
    color:var(--blue-800);font-weight:600;font-size:.9rem;
    display:inline-flex;align-items:center;gap:4px;
}
.sc-link:hover{gap:10px;}

/* ============ ESPACES ACTEURS ============ */
.actors-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:24px;
}
.actor-card{
    background:var(--white);
    padding:0;
    border-radius:var(--radius-lg);
    overflow:hidden;
    box-shadow:var(--shadow-sm);
    transition:var(--transition);
    display:flex;flex-direction:column;
}
.actor-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);}
.actor-head{
    padding:36px 30px 30px;
    color:var(--white);
    text-align:center;
    position:relative;
}
.actor-head::after{
    content:"";position:absolute;bottom:-1px;left:0;right:0;height:30px;
    background:var(--white);
    clip-path:polygon(0 100%,100% 100%,100% 0,50% 100%,0 0);
}
.actor-blue .actor-head{background:linear-gradient(135deg,var(--blue-600),var(--blue-800));}
.actor-yellow .actor-head{background:linear-gradient(135deg,var(--yellow),var(--yellow-dark));}
.actor-yellow .actor-head{color:var(--blue-900);}
.actor-blue-dark .actor-head{background:linear-gradient(135deg,var(--blue-800),var(--blue-900));}
.actor-icon{
    width:72px;height:72px;
    background:rgba(255,255,255,.2);
    border-radius:20px;
    margin:0 auto 18px;
    display:flex;align-items:center;justify-content:center;
}
.actor-yellow .actor-icon{background:rgba(255,255,255,.4);}
.actor-head h3{color:inherit;margin-bottom:6px;}
.actor-head p{font-size:.92rem;opacity:.9;}

.actor-list{padding:30px 30px 24px;flex:1;}
.actor-list li{
    padding:10px 0;
    color:var(--gray-700);
    font-size:.94rem;
    display:flex;align-items:center;gap:10px;
}
.actor-list li span{
    width:18px;height:18px;flex-shrink:0;
    background:var(--blue-100);
    border-radius:50%;
    position:relative;
}
.actor-list li span::after{
    content:"";position:absolute;
    top:50%;left:50%;
    width:6px;height:3px;
    border-left:2px solid var(--blue-800);
    border-bottom:2px solid var(--blue-800);
    transform:translate(-50%,-65%) rotate(-45deg);
}
.actor-yellow .actor-list li span{background:var(--yellow-50);}
.actor-yellow .actor-list li span::after{border-color:var(--yellow-dark);}

.actor-btn{margin:0 30px 30px;}

/* ============ FORMATIONS ============ */
.filter-tabs{
    display:flex;justify-content:center;
    gap:10px;flex-wrap:wrap;
    margin-bottom:40px;
}
.tab{
    padding:10px 20px;
    border-radius:100px;
    background:var(--white);
    color:var(--gray-700);
    font-weight:500;font-size:.9rem;
    border:1px solid var(--gray-300);
    transition:var(--transition);
}
.tab:hover{border-color:var(--blue-800);color:var(--blue-800);}
.tab.active{background:var(--blue-800);color:var(--white);border-color:var(--blue-800);}

.formations-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:24px;
}
.formation-card{
    background:var(--white);
    border-radius:var(--radius);
    overflow:hidden;
    box-shadow:var(--shadow-sm);
    transition:var(--transition);
    border:1px solid var(--gray-100);
    display:flex;flex-direction:column;
}
.formation-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);}
.formation-card.hide{display:none;}
.fc-image{
    height:160px;position:relative;
    display:flex;align-items:flex-end;
    padding:14px;
    background-size:cover !important;
    background-position:center !important;
}
.fc-tag{
    position:absolute;top:14px;right:14px;
    background:var(--yellow);color:var(--blue-900);
    padding:4px 10px;border-radius:6px;
    font-size:.72rem;font-weight:700;
}
.fc-cat{
    background:rgba(255,255,255,.2);backdrop-filter:blur(8px);
    color:var(--white);
    padding:4px 12px;border-radius:6px;
    font-size:.78rem;font-weight:600;
}
.fc-body{padding:22px;display:flex;flex-direction:column;flex:1;}
.fc-body h4{margin-bottom:8px;line-height:1.3;}
.fc-body p{color:var(--gray-500);font-size:.88rem;margin-bottom:14px;flex:1;}
.fc-meta{
    display:flex;flex-wrap:wrap;gap:6px;align-items:center;
    color:var(--gray-500);font-size:.82rem;
    padding-bottom:16px;border-bottom:1px solid var(--gray-100);
    margin-bottom:14px;
}
.fc-btn{
    align-self:flex-start;
    background:var(--blue-50);
    color:var(--blue-800);
    padding:8px 16px;border-radius:8px;
    font-weight:600;font-size:.88rem;
}
.fc-btn:hover{background:var(--blue-800);color:var(--white);}

/* ============ SECTEURS ============ */
.sectors-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:18px;
}
.sector{
    background:var(--white);
    padding:24px 22px;
    border-radius:var(--radius);
    border:1px solid var(--gray-100);
    transition:var(--transition);
    cursor:pointer;
    display:flex;align-items:center;gap:14px;
    position:relative;
    overflow:hidden;
}
.sector::before{
    content:"";position:absolute;
    inset:0;
    background:linear-gradient(135deg,var(--blue-800),var(--blue-600));
    opacity:0;
    transition:var(--transition);
}
.sector:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:transparent;color:var(--white);}
.sector:hover::before{opacity:1;}
.sector svg,.sector span,.sector small{position:relative;z-index:1;transition:var(--transition);}
.sector svg{
    color:var(--blue-800);
    flex-shrink:0;
    width:36px;height:36px;
    padding:6px;
    background:var(--blue-50);
    border-radius:10px;
}
.sector:hover svg{background:rgba(255,255,255,.2);color:var(--yellow);}
.sector span{font-weight:600;display:block;font-size:.92rem;}
.sector small{display:block;color:var(--gray-500);font-size:.78rem;margin-top:2px;}
.sector:hover small{color:rgba(255,255,255,.85);}

/* ============ POURQUOI ============ */
.why-grid{
    display:grid;
    grid-template-columns:1fr 1.2fr;
    gap:60px;
    align-items:center;
}
.why-img{
    position:relative;
    height:480px;
    background:linear-gradient(135deg,var(--blue-50),var(--blue-100));
    border-radius:var(--radius-lg);
    display:flex;align-items:center;justify-content:center;
    overflow:hidden;
}
.why-photo{
    position:absolute;inset:0;
    width:100%;height:100%;
    object-fit:cover;
    z-index:0;
}
.why-img::after{
    content:"";position:absolute;inset:0;
    background:linear-gradient(135deg,rgba(0,59,122,.55),rgba(0,87,183,.35));
    z-index:0;
}
.why-shape{
    position:absolute;
    width:300px;height:300px;
    background:linear-gradient(135deg,var(--yellow),var(--yellow-dark));
    border-radius:50%;
    opacity:.7;
    top:50%;left:50%;
    transform:translate(-50%,-50%);
    animation:pulse-bg 4s ease-in-out infinite;
}
@keyframes pulse-bg{
    0%,100%{transform:translate(-50%,-50%) scale(1);opacity:.7;}
    50%{transform:translate(-50%,-50%) scale(1.1);opacity:.5;}
}
.why-card{
    position:relative;z-index:1;
    background:var(--white);
    padding:34px 40px;
    border-radius:var(--radius);
    box-shadow:var(--shadow-lg);
    text-align:center;
}
.why-card strong{
    display:block;
    font-family:'Poppins';
    font-size:4.2rem;
    font-weight:800;
    color:var(--blue-800);
    line-height:1;
    margin-bottom:10px;
}
.why-card span{color:var(--gray-700);font-size:1rem;}

.why-lead{font-size:1.05rem;color:var(--gray-700);margin:18px 0 30px;}
.why-list li{
    display:flex;gap:16px;
    margin-bottom:22px;
    align-items:flex-start;
}
.wl-icon{
    flex-shrink:0;
    width:40px;height:40px;
    background:var(--yellow);
    color:var(--blue-900);
    border-radius:50%;
    display:flex;align-items:center;justify-content:center;
}
.why-list strong{display:block;color:var(--dark);font-size:1.05rem;margin-bottom:3px;}
.why-list span{color:var(--gray-500);font-size:.92rem;}

/* ============ TÉMOIGNAGES ============ */
.testimonials-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:24px;
}
.testimonial{
    background:rgba(255,255,255,.05);
    border:1px solid rgba(255,255,255,.1);
    padding:34px 28px;
    border-radius:var(--radius);
    backdrop-filter:blur(10px);
    transition:var(--transition);
}
.testimonial:hover{background:rgba(255,255,255,.08);transform:translateY(-4px);}
.quote{margin-bottom:14px;}
.testimonial p{
    font-size:1.02rem;line-height:1.6;
    margin-bottom:24px;
    color:rgba(255,255,255,.9);
    font-style:italic;
}
.t-author{display:flex;align-items:center;gap:14px;}
.t-avatar{
    width:48px;height:48px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    font-weight:700;
    flex-shrink:0;
    object-fit:cover;
    border:2px solid var(--yellow);
}
.t-author strong{display:block;color:var(--white);}
.t-author span{font-size:.85rem;color:rgba(255,255,255,.6);}

/* ============ BLOG ============ */
.blog-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:30px;
}
.blog-card{
    background:var(--white);
    border-radius:var(--radius);
    overflow:hidden;
    box-shadow:var(--shadow-sm);
    transition:var(--transition);
    border:1px solid var(--gray-100);
}
.blog-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);}
.blog-img{
    height:200px;
    display:flex;align-items:center;justify-content:center;
    color:var(--white);
    font-family:'Poppins';font-weight:700;font-size:1.4rem;
    letter-spacing:.05em;
    text-transform:uppercase;
    background-size:cover !important;
    background-position:center !important;
    text-shadow:0 2px 8px rgba(0,0,0,.4);
}
.blog-body{padding:26px;}
.blog-cat{
    display:inline-block;
    background:var(--yellow-50);
    color:var(--yellow-dark);
    padding:4px 10px;border-radius:6px;
    font-size:.74rem;font-weight:700;
    text-transform:uppercase;
    margin-bottom:12px;letter-spacing:.05em;
}
.blog-card h4{margin-bottom:10px;line-height:1.35;}
.blog-card p{color:var(--gray-500);font-size:.92rem;margin-bottom:14px;}
.blog-card a{color:var(--blue-800);font-weight:600;font-size:.9rem;}
.blog-card a:hover{color:var(--yellow-dark);}

/* ============ CTA BAND ============ */
.cta-band{
    background:linear-gradient(135deg,var(--blue-800),var(--blue-600));
    color:var(--white);
    padding:60px 0;
    position:relative;
    overflow:hidden;
}
.cta-band::before{
    content:"";position:absolute;
    top:-100px;right:-100px;width:400px;height:400px;
    background:radial-gradient(circle,rgba(255,199,44,.2),transparent 70%);
    border-radius:50%;
}
.cta-inner{
    display:grid;grid-template-columns:1.2fr 1fr;
    gap:40px;align-items:center;
    position:relative;z-index:1;
}
.cta-inner h2{color:var(--white);margin-bottom:12px;}
.cta-inner p{opacity:.9;}
.cta-form{display:flex;gap:10px;}
.cta-form input{
    flex:1;
    padding:16px 20px;
    border:none;border-radius:10px;
    font-size:.95rem;
    font-family:inherit;
    outline:none;
}

/* ============ CONTACT ============ */
.contact-grid{
    display:grid;
    grid-template-columns:1fr 1.1fr;
    gap:60px;
    align-items:flex-start;
}
.contact-list{margin-top:30px;}
.contact-list li{
    display:flex;gap:16px;
    padding:16px 0;
    border-bottom:1px solid var(--gray-100);
}
.contact-list li:last-child{border-bottom:none;}
.ci-icon{
    width:46px;height:46px;
    background:var(--blue-50);color:var(--blue-800);
    border-radius:12px;
    display:flex;align-items:center;justify-content:center;
    flex-shrink:0;
}
.contact-list strong{display:block;margin-bottom:3px;}
.contact-list span{color:var(--gray-500);font-size:.92rem;}

.contact-form{
    background:var(--white);
    padding:40px;
    border-radius:var(--radius-lg);
    box-shadow:var(--shadow);
    border:1px solid var(--gray-100);
}
.contact-form h3{margin-bottom:24px;}
.contact-form .row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.field{margin-bottom:16px;}
.field label{display:block;font-size:.85rem;font-weight:600;margin-bottom:6px;color:var(--gray-700);}
.field input,.field select,.field textarea{
    width:100%;
    padding:12px 14px;
    border:1px solid var(--gray-300);
    border-radius:10px;
    font-size:.95rem;
    font-family:inherit;
    background:var(--white);
    transition:var(--transition);
    outline:none;
    color:var(--dark);
}
.field input:focus,.field select:focus,.field textarea:focus{
    border-color:var(--blue-800);
    box-shadow:0 0 0 3px rgba(0,59,122,.1);
}
.field textarea{resize:vertical;min-height:100px;}

/* Barre de filtres (offres / formations) — responsive */
.vfilter{display:grid;grid-template-columns:2fr 1fr 1fr 1fr auto;gap:12px;align-items:end;
    background:#fff;padding:20px;border-radius:14px;box-shadow:0 4px 12px rgba(0,0,0,.04);margin-bottom:24px;}
.vfilter .field{margin-bottom:0;}
.vfilter .btn{white-space:nowrap;}
[data-ajax-results]{transition:opacity .15s;}
[data-ajax-results].is-loading{opacity:.45;pointer-events:none;}
@media(max-width:900px){
    .vfilter{grid-template-columns:1fr 1fr;}
    .vfilter-kw{grid-column:1 / -1;}
    .vfilter .btn{grid-column:1 / -1;width:100%;}
}
@media(max-width:520px){
    .vfilter{grid-template-columns:1fr;}
}

/* Recherche pro */
.search-filter{display:grid;grid-template-columns:repeat(auto-fit,minmax(165px,1fr));gap:12px;align-items:end;
    background:#fff;padding:20px;border-radius:14px;box-shadow:0 4px 12px rgba(0,0,0,.04);margin:20px 0 24px;}
.search-filter .field{margin-bottom:0;}
.search-filter .sf-actions{display:flex;align-items:end;}
.search-group-head h2{display:flex;align-items:center;gap:10px;margin:0 0 14px;font-size:1.4rem;}
.search-group-head h2 span{font-size:13px;font-weight:700;background:var(--blue-50);color:var(--blue-800);padding:3px 12px;border-radius:20px;}
@media(max-width:640px){ .search-filter{grid-template-columns:1fr 1fr;} .search-filter .field[style*="span 2"]{grid-column:1 / -1 !important;} .search-filter .sf-actions{grid-column:1 / -1;} }

/* Pagination NADCI */
.nadci-pagination{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;align-items:center;margin:10px 0 40px;}
.nadci-pagination .np-link{display:inline-flex;align-items:center;justify-content:center;
    min-width:40px;height:40px;padding:0 12px;border-radius:10px;
    border:1px solid #E2E8F0;background:#fff;color:var(--blue-800);
    font-weight:600;font-size:14px;text-decoration:none;transition:background .15s,border-color .15s,color .15s,transform .12s;}
.nadci-pagination a.np-link:hover{background:var(--blue-50);border-color:var(--blue-600);transform:translateY(-1px);}
.nadci-pagination .np-link.is-active{background:var(--blue-800);border-color:var(--blue-800);color:#fff;box-shadow:0 4px 12px rgba(0,59,122,.25);}
.nadci-pagination .np-link.is-disabled{opacity:.4;cursor:not-allowed;color:var(--gray-500);}
.nadci-pagination .np-dots{padding:0 4px;color:var(--gray-500);font-weight:600;}
/* Cases à cocher / boutons radio : taille naturelle (sinon étirés en pleine largeur) */
.field input[type="checkbox"],.field input[type="radio"]{
    width:auto;
    padding:0;
    margin:0;
    flex-shrink:0;
    accent-color:var(--blue-800);
    cursor:pointer;
}

/* ============ FOOTER ============ */
.footer{
    background:var(--dark);
    color:rgba(255,255,255,.75);
    padding:80px 0 24px;
}
.footer-grid{
    display:grid;
    grid-template-columns:1.5fr repeat(4,1fr);
    gap:40px;
    margin-bottom:50px;
}
.footer-brand p{margin:18px 0 24px;font-size:.92rem;line-height:1.7;}
.logo-light .logo-name{color:var(--white);}
.logo-light .logo-tag{color:rgba(255,255,255,.6);}
.socials{display:flex;gap:10px;}
.socials a{
    width:38px;height:38px;
    border-radius:50%;
    background:rgba(255,255,255,.08);
    color:var(--white);
    display:flex;align-items:center;justify-content:center;
}
.socials a:hover{background:var(--yellow);color:var(--blue-900);transform:translateY(-3px);}

.footer-col h5{
    color:var(--white);
    font-size:1rem;
    margin-bottom:18px;
    position:relative;
    padding-bottom:10px;
}
.footer-col h5::after{
    content:"";position:absolute;bottom:0;left:0;
    width:30px;height:2px;background:var(--yellow);
}
.footer-col ul li{margin-bottom:10px;}
.footer-col a{font-size:.92rem;color:rgba(255,255,255,.7);}
.footer-col a:hover{color:var(--yellow);padding-left:5px;}
.contact-foot li{font-size:.92rem;color:rgba(255,255,255,.7);}

.footer-bottom{
    border-top:1px solid rgba(255,255,255,.08);
    padding-top:24px;
    display:flex;justify-content:space-between;
    flex-wrap:wrap;gap:16px;
    font-size:.88rem;
}
.footer-bottom div{display:flex;gap:24px;}

/* ============ FLOATING ESPACES (LEFT) ============ */
.floating-spaces{
    position:fixed;
    top:50%;left:0;
    transform:translateY(-50%);
    z-index:998;
    display:flex;align-items:flex-start;
    /* Le panneau fermé occupe l'espace (visibility:hidden) : sans ceci, le
       conteneur recouvre la colonne de gauche et bloque les clics. */
    pointer-events:none;
}
.fs-toggle,
.floating-spaces.open .fs-panel{
    pointer-events:auto;
}
.fs-toggle{
    background:linear-gradient(135deg,var(--blue-800),var(--blue-600));
    color:var(--white);
    padding:18px 14px;
    border-radius:0 14px 14px 0;
    box-shadow:0 10px 30px rgba(0,59,122,.35);
    display:flex;flex-direction:column;align-items:center;gap:8px;
    transition:var(--transition);
    border:none;cursor:pointer;
    position:relative;
}
.fs-toggle::after{
    content:"";position:absolute;
    top:8px;right:8px;
    width:8px;height:8px;border-radius:50%;
    background:var(--yellow);
    box-shadow:0 0 0 4px rgba(255,199,44,.3);
    animation:pulse 1.6s infinite;
}
.fs-toggle:hover{padding-left:18px;box-shadow:0 14px 40px rgba(0,59,122,.5);}
.fs-label{
    writing-mode:vertical-rl;
    transform:rotate(180deg);
    font-weight:600;font-size:.85rem;
    letter-spacing:.05em;
}
.fs-panel{
    width:320px;
    background:var(--white);
    border-radius:0 16px 16px 0;
    box-shadow:0 20px 60px rgba(15,23,42,.2);
    margin-left:-10px;
    padding:20px;
    transform:translateX(-110%);
    opacity:0;
    visibility:hidden;
    transition:transform .35s cubic-bezier(.4,0,.2,1),opacity .25s,visibility .35s;
}
.floating-spaces.open .fs-panel{
    transform:translateX(0);
    opacity:1;visibility:visible;
}
.floating-spaces.open .fs-toggle{
    border-radius:0;
    background:var(--dark);
}
.fs-panel-head{
    padding-bottom:14px;margin-bottom:12px;
    border-bottom:1px solid var(--gray-100);
}
.fs-panel-head strong{display:block;font-family:'Poppins';font-size:1.05rem;color:var(--dark);}
.fs-panel-head span{font-size:.82rem;color:var(--gray-500);}

.fs-item{
    display:flex;align-items:center;gap:12px;
    padding:12px;
    border-radius:12px;
    margin-bottom:8px;
    border:1px solid transparent;
    transition:var(--transition);
    position:relative;
}
.fs-item:hover{border-color:var(--blue-100);background:var(--blue-50);transform:translateX(4px);}
.fs-icon{
    width:44px;height:44px;border-radius:12px;
    display:flex;align-items:center;justify-content:center;
    flex-shrink:0;
}
.fs-item strong{display:block;font-size:.95rem;color:var(--dark);}
.fs-item span{font-size:.78rem;color:var(--gray-500);}
.fs-arrow{margin-left:auto;color:var(--gray-300);transition:var(--transition);}
.fs-item:hover .fs-arrow{color:var(--blue-800);transform:translateX(3px);}
.fs-blue .fs-icon{background:var(--blue-100);color:var(--blue-800);}
.fs-yellow .fs-icon{background:var(--yellow-50);color:var(--yellow-dark);}
.fs-dark .fs-icon{background:#E6E8F0;color:var(--dark);}

.fs-foot{
    margin-top:8px;padding-top:14px;
    border-top:1px solid var(--gray-100);
    display:flex;gap:8px;align-items:center;justify-content:center;
    font-size:.88rem;
}
.fs-foot a{color:var(--blue-800);font-weight:600;}
.fs-foot a:hover{color:var(--yellow-dark);}
.fs-foot span{color:var(--gray-300);}

@media (max-width:768px){
    .fs-toggle{padding:14px 10px;}
    .fs-label{font-size:.75rem;}
    .fs-panel{width:280px;}
}

/* ============ BACK TO TOP ============ */
.back-top{
    position:fixed;
    bottom:30px;right:30px;
    width:46px;height:46px;
    background:var(--yellow);
    color:var(--blue-900);
    border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    box-shadow:var(--shadow-lg);
    z-index:999;
    opacity:0;visibility:hidden;
    transition:var(--transition);
}
.back-top.show{opacity:1;visibility:visible;}
.back-top:hover{background:var(--blue-800);color:var(--white);transform:translateY(-4px);}

/* ============ ANIMATIONS ON SCROLL ============ */
.fade-in{opacity:0;transform:translateY(30px);transition:opacity .8s,transform .8s;}
.fade-in.visible{opacity:1;transform:translateY(0);}

/* ============ RESPONSIVE ============ */
@media (max-width:1024px){
    .services-grid,.actors-grid,.testimonials-grid,.blog-grid{grid-template-columns:repeat(2,1fr);}
    .formations-grid{grid-template-columns:repeat(2,1fr);}
    .sectors-grid{grid-template-columns:repeat(3,1fr);}
    .stats-grid{grid-template-columns:repeat(3,1fr);}
    .footer-grid{grid-template-columns:1fr 1fr;}
    .why-grid,.contact-grid,.cta-inner{grid-template-columns:1fr;gap:40px;}
}

@media (max-width:1100px){
    .topbar-left{display:none;}
    .header-inner{display:flex;justify-content:space-between;min-height:0;}
    .header .logo{position:static;transform:none;}
    .nav{
        position:fixed;top:0;right:-100%;
        width:80%;max-width:320px;height:100vh;
        background:var(--white);
        flex-direction:column;
        padding:80px 20px 20px;
        transition:right .4s;
        box-shadow:var(--shadow-lg);
        gap:0;
    }
    .nav.open{right:0;}
    .nav a{padding:14px;border-bottom:1px solid var(--gray-100);font-size:.95rem;}
    .nav-dropdown{width:100%;}
    .nav-trigger{width:100%;padding:14px;border-bottom:1px solid var(--gray-100);font-size:.95rem;}
    .nav-menu{position:static;width:100%;box-shadow:none;border:none;opacity:1;visibility:visible;transform:none;display:none;padding:8px 0;}
    .nav-dropdown:hover .nav-menu{display:block;}
    .nav-menu::before{display:none;}
    .header-cta{display:none;}
    .burger{display:flex;}
    h1{font-size:2.2rem;}
    h2{font-size:1.7rem;}
    .section{padding:60px 0;}
    .services-grid,.actors-grid,.testimonials-grid,.blog-grid,
    .formations-grid,.sectors-grid,.stats-grid,.footer-grid{grid-template-columns:1fr;}
    .stats-grid{grid-template-columns:repeat(2,1fr);}
    .sectors-grid{grid-template-columns:repeat(2,1fr);}
    .contact-form .row{grid-template-columns:1fr;}
    .cta-form{flex-direction:column;}
    .footer-bottom{flex-direction:column;text-align:center;}
    .footer-bottom div{justify-content:center;flex-wrap:wrap;}
}

/* ============ DETAIL PAGE (formation / offre / blog) ============ */
.detail-hero{
    background:linear-gradient(135deg,var(--blue-900),var(--blue-600));
    color:var(--white);
    padding:54px 0 46px;
}
.detail-hero h1{color:var(--white);margin:10px 0 16px;font-size:2.2rem;line-height:1.2;}
.dh-meta{
    display:flex;flex-wrap:wrap;gap:10px 18px;
    font-size:.92rem;color:rgba(255,255,255,.9);
}
.dh-meta span{display:inline-flex;align-items:center;gap:6px;}

.detail-grid{
    display:grid;
    grid-template-columns:1fr 340px;
    gap:36px;
    align-items:start;
    margin:34px 0 70px;
}

/* Contenu principal — typographie des champs HTML (description, objectifs, programme) */
.detail-main{font-size:15px;color:var(--gray-700);line-height:1.8;}
.detail-main h2{
    font-family:'Poppins';
    font-size:1.4rem;color:var(--blue-800);
    margin:30px 0 14px;padding-bottom:8px;
    border-bottom:2px solid var(--gray-100);
}
.detail-main h2:first-child{margin-top:0;}
.detail-main p{margin:0 0 14px;}
.detail-main ul,.detail-main ol{margin:0 0 16px;padding-left:22px;}
.detail-main li{margin-bottom:8px;}
.detail-main ul li{list-style:disc;}
.detail-main ol li{list-style:decimal;}
.detail-main :last-child{margin-bottom:0;}
.detail-main .field{margin-bottom:14px;}
.detail-main .field label{display:block;font-weight:600;margin-bottom:6px;color:var(--dark);}
.detail-main .field input,
.detail-main .field select,
.detail-main .field textarea{
    width:100%;padding:11px 14px;
    border:1px solid var(--gray-300);border-radius:10px;
    font-family:inherit;font-size:14px;background:var(--white);
}
.detail-main .field input[type="checkbox"],
.detail-main .field input[type="radio"]{
    width:auto;padding:0;border:0;border-radius:0;
}

/* Colonne latérale */
.detail-aside{position:sticky;top:90px;}
.detail-card{
    background:var(--white);
    border:1px solid var(--gray-100);
    border-radius:var(--radius-lg);
    padding:24px;
    box-shadow:var(--shadow-sm);
}
.detail-card h4{
    font-family:'Poppins';font-size:1.05rem;color:var(--blue-800);
    margin:0 0 14px;
}
.detail-card p{margin:0 0 8px;font-size:.92rem;color:var(--gray-700);}
.detail-card p strong{color:var(--dark);}

.breadcrumbs{margin:18px 0;font-size:.88rem;color:var(--gray-500);}
.breadcrumbs a{color:var(--blue-600);}
.breadcrumbs .sep{margin:0 8px;color:var(--gray-300);}

@media (max-width:900px){
    .detail-grid{grid-template-columns:1fr;}
    .detail-aside{position:static;}
}

/* ============ TOPBAR SEARCH (autocomplete) ============ */
.topbar-search{flex:1;min-width:160px;max-width:440px;margin:0 8px;}
.topbar-search-box{
    position:relative;
    display:flex;align-items:center;gap:8px;
    background:rgba(255,255,255,.12);
    border:1px solid rgba(255,255,255,.18);
    border-radius:20px;
    padding:5px 14px;
    transition:var(--transition);
}
.topbar-search-box:focus-within{background:rgba(255,255,255,.18);border-color:var(--yellow);}
.topbar-search-box > svg{flex-shrink:0;color:rgba(255,255,255,.8);}
.topbar-search input{
    flex:1;min-width:0;background:transparent;border:none;outline:none;
    color:#fff;font-size:.82rem;font-family:inherit;
}
.topbar-search input::placeholder{color:rgba(255,255,255,.6);}
.topbar-search input::-webkit-search-cancel-button{filter:invert(1);opacity:.6;}
/* le dropdown .ac-dropdown est stylé globalement ; on relève juste son z-index sous la topbar */
.topbar-search .ac-dropdown{z-index:1300;text-align:left;}

@media (max-width:768px){
    .topbar-search{order:3;flex-basis:100%;max-width:none;margin:6px 0 0;}
}
