/* ═══════════════════════════════════════════════════════════
   EUROMÉDECINE.COM — Design Science & Nature Premium
   Palette : Vert Recherche #1A7A4A · Cobalt Médical #0B3D6B
            Aqua Biotech #00A8C6 · Or Agropolis #C8A84B
            Nuit Science #0D1B2A · Crème #F8F6F1
   ═══════════════════════════════════════════════════════════ */
:root {
  --vert:   #1A7A4A;
  --vert-l: #2A9D6A;
  --cobalt: #0B3D6B;
  --aqua:   #00A8C6;
  --or:     #C8A84B;
  --nuit:   #0D1B2A;
  --creme:  #F8F6F1;
  --pierre: #EEE9E0;
  --encre:  #1A1A2E;
  --gris:   #6B7280;
  --ligne:  rgba(11,61,107,.1);
  --s1:     rgba(13,27,42,.06);
  --s2:     rgba(13,27,42,.12);
}
*,*::before,*::after { box-sizing:border-box;margin:0;padding:0 }
html { scroll-behavior:smooth }
body { font-family:'Instrument Sans',system-ui,sans-serif;background:var(--creme);color:var(--encre);font-size:16px;line-height:1.65 }

/* ── TYPO ── */
h1,h2,h3,h4 { font-family:'Cormorant Garamond',Georgia,serif;line-height:1.1 }
h1 { font-size:clamp(2.75rem,6vw,5.5rem);font-weight:300 }
h2 { font-size:clamp(2rem,4vw,3.5rem);font-weight:300 }
h3 { font-size:1.375rem;font-weight:400 }
em { font-style:italic }

/* ── LAYOUT ── */
.w { max-width:1340px;margin:0 auto;padding:0 2rem }
.s { padding:5rem 0 }
.s-creme  { background:var(--creme) }
.s-pierre { background:var(--pierre) }
.s-nuit   { background:var(--nuit) }
.s-vert   { background:var(--vert) }
.s-cobalt { background:var(--cobalt) }

/* ── HEADER ── */
.site-hdr {
  position:sticky;top:0;z-index:100;
  background:var(--creme);border-bottom:1px solid var(--ligne);
  height:70px;
}
.hdr-inner { display:flex;align-items:center;height:70px;gap:1.5rem }
.logo { display:flex;align-items:center;gap:.875rem;text-decoration:none;flex-shrink:0 }
.logo-mark {
  width:40px;height:40px;background:var(--vert);color:#fff;border-radius:4px;
  display:flex;align-items:center;justify-content:center;
  font-family:'Cormorant Garamond',serif;font-size:1.375rem;font-style:italic;font-weight:600
}
.logo-stack { line-height:1.2 }
.logo-top { font-family:'Cormorant Garamond',serif;font-size:1.1rem;font-weight:600;color:var(--cobalt) }
.logo-top em { color:var(--vert) }
.logo-btm { font-family:'Space Grotesk',sans-serif;font-size:.55rem;color:var(--gris);letter-spacing:.1em;text-transform:uppercase }

.mnav { list-style:none;display:flex;align-items:center;gap:.125rem;margin-left:auto }
.mnav li a {
  font-family:'Space Grotesk',sans-serif;font-size:.62rem;font-weight:500;
  color:var(--encre);letter-spacing:.06em;text-transform:uppercase;
  padding:.375rem .625rem;text-decoration:none;transition:.2s;white-space:nowrap;
  display:block;height:70px;line-height:70px;
}
.mnav li a:hover,.mnav li a.on { color:var(--vert);border-bottom:2px solid var(--vert) }
.hcta {
  background:var(--vert);color:#fff!important;padding:.5rem 1.125rem!important;
  border-radius:3px;height:auto!important;line-height:normal!important;
  font-size:.62rem!important;font-weight:600!important;white-space:nowrap;
  transition:.2s;text-decoration:none;
}
.hcta:hover { background:var(--vert-l)!important }
.brg { display:none;background:none;border:none;cursor:pointer;padding:.5rem }

/* ── DROPDOWN ── */
.mnav li.drop { position:relative }
.mnav li.drop > a::after { content:' ▾';font-size:.5rem }
.drop-menu {
  display:none;position:absolute;top:70px;left:0;
  background:var(--creme);min-width:230px;
  border-top:3px solid var(--vert);box-shadow:0 8px 30px var(--s2);z-index:200
}
.mnav li.drop:hover .drop-menu { display:block }
.drop-menu a {
  display:block!important;padding:.625rem 1.25rem!important;
  font-size:.68rem!important;font-weight:500;color:var(--encre)!important;
  border-bottom:1px solid rgba(11,61,107,.06);
  transition:.15s;height:auto!important;line-height:normal!important;
}
.drop-menu a:hover { background:var(--vert)!important;color:#fff!important }

/* ── TICKER ── */
.ticker { background:var(--cobalt);padding:.5rem 0;overflow:hidden }
.tk-track { display:flex;animation:ticker 50s linear infinite }
.tk-track:hover { animation-play-state:paused }
.tk-i { white-space:nowrap;padding:0 2rem;font-family:'Space Grotesk',sans-serif;font-size:.65rem;color:rgba(255,255,255,.75);letter-spacing:.06em }
.tk-d { display:inline-block;width:6px;height:6px;background:var(--aqua);border-radius:50%;margin-right:1.5rem;vertical-align:middle }
@keyframes ticker { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ── HERO ── */
.hero {
  position:relative;min-height:92vh;display:flex;align-items:center;
  background:var(--nuit);overflow:hidden;
}
.hero-canvas { position:absolute;inset:0;background:radial-gradient(ellipse at 20% 50%,rgba(26,122,74,.25) 0%,transparent 60%),radial-gradient(ellipse at 80% 30%,rgba(0,168,198,.15) 0%,transparent 50%) }
.hero-grid { position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:60px 60px }
.hero-deco { position:absolute;top:-3rem;right:-5rem;font-family:'Cormorant Garamond',serif;font-size:28vw;font-weight:300;color:rgba(26,122,74,.04);font-style:italic;line-height:1;pointer-events:none;user-select:none }
.hero-c { position:relative;z-index:1;max-width:760px }
.hero-pill { display:inline-block;background:rgba(26,122,74,.25);border:1px solid rgba(26,122,74,.4);color:rgba(255,255,255,.85);padding:.375rem 1rem;font-family:'Space Grotesk',sans-serif;font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;border-radius:2px;margin-bottom:1.5rem }
.hero-c h1 { color:#fff;font-weight:300 }
.hero-c h1 strong { color:var(--aqua);font-weight:600 }
.hero-c h1 span { display:block;font-family:'Instrument Sans',sans-serif;font-size:clamp(1rem,2.5vw,1.5rem);font-weight:300;color:rgba(255,255,255,.55);margin-top:.75rem;letter-spacing:.02em }
.hero-desc { font-size:1.0625rem;color:rgba(255,255,255,.7);max-width:560px;margin-top:1.25rem }
.bg { display:flex;gap:1rem;flex-wrap:wrap;margin-top:2rem }
.hero-strip { display:grid;grid-template-columns:repeat(4,1fr);background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);margin-top:3rem;max-width:640px }
.hs-item { padding:1.25rem;border-right:1px solid rgba(255,255,255,.08);text-align:center }
.hs-item:last-child { border:none }
.hs-n { font-family:'Cormorant Garamond',serif;font-size:1.875rem;color:var(--aqua);font-style:italic }
.hs-l { font-family:'Space Grotesk',sans-serif;font-size:.55rem;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:.1em;margin-top:.25rem }

/* ── KICKER ── */
.kicker { font-family:'Space Grotesk',sans-serif;font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--vert);font-weight:600 }
.kicker-aqua { color:var(--aqua) }

/* ── BUTTONS ── */
.btn { display:inline-block;padding:.6875rem 1.625rem;font-family:'Space Grotesk',sans-serif;font-size:.7rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;text-decoration:none;border:none;cursor:pointer;transition:.2s }
.btn-s { background:var(--vert);color:#fff }
.btn-s:hover { background:var(--vert-l) }
.btn-ol { background:transparent;border:1.5px solid rgba(255,255,255,.35);color:#fff }
.btn-ol:hover { background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.6) }
.btn-ol-c { background:transparent;border:1.5px solid var(--cobalt);color:var(--cobalt) }
.btn-ol-c:hover { background:var(--cobalt);color:#fff }
.btn-vert { background:transparent;border:1.5px solid var(--vert);color:var(--vert) }
.btn-vert:hover { background:var(--vert);color:#fff }

/* ── ZONE CARDS (2 zones) ── */
.zone-grid { display:grid;grid-template-columns:1fr 1fr;gap:2.5rem }
.zc { border:1px solid var(--ligne);background:#fff;padding:2.5rem;position:relative;transition:.3s }
.zc:hover { transform:translateY(-4px);box-shadow:0 12px 40px var(--s2) }
.zc-ico { font-size:2.5rem;margin-bottom:1rem }
.zc-tag { display:inline-block;font-family:'Space Grotesk',sans-serif;font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;padding:.25rem .75rem;margin-bottom:1rem;border-radius:2px }
.t-vert  { background:rgba(26,122,74,.1);color:var(--vert) }
.t-cobalt{ background:rgba(11,61,107,.1);color:var(--cobalt) }
.zc-facts { display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;margin-top:1.5rem;background:var(--pierre);padding:1.25rem }
.zf-n { font-family:'Cormorant Garamond',serif;font-size:1.5rem;color:var(--cobalt);font-style:italic }
.zf-l { font-family:'Space Grotesk',sans-serif;font-size:.55rem;color:var(--gris);text-transform:uppercase;letter-spacing:.08em }
@media(max-width:900px){ .zone-grid{grid-template-columns:1fr} }

/* ── FEATURE CARDS ── */
.fc-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:2rem }
.fc { padding:1.75rem;border-top:3px solid var(--vert);background:#fff;transition:.2s }
.fc:hover { box-shadow:0 4px 20px var(--s1) }
.fc-ico { font-size:1.75rem;margin-bottom:.875rem }
.fc h3 { color:var(--cobalt);margin-bottom:.625rem;font-size:1.1rem }
.fc p { font-size:.9375rem;color:var(--encre);line-height:1.65 }
@media(max-width:900px){ .fc-grid{grid-template-columns:1fr 1fr} }
@media(max-width:600px){ .fc-grid{grid-template-columns:1fr} }

/* ── STATS ── */
.st-grid { display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(255,255,255,.1) }
.stb { padding:1.5rem;background:rgba(255,255,255,.06);text-align:center }
.stb-v { font-family:'Cormorant Garamond',serif;font-size:2.25rem;font-style:italic;line-height:1 }
.stb-l { font-family:'Space Grotesk',sans-serif;font-size:.55rem;color:rgba(255,255,255,.45);text-transform:uppercase;letter-spacing:.1em;margin-top:.25rem }
.s1 .stb-v { color:var(--aqua) }
.s2 .stb-v { color:var(--or) }
.s3 .stb-v { color:var(--aqua) }
.s4 .stb-v { color:var(--or) }
@media(max-width:700px){ .st-grid{grid-template-columns:1fr 1fr} }

/* ── ANNUAIRE / COMPANY CARDS ── */
.fbr { display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem }
.fb { background:var(--pierre);border:1.5px solid var(--ligne);padding:.375rem .875rem;font-family:'Space Grotesk',sans-serif;font-size:.62rem;font-weight:500;cursor:pointer;transition:.15s;letter-spacing:.04em }
.fb:hover,.fb.on { background:var(--cobalt);border-color:var(--cobalt);color:#fff }
.cg { display:grid;grid-template-columns:repeat(3,1fr);gap:1rem }
.cc { background:#fff;border:1px solid var(--ligne);padding:1.25rem;transition:.2s }
.cc:hover { border-color:var(--vert);box-shadow:0 2px 12px var(--s1) }
.cc-n { font-family:'Space Grotesk',sans-serif;font-size:.8125rem;font-weight:700;color:var(--cobalt);margin-bottom:.5rem }
.cc-n a { color:inherit;text-decoration:none }
.cc-n a:hover { color:var(--vert) }
.cb { display:inline-block;font-family:'Space Grotesk',sans-serif;font-size:.55rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:.2rem .625rem;border-radius:2px;margin-bottom:.625rem }
.bm  { background:rgba(11,61,107,.08);color:var(--cobalt) }
.bs  { background:rgba(26,122,74,.1);color:var(--vert) }
.br  { background:rgba(0,168,198,.1);color:#006A80 }
.bo  { background:rgba(200,168,75,.12);color:#7A5A00 }
.bt  { background:rgba(11,61,107,.06);color:var(--cobalt) }
.bsv { background:rgba(26,122,74,.06);color:var(--vert) }
.btr { background:rgba(0,168,198,.08);color:#006A80 }
.bph { background:rgba(150,50,200,.08);color:#6A1F9A }
.cc-d { font-size:.8125rem;color:var(--gris);margin-bottom:.625rem;line-height:1.5 }
.cc-a { font-size:.75rem;color:var(--cobalt);display:flex;gap:.375rem;align-items:flex-start }
.cc-z { font-family:'Space Grotesk',sans-serif;font-size:.58rem;color:var(--gris);margin-top:.5rem;letter-spacing:.04em }
@media(max-width:900px){ .cg{grid-template-columns:1fr 1fr} }
@media(max-width:600px){ .cg{grid-template-columns:1fr} }

/* ── TABLE ── */
.dt { width:100%;border-collapse:collapse }
.dt tr { border-bottom:1px solid var(--ligne) }
.dt td { padding:.625rem .875rem;font-size:.875rem }
.dt td:first-child { color:var(--gris);font-family:'Space Grotesk',sans-serif;font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;width:40% }
.dt td:last-child { color:var(--encre);font-weight:500 }

/* ── MAP ── */
.map-wrap { border:1px solid var(--ligne);overflow:hidden }
.map-bar { background:var(--pierre);padding:.625rem 1.25rem;display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--ligne) }
.map-bar span { font-family:'Space Grotesk',sans-serif;font-size:.62rem;color:var(--gris);letter-spacing:.06em }
.map-bar a { font-family:'Space Grotesk',sans-serif;font-size:.62rem;color:var(--cobalt);font-weight:600;text-decoration:none }

/* ── PHOTOS ── */
.photo-wrap { overflow:hidden;position:relative }
.photo-real { width:100%;object-fit:cover;display:block;transition:.4s }
.photo-wrap:hover .photo-real { transform:scale(1.04) }
.photo-credit-bar { background:rgba(13,27,42,.78);padding:.375rem .875rem;display:flex;justify-content:space-between;align-items:center }
.photo-credit-bar span { font-family:'Space Grotesk',sans-serif;font-size:.55rem;color:rgba(255,255,255,.55);letter-spacing:.06em }
.photo-credit-bar a { color:var(--aqua)!important;font-size:.55rem;text-decoration:none }

/* ── QA ── */
.qa-block { border-left:3px solid var(--vert);padding:.875rem 1.5rem;margin-bottom:1.25rem;background:rgba(26,122,74,.04) }
.qa-q { font-family:'Cormorant Garamond',serif;font-size:1.1rem;font-weight:600;color:var(--cobalt);margin-bottom:.5rem }
.qa-a { font-size:.9375rem;color:var(--encre);line-height:1.7 }
.qa-a strong { color:var(--vert) }
.qa-a a { color:var(--cobalt) }

/* ── TIMELINE ── */
.tl { position:relative;padding-left:2.5rem }
.tl::before { content:'';position:absolute;left:.75rem;top:0;bottom:0;width:1px;background:var(--ligne) }
.tl-e { position:relative;margin-bottom:2.5rem }
.tl-dot { position:absolute;left:-2rem;top:.5rem;width:10px;height:10px;background:var(--vert);border-radius:50%;border:2px solid var(--creme) }
.tl-y { font-family:'Space Grotesk',sans-serif;font-size:.6rem;font-weight:700;color:var(--vert);letter-spacing:.1em;text-transform:uppercase;margin-bottom:.375rem }
.tl-t { font-family:'Cormorant Garamond',serif;font-size:1.25rem;font-weight:600;color:var(--cobalt);margin-bottom:.625rem }
.tl-e p { font-size:.9375rem;color:var(--encre);line-height:1.7 }

/* ── SVC CARDS ── */
.svc-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:1.75rem }
.svc-card { border-top:4px solid var(--vert);background:#fff;padding:2rem;transition:.25s;position:relative;overflow:hidden }
.svc-card::before { content:attr(data-icon);position:absolute;top:-1rem;right:1rem;font-size:4.5rem;opacity:.06;line-height:1 }
.svc-card:hover { transform:translateY(-4px);box-shadow:0 8px 32px var(--s2) }
.svc-card h3 { font-size:1.25rem;color:var(--nuit);margin-bottom:.875rem }
.svc-feat { list-style:none;margin:.75rem 0 1.25rem }
.svc-feat li { font-size:.875rem;padding:.25rem 0;border-bottom:1px solid rgba(11,61,107,.07);color:var(--encre) }
.svc-feat li::before { content:'✓ ';color:var(--vert);font-weight:700 }
@media(max-width:900px){ .svc-grid{grid-template-columns:1fr} }

/* ── FOOTER ── */
.ft { background:var(--nuit);padding:4rem 0 0 }
.ft-g { display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:3rem;padding-bottom:3rem }
.ft-brand { font-family:'Cormorant Garamond',serif;font-size:1.625rem;color:#fff;margin-bottom:.75rem }
.ft-brand em { color:var(--vert) }
.ft-desc { font-size:.8125rem;color:rgba(255,255,255,.45);line-height:1.7;margin-bottom:1rem }
.ft-tel { font-family:'Cormorant Garamond',serif;font-size:1.375rem;color:var(--aqua);text-decoration:none;font-style:italic }
.ft-col h5 { font-family:'Space Grotesk',sans-serif;font-size:.6rem;font-weight:700;color:rgba(255,255,255,.35);letter-spacing:.18em;text-transform:uppercase;margin-bottom:1rem }
.ft-col ul { list-style:none }
.ft-col li { margin-bottom:.5rem }
.ft-col a { color:rgba(255,255,255,.55);text-decoration:none;font-size:.875rem;transition:.15s }
.ft-col a:hover { color:var(--aqua) }
.ft-sitemap { border-top:1px solid rgba(255,255,255,.07);padding:1.25rem 0;display:flex;flex-wrap:wrap;gap:.4rem 1.25rem;align-items:center }
.ft-sitemap-l { font-family:'Space Grotesk',sans-serif;font-size:.55rem;font-weight:700;color:rgba(255,255,255,.3);letter-spacing:.14em;text-transform:uppercase;flex-basis:100%;margin-bottom:.25rem }
.ft-sitemap a { color:rgba(255,255,255,.5);text-decoration:none;font-size:.78rem;transition:.15s }
.ft-sitemap a:hover { color:var(--aqua) }
.ft-bot { border-top:1px solid rgba(255,255,255,.07);padding:1.25rem 0;display:flex;justify-content:space-between;flex-wrap:wrap;gap:.5rem }
.ft-bot span { font-family:'Space Grotesk',sans-serif;font-size:.62rem;color:rgba(255,255,255,.3);letter-spacing:.04em }
@media(max-width:900px){ .ft-g{grid-template-columns:1fr 1fr} }
@media(max-width:600px){ .ft-g{grid-template-columns:1fr} }

/* ── ACCESS ── */
.ac-grid { display:grid;grid-template-columns:1fr 1fr 1fr;gap:1.5rem }
.ac { background:#fff;padding:1.5rem;border-top:3px solid var(--cobalt) }
.ac.ac-warn { border-top-color:var(--or) }
.ac-ico { font-size:1.5rem;margin-bottom:.5rem }
.ac h3 { font-size:1rem;color:var(--cobalt);margin-bottom:.375rem;font-family:'Space Grotesk',sans-serif;font-size:.8125rem;font-weight:700;letter-spacing:.04em }
.ac p { font-size:.8125rem;color:var(--encre) }
.warn-tag { background:rgba(200,168,75,.15);color:#7A5A00;font-family:'Space Grotesk',sans-serif;font-size:.55rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:.2rem .5rem;display:inline-block;margin-bottom:.5rem }
@media(max-width:900px){ .ac-grid{grid-template-columns:1fr 1fr} }
@media(max-width:600px){ .ac-grid{grid-template-columns:1fr} }

/* ── SKIP LINK ── */
.skip-l { position:absolute;left:-9999px;top:0;z-index:999;padding:.5rem 1rem;background:var(--vert);color:#fff;text-decoration:none }
.skip-l:focus { left:0 }

/* ── MOBILE NAV ── */
@media(max-width:1000px) {
  .mnav { display:none;position:fixed;top:70px;left:0;right:0;background:var(--creme);border-top:2px solid var(--vert);flex-direction:column;z-index:200;padding:1rem;gap:0;max-height:80vh;overflow-y:auto }
  .mnav.on { display:flex }
  .mnav li a { height:auto;line-height:1.4;padding:.75rem 1rem;border-bottom:1px solid var(--ligne) }
  .drop-menu { display:none!important;position:static;border:none;box-shadow:none;background:rgba(26,122,74,.05);min-width:auto }
  .mnav li.drop:hover .drop-menu { display:none!important }
  .mnav li.drop.open .drop-menu { display:block!important }
  .drop-menu a { padding:.5rem 2rem!important;font-size:.68rem!important }
  .brg { display:block }
  .hcta { display:none }
}

/* ══════════════════════════════════════════════════════════════
   MOBILE RESPONSIVE — euromedecine.com
   Breakpoints : 1000px (tablet/nav), 700px (tablet), 600px (mobile), 480px (small)
   ══════════════════════════════════════════════════════════════ */

/* ── Protection overflow global ── */
*, *::before, *::after { box-sizing:border-box }
html, body { overflow-x:hidden; max-width:100vw }
img, svg, video, iframe { max-width:100%; height:auto }
table { width:100%; table-layout:fixed }
.dt td { word-break:break-word }

/* ═══════════════════════════════
   TABLETTE — max 1000px
   ═══════════════════════════════ */
@media(max-width:1000px){
  /* Header */
  .site-hdr .w { padding:0 1rem }
  .logo-btm    { display:none }
  .logo-top    { font-size:.9rem }
  .logo-mark   { width:34px;height:34px;font-size:1.15rem }
  .hcta        { display:none }   /* CTA tel caché sur tablette/mobile */

  /* Menu hamburger */
  .brg { display:flex }
  .mnav {
    display:none;
    position:absolute;
    top:100%; left:0; right:0;
    background:var(--nuit);
    flex-direction:column;
    padding:.5rem 0;
    z-index:200;
    box-shadow:0 8px 24px rgba(0,0,0,.2);
  }
  .mnav.on { display:flex }
  .mnav li  { border:none }
  .mnav li a{
    display:flex;align-items:center;
    padding:.875rem 1.5rem;
    min-height:44px;
    font-size:.75rem;
    color:rgba(255,255,255,.8);
    border-bottom:1px solid rgba(255,255,255,.05);
  }
  .mnav li a:hover, .mnav li a.on { color:#fff;background:rgba(255,255,255,.06) }

  /* Sous-menu dropdown */
  .drop-menu {
    display:none;
    position:static;
    background:rgba(26,122,74,.08);
    border-left:3px solid var(--vert);
    padding:.25rem 0;
    margin-left:1rem;
    box-shadow:none;
    min-width:0;
  }
  .drop-menu.open { display:block }
  .drop-menu li a {
    font-size:.7rem;
    padding:.625rem 1.25rem;
    color:rgba(255,255,255,.65);
  }
  .drop > a::after { content:' ▾';font-size:.6rem;opacity:.6 }

  /* Touch targets */
  .ft-col a,
  .btn       { min-height:44px; display:inline-flex; align-items:center; justify-content:center }
}

/* ═══════════════════════════════
   TABLETTE PORTRAIT — max 700px
   ═══════════════════════════════ */
@media(max-width:700px){
  /* Zone cards 2 col → 1 col */
  .zone-grid { grid-template-columns:1fr !important }

  /* Grille accès 3 col → 1 col */
  .ac-grid { grid-template-columns:1fr !important }

  /* Feature cards 3 col → 1 col */
  .fc-grid { grid-template-columns:1fr !important }

  /* Section services grid */
  .svc-grid { grid-template-columns:1fr }

  /* Grid annuaire */
  .cg { grid-template-columns:1fr !important }
}

/* ═══════════════════════════════
   MOBILE — max 600px
   ═══════════════════════════════ */
@media(max-width:600px){
  /* Base */
  .s     { padding:2.5rem 0 }
  .w     { padding:0 .875rem }

  /* Hero */
  .hero             { min-height:auto;padding:3.5rem 0 2.5rem }
  .hero-deco        { display:none }
  .bg               { flex-direction:column;gap:.625rem }
  .bg .btn          { width:100%;text-align:center }
  .hero-strip       { grid-template-columns:1fr 1fr;margin-top:1.5rem }

  /* Typographie fluide */
  h1 { font-size:clamp(2rem,9vw,3rem) }
  h2 { font-size:clamp(1.5rem,7.5vw,2.25rem) }
  h3 { font-size:1.1rem }
  body { font-size:15px;line-height:1.65 }
  .kicker { font-size:.55rem;letter-spacing:.1em }

  /* Ticker */
  .tk-i  { font-size:.6rem;padding:0 .875rem }

  /* Sections hero inline */
  [style*="padding:4.5rem 0 3rem"] { padding:3rem 0 2rem !important }
  [style*="padding:4rem 0 3rem"]   { padding:2.5rem 0 2rem !important }

  /* ─ Grilles utilitaires (classes ajoutées sur les divs) ─ */
  .grid-2col-resp  { grid-template-columns:1fr !important }
  .grid-3col-resp  { grid-template-columns:1fr 1fr !important }
  .grid-4col-resp  { grid-template-columns:1fr 1fr !important }

  /* ─ Grilles photo galleries inline ─ */
  [style*="grid-template-columns:1fr 1fr;gap:4px"],
  [style*="grid-template-columns:1fr 1fr;gap:3px"],
  [style*="grid-template-columns:2fr 1fr;gap:4px"],
  [style*="grid-template-columns:2fr 1fr;gap:3px"],
  [style*="grid-template-columns:1fr 1fr 1fr;gap:3px"],
  [style*="grid-template-columns:repeat(4,1fr);gap:1px"] {
    grid-template-columns:1fr !important;
  }

  /* ─ Grilles 4 stats (2×2 sur mobile) ─ */
  [style*="grid-template-columns:repeat(4,1fr);gap:1px;background:var(--nuit)"] {
    grid-template-columns:1fr 1fr !important;
  }
  .st-grid { grid-template-columns:1fr 1fr }

  /* ─ Hauteurs photos galerie ─ */
  [style*="height:280px;object-fit:cover"],
  [style*="height:300px;object-fit:cover"],
  [style*="height:320px;object-fit:cover"] { height:190px !important }
  [style*="height:220px;object-fit:cover"],
  [style*="height:240px;object-fit:cover"] { height:170px !important }
  [style*="height:180px;object-fit:cover"]  { height:150px !important }
  [style*="height:260px;display:block"],
  [style*="height:280px;display:block"] { height:190px !important }

  /* ─ Blocs d'actions CTA flex ─ */
  [style*="display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap"] {
    flex-direction:column !important;
    align-items:flex-start !important;
    gap:.875rem !important;
  }

  /* ─ Maps ─ */
  .map-wrap iframe { height:220px }
  .map-bar { flex-direction:column;align-items:flex-start;gap:.25rem;padding:.5rem .875rem }

  /* ─ Annuaire filtres ─ */
  .fbr { gap:.3rem;flex-wrap:wrap }
  .fb  { font-size:.57rem;padding:.3rem .5rem;flex-shrink:0 }

  /* ─ Company cards ─ */
  .cg  { grid-template-columns:1fr !important }
  .cc  { padding:1rem }
  .cc-n{ font-size:.8rem }
  .cc-d{ font-size:.75rem }
  .cc-a{ font-size:.7rem }
  .cb  { font-size:.5rem;padding:.15rem .375rem }

  /* ─ QA blocks ─ */
  .qa-block { padding:.875rem 1rem }
  .qa-q     { font-size:1rem }
  .qa-a     { font-size:.875rem }

  /* ─ Timeline ─ */
  .tl       { padding-left:1.75rem }
  .tl-y     { font-size:.875rem }
  .tl-t     { font-size:1.1rem }
  .tl-e p   { font-size:.875rem;line-height:1.65 }

  /* ─ Table ─ */
  .dt td          { font-size:.78rem;padding:.5rem .625rem }
  .dt td:first-child { width:40%;font-size:.7rem }

  /* ─ Footer ─ */
  .ft-g    { grid-template-columns:1fr;gap:1.25rem }
  .ft-bot  { flex-direction:column;gap:.375rem;font-size:.58rem;text-align:center }
  .ft-brand{ font-size:1.375rem }
  .ft-tel  { font-size:1.125rem }

  /* ─ Logos footer partenaires ─ */
  [style*="border-top:1px solid rgba(255,255,255,.07)"] {
    gap:1rem !important;
  }
  [style*="border-top:1px solid rgba(255,255,255,.07)"] img {
    height:28px !important;
  }

  /* ─ Boutons pleine largeur mobile ─ */
  .btn-s, .btn-ol, .btn-ol-c, .btn-vert {
    display:inline-flex;
    width:100%;
    justify-content:center;
    margin-bottom:.375rem;
  }

  /* ─ Liens utiles 3 colonnes ─ */
  .liens-cols,
  [style*="grid-template-columns:1fr 1fr 1fr"] { grid-template-columns:1fr !important }

  /* ─ Bannière officielle ─ */
  [style*="max-width:1000px"] img { height:auto }

  /* ─ max-width:560px inline → 100% ─ */
  [style*="max-width:560px"] { max-width:100% !important }
}

/* ═══════════════════════════════
   PETIT MOBILE — max 480px
   ═══════════════════════════════ */
@media(max-width:480px){
  .s   { padding:2rem 0 }
  .w   { padding:0 .75rem }

  h1   { font-size:clamp(1.875rem,9.5vw,2.75rem) }
  h2   { font-size:clamp(1.375rem,8vw,2rem) }
  h3   { font-size:1.05rem }
  body { font-size:14.5px }

  /* Header compact */
  .logo-mark { width:30px;height:30px;font-size:1.05rem }
  .logo-top  { font-size:.82rem }

  /* Hero strip 2×2 */
  .hero-strip { grid-template-columns:1fr 1fr }
  .hs-n       { font-size:1.5rem }
  .hs-l       { font-size:.5rem;letter-spacing:.05em }

  /* Boutons  */
  .btn { font-size:.65rem;padding:.5rem 1rem;min-height:42px }

  /* Ticker compact */
  .tk-i { font-size:.57rem;padding:0 .75rem }

  /* Timeline encore plus compact */
  .tl { padding-left:1.5rem }

  /* fc cards */
  .fc { padding:1.25rem }
  .fc-ico { font-size:2rem }

  /* Zone cards */
  .zc { padding:1.5rem }
  .zc-facts { grid-template-columns:repeat(3,1fr);gap:.5rem }
  .zf-n { font-size:1.25rem }

  /* Stats bande */
  .st-grid { grid-template-columns:1fr 1fr }
  .stb     { padding:1rem }
  .stb-v   { font-size:1.5rem !important }

  /* Galeries photos encore réduites */
  [style*="height:190px;object-fit:cover"],
  [style*="height:200px;object-fit:cover"] { height:160px !important }

  /* Cards info compactes */
  .cc  { padding:.875rem }
  .fb  { font-size:.55rem;padding:.25rem .45rem }
}
