/* ── TAILWIND BASE (reset) ── */
*,::after,::before{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}
html{line-height:1.5;-webkit-text-size-adjust:100%;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif;scroll-behavior:smooth}
body{margin:0;line-height:inherit}
h1,h2,h3,h4{font-size:inherit;font-weight:inherit;margin:0}
a{color:inherit;text-decoration:inherit}
b,strong{font-weight:bolder}
button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;font-weight:inherit;line-height:inherit;color:inherit;margin:0;padding:0}
button,select{text-transform:none}
button,[type=button],[type=reset],[type=submit]{-webkit-appearance:button;background-color:transparent;background-image:none}
:-moz-focusring{outline:auto}
:-moz-ui-invalid{box-shadow:none}
progress{vertical-align:baseline}
::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}
[type=search]{-webkit-appearance:textfield;outline-offset:-2px}

/* ── ACCESSIBILITY: Focus visible styles ── */
*:focus-visible{outline:3px solid #2563eb;outline-offset:2px}
a:focus-visible,button:focus-visible{outline:3px solid #2563eb;outline-offset:2px;border-radius:4px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}
.sr-only:focus{position:static;width:auto;height:auto;padding:inherit;margin:inherit;overflow:visible;clip:auto;white-space:normal}
::-webkit-search-decoration{-webkit-appearance:none}
::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}
summary{display:list-item}
blockquote,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}
fieldset{margin:0;padding:0}
legend{padding:0}
ol,ul,menu{list-style:none;margin:0;padding:0}
textarea{resize:vertical}
input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}
button,[role=button]{cursor:pointer}
:disabled{cursor:default}
img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}
img,video{max-width:100%;height:auto}

/* ── TAILWIND UTILITIES ── */
.absolute{position:absolute}
.fixed{position:fixed}
.relative{position:relative}
.sticky{position:sticky}
.inset-0{inset:0px}
.bottom-6{bottom:1.5rem}
.left-4{left:1rem}
.right-6{right:1.5rem}
.top-0{top:0px}
.top-4{top:1rem}
.z-0{z-index:0}
.z-10{z-index:10}
.z-50{z-index:50}
.mx-auto{margin-left:auto;margin-right:auto}
.mb-2{margin-bottom:.5rem}
.mb-3{margin-bottom:.75rem}
.mb-6{margin-bottom:1.5rem}
.mb-8{margin-bottom:2rem}
.mb-10{margin-bottom:2.5rem}
.mb-12{margin-bottom:3rem}
.mb-16{margin-bottom:4rem}
.mt-4{margin-top:1rem}
.mt-6{margin-top:1.5rem}
.mt-10{margin-top:2.5rem}
.mt-12{margin-top:3rem}
.block{display:block}
.flex{display:flex}
.grid{display:grid}
.hidden{display:none}
.inline-block{display:inline-block}
.h-5{height:1.25rem}
.h-6{height:1.5rem}
.h-8{height:2rem}
.h-9{height:2.25rem}
.h-20{height:5rem}
.h-56{height:14rem}
.h-full{height:100%}
.w-5{width:1.25rem}
.w-6{width:1.5rem}
.w-8{width:2rem}
.w-9{width:2.25rem}
.w-full{width:100%}
.max-w-sm{max-width:24rem}
.max-w-3xl{max-width:48rem}
.max-w-4xl{max-width:56rem}
.max-w-7xl{max-width:80rem}
.flex-col{flex-direction:column}
.flex-grow{flex-grow:1}
.flex-shrink-0{flex-shrink:0}
.cursor-pointer{cursor:pointer}
.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}
.items-center{align-items:center}
.justify-between{justify-content:space-between}
.justify-center{justify-content:center}
.justify-start{justify-content:flex-start}
.gap-2{gap:.5rem}
.gap-3{gap:.75rem}
.gap-4{gap:1rem}
.gap-6{gap:1.5rem}
.gap-8{gap:2rem}
.gap-10{gap:2.5rem}
.gap-12{gap:3rem}
.space-x-8>:not([hidden])~:not([hidden]){margin-left:2rem}
.space-y-1>:not([hidden])~:not([hidden]){margin-top:.25rem}
.space-y-4>:not([hidden])~:not([hidden]){margin-top:1rem}
.space-y-6>:not([hidden])~:not([hidden]){margin-top:1.5rem}
.overflow-hidden{overflow:hidden}
.rounded-md{border-radius:.375rem}
.rounded-lg{border-radius:.5rem}
.rounded-xl{border-radius:.75rem}
.rounded-2xl{border-radius:1rem}
.rounded-full{border-radius:9999px}
.border{border-width:1px}
.border-b{border-bottom-width:1px}
.border-b-2{border-bottom-width:2px}
.border-t{border-top-width:1px}
.border-y{border-top-width:1px;border-bottom-width:1px}
.border-blue-100{border-color:#dbeafe}
.border-gray-100{border-color:#f3f4f6}
.border-gray-300{border-color:#d1d5db}
.border-green-200{border-color:#bbf7d0}
.border-red-200{border-color:#fecaca}
.border-white\/50{border-color:rgba(255,255,255,.5)}
.bg-gray-50{background-color:#f9fafb}
.bg-green-50{background-color:#f0fdf4}
.bg-red-50{background-color:#fef2f2}
.bg-transparent{background-color:transparent}
.bg-white{background-color:#fff}
.bg-\[\#25D366\]{background-color:#25D366}
.object-cover{object-fit:cover}
.p-4{padding:1rem}
.p-6{padding:1.5rem}
.p-8{padding:2rem}
.pb-1{padding-bottom:.25rem}
.pb-4{padding-bottom:1rem}
.pb-6{padding-bottom:1.5rem}
.pt-2{padding-top:.5rem}
.pt-8{padding-top:2rem}
.px-2{padding-left:.5rem;padding-right:.5rem}
.px-3{padding-left:.75rem;padding-right:.75rem}
.px-4{padding-left:1rem;padding-right:1rem}
.px-6{padding-left:1.5rem;padding-right:1.5rem}
.px-8{padding-left:2rem;padding-right:2rem}
.py-1{padding-top:.25rem;padding-bottom:.25rem}
.py-2{padding-top:.5rem;padding-bottom:.5rem}
.px-1{padding-left:.25rem;padding-right:.25rem}
.py-3{padding-top:.75rem;padding-bottom:.75rem}
.py-4{padding-top:1rem;padding-bottom:1rem}
.py-12{padding-top:3rem;padding-bottom:3rem}
.py-20{padding-top:5rem;padding-bottom:5rem}
.text-center{text-align:center}
.text-xs{font-size:.75rem;line-height:1rem}
.text-sm{font-size:.875rem;line-height:1.25rem}
.text-base{font-size:1rem;line-height:1.5rem}
.text-lg{font-size:1.125rem;line-height:1.75rem}
.text-xl{font-size:1.25rem;line-height:1.75rem}
.text-2xl{font-size:1.5rem;line-height:2rem}
.text-3xl{font-size:1.875rem;line-height:2.25rem}
.text-4xl{font-size:2.25rem;line-height:2.5rem}
.font-bold{font-weight:700}
.font-extrabold{font-weight:800}
.font-sans{font-family:ui-sans-serif,system-ui,sans-serif}
.font-semibold{font-weight:600}
.italic{font-style:italic}
.leading-relaxed{line-height:1.625}
.leading-tight{line-height:1.25}
.tracking-tight{letter-spacing:-.025em}
.tracking-widest{letter-spacing:.1em}
.text-gray-600{color:#4b5563}
.text-gray-800{color:#1f2937}
.text-gray-900{color:#111827}
.text-green-700{color:#15803d}
.text-red-700{color:#b91c1c}
.text-white{color:#fff}
.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
.uppercase{text-transform:uppercase}
.shadow-inner{box-shadow:inset 0 2px 4px 0 rgba(0,0,0,.05)}
.shadow-lg{box-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1)}
.shadow-md{box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1)}
.shadow-2xl{box-shadow:0 25px 50px -12px rgba(0,0,0,.25)}
.outline-none{outline:2px solid transparent;outline-offset:2px}
.resize-none{resize:none}
.transition{transition-property:color,background-color,opacity,box-shadow,transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:150ms}
.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:150ms}
.duration-300{transition-duration:300ms}
.duration-500{transition-duration:500ms}
.transform{transform:translateX(var(--tw-translate-x,0)) translateY(var(--tw-translate-y,0)) rotate(var(--tw-rotate,0)) skewX(var(--tw-skew-x,0)) skewY(var(--tw-skew-y,0)) scaleX(var(--tw-scale-x,1)) scaleY(var(--tw-scale-y,1))}

/* ── COULEURS TRUST-BLUE ── */
.bg-trust-blue-50{background-color:#eff6ff}
.bg-trust-blue-100{background-color:#dbeafe}
.bg-trust-blue-400{background-color:#60a5fa}
.bg-trust-blue-500{background-color:#3b82f6}
.bg-trust-blue-600{background-color:#2563eb}
.bg-trust-blue-700{background-color:#1d4ed8}
.bg-trust-blue-800{background-color:#1e40af}
.bg-trust-blue-900{background-color:#1e3a8a}
.bg-trust-blue-950{background-color:#172554}
.bg-trust-blue-900\/90{background-color:rgba(30,58,138,.9)}
.border-trust-blue-100{border-color:#dbeafe}
.border-trust-blue-200{border-color:#bfdbfe}
.border-trust-blue-400{border-color:#60a5fa}
.border-trust-blue-500{border-color:#3b82f6}
.border-trust-blue-700{border-color:#1d4ed8}
.border-trust-blue-800{border-color:#1e40af}
.border-trust-blue-900{border-color:#1e3a8a}
.text-trust-blue-100{color:#dbeafe}
.text-trust-blue-200{color:#bfdbfe}
.text-trust-blue-300{color:#93c5fd}
.text-trust-blue-400{color:#60a5fa}
.text-trust-blue-500{color:#3b82f6}
.text-trust-blue-600{color:#2563eb}
.text-trust-blue-700{color:#1d4ed8}
.text-trust-blue-800{color:#1e40af}
.text-trust-blue-900{color:#1e3a8a}

/* ── COULEURS GREEN (pour informatique pas cher) ── */
.bg-green-500{background-color:#22c55e}
.bg-green-600{background-color:#16a34a}
.bg-green-500\/20{background-color:rgba(34,197,94,.2)}
.bg-green-100{background-color:#dcfce7}
.text-green-300{color:#86efac}
.text-green-500{color:#22c55e}
.text-green-600{color:#16a34a}
.text-green-700{color:#15803d}
.text-green-800{color:#166534}
.border-green-500{border-color:#22c55e}
.border-green-500\/30{border-color:rgba(34,197,94,.3)}
.hover\:bg-green-500:hover{background-color:#22c55e}
.hover\:bg-green-600:hover{background-color:#16a34a}
.focus\:ring-2:focus{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width,0px)) var(--tw-ring-color,rgba(59,130,246,.5));box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow,0 0 #0000)}
.focus\:ring-trust-blue-600:focus{--tw-ring-color:#2563eb}
.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}

/* ── UTILITIES SUPPLÉMENTAIRES ── */
.min-h-screen{min-height:100vh}
.items-start{align-items:flex-start}
.mr-3{margin-right:.75rem}
.mt-1{margin-top:.25rem}
.mt-8{margin-top:2rem}
.h-64{height:16rem}
.object-contain{object-fit:contain}
.max-h-full{max-height:100%}
.font-black{font-weight:900}
.font-normal{font-weight:400}
.py-8{padding-top:2rem;padding-bottom:2rem}
.py-16{padding-top:4rem;padding-bottom:4rem}
.mt-auto{margin-top:auto}
.scroll-smooth{scroll-behavior:smooth}
.max-w-6xl{max-width:72rem}
.text-gray-400{color:#9ca3af}
.text-trust-blue-300{color:#93c5fd}
.text-trust-blue-500{color:#3b82f6}
.gap-x-6{column-gap:1.5rem}
.gap-x-10{column-gap:2.5rem}
.gap-y-2{row-gap:.5rem}
.py-24{padding-top:6rem;padding-bottom:6rem}
.mb-14{margin-bottom:3.5rem}
.flex-wrap{flex-wrap:wrap}
.whitespace-nowrap{white-space:nowrap}
.inline-flex{display:inline-flex}
.gap-1{gap:.25rem}
.text-green-600{color:#16a34a}
.line-through{text-decoration:line-through}
.bg-green-500{background-color:#22c55e}
.bg-green-600{background-color:#16a34a}
@media(min-width:640px){.sm\:inline{display:inline}}

/* ── HOVER ── */
.hover\:opacity-80:hover{opacity:.8}
.hover\:shadow-lg:hover{box-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1)}
.hover\:shadow-md:hover{box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1)}
.hover\:text-white:hover{color:#fff}
.hover\:text-trust-blue-400:hover{color:#60a5fa}
.hover\:text-trust-blue-800:hover{color:#1e40af}
.hover\:bg-\[\#128C7E\]:hover{background-color:#128C7E}
.hover\:bg-trust-blue-500:hover{background-color:#3b82f6}
.hover\:bg-trust-blue-700:hover{background-color:#1d4ed8}
.hover\:bg-trust-blue-50:hover{background-color:#eff6ff}
.hover\:bg-white\/10:hover{background-color:rgba(255,255,255,.1)}
.hover\:bg-green-500:hover{background-color:#22c55e}
.hover\:bg-green-600:hover{background-color:#16a34a}
.hover\:scale-105:hover{transform:scale(1.05)}
.hover\:-translate-y-1:hover{transform:translateY(-.25rem)}
.line-through{text-decoration:line-through}

/* ── RESPONSIVE ── */
@media(min-width:640px){
  .sm\:flex-row{flex-direction:row}
  .sm\:px-3{padding-left:.75rem;padding-right:.75rem}
  .sm\:px-6{padding-left:1.5rem;padding-right:1.5rem}
}
@media(min-width:768px){
  .md\:flex{display:flex}
  .md\:hidden{display:none}
  .md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
  .md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
  .md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
  .md\:justify-end{justify-content:flex-end}
  .md\:p-10{padding:2.5rem}
  .md\:text-right{text-align:right}
  .md\:text-5xl{font-size:3rem;line-height:1}
  .md\:text-6xl{font-size:3.75rem;line-height:1}
  .md\:text-5xl{font-size:3rem;line-height:1.1}
  .md\:leading-tight{line-height:1.25}
  .max-w-5xl{max-width:64rem}
}
@media(min-width:1024px){
  .lg\:px-8{padding-left:2rem;padding-right:2rem}
  .lg\:py-32{padding-top:8rem;padding-bottom:8rem}
}

/* ── ANIMATIONS TAILWIND ── */
@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}100%{opacity:1;transform:translateY(0)}}
@keyframes bounce{0%,100%{transform:translateY(-25%);animation-timing-function:cubic-bezier(.8,0,1,1)}50%{transform:none;animation-timing-function:cubic-bezier(0,0,.2,1)}}
.animate-fade-in-up{animation:fadeInUp .8s ease-out forwards}
.animate-bounce-slow{animation:bounce 3s infinite}

/* ── ANIMATIONS SCROLL ── */
.anim{opacity:0;transform:translateY(28px);transition:opacity .65s ease,transform .65s ease;contain:layout style}
.anim.visible{opacity:1;transform:translateY(0);will-change:auto}
.anim-d1{transition-delay:.1s}
.anim-d2{transition-delay:.2s}
.anim-d3{transition-delay:.3s}
.anim-d4{transition-delay:.4s}
.anim-d5{transition-delay:.5s}

/* ── MACHINE À ÉCRIRE ── */
.blink-cursor{display:inline-block;border-right:3px solid #60a5fa;margin-left:2px;animation:blink-cursor .75s step-end infinite}
@keyframes blink-cursor{0%,100%{border-right-color:#60a5fa}50%{border-right-color:transparent}}

/* ── DÉFILEMENT MARQUES ── */
.brands-scroll-wrap{overflow:hidden}
.brands-scroll-track{display:flex;gap:4rem;animation:marquee 18s linear infinite;width:max-content}
.brands-scroll-track:hover{animation-play-state:paused}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.brand-scroll-item{font-size:1.5rem;font-weight:900;color:#fff;opacity:.7;white-space:nowrap;transition:opacity .3s;cursor:default}
.brand-scroll-item:hover{opacity:1}

/* ── FAQ ACCORDÉON MODERNE ── */
.faq-item{border:none;border-radius:1.25rem;background:#fff;box-shadow:0 1px 4px rgba(0,0,0,.05),0 4px 16px rgba(30,58,138,.04);transition:transform .3s}
.faq-item:hover{box-shadow:0 4px 24px rgba(30,58,138,.1);transform:translateY(-2px)}
details[open].faq-item{box-shadow:0 4px 24px rgba(30,58,138,.1)}
.faq-question{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;font-weight:700;font-size:1.05rem;color:#111827;cursor:pointer;list-style:none;gap:1rem}
.faq-question::-webkit-details-marker{display:none}
.faq-question::after{content:'';display:block;width:1.5rem;height:1.5rem;flex-shrink:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%232563eb'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2.5' d='M19 9l-7 7-7-7'/%3E%3C/svg%3E");background-repeat:no-repeat;background-size:contain;transition:transform .35s ease}
details[open]>.faq-question::after{transform:rotate(180deg)}
.faq-answer{padding:0 2rem;color:#6b7280;line-height:1.85;font-size:.975rem;overflow:hidden;max-height:0;opacity:0;transition:max-height .4s ease,opacity .3s ease}
details[open]>.faq-answer{max-height:500px;opacity:1;padding:0 2rem 1.75rem}

/* ── STATS CARDS ── */
.stat-card{background:#fff;border-radius:1.5rem;padding:2.5rem 1.5rem;text-align:center;box-shadow:0 1px 3px rgba(0,0,0,.05),0 4px 20px rgba(30,58,138,.05);transition:transform .35s ease,box-shadow .35s ease;border:1px solid rgba(224,231,255,.6)}
.stat-card:hover{transform:translateY(-8px);box-shadow:0 20px 48px rgba(30,58,138,.12)}
.stat-icon-wrap{width:3.25rem;height:3.25rem;border-radius:1rem;background:linear-gradient(135deg,#eff6ff,#dbeafe);display:flex;align-items:center;justify-content:center;margin:0 auto 1.25rem}
.stat-number{font-size:2.75rem;font-weight:900;background:linear-gradient(135deg,#1d4ed8,#60a5fa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;margin-bottom:.5rem}
.stat-label{font-weight:700;color:#111827;font-size:.95rem;margin-bottom:.25rem}
.stat-sub{color:#9ca3af;font-size:.8rem}

