/*
 * Mega-Ique — Accueil (front-page.php)
 * Direction « audacieux & animé » (startup tech) : hero dark + aurora animée,
 * bento grid, marquees, micro-animations, motif losange. Visuels CSS/SVG.
 */

.mqh-main {
	--ink:    #0c1322;
	--ink-2:  #111a2c;
	--body:   #46515f;
	--muted:  #6c7787;
	--soft:   #f4f7fb;
	--line:   #e7edf4;
	--blue:   #2aa8f6;
	--blue-l: #dff1ff;
	--blue-d: #1685cf;
	--indigo: #5b6ef0;
	--red:    #e23b3b;
	--yellow: #ffc02e;
	--orange: #f39200;
	--orange-d: #db8200;
	--g1: #2aa8f6; --g2: #4f7df0; --g3: #7cd9ff;

	background: #fff; color: var(--body); overflow-x: clip;
	font-family: var(--mq-font-body);
}
.home #content, .home .site-content, .home #primary { background: #fff; }

.mqh-container { width: 100%; max-width: 1200px; margin-inline: auto; padding-inline: clamp(1.2rem, 4vw, 2.5rem); }
.mqh-section { position: relative; padding-block: clamp(3.8rem, 7vw, 6.5rem); }
.mqh-section--soft { background: var(--soft); }

/* ---------- En-têtes ---------- */
.mqh-kicker { display: inline-flex; align-items: center; gap: .5rem; font-family: var(--mq-font-sub); font-weight: 700; font-size: .76rem; letter-spacing: .14em; text-transform: uppercase; color: var(--blue-d); margin: 0 0 1rem; }
.mqh-kicker::before { content: ""; width: 24px; height: 2px; background: var(--orange); }
.mqh-section__head { max-width: 760px; margin-bottom: clamp(2.2rem, 4vw, 3.4rem); }
.mqh-section__head--center { margin-inline: auto; text-align: center; }
.mqh-section__head--center .mqh-kicker { justify-content: center; }
.mqh-section__title { font-family: var(--mq-font-heading); font-weight: 800; line-height: 1.08; font-size: clamp(1.9rem, 3.8vw, 2.9rem); margin: 0; color: var(--ink); letter-spacing: -0.02em; }
.mqh-section__sub { margin: 1rem 0 0; color: var(--muted); font-size: 1.05rem; line-height: 1.6; }
.mqh-grad { background: linear-gradient(100deg, var(--g1), var(--g2) 60%, var(--g3)); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }

/* ---------- Boutons ---------- */
.mqh-btn { display: inline-flex; align-items: center; gap: .5rem; font-family: var(--mq-font-sub); font-weight: 700; font-size: 1rem; padding: .9rem 1.7rem; border-radius: 12px; text-decoration: none; border: 0; cursor: pointer; transition: transform .15s ease, box-shadow .2s ease, background-color .2s ease, color .2s ease; }
.mqh-btn:hover { transform: translateY(-2px); }
.mqh-btn--sm { padding: .6rem 1.1rem; font-size: .92rem; border-radius: 10px; }
.mqh-btn--grad { background: linear-gradient(100deg, var(--g1), var(--g2)); color: #fff; box-shadow: 0 10px 30px rgba(42,168,246,.4); }
.mqh-btn--grad:hover { box-shadow: 0 14px 38px rgba(79,125,240,.5); color: #fff; }
.mqh-btn--glass { background: rgba(255,255,255,.08); color: #fff; border: 1px solid rgba(255,255,255,.25); backdrop-filter: blur(6px); }
.mqh-btn--glass:hover { background: rgba(255,255,255,.16); color: #fff; }
.mqh-btn--light { background: #fff; color: var(--ink); box-shadow: 0 8px 22px rgba(0,0,0,.12); }
.mqh-btn--light:hover { box-shadow: 0 12px 30px rgba(0,0,0,.2); color: var(--ink); }
.mqh-btn--orange { background: var(--orange); color: #fff; box-shadow: 0 10px 28px rgba(243,146,0,.35); }
.mqh-btn--orange:hover { background: var(--orange-d); color: #fff; box-shadow: 0 14px 34px rgba(243,146,0,.45); }
.mqh-btn--outline { background: #fff; color: var(--blue-d); border: 2px solid #cfe6f7; }
.mqh-btn--outline:hover { border-color: var(--blue); background: var(--blue-l); color: var(--blue-d); }
.mqh-btn--ghost { background: rgba(255,255,255,.10); color: #fff; border: 1px solid rgba(255,255,255,.45); backdrop-filter: blur(4px); }
.mqh-btn--ghost:hover { background: rgba(255,255,255,.2); color: #fff; }

.mqh-link { font-family: var(--mq-font-sub); font-weight: 700; text-decoration: none; color: var(--blue-d); }
.mqh-link::after { content: " →"; }
.mqh-link:hover { color: var(--red); }

.mqh-pill { display: inline-flex; align-items: center; gap: .5rem; font-family: var(--mq-font-sub); font-weight: 700; font-size: .76rem; letter-spacing: .1em; text-transform: uppercase; color: var(--blue-d); background: var(--blue-l); border: 1px solid #cfe6f7; border-radius: 999px; padding: .45rem .9rem; margin: 0 0 1.6rem; }
.mqh-pill__dot { width: 7px; height: 7px; border-radius: 50%; background: #4fe3a0; box-shadow: 0 0 0 4px rgba(79,227,160,.22); }

/* ---------- Reveal (masqué uniquement quand le JS est actif : .mqh-anim) ---------- */
.mqh-anim .mqh-reveal { opacity: 0; transform: translateY(26px); transition: opacity .6s ease, transform .6s ease; }
.mqh-anim .mqh-reveal.is-visible { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .mqh-anim .mqh-reveal { opacity: 1; transform: none; } .mqh-hero__aurora, .mqh-dia, .mqh-marquee__track, .mqh-hero__marquee { animation: none !important; } }

/* ================================ HERO SLIDER (photos réelles plein cadre) ============== */
.mqh-sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0; }

.mqh-hero-slider { position: relative; width: 100%; height: clamp(540px, 82vh, 820px); background: #14163a; color: #fff; overflow: hidden; isolation: isolate; }
.mqh-slider { position: absolute; inset: 0; }

.mqh-slide { position: absolute; inset: 0; opacity: 0; visibility: hidden; transition: opacity .9s ease; }
.mqh-slide.is-active { opacity: 1; visibility: visible; }
.mqh-slide__bg { position: absolute; inset: 0; background-size: cover; background-position: center; transform: scale(1.06); transition: transform 8s ease; }
.mqh-slide.is-active .mqh-slide__bg { transform: scale(1); }
/* Voile sombre pondéré à gauche (navy de marque) pour la lisibilité du texte sur photo */
.mqh-slide__shade { position: absolute; inset: 0; background:
	linear-gradient(90deg, rgba(20,22,58,.93) 0%, rgba(20,22,58,.66) 38%, rgba(20,22,58,.18) 72%, rgba(20,22,58,0) 100%),
	linear-gradient(0deg, rgba(20,22,58,.55) 0%, transparent 44%); }

.mqh-slide__inner { position: relative; z-index: 2; height: 100%; display: flex; align-items: center; }
.mqh-slide__content { max-width: 620px; padding-block: 1.5rem; }
.mqh-slide__eyebrow { display: inline-flex; align-items: center; gap: .5rem; font-family: var(--mq-font-sub); font-weight: 700; font-size: .74rem; letter-spacing: .12em; text-transform: uppercase; color: #fff; background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.24); border-radius: 999px; padding: .42rem .9rem; margin: 0 0 1.2rem; }
.mqh-slide__dot { width: 7px; height: 7px; border-radius: 50%; background: var(--blue); box-shadow: 0 0 0 4px rgba(42,168,246,.3); }
.mqh-slide__title { font-family: var(--mq-font-heading); font-weight: 800; line-height: 1.06; letter-spacing: -.02em; font-size: clamp(1.9rem, 4.2vw, 3.4rem); margin: 0 0 1rem; text-shadow: 0 2px 26px rgba(0,0,0,.4); }
.mqh-slide__title em { font-style: normal; color: #7fd0ff; }
.mqh-slide__lead { font-size: clamp(1rem, 1.5vw, 1.18rem); line-height: 1.6; color: rgba(255,255,255,.9); max-width: 540px; margin: 0 0 1.8rem; text-shadow: 0 1px 14px rgba(0,0,0,.35); }
.mqh-slide__cta { display: flex; flex-wrap: wrap; gap: .9rem; }

/* Flèches */
.mqh-slider__arrow { position: absolute; top: 50%; transform: translateY(-50%); z-index: 6; width: 54px; height: 54px; display: grid; place-items: center; border: 1px solid rgba(255,255,255,.5); border-radius: 50%; background: rgba(20,22,58,.45); color: #fff; cursor: pointer; backdrop-filter: blur(4px); box-shadow: 0 8px 24px rgba(0,0,0,.3); transition: background .2s ease, border-color .2s ease; }
.mqh-slider__arrow:hover { background: var(--orange); border-color: var(--orange); }
.mqh-slider__arrow svg { width: 26px; height: 26px; }
.mqh-slider__arrow--prev { left: clamp(.6rem, 2vw, 1.6rem); }
.mqh-slider__arrow--next { right: clamp(.6rem, 2vw, 1.6rem); }

/* Puces */
.mqh-slider__dots { position: absolute; left: 0; right: 0; bottom: clamp(1.1rem, 3vh, 2rem); z-index: 4; display: flex; justify-content: center; gap: .6rem; }
.mqh-slider__dot { width: 11px; height: 11px; padding: 0; border: 0; border-radius: 50%; background: rgba(255,255,255,.4); cursor: pointer; transition: background .2s ease, width .2s ease, border-radius .2s ease; }
.mqh-slider__dot:hover { background: rgba(255,255,255,.7); }
.mqh-slider__dot.is-active { width: 30px; border-radius: 999px; background: var(--orange); }

@media (max-width: 768px) {
	.mqh-slide__shade { background: linear-gradient(90deg, rgba(20,22,58,.92) 0%, rgba(20,22,58,.7) 60%, rgba(20,22,58,.45) 100%), linear-gradient(0deg, rgba(20,22,58,.6) 0%, transparent 50%); }
	.mqh-slider__arrow { display: none; }
	.mqh-slide__cta .mqh-btn { padding: .8rem 1.3rem; font-size: .95rem; }
}
@media (prefers-reduced-motion: reduce) { .mqh-slide, .mqh-slide__bg { transition: none; } }

/* ================================ HERO (clair, intégré à la page) ================================ */
.mqh-hero { position: relative; overflow: hidden; background: radial-gradient(120% 110% at 78% -10%, #e7f3ff 0%, #fff 58%); color: var(--ink); padding-block: clamp(3rem, 6vw, 5rem); isolation: isolate; }
.mqh-hero__aurora { position: absolute; inset: -25% -10% auto -10%; height: 95%; z-index: 0; pointer-events: none; filter: blur(70px); opacity: .65;
	background:
		radial-gradient(34% 50% at 80% 22%, rgba(42,168,246,.32), transparent 70%),
		radial-gradient(34% 50% at 60% 30%, rgba(91,110,240,.2), transparent 70%),
		radial-gradient(28% 42% at 92% 55%, rgba(243,146,0,.16), transparent 70%);
	animation: mqh-aurora 16s ease-in-out infinite alternate;
}
@keyframes mqh-aurora { 0% { transform: translate3d(-3%, -2%, 0) scale(1); } 50% { transform: translate3d(4%, 3%, 0) scale(1.08); } 100% { transform: translate3d(-2%, 1%, 0) scale(1.03); } }
.mqh-hero__grid { position: absolute; inset: 0; z-index: 0; opacity: .6; pointer-events: none; background-image: linear-gradient(rgba(42,168,246,.06) 1px, transparent 1px), linear-gradient(90deg, rgba(42,168,246,.06) 1px, transparent 1px); background-size: 46px 46px; -webkit-mask-image: radial-gradient(75% 70% at 75% 30%, #000, transparent 80%); mask-image: radial-gradient(75% 70% at 75% 30%, #000, transparent 80%); }
.mqh-dia { position: absolute; z-index: 0; transform: rotate(45deg); border-radius: 6px; pointer-events: none; opacity: .9; }
.mqh-dia--1 { width: 64px; height: 64px; background: linear-gradient(135deg, var(--blue), #7fd0ff); top: 18%; right: 12%; animation: mqh-float 7s ease-in-out infinite; }
.mqh-dia--2 { width: 34px; height: 34px; background: var(--red); top: 60%; right: 24%; animation: mqh-float 5.5s ease-in-out infinite .6s; }
.mqh-dia--3 { width: 24px; height: 24px; background: var(--yellow); top: 30%; left: 8%; animation: mqh-float 6.5s ease-in-out infinite .3s; }
@keyframes mqh-float { 0%,100% { transform: translateY(0) rotate(45deg); } 50% { transform: translateY(-16px) rotate(55deg); } }

.mqh-hero__inner { position: relative; z-index: 1; display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(2rem, 5vw, 4rem); align-items: center; }
.mqh-hero__copy { max-width: 620px; }
.mqh-hero__title { font-family: var(--mq-font-heading); font-weight: 800; line-height: 1.05; font-size: clamp(2.5rem, 5vw, 4.2rem); letter-spacing: -0.03em; margin: 0 0 1.3rem; color: var(--ink); }

/* Mockup produit (clair, brille sur le hero sombre) */
.mqh-hero__visual { position: relative; z-index: 1; }
.mqh-mock { position: relative; padding: 1rem .5rem 2.5rem; filter: drop-shadow(0 30px 60px rgba(20,40,80,.18)); animation: mqh-floaty 8s ease-in-out infinite; }
@keyframes mqh-floaty { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-12px); } }
.mqh-mock__browser { background: #fff; border-radius: 14px; overflow: hidden; box-shadow: 0 0 0 1px var(--line); transform: rotate(-1.2deg); }
.mqh-mock__bar { display: flex; align-items: center; gap: 6px; padding: .7rem .9rem; background: #f4f7fb; border-bottom: 1px solid #e7edf4; }
.mqh-mock__bar i { width: 9px; height: 9px; border-radius: 50%; background: #d3dde7; }
.mqh-mock__bar i:nth-child(1){ background:#ff6058; } .mqh-mock__bar i:nth-child(2){ background:#ffbd2e; } .mqh-mock__bar i:nth-child(3){ background:#28c840; }
.mqh-mock__url { margin-left: .6rem; flex: 1; background: #fff; border: 1px solid #e7edf4; border-radius: 6px; font-size: .72rem; color: var(--muted); padding: .25rem .7rem; font-family: var(--mq-font-sub); }
.mqh-mock__app { display: grid; grid-template-columns: 52px 1fr; min-height: 290px; }
.mqh-mock__side { background: linear-gradient(180deg, #16233c, #0f1b2e); padding: 1rem .75rem; display: flex; flex-direction: column; gap: .6rem; }
.mqh-mock__logo { width: 22px; height: 22px; background: linear-gradient(135deg, var(--blue), #7fd0ff); border-radius: 6px; transform: rotate(45deg); margin-bottom: .5rem; }
.mqh-mock__navline { height: 8px; border-radius: 4px; background: rgba(255,255,255,.14); }
.mqh-mock__navline.is-active { background: var(--blue); }
.mqh-mock__main { padding: 1.1rem; display: flex; flex-direction: column; gap: 1rem; }
.mqh-mock__tiles { display: grid; grid-template-columns: repeat(3,1fr); gap: .6rem; }
.mqh-mock__tile { border: 1px solid #e7edf4; border-radius: 9px; padding: .65rem .55rem; position: relative; }
.mqh-mock__tile b { display: block; font-family: var(--mq-font-heading); font-weight: 800; font-size: 1.15rem; color: var(--ink); line-height: 1; }
.mqh-mock__tile i { font-style: normal; font-size: .66rem; color: var(--muted); }
.mqh-mock__t-up { position: absolute; top: .55rem; right: .55rem; width: 0; height: 0; border-left: 5px solid transparent; border-right: 5px solid transparent; border-bottom: 8px solid var(--blue); }
.mqh-mock__chart { display: flex; align-items: flex-end; gap: .5rem; height: 110px; padding-top: .5rem; border-top: 1px solid #e7edf4; }
.mqh-mock__chart span { flex: 1; height: var(--h); border-radius: 6px 6px 0 0; background: linear-gradient(180deg, var(--blue), #bfe6ff); }
.mqh-mock__chart span:nth-child(7){ background: linear-gradient(180deg, var(--blue-d), var(--blue)); }
.mqh-mock__phone { position: absolute; right: -.6rem; bottom: 0; width: 112px; height: 224px; background: #0f1b2e; border-radius: 22px; padding: 8px; box-shadow: 0 20px 40px rgba(0,0,0,.45); transform: rotate(3deg); }
.mqh-mock__notch { position: absolute; top: 14px; left: 50%; transform: translateX(-50%); width: 36px; height: 5px; background: #2a3a4a; border-radius: 3px; z-index: 2; }
.mqh-mock__screen { background: #fff; border-radius: 15px; height: 100%; padding: 1.25rem .65rem .65rem; display: flex; flex-direction: column; gap: .5rem; }
.mqh-mock__p-head { height: 28px; border-radius: 7px; background: linear-gradient(120deg, var(--blue), #7fd0ff); }
.mqh-mock__p-row { height: 13px; border-radius: 4px; background: #eef3f8; }
.mqh-mock__p-row.short { width: 60%; }
.mqh-mock__p-btn { margin-top: auto; height: 24px; border-radius: 7px; background: var(--blue); }
.mqh-mock__chip { position: absolute; background: #fff; border-radius: 10px; padding: .5rem .8rem; font-family: var(--mq-font-sub); font-weight: 600; font-size: .8rem; color: var(--ink); box-shadow: 0 14px 30px rgba(0,0,0,.25); display: flex; align-items: center; gap: .45rem; }
.mqh-mock__chip--1 { top: .6rem; left: -.6rem; }
.mqh-mock__chip--2 { bottom: 2.6rem; left: .6rem; color: var(--blue-d); }
.mqh-dot-live { width: 8px; height: 8px; border-radius: 50%; background: #28c840; box-shadow: 0 0 0 3px rgba(40,200,64,.2); }

/* Chip animé (rotor de capacités) */
.mqh-rotor { gap: .45rem; }
.mqh-rotor__pre { color: var(--muted); font-weight: 600; }
.mqh-rotor__win { height: 1.45em; overflow: hidden; display: inline-block; vertical-align: middle; }
.mqh-rotor__list { display: flex; flex-direction: column; animation: mqh-rotor 12s cubic-bezier(.7,0,.3,1) infinite; }
.mqh-rotor__list span { height: 1.45em; line-height: 1.45em; color: var(--blue-d); font-weight: 700; white-space: nowrap; }
@keyframes mqh-rotor {
	0%,11%   { transform: translateY(0); }
	16.6%,28%{ transform: translateY(-1.45em); }
	33.3%,45%{ transform: translateY(-2.9em); }
	50%,61%  { transform: translateY(-4.35em); }
	66.6%,78%{ transform: translateY(-5.8em); }
	83.3%,95%{ transform: translateY(-7.25em); }
	100%     { transform: translateY(-8.7em); }
}
@media (prefers-reduced-motion: reduce) { .mqh-rotor__list { animation: none !important; } }
.mqh-hero__lead { font-size: clamp(1.05rem, 1.5vw, 1.25rem); line-height: 1.6; color: var(--body); max-width: 560px; margin: 0 0 2rem; }
.mqh-hero__lead em { color: var(--ink); font-style: italic; font-weight: 600; }
.mqh-hero__cta { display: flex; flex-wrap: wrap; gap: 1rem; margin-bottom: 2.6rem; }
.mqh-hero__marquee { list-style: none; display: flex; gap: 2.2rem; padding: 1.6rem 0 0; margin: 1.5rem 0 0; border-top: 1px solid var(--line); width: max-content; animation: mqh-scroll 26s linear infinite; }
.mqh-hero__marquee li { font-family: var(--mq-font-sub); font-weight: 600; font-size: .95rem; color: var(--muted); white-space: nowrap; position: relative; }
.mqh-hero__marquee li::before { content: "◆"; color: var(--blue); margin-right: 2.2rem; font-size: .7em; vertical-align: middle; }
@keyframes mqh-scroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* Filet de marque (4 couleurs charte, discret) */
.mqh-brandline { display: block; width: 120px; height: 4px; border-radius: 4px; margin: 0 0 1.5rem; background: linear-gradient(90deg, var(--blue) 0 55%, var(--orange) 55% 100%); }

/* Drapeaux */
.mqh-flag { width: 22px; height: 15px; border-radius: 3px; overflow: hidden; display: inline-flex; flex: none; box-shadow: 0 0 0 1px rgba(0,0,0,.08); }
.mqh-flag svg { width: 100%; height: 100%; display: block; }

/* Hub diaspora + local */
.mqh-hub { position: relative; width: 100%; max-width: 480px; aspect-ratio: 1; margin-inline: auto; }
.mqh-hub__links { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 0; }
.mqh-hub__links line { stroke: rgba(42,168,246,.6); stroke-width: .6; stroke-dasharray: 1.4 1.6; stroke-linecap: round; }
.mqh-hub__core { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); width: 34%; aspect-ratio: 1; border-radius: 50%; background: #fff; box-shadow: 0 20px 50px rgba(20,40,80,.16), inset 0 0 0 1px var(--line); display: grid; place-content: center; text-align: center; padding: 6%; z-index: 1; animation: mqh-floaty 9s ease-in-out infinite; }
.mqh-hub__brand { font-family: var(--mq-font-heading); font-weight: 800; font-size: clamp(1rem, 2.3vw, 1.5rem); color: var(--ink); letter-spacing: -0.01em; }
.mqh-hub__brand span { color: var(--blue); }
.mqh-hub__tag { display: block; font-size: .58rem; letter-spacing: .07em; text-transform: uppercase; color: var(--muted); margin-top: .35rem; }
.mqh-hub__node { position: absolute; z-index: 3; transform: translate(-50%,-50%); background: #fff; border: 1px solid var(--line); border-radius: 12px; padding: .55rem .7rem; box-shadow: 0 10px 26px rgba(20,40,80,.1); display: flex; flex-direction: column; align-items: center; text-align: center; min-width: 88px; }
.mqh-hub__node svg { width: 19px; height: 19px; color: var(--blue-d); }
.mqh-hub__node b { font-family: var(--mq-font-sub); font-weight: 700; font-size: .76rem; color: var(--ink); margin-top: .2rem; line-height: 1.1; }
.mqh-hub__node i { font-style: normal; font-size: .64rem; color: var(--muted); margin-top: .1rem; }
.mqh-hub__node--top { top: 8%; left: 50%; }
.mqh-hub__node--cm  { top: 33%; left: 13%; }
.mqh-hub__node--de  { top: 33%; left: 87%; }
.mqh-hub__node--dev { top: 86%; left: 19%; }
.mqh-hub__node--off { top: 86%; left: 81%; }

/* Bandeau services (6 items) */
.mqh-strip { background: var(--soft); border-top: 1px solid var(--line); padding-block: clamp(2.5rem, 5vw, 3.6rem); }
.mqh-strip__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.6rem 2.6rem; }
.mqh-strip__item { display: flex; gap: .9rem; }
.mqh-strip__ico { flex: none; width: 46px; height: 46px; display: grid; place-items: center; border-radius: 12px; background: var(--blue-l); color: var(--blue-d); }
.mqh-strip__ico svg { width: 22px; height: 22px; }
.mqh-strip__item h3 { font-family: var(--mq-font-sub); font-weight: 700; font-size: 1.02rem; margin: 0 0 .25rem; color: var(--ink); }
.mqh-strip__item p { margin: 0; color: var(--muted); font-size: .92rem; line-height: 1.5; }

/* Stat texte (CM + DE) */
.mqh-stat__num--sm { font-size: clamp(1.4rem, 2.8vw, 2rem) !important; }

/* ============================ BENTO ============================ */
.mqh-bento { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); grid-auto-rows: minmax(180px, auto); gap: 1.4rem; }
.mqh-bento > *, .mqh-grid > * { min-width: 0; }
.mqh-tile { position: relative; overflow: hidden; border-radius: 20px; padding: 1.8rem; border: 1px solid var(--line); background: #fff; display: flex; flex-direction: column; min-width: 0; transition: transform .2s ease, box-shadow .2s ease; }
.mqh-tile__body { min-width: 0; }
.mqh-tile:hover { transform: translateY(-4px); box-shadow: 0 22px 46px rgba(12,19,34,.12); }
.mqh-tile h3 { font-family: var(--mq-font-sub); font-weight: 800; color: var(--ink); margin: 0 0 .5rem; font-size: 1.3rem; }
.mqh-tile p { color: var(--muted); line-height: 1.6; margin: 0 0 1rem; }
.mqh-tile__ico { width: 50px; height: 50px; display: grid; place-items: center; border-radius: 13px; background: var(--blue-l); color: var(--blue-d); margin-bottom: 1rem; }
.mqh-tile__ico svg { width: 26px; height: 26px; }

/* Flagship (large, span 2 colonnes) */
.mqh-tile--flagship { grid-column: span 2; min-height: 270px; color: #fff; border: 0; background: linear-gradient(135deg, #1b50c8, var(--blue) 60%, #2bd4d4); flex-direction: row; align-items: stretch; gap: 1.5rem; }
.mqh-tile--flagship h3 { color: #fff; font-size: clamp(1.6rem, 2.6vw, 2.2rem); }
.mqh-tile--flagship p { color: rgba(255,255,255,.92); max-width: 460px; }
.mqh-tile__body { position: relative; z-index: 1; display: flex; flex-direction: column; }
.mqh-tag { display: inline-block; align-self: flex-start; font-family: var(--mq-font-sub); font-weight: 700; font-size: .72rem; letter-spacing: .08em; text-transform: uppercase; padding: .3rem .7rem; border-radius: 999px; margin-bottom: 1rem; }
.mqh-tag--light { background: rgba(255,255,255,.18); color: #fff; }
.mqh-tile__meta { font-size: 1rem; color: #fff; margin: 0 0 1.2rem; }
.mqh-tile__meta strong { font-family: var(--mq-font-heading); font-weight: 800; font-size: 1.5rem; }
.mqh-tile__cta { display: flex; flex-wrap: wrap; align-items: center; gap: .9rem; margin-top: auto; }
.mqh-store { display: inline-flex; align-items: center; gap: .4rem; color: #fff; text-decoration: none; font-family: var(--mq-font-sub); font-weight: 600; font-size: .9rem; border: 1px solid rgba(255,255,255,.4); border-radius: 10px; padding: .55rem .9rem; }
.mqh-store svg { width: 16px; height: 16px; }
.mqh-store:hover { background: rgba(255,255,255,.14); color: #fff; }
.mqh-tile__art { position: relative; flex: 1; min-width: 120px; }
.mqh-gps-route { position: absolute; inset: 20% 10% 18% 18%; border: 3px dashed rgba(255,255,255,.55); border-radius: 50% 40% 55% 45%; }
.mqh-gps-pin { position: absolute; top: 26%; right: 26%; width: 30px; height: 30px; background: #fff; border-radius: 50% 50% 50% 0; transform: rotate(-45deg); box-shadow: 0 8px 20px rgba(0,0,0,.25); }
.mqh-gps-pin::after { content: ""; position: absolute; inset: 8px; background: var(--blue); border-radius: 50%; }

/* Formation (pôle majeur, span 2, clair) */
.mqh-tile--training { grid-column: span 2; background: linear-gradient(135deg, #eaf2ff, #fff 70%); flex-direction: row; align-items: center; gap: 1.6rem; }
.mqh-tile--training .mqh-tile__body { flex: 1; }
.mqh-tag--blue { background: var(--blue-l); color: var(--blue-d); }
.mqh-tile__cta { display: flex; flex-wrap: wrap; align-items: center; gap: 1rem; margin-top: .4rem; }
.mqh-tile__hl { font-size: .95rem; color: var(--muted); }
.mqh-tile__hl strong { font-family: var(--mq-font-heading); font-weight: 800; font-size: 1.4rem; color: var(--blue-d); }
.mqh-tile__art2 { flex: none; width: 120px; height: 120px; display: grid; place-items: center; border-radius: 24px; background: linear-gradient(135deg, var(--blue), #6fd0ff); box-shadow: 0 18px 40px rgba(42,168,246,.35); }
.mqh-cap { color: #fff; } .mqh-cap svg { width: 56px; height: 56px; }

.mqh-tile--cta { background: linear-gradient(135deg, #1d2150, #14163a); color: #fff; border: 0; justify-content: center; }
.mqh-tile--cta h3 { color: #fff; } .mqh-tile--cta p { color: rgba(255,255,255,.8); }
.mqh-chips { list-style: none; display: flex; flex-wrap: wrap; gap: .45rem; padding: 0; margin: 0 0 1rem; }
.mqh-chips li { font-family: var(--mq-font-sub); font-weight: 600; font-size: .82rem; color: var(--blue-d); background: var(--blue-l); border-radius: 999px; padding: .3rem .7rem; }

/* ============================ PRODUITS IoT ============================ */
.mqh-grid { display: grid; gap: 1.4rem; align-items: stretch; }
.mqh-grid--4 { grid-template-columns: repeat(4, 1fr); }
.mqh-pcard { display: flex; flex-direction: column; height: 100%; background: #fff; border: 1px solid var(--line); border-radius: 16px; overflow: hidden; transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease; }
.mqh-pcard:hover { transform: translateY(-5px); box-shadow: 0 18px 36px rgba(12,19,34,.12); border-color: #cfe6f7; }
/* En-tête illustré (placeholder — à remplacer par les vraies photos du catalogue) */
.mqh-pcard__media { position: relative; aspect-ratio: 16 / 10; display: grid; place-items: center; overflow: hidden; }
.mqh-pcard__media::after { content: ""; position: absolute; inset: 0; background-image: radial-gradient(rgba(255,255,255,.5) 1.4px, transparent 1.5px); background-size: 16px 16px; opacity: .35; }
.mqh-pcard__media--0 { background: linear-gradient(135deg, #2aa8f6, #6fd0ff); }
.mqh-pcard__media--1 { background: linear-gradient(135deg, #1b50c8, #3f8df5); }
.mqh-pcard__media--2 { background: linear-gradient(135deg, #2bb1c4, #65d6e6); }
.mqh-pcard__media--3 { background: linear-gradient(135deg, #4f6ef0, #8aa0ff); }
.mqh-pcard__art { position: relative; z-index: 1; color: rgba(255,255,255,.92); }
.mqh-pcard__art svg { width: 64px; height: 64px; }
.mqh-pcard__icon { position: absolute; left: 1.1rem; bottom: -1.3rem; z-index: 2; width: 50px; height: 50px; display: grid; place-items: center; border-radius: 13px; background: #fff; color: var(--blue-d); box-shadow: 0 8px 20px rgba(20,40,80,.18); }
.mqh-pcard__icon svg { width: 25px; height: 25px; }
.mqh-pcard__body { padding: 2.1rem 1.3rem 1.5rem; flex: 1; display: flex; flex-direction: column; }
.mqh-pcard__body h3 { font-family: var(--mq-font-sub); font-weight: 700; font-size: 1.08rem; margin: 0 0 .35rem; color: var(--ink); }
.mqh-pcard__body p { margin: 0; color: var(--muted); font-size: .92rem; line-height: 1.5; }
.mqh-iot__cta { text-align: center; margin-top: 2.5rem; display: flex; flex-direction: column; align-items: center; gap: .8rem; }
.mqh-iot__note { color: var(--muted); font-size: .9rem; }

/* ============================ STATS ============================ */
.mqh-stats__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; }
.mqh-stat { text-align: center; position: relative; }
.mqh-stat + .mqh-stat::before { content: ""; position: absolute; left: 0; top: 14%; height: 72%; width: 1px; background: var(--line); }
.mqh-stat__num { font-family: var(--mq-font-heading); font-weight: 800; font-size: clamp(2.4rem, 5vw, 3.6rem); line-height: 1; background: linear-gradient(120deg, var(--g1), var(--g2)); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.mqh-stat__unit { font-family: var(--mq-font-heading); font-weight: 800; font-size: clamp(1.6rem,3vw,2.4rem); color: var(--blue); }
.mqh-stat__label { display: block; margin-top: .6rem; font-size: .95rem; color: var(--muted); }

/* ============================ RÉFÉRENCES (marquee) ============================ */
.mqh-marquee { overflow: hidden; -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); padding-block: 1.5rem; }
.mqh-marquee__track { display: flex; gap: 3rem; width: max-content; animation: mqh-scroll 28s linear infinite; }
.mqh-logo { font-family: var(--mq-font-heading); font-weight: 800; font-size: 1.4rem; color: #9aa7b5; white-space: nowrap; transition: color .2s ease; }
.mqh-logo:hover { color: var(--ink); }
.mqh-refs__cta { text-align: center; margin-top: 1.5rem; }

/* ============================ CTA ============================ */
.mqh-cta { position: relative; overflow: hidden; text-align: center; background: radial-gradient(120% 120% at 50% 120%, #262c66, #14163a); color: #fff; }
.mqh-cta__aurora { position: absolute; inset: auto -10% -40% -10%; height: 80%; filter: blur(70px); opacity: .7; background: radial-gradient(40% 60% at 28% 60%, rgba(42,168,246,.5), transparent 70%), radial-gradient(38% 55% at 72% 55%, rgba(243,146,0,.3), transparent 70%); }
.mqh-cta__inner { position: relative; z-index: 1; padding-block: clamp(4rem, 8vw, 6rem); }
.mqh-cta__title { font-family: var(--mq-font-heading); font-weight: 800; font-size: clamp(2rem, 4.4vw, 3.2rem); margin: 0 0 .9rem; color: #fff; letter-spacing: -0.02em; }
.mqh-cta__text { color: rgba(255,255,255,.82); font-size: 1.12rem; margin: 0 0 2rem; }
.mqh-cta__actions { display: flex; flex-wrap: wrap; gap: 1rem; justify-content: center; }

/* ============================ RESPONSIVE ============================ */
@media (max-width: 1000px) {
	.mqh-grid--4 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
	.mqh-bento { grid-template-columns: repeat(2, minmax(0, 1fr)); }
	.mqh-tile--flagship, .mqh-tile--training { grid-column: span 2; grid-row: span 1; flex-direction: column; align-items: stretch; }
	.mqh-tile--training .mqh-tile__art2 { display: none; }
	.mqh-tile--flagship .mqh-tile__art { min-width: 0; min-height: 90px; }
	.mqh-hero__inner { grid-template-columns: 1fr; }
	.mqh-hero__visual { max-width: 420px; margin-inline: auto; width: 100%; }
	.mqh-strip__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 700px) {
	.mqh-bento { grid-template-columns: minmax(0, 1fr); }
	.mqh-tile--flagship, .mqh-tile--training { grid-column: span 1; }
	.mqh-tile--flagship .mqh-tile__art { display: none; }
}
@media (max-width: 600px) {
	.mqh-grid--4 { grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); }
	.mqh-strip__grid { grid-template-columns: 1fr; }
	.mqh-hub__node { min-width: 74px; padding: .4rem .5rem; }
	.mqh-hub__node b { font-size: .68rem; }
	.mqh-hub__node i { display: none; }
	.mqh-stats__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 2rem 1rem; }
	.mqh-stat + .mqh-stat:nth-child(odd)::before { display: none; }
	.mqh-hero__cta .mqh-btn { width: 100%; justify-content: center; }
}
