/* ====================================================
   FAMEEN GROUP — styles des menus déroulants & pages internes
   (complète styles.css)
   ==================================================== */

/* ---------- MENUS DÉROULANTS (header) ---------- */
.nav{display:flex;gap:24px;align-items:center}
.nav a::after{content:none !important}
.nav-item{position:relative;display:flex;align-items:center}
.nav .nav-top,.nav>a.nav-item{display:flex;align-items:center;gap:5px;font-size:.92rem;font-weight:500;color:var(--ink);padding:8px 0;cursor:pointer;transition:.2s}
.nav .nlabel{transition:.2s}
.nav .nav-top:hover .nlabel,.nav>a.nav-item:hover .nlabel,.nav a.active .nlabel{color:var(--orange)}
.nav-caret{width:13px;height:13px;color:var(--muted);transition:transform .2s;flex:0 0 auto}
.has-sub:hover .nav-caret,.has-sub.open .nav-caret{transform:rotate(180deg);color:var(--orange)}
.subnav{position:absolute;top:calc(100% + 10px);left:50%;transform:translateX(-50%) translateY(-8px);min-width:264px;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:0 22px 54px rgba(40,50,109,.18);padding:8px;opacity:0;visibility:hidden;transition:.22s ease;z-index:120;display:flex;flex-direction:column}
.has-sub:hover .subnav,.has-sub.open .subnav{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.subnav a{padding:10px 14px;border-radius:8px;font-size:.86rem;font-weight:500;color:var(--ink);white-space:nowrap;transition:.16s}
.subnav a:hover{background:color-mix(in srgb,var(--navy) 7%,#fff);color:var(--navy);padding-left:18px}
[dir="rtl"] .subnav{left:auto;right:50%;transform:translateX(50%) translateY(-8px)}
[dir="rtl"] .has-sub:hover .subnav,[dir="rtl"] .has-sub.open .subnav{transform:translateX(50%) translateY(0)}

/* ---------- PAGE HERO (pages internes) ---------- */
.page-hero{position:relative;overflow:hidden;background:linear-gradient(150deg,var(--navy),var(--navy-deep));color:#fff;padding:58px 0 52px}
.page-hero::after{content:"";position:absolute;right:-80px;top:-80px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(233,161,36,.22),transparent 70%)}
.page-hero .container{position:relative;z-index:1}
.breadcrumb{display:flex;gap:8px;align-items:center;font-size:.82rem;color:#9fb0db;margin-bottom:16px;flex-wrap:wrap}
.breadcrumb a{color:#9fb0db;transition:.2s}.breadcrumb a:hover{color:#fff}.breadcrumb span{opacity:.5}
.page-hero .eyebrow{color:var(--orange)}
.page-hero h1{color:#fff;font-size:clamp(2.1rem,4.4vw,3.1rem);font-weight:900;margin-bottom:14px;max-width:880px}
.page-hero .ph-sub{color:#cfd8f2;max-width:700px;font-size:1.12rem}

/* ---------- TEXTE + MÉDIA ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.split.rev .split-media{order:-1}
.split-media{border-radius:16px;overflow:hidden;box-shadow:var(--shadow);position:relative}
.split-media img{width:100%;display:block;object-fit:cover}
.split-text h2{font-size:clamp(1.6rem,3vw,2.15rem);margin-bottom:16px}
.split-text p{color:var(--muted);margin-bottom:14px}
.prose{max-width:860px}
.prose p{color:var(--muted);margin-bottom:16px}
.lead-c{max-width:760px;margin:0 auto 36px;text-align:center;color:var(--muted)}

/* ---------- TIMELINE ---------- */
.timeline{max-width:760px;margin:0 auto;border-left:2px solid var(--line);padding-left:30px;display:flex;flex-direction:column;gap:26px}
.tl-item{position:relative}
.tl-item::before{content:"";position:absolute;left:-39px;top:3px;width:14px;height:14px;border-radius:50%;background:var(--orange);border:3px solid #fff;box-shadow:0 0 0 2px var(--orange)}
.tl-year{font-family:'Yantramanav';font-weight:800;color:var(--navy);font-size:1.15rem}
.tl-item h3{font-size:1.05rem;margin:3px 0 6px}
.tl-item p{color:var(--muted);font-size:.95rem;margin:0}
[dir="rtl"] .timeline{border-left:none;border-right:2px solid var(--line);padding-left:0;padding-right:30px}
[dir="rtl"] .tl-item::before{left:auto;right:-39px}

/* ---------- MISSION / VISION / VALEURS ---------- */
.mv-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.mv{background:#fff;border:1px solid var(--line);border-radius:16px;padding:32px 30px;transition:.3s}
.mv:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.mv .ic{width:56px;height:56px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(135deg,var(--navy),var(--blue));margin-bottom:18px}
.mv .ic [data-ico]{width:28px;height:28px;color:#fff}
.mv h3{font-size:1.25rem;margin-bottom:10px}
.mv p{color:var(--muted)}
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.value{text-align:center;background:#fff;border:1px solid var(--line);border-radius:16px;padding:34px 24px;transition:.3s}
.value:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:color-mix(in srgb,var(--orange) 40%,#fff)}
.value .ic{width:60px;height:60px;border-radius:50%;margin:0 auto 16px;display:grid;place-items:center;background:color-mix(in srgb,var(--orange) 14%,#fff)}
.value .ic [data-ico]{width:28px;height:28px;color:var(--orange-deep)}
.value h3{font-size:1.15rem;margin-bottom:8px}
.value p{color:var(--muted);font-size:.94rem}

/* ---------- GRILLES (services, pôles) ---------- */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.tile{background:#fff;border:1px solid var(--line);border-radius:14px;padding:28px 26px;transition:.3s;position:relative;overflow:hidden}
.tile::before{content:"";position:absolute;left:0;top:0;height:3px;width:0;background:var(--orange);transition:.3s}
.tile:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.tile:hover::before{width:100%}
.tile .ic{width:54px;height:54px;border-radius:13px;display:grid;place-items:center;background:linear-gradient(135deg,var(--navy),var(--blue));margin-bottom:16px}
.tile .ic [data-ico]{width:26px;height:26px;color:#fff}
.tile h3{font-size:1.12rem;margin-bottom:9px}
.tile p{color:var(--muted);font-size:.93rem}

/* ---------- SECTEURS ---------- */
.sectors{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.sector{display:flex;align-items:center;gap:14px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:18px 20px;transition:.25s}
.sector:hover{border-color:color-mix(in srgb,var(--orange) 45%,#fff);box-shadow:var(--shadow-sm);transform:translateY(-3px)}
.sector .ic{width:42px;height:42px;border-radius:10px;display:grid;place-items:center;background:color-mix(in srgb,var(--navy) 8%,#fff);flex:0 0 auto}
.sector .ic [data-ico]{width:22px;height:22px;color:var(--navy)}
.sector b{font-size:.98rem;color:var(--navy);font-weight:700}

/* ---------- CHECKLIST SERVICES ---------- */
.checklist{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:14px}
.checklist li{position:relative;padding-left:34px;color:var(--ink);font-weight:500}
.checklist li [data-ico]{position:absolute;left:0;top:1px;width:22px;height:22px;color:#fff;background:var(--orange);border-radius:6px;padding:3px}
[dir="rtl"] .checklist li{padding-left:0;padding-right:34px}
[dir="rtl"] .checklist li [data-ico]{left:auto;right:0}

/* ---------- ÉQUIPE ---------- */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:920px;margin:0 auto}
.tmember{text-align:center;background:#fff;border:1px solid var(--line);border-radius:16px;padding:36px 24px;transition:.3s}
.tmember:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.tmember .avatar{width:96px;height:96px;border-radius:50%;margin:0 auto 16px;display:grid;place-items:center;font-family:'Yantramanav';font-weight:800;font-size:1.7rem;color:#fff}
.tmember h3{font-size:1.15rem;margin-bottom:5px}
.tmember .role{color:var(--orange-deep);font-weight:700;font-size:.9rem;margin-bottom:6px}
.tmember p{color:var(--muted);font-size:.9rem}

/* ---------- BANDE CTA ---------- */
.cta-band{background:linear-gradient(150deg,var(--navy),var(--navy-deep));text-align:center;color:#fff}
.cta-band h2{color:#fff;font-size:clamp(1.7rem,3.2vw,2.4rem);margin:0 auto 14px;max-width:760px}
.cta-band p{color:#cdd6f0;max-width:600px;margin:0 auto 28px}
.cta-band .cta-row{justify-content:center;display:flex;gap:14px;flex-wrap:wrap}

/* ---------- RESPONSIVE ---------- */
@media(max-width:980px){
  .split{grid-template-columns:1fr;gap:32px}
  .split.rev .split-media{order:0}
  .mv-grid,.grid-3,.grid-2,.values,.sectors,.team-grid{grid-template-columns:1fr 1fr}
  .checklist{grid-template-columns:1fr}
}
@media(max-width:680px){
  .nav-item{flex-direction:column;align-items:stretch;width:100%}
  .nav .nav-top,.nav>a.nav-item{padding:14px 0;border-bottom:1px solid var(--line);justify-content:space-between;width:100%}
  .subnav{position:static;transform:none;opacity:1;visibility:visible;box-shadow:none;border:none;min-width:0;padding:0 0 6px 14px;max-height:0;overflow:hidden;transition:max-height .28s ease}
  .has-sub.open .subnav{max-height:600px}
  .subnav a{padding:10px 6px;font-size:.92rem}
  .mv-grid,.grid-3,.grid-2,.values,.sectors,.team-grid{grid-template-columns:1fr}
  .page-hero{padding:42px 0 38px}
}


/* ---------- RÉALISATIONS : filtres + grille projets ---------- */
.filters{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-bottom:30px}
.filter-btn{padding:9px 18px;border:1px solid var(--line);background:#fff;border-radius:999px;font-weight:600;font-size:.86rem;color:var(--navy);cursor:pointer;transition:.2s;font-family:inherit}
.filter-btn:hover{border-color:var(--orange)}
.filter-btn.active{background:var(--navy);color:#fff;border-color:var(--navy)}
.pgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.pcard{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:.3s}
.pcard:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.pcard .thumb{display:block;height:200px;overflow:hidden;background:var(--bg-soft)}
.pcard .thumb img{width:100%;height:100%;object-fit:cover;transition:.5s ease}
.pcard:hover .thumb img{transform:scale(1.06)}
.pbody{padding:18px 18px 20px;display:flex;flex-direction:column;flex:1}
.pcat{align-self:flex-start;font-size:.64rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--orange-deep);background:color-mix(in srgb,var(--orange) 14%,#fff);padding:4px 9px;border-radius:6px;margin-bottom:10px}
.pcard h3{font-size:1.02rem;margin-bottom:8px;color:var(--navy);line-height:1.25}
.pdesc{color:var(--muted);font-size:.88rem;margin-bottom:14px}
.plink{margin-top:auto;color:var(--orange-deep);font-weight:700;font-size:.84rem;display:inline-flex;align-items:center;gap:6px}
.plink [data-ico]{width:15px;height:15px;transition:transform .2s}
.pcard:hover .plink [data-ico]{transform:translateX(3px)}
.pcard.hide{display:none}

/* ---------- SOLUTIONS : 3 plateformes (accueil) ---------- */
.sol-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.sol-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:16px;padding:34px 30px;transition:.3s;position:relative;overflow:hidden}
.sol-card::before{content:"";position:absolute;left:0;top:0;height:4px;width:0;background:var(--orange);transition:.3s}
.sol-card:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.sol-card:hover::before{width:100%}
.sol-card .ic{width:62px;height:62px;border-radius:15px;display:grid;place-items:center;background:linear-gradient(135deg,var(--navy),var(--blue));margin-bottom:20px}
.sol-card .ic [data-ico]{width:30px;height:30px;color:#fff}
.sol-card h3{font-size:1.3rem;margin-bottom:4px}
.sol-tag{color:var(--orange-deep);font-weight:700;font-size:.84rem;margin-bottom:12px}
.sol-card p{color:var(--muted);font-size:.94rem;margin-bottom:14px}
.sol-feats{list-style:none;display:grid;gap:9px;margin-bottom:22px}
.sol-feats li{position:relative;padding-left:26px;font-size:.9rem;color:var(--ink)}
.sol-feats li [data-ico]{position:absolute;left:0;top:1px;width:18px;height:18px;color:var(--orange)}
.sol-card .btn{margin-top:auto;align-self:flex-start}

@media(max-width:980px){ .pgrid{grid-template-columns:repeat(2,1fr)} .sol-grid{grid-template-columns:1fr} }
@media(max-width:680px){ .pgrid{grid-template-columns:1fr} }


/* ---------- ÉQUIPE : libellés de pôle + LinkedIn ---------- */
.team-pole{text-align:center;font-size:1.05rem;color:var(--navy);font-weight:800;letter-spacing:.02em;margin:6px 0 20px;position:relative}
.team-pole::after{content:"";display:block;width:48px;height:3px;border-radius:3px;background:var(--orange);margin:10px auto 0}
.tmember{position:relative}
.tmember .tlink{display:inline-grid;place-items:center;width:34px;height:34px;border-radius:50%;background:color-mix(in srgb,var(--navy) 8%,#fff);color:var(--navy);margin-top:14px;transition:.2s}
.tmember .tlink svg{width:16px;height:16px}
.tmember .tlink:hover{background:var(--navy);color:#fff;transform:translateY(-2px)}


/* ---------- CATÉGORIES DE SERVICES (Impression & Branding) ---------- */
.svc-cat{background:#fff;border:1px solid var(--line);border-radius:16px;padding:28px 28px 24px;transition:.3s}
.svc-cat:hover{box-shadow:var(--shadow);transform:translateY(-4px)}
.svc-cat-h{display:flex;align-items:center;gap:14px;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--line)}
.svc-cat-h .ic{width:48px;height:48px;border-radius:12px;display:grid;place-items:center;background:linear-gradient(135deg,var(--navy),var(--blue));flex:0 0 auto}
.svc-cat-h .ic [data-ico]{width:24px;height:24px;color:#fff}
.svc-cat-h h3{font-size:1.15rem;color:var(--navy)}
.svc-list{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:8px 18px}
.svc-list li{position:relative;padding-left:18px;font-size:.9rem;color:var(--ink)}
.svc-list li::before{content:"";position:absolute;left:0;top:8px;width:6px;height:6px;border-radius:50%;background:var(--orange)}
[dir="rtl"] .svc-list li{padding-left:0;padding-right:18px}
[dir="rtl"] .svc-list li::before{left:auto;right:0}
@media(max-width:680px){ .svc-list{grid-template-columns:1fr} }


/* ---------- ACTUALITÉS : à la une, newsletter, filtres ---------- */
.featured{display:grid;grid-template-columns:1.1fr .9fr;background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:var(--shadow)}
.featured .fimg{display:block;min-height:340px;background:var(--bg-soft);overflow:hidden}
.featured .fimg img{width:100%;height:100%;object-fit:cover;transition:.5s}
.featured:hover .fimg img{transform:scale(1.04)}
.featured .fbody{padding:40px 42px;display:flex;flex-direction:column;justify-content:center}
.featured h2{font-size:clamp(1.4rem,2.4vw,2rem);color:var(--navy);margin:10px 0 14px;line-height:1.22}
.featured p{color:var(--muted);margin-bottom:22px}
.featured .btn{align-self:flex-start}
.post.hide{display:none}
.nl-box{max-width:720px;margin:0 auto;text-align:center;background:#fff;border:1px solid var(--line);border-radius:18px;padding:44px 40px;box-shadow:var(--shadow-sm)}
.nl-form{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}
.nl-form input{flex:1;min-width:200px;padding:14px 16px;border:1px solid var(--line);border-radius:8px;background:var(--bg-soft);font-family:inherit;font-size:.95rem;color:var(--ink)}
.nl-form input:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 3px rgba(233,161,36,.15)}
@media(max-width:880px){ .featured{grid-template-columns:1fr} .featured .fimg{min-height:240px} }


/* ---------- CONTACT ---------- */
.ct-layout{display:grid;grid-template-columns:1.4fr .9fr;gap:36px;align-items:start}
.contact-form select{width:100%;background:var(--bg-soft);border:1px solid var(--line);border-radius:8px;padding:14px 16px;color:var(--ink);font-family:inherit;font-size:.95rem;transition:.2s;cursor:pointer}
.contact-form select:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 3px rgba(233,161,36,.15)}
.ct-side{background:#fff;border:1px solid var(--line);border-radius:16px;padding:30px 28px;box-shadow:var(--shadow-sm)}
.ct-side h3{font-size:1.2rem;margin-bottom:6px}
.ct-side-sub{color:var(--muted);font-size:.92rem;margin-bottom:20px}
.qbtn{display:flex;align-items:center;gap:14px;padding:14px 16px;border-radius:12px;border:1px solid var(--line);margin-bottom:12px;transition:.2s;background:#fff}
.qbtn [data-ico]{width:24px;height:24px;flex:0 0 auto;color:var(--navy)}
.qbtn b{display:block;color:var(--navy);font-size:.96rem}
.qbtn small{color:var(--muted);font-size:.82rem}
.qbtn:hover{border-color:var(--orange);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.qbtn-wa{background:#25d366;border-color:#25d366}
.qbtn-wa [data-ico]{color:#fff}
.qbtn-wa b,.qbtn-wa small{color:#fff}
.qbtn-wa small{opacity:.9}
.qbtn-wa:hover{filter:brightness(.96);border-color:#25d366}
.ct-socials{display:flex;gap:10px;margin-top:18px;padding-top:18px;border-top:1px solid var(--line)}
.ct-socials a{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;background:color-mix(in srgb,var(--navy) 8%,#fff);color:var(--navy);transition:.2s}
.ct-socials a svg{width:17px;height:17px}
.ct-socials a:hover{background:var(--navy);color:#fff;transform:translateY(-2px)}
.map-box{border-radius:16px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-sm)}

/* FAQ */
.faq{display:flex;flex-direction:column;gap:12px}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden}
.faq-item summary{list-style:none;cursor:pointer;padding:18px 20px;font-weight:700;color:var(--navy);display:flex;align-items:center;justify-content:space-between;gap:14px;font-size:.98rem}
.faq-item summary::-webkit-details-marker{display:none}
.faq-ic{width:18px;height:18px;color:var(--orange);flex:0 0 auto;transition:transform .25s}
.faq-item[open] .faq-ic{transform:rotate(180deg)}
.faq-item[open] summary{color:var(--orange-deep)}
.faq-item p{padding:0 20px 18px;color:var(--muted);margin:0}

@media(max-width:880px){ .ct-layout{grid-template-columns:1fr;gap:28px} }


/* ---------- WIZARD DEMANDE DE DEVIS ---------- */
.wizard{background:#fff;border:1px solid var(--line);border-radius:18px;padding:34px 34px 30px;box-shadow:var(--shadow)}
.wz-head{margin-bottom:24px}
.wz-step-label{font-size:.85rem;color:var(--muted);font-weight:600;margin-bottom:10px}
.wz-step-label b{color:var(--navy)}
.wz-progress{height:8px;background:var(--bg-soft);border-radius:8px;overflow:hidden}
.wz-progress span{display:block;height:100%;width:16%;background:linear-gradient(90deg,var(--navy),var(--orange));border-radius:8px;transition:width .35s ease}
.wz-form{display:block}
.fstep{display:none}
.fstep.active{display:grid;gap:16px}
.wz-q{font-weight:700;color:var(--navy);font-size:.92rem;margin-bottom:-6px}
.wz-file{display:flex;align-items:center;gap:14px;border:2px dashed var(--line);border-radius:12px;padding:18px 20px;cursor:pointer;transition:.2s}
.wz-file:hover{border-color:var(--orange);background:var(--bg-soft)}
.wz-file [data-ico]{width:26px;height:26px;color:var(--navy);flex:0 0 auto}
.wz-file b{display:block;color:var(--navy);font-size:.92rem}.wz-file small{color:var(--muted)}
.wz-files{font-size:.85rem;color:var(--navy);font-weight:600;min-height:1em;margin:0}
.wz-consent{display:flex;gap:10px;align-items:flex-start;font-size:.9rem;color:var(--ink)}
.wz-consent input{margin-top:3px;width:18px;height:18px;accent-color:var(--orange)}
.wz-nav{display:flex;justify-content:space-between;gap:12px;margin-top:10px}
.wz-confirm{text-align:center;background:#fff;border:1px solid var(--line);border-radius:18px;padding:54px 34px;box-shadow:var(--shadow)}
.wz-confirm-ic{width:74px;height:74px;border-radius:50%;background:#16a34a;display:grid;place-items:center;margin:0 auto 18px}
.wz-confirm-ic [data-ico]{width:38px;height:38px;color:#fff}
.wz-confirm h2{color:var(--navy);margin-bottom:10px}
.wz-confirm p{color:var(--muted);max-width:480px;margin:0 auto 24px}
@media(max-width:680px){ .wizard{padding:24px 20px} }


/* ---------- FORMULAIRE CONTACT PREMIUM (labels + icônes) ---------- */
.ctf .field{display:flex;flex-direction:column;gap:6px}
.ctf label{font-size:.82rem;font-weight:600;color:var(--navy)}
.ctf .req{color:var(--orange-deep)}
.ctf .input-ic{position:relative}
.ctf .input-ic > [data-ico]{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--muted);pointer-events:none;transition:color .2s}
.ctf .input-ic input,.ctf .input-ic select{padding-left:42px}
.ctf .input-ic:focus-within > [data-ico]{color:var(--orange)}
.ctf .field:focus-within label{color:var(--orange-deep)}
.btn-block{width:100%;justify-content:center;gap:8px}
.btn-block [data-ico]{width:18px;height:18px;transition:transform .2s}
.btn-block:hover [data-ico]{transform:translateX(4px)}
.ct-reassure{display:flex;align-items:center;gap:8px;font-size:.82rem;color:var(--muted);margin:2px 0 0}
.ct-reassure [data-ico]{width:16px;height:16px;color:#16a34a;flex:0 0 auto}
[dir="rtl"] .ctf .input-ic > [data-ico]{left:auto;right:14px}
[dir="rtl"] .ctf .input-ic input,[dir="rtl"] .ctf .input-ic select{padding-left:16px;padding-right:42px}


/* ---------- WIZARD PREMIUM : stepper, en-têtes, options ---------- */
.wz-steps{list-style:none;display:flex;justify-content:space-between;margin:0 0 16px;padding:0}
.wz-st{display:flex;flex-direction:column;align-items:center;gap:7px;flex:1;position:relative;color:var(--muted)}
.wz-st:not(:last-child)::after{content:"";position:absolute;top:16px;left:calc(50% + 18px);right:calc(-50% + 18px);height:2px;background:var(--line);z-index:0}
.wz-st.done:not(:last-child)::after{background:var(--orange)}
.wz-num{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;background:#fff;border:2px solid var(--line);color:var(--muted);font-weight:700;font-size:.85rem;position:relative;z-index:1;transition:.25s}
.wz-lbl{font-size:.72rem;font-weight:600;text-align:center}
.wz-st.active .wz-num{border-color:var(--navy);background:var(--navy);color:#fff;transform:scale(1.08)}
.wz-st.active .wz-lbl{color:var(--navy)}
.wz-st.done .wz-num{border-color:var(--orange);background:var(--orange);color:#fff}
.wz-st.done .wz-lbl{color:var(--navy)}
.wz-mini{display:block;text-align:right;font-size:.82rem;color:var(--muted);font-weight:600;margin:-6px 0 16px}
.wz-mini b{color:var(--navy)}
.fstep-head{display:flex;align-items:center;gap:14px;margin-bottom:6px}
.fstep-head .ic{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;background:linear-gradient(135deg,var(--navy),var(--blue));flex:0 0 auto}
.fstep-head .ic [data-ico]{width:24px;height:24px;color:#fff}
.fstep-head h3{font-size:1.15rem;color:var(--navy);margin:0}
.fstep-head p{font-size:.88rem;color:var(--muted);margin:2px 0 0}
.opt-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.opt-grid-chips{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}
.opt{position:relative;display:flex;align-items:center;gap:11px;padding:15px 18px;border:1.5px solid var(--line);border-radius:12px;cursor:pointer;transition:.2s;font-weight:600;color:var(--navy);font-size:.92rem}
.opt input{position:absolute;opacity:0;pointer-events:none}
.opt::before{content:"";width:18px;height:18px;border-radius:50%;border:2px solid var(--line);flex:0 0 auto;transition:.2s}
.opt:hover{border-color:color-mix(in srgb,var(--orange) 55%,#fff);transform:translateY(-2px)}
.opt:has(input:checked){border-color:var(--orange);background:color-mix(in srgb,var(--orange) 8%,#fff)}
.opt:has(input:checked)::before{border-color:var(--orange);background:var(--orange);box-shadow:inset 0 0 0 3px #fff}
.ic-back{transform:rotate(180deg)}
#wzPrev,#wzNext,#wzSubmit{display:inline-flex;align-items:center;gap:8px}
#wzPrev [data-ico],#wzNext [data-ico],#wzSubmit [data-ico]{width:16px;height:16px}
@media(max-width:680px){
  .wz-lbl{display:none}
  .wz-mini{display:block}
  .wz-st:not(:last-child)::after{left:calc(50% + 14px);right:calc(-50% + 14px)}
  .opt-grid{grid-template-columns:1fr}
}


/* ============================================================
   DESIGN SYSTEM FORMULAIRES (unifié — contact, devis, newsletter)
   ============================================================ */
.contact-form{display:grid;gap:16px}
.contact-form .row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.contact-form input,.contact-form select,.contact-form textarea,
.nl-form input{
  width:100%;font-family:inherit;font-size:1rem;color:var(--ink);
  background:#fff;border:1.5px solid var(--line);border-radius:10px;
  padding:14px 16px;transition:border-color .2s,box-shadow .2s,background .2s}
.contact-form textarea{resize:vertical;min-height:120px;line-height:1.55}
.contact-form input::placeholder,.contact-form textarea::placeholder{color:#9aa3b2}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus,
.nl-form input:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px rgba(40,50,109,.13);background:#fff}
/* chevron des selects */
.contact-form select{cursor:pointer;-webkit-appearance:none;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2328326D' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;background-size:16px;padding-right:42px}
[dir="rtl"] .contact-form select{background-position:left 14px center;padding-right:16px;padding-left:42px}
/* erreurs en ligne */
.contact-form .field.invalid input,.contact-form .field.invalid select,.contact-form .field.invalid textarea{border-color:#e23d3d;box-shadow:0 0 0 3px rgba(226,61,61,.12)}
.field-err{display:none;color:#e23d3d;font-size:.78rem;font-weight:600;margin-top:-2px;display:flex;align-items:center;gap:5px}
.field.invalid > .field-err,.wz-consent.invalid > .field-err{display:flex}
.wz-consent.invalid{color:#e23d3d}
/* carte de succès premium (formulaire contact) */
.form-success{display:none;text-align:center;background:#fff;border:1px solid var(--line);border-radius:16px;padding:46px 32px;box-shadow:var(--shadow)}
.form-success.show{display:block;animation:fgpop .4s ease}
@keyframes fgpop{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.form-success .fs-ic{width:72px;height:72px;border-radius:50%;background:#16a34a;display:grid;place-items:center;margin:0 auto 18px;box-shadow:0 10px 26px rgba(22,163,74,.3)}
.form-success .fs-ic [data-ico]{width:38px;height:38px;color:#fff}
.form-success h3{color:var(--navy);font-size:1.45rem;margin-bottom:10px}
.form-success p{color:var(--muted);max-width:440px;margin:0 auto 24px}
.form-success .cta-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
/* dropzone : état glisser-déposer + aperçus */
.wz-file.is-drag{border-color:var(--orange);background:color-mix(in srgb,var(--orange) 8%,#fff)}
.wz-previews{display:flex;flex-wrap:wrap;gap:8px;margin:0}
.wz-chip{display:inline-flex;align-items:center;gap:7px;background:var(--bg-soft);border:1px solid var(--line);border-radius:8px;padding:6px 10px;font-size:.8rem;color:var(--navy);font-weight:600}
.wz-chip [data-ico]{width:14px;height:14px;color:var(--orange)}
/* mobile : champs confortables, pas de zoom iOS */
@media(max-width:680px){
  .contact-form .row{grid-template-columns:1fr}
  .contact-form input,.contact-form select,.contact-form textarea,.nl-form input{font-size:16px;padding:15px 16px}
}


/* ============================================================
   RESPONSIVE — garde-fous universels & très petits écrans
   ============================================================ */
img,svg,video,iframe{max-width:100%}
body{overflow-wrap:break-word}
/* éviter qu'un mot/URL très long ne pousse la mise en page */
.tile p,.card p,.mv p,.value p,.post p,.pdesc,.lead,.ph-sub,.hsub,.footer-col a,.breadcrumb{overflow-wrap:anywhere}
/* grilles : jamais en dessous de 0 (anti-débordement flex/grid) */
.cards>*,.grid-3>*,.grid-2>*,.pgrid>*,.news-grid>*,.sol-grid>*,.team-grid>*,.values>*,.cols-3>*,.cols-4>*{min-width:0}

@media(max-width:480px){
  .container{padding:0 16px}
  section{padding:48px 0}
  .page-hero{padding:38px 0 34px}
  .section-head{margin-bottom:30px}
  .cta-row{width:100%}
  .cta-row .btn{width:100%}            /* CTA empilés pleine largeur */
  .hero-cta .btn{width:100%}
  .center-btn .btn{width:100%}
  .wz-nav{flex-wrap:wrap}
  .wz-nav .btn{flex:1;min-width:130px}
}
