/* ==========================================================================
   EasyShopBuilder — Global Styles (BEM, mobile-first, tokens, a11y)
   Single CSS file for all pages
   ========================================================================== */

/* -------------------------------
   CSS TOKENS (Design System)
----------------------------------*/
:root {
  /* Colors */
  --color-bg: #ffffff;
  --color-surface: #f7f9f8;
  --color-surface-2: #eef3f1;
  --color-text: #0a0f0d;
  --color-text-muted: #5b6c66;
  --color-primary: #008060;         /* Easy green */
  --color-primary-600: #006a4f;
  --color-primary-700: #005341;
  --color-contrast: #111827;        /* dark for contrast CTAs */
  --color-border: #d6e2dd;
  --color-accent: #0ea5e9;
  --color-danger: #dc2626;
  --color-success: #059669;
  --color-warning: #d97706;

  /* Elevation & effects */
  --shadow-sm: 0 1px 2px rgba(0,0,0,.06);
  --shadow-md: 0 4px 14px rgba(0,0,0,.08);
  --shadow-lg: 0 8px 30px rgba(0,0,0,.12);

  /* Radii */
  --radius-sm: .5rem;
  --radius: .75rem;
  --radius-lg: 1.25rem;
  --radius-xl: 1.75rem;
  --radius-2xl: 2rem;

  /* Spacing scale (4px grid) */
  --space-1: .25rem;  /* 4px */
  --space-2: .5rem;   /* 8px */
  --space-3: .75rem;  /* 12px */
  --space-4: 1rem;    /* 16px */
  --space-5: 1.25rem; /* 20px */
  --space-6: 1.5rem;  /* 24px */
  --space-7: 1.75rem; /* 28px */
  --space-8: 2rem;    /* 32px */
  --space-10: 2.5rem; /* 40px */
  --space-12: 3rem;   /* 48px */
  --space-16: 4rem;   /* 64px */
  --space-20: 5rem;   /* 80px */

  /* Container */
  --container: 1120px;
  --container-narrow: 860px;

  /* Typography (fluid) */
  --font-sans: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Inter, "Helvetica Neue", Arial, "Noto Sans", "Apple Color Emoji", "Segoe UI Emoji";
  --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;

  --fs-xs: clamp(.78rem, .72rem + .2vw, .85rem);
  --fs-sm: clamp(.9rem, .84rem + .25vw, 1rem);
  --fs-base: clamp(1rem, .95rem + .35vw, 1.1rem);
  --fs-lg: clamp(1.125rem, 1.05rem + .5vw, 1.25rem);
  --fs-xl: clamp(1.35rem, 1.2rem + .8vw, 1.6rem);
  --fs-2xl: clamp(1.7rem, 1.4rem + 1.6vw, 2.3rem);
  --fs-3xl: clamp(2rem, 1.6rem + 2.4vw, 3rem);
  --fs-4xl: clamp(2.4rem, 1.8rem + 3.2vw, 3.6rem);

  /* Line heights */
  --lh-tight: 1.15;
  --lh-normal: 1.5;
  --lh-relaxed: 1.75;

  /* Z-index */
  --z-header: 50;
  --z-cookie: 60;
  --z-skip: 70;
  --z-overlay: 80;

  /* Transitions */
  --ease: cubic-bezier(.2,.6,.2,1);
  --transition: 180ms var(--ease);
}

/* Dark mode */
@media (prefers-color-scheme: dark) {
  :root {
    --color-bg: #0b0f0e;
    --color-surface: #121816;
    --color-surface-2: #0e1412;
    --color-text: #eef6f3;
    --color-text-muted: #9fb3ac;
    --color-primary: #11a87f;
    --color-primary-600: #0e906d;
    --color-primary-700: #0a7659;
    --color-border: #28443b;
    --color-contrast: #f5f7f6;
  }
}

/* -------------------------------
   Reset / Base
----------------------------------*/
*,
*::before,
*::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--fs-base);
  line-height: var(--lh-normal);
  color: var(--color-text);
  background: var(--color-bg);
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}

img, picture, video, canvas, svg { display: block; max-width: 100%; height: auto; }
iframe { border: 0; }

a { color: var(--color-primary); text-decoration-thickness: .08em; text-underline-offset: .15em; }
a:hover { color: var(--color-primary-600); }
a:focus-visible, button:focus-visible, [role="button"]:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible {
  outline: 3px solid var(--color-accent);
  outline-offset: 2px;
  border-radius: .2rem;
}

::selection { background: color-mix(in srgb, var(--color-primary) 25%, transparent); }

/* Utility */
.container {
  width: min(100% - 2rem, var(--container));
  margin-inline: auto;
}
.container.narrow { width: min(100% - 2rem, var(--container-narrow)); }

.sr-only {
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0);
  white-space: nowrap; border: 0;
}

.skip-link {
  position: fixed;
  top: .5rem; left: .5rem;
  z-index: var(--z-skip);
  padding: .5rem .75rem;
  background: var(--color-contrast);
  color: #fff;
  transform: translateY(-120%);
  transition: transform var(--transition);
  border-radius: var(--radius-sm);
}
.skip-link:focus { transform: translateY(0); }

/* Text helpers */
.lead { font-size: var(--fs-lg); color: var(--color-text); opacity: .9; }
.muted { color: var(--color-text-muted); }
.note, .tip { background: var(--color-surface-2); border: 1px solid var(--color-border); padding: var(--space-4); border-radius: var(--radius); }
.eyebrow { font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: .06em; color: var(--color-text-muted); }

/* Buttons */
.btn {
  --_bg: var(--color-surface);
  --_fg: var(--color-text);
  --_bd: var(--color-border);
  appearance: none;
  display: inline-flex; align-items: center; justify-content: center;
  gap: .5rem;
  font-weight: 600;
  font-size: var(--fs-sm);
  padding: .8rem 1.1rem;
  border-radius: var(--radius);
  border: 1px solid var(--_bd);
  background: var(--_bg);
  color: var(--_fg);
  cursor: pointer;
  transition: transform var(--transition), background var(--transition), color var(--transition), border-color var(--transition), box-shadow var(--transition);
  box-shadow: var(--shadow-sm);
  text-decoration: none;
}
.btn:hover { transform: translateY(-1px); box-shadow: var(--shadow-md); }
.btn:active { transform: translateY(0); box-shadow: var(--shadow-sm); }
.btn[disabled], .btn:disabled { opacity: .6; cursor: not-allowed; }

.btn--primary {
  --_bg: var(--color-primary);
  --_fg: #fff;
  --_bd: var(--color-primary);
}
.btn--primary:hover { --_bg: var(--color-primary-600); --_bd: var(--color-primary-600); }

.btn--ghost {
  --_bg: transparent;
  --_fg: var(--color-text);
  --_bd: var(--color-border);
}
.btn--ghost:hover { --_bg: var(--color-surface-2); }

.btn--contrast {
  --_bg: var(--color-contrast);
  --_fg: #fff;
  --_bd: var(--color-contrast);
}

.btn--full { width: 100%; }

.cta-row { display: flex; flex-wrap: wrap; gap: .75rem; }

/* Header */
.header {
  position: sticky; top: 0; z-index: var(--z-header);
  background: color-mix(in srgb, var(--color-bg) 88%, transparent);
  backdrop-filter: blur(6px);
  box-shadow: 0 1px 0 var(--color-border);
}
.header__inner {
  display: flex; align-items: center; justify-content: space-between;
  min-height: 64px;
  gap: 1rem;
}
.header__brand img { display: block; height: auto; }

.nav__toggle {
  display: inline-flex; flex-direction: column; gap: 4px;
  background: transparent; border: 0; padding: .5rem;
  cursor: pointer;
}
.nav__toggle-bar {
  display: block; width: 26px; height: 2px; background: var(--color-text); position: relative;
}
.nav__toggle-bar::before, .nav__toggle-bar::after {
  content: ""; position: absolute; inset-inline: 0; height: 2px; background: currentColor;
}
.nav__toggle-bar::before { top: -7px; }
.nav__toggle-bar::after { top: 7px; }
.nav__toggle-label { font-size: var(--fs-xs); color: var(--color-text-muted); }

.nav__menu {
  list-style: none; margin: 0; padding: 0;
  display: none; flex-direction: column; gap: .25rem;
  position: absolute; top: 100%; right: .5rem;
  background: var(--color-bg); border: 1px solid var(--color-border); border-radius: var(--radius);
  padding: .5rem;
  box-shadow: var(--shadow-md);
}
.nav__menu a { display: block; padding: .6rem .75rem; border-radius: .5rem; color: var(--color-text); text-decoration: none; }
.nav__menu a:hover, .nav__menu a[aria-current="page"] { background: var(--color-surface-2); }

.nav__menu.is-open { display: flex; }

/* Desktop nav */
@media (min-width: 960px) {
  .nav__toggle { display: none; }
  .nav__menu {
    position: static; display: flex; flex-direction: row; gap: .5rem;
    background: transparent; border: 0; border-radius: 0; padding: 0; box-shadow: none;
  }
  .nav__menu a { padding: .75rem .9rem; }
}

/* Lang switch */
.lang-switch { display: none; gap: .5rem; align-items: center; }
.lang-switch__sep { opacity: .5; }
.lang-switch__item { font-size: var(--fs-sm); text-decoration: none; color: var(--color-text-muted); }
.lang-switch__item.is-active { color: var(--color-text); font-weight: 600; }

@media (min-width: 600px) {
  .lang-switch { display: inline-flex; }
}

/* Disclaimer / affiliate badge (hidden by default) */
.disclaimer {
  display: none; /* becomes flex if you want to show top disclaimer */
  background: var(--color-surface-2);
  border-bottom: 1px solid var(--color-border);
  padding: .4rem 1rem;
  font-size: var(--fs-sm);
}
.affiliate-badge { display: none; } /* Shown only if legally required */
.show-affiliate .affiliate-badge { display: inline; }

/* Hero */
.hero {
  padding: var(--space-12) 0 var(--space-8);
  background:
    radial-gradient(1200px 600px at 10% -100px, color-mix(in srgb, var(--color-primary) 8%, transparent), transparent),
    linear-gradient(180deg, color-mix(in srgb, var(--color-surface) 65%, transparent), transparent);
}
.hero--sub { padding: var(--space-10) 0 var(--space-6); }

.hero__grid {
  display: grid; gap: var(--space-8);
}
@media (min-width: 960px) {
  .hero__grid { grid-template-columns: 1.1fr .9fr; align-items: center; }
}
.hero__banner-cta { margin-top: var(--space-6); }

.trust-list {
  display: flex; flex-wrap: wrap; gap: .75rem 1rem;
  list-style: none; margin: var(--space-4) 0 0; padding: 0;
  color: var(--color-text-muted); font-size: var(--fs-sm);
}

/* Video thumbnail (lazy embed) */
.video-thumb {
  position: relative; width: 100%; border: 0; padding: 0; background: none; cursor: pointer;
  border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-md);
}
.video-thumb__play {
  position: absolute; inset: auto auto 1rem 1rem;
  background: rgba(0,0,0,.6); color: #fff; padding: .4rem .6rem; border-radius: .6rem;
  font-weight: 700;
}

/* Sections */
.section { padding: var(--space-10) 0; }
.section--alt { background: var(--color-surface); }
.section--newsletter { background: var(--color-surface-2); border-block: 1px solid var(--color-border); }

/* Grids */
.benefits, .features, .usecases, .testimonials {
  display: grid; gap: var(--space-4);
  list-style: none; padding: 0; margin: 0;
}
.benefits .benefit, .features .feature, .usecases .usecase { background: var(--color-bg); border: 1px solid var(--color-border); border-radius: var(--radius); padding: var(--space-4); box-shadow: var(--shadow-sm); }
@media (min-width: 720px) {
  .benefits { grid-template-columns: repeat(3, 1fr); }
  .features { grid-template-columns: repeat(3, 1fr); }
  .usecases { grid-template-columns: repeat(3, 1fr); }
}

/* Testimonials */
.testimonials { grid-template-columns: 1fr; }
@media (min-width: 720px) { .testimonials { grid-template-columns: repeat(3, 1fr); } }
.testimonial { background: var(--color-bg); border: 1px solid var(--color-border); border-radius: var(--radius); padding: var(--space-4); box-shadow: var(--shadow-sm); }
.testimonial blockquote { margin: 0 0 .5rem; font-size: var(--fs-base); }

/* Tables */
.table-scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.table {
  width: 100%; border-collapse: collapse; font-size: var(--fs-sm);
  background: var(--color-bg); border: 1px solid var(--color-border); border-radius: var(--radius);
}
.table th, .table td { padding: .75rem .9rem; border-bottom: 1px solid var(--color-border); text-align: left; }
.table thead th { position: sticky; top: 0; background: var(--color-surface-2); z-index: 1; }
.table tbody tr:hover { background: color-mix(in srgb, var(--color-surface) 60%, transparent); }

/* FAQ Accordion */
.faq { display: grid; gap: .5rem; }
.faq__item { border: 1px solid var(--color-border); border-radius: var(--radius); background: var(--color-bg); box-shadow: var(--shadow-sm); overflow: hidden; }
.faq__q {
  width: 100%; text-align: left; padding: 1rem 1rem;
  border: 0; background: none; cursor: pointer; font-size: var(--fs-base); font-weight: 600;
  display: flex; align-items: center; justify-content: space-between;
}
.faq__q::after {
  content: "▾"; transition: transform var(--transition);
}
.faq__q[aria-expanded="true"]::after { transform: rotate(-180deg); }
.faq__a { display: none; padding: 0 1rem 1rem; color: var(--color-text); }
.faq__item.is-open .faq__a,
.faq__q[aria-expanded="true"] + .faq__a { display: block; }

/* Blog grid + cards */
.blog-grid {
  display: grid; gap: var(--space-6);
  grid-template-columns: 1fr;
}
@media (min-width: 760px) { .blog-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1080px) { .blog-grid { grid-template-columns: repeat(3, 1fr); } }

.card {
  display: flex; flex-direction: column; gap: .75rem;
  border: 1px solid var(--color-border); border-radius: var(--radius-lg); background: var(--color-bg);
  box-shadow: var(--shadow-sm); overflow: hidden;
  transition: transform var(--transition), box-shadow var(--transition);
}
.card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.card__media img { width: 100%; aspect-ratio: 16/9; object-fit: cover; }
.card__body { padding: 1rem 1rem 1.1rem; }
.card__title { margin: 0 0 .4rem; font-size: var(--fs-lg); }
.card__excerpt { margin: 0 0 .5rem; color: var(--color-text-muted); }
.card__meta { display: flex; gap: .75rem; list-style: none; padding: 0; margin: 0 0 .75rem; color: var(--color-text-muted); font-size: var(--fs-xs); }
.card__actions { display: flex; gap: .5rem; align-items: center; flex-wrap: wrap; }

/* Forms */
.form { display: grid; gap: .75rem; max-width: 560px; }
.form__row { display: grid; gap: .35rem; }
label { font-weight: 600; font-size: var(--fs-sm); }
input[type="email"], input[type="text"], input[type="search"] {
  width: 100%; padding: .8rem .9rem; border-radius: .6rem;
  border: 1px solid var(--color-border); background: var(--color-bg);
  color: var(--color-text); font-size: var(--fs-base);
  transition: border-color var(--transition), box-shadow var(--transition);
}
input:focus { border-color: var(--color-primary); box-shadow: 0 0 0 4px color-mix(in srgb, var(--color-primary) 25%, transparent); }
.form__msg { min-height: 1.2em; font-size: var(--fs-sm); }
.hp { display: none !important; }

/* Search field */
.search input[type="search"] {
  border-radius: 999px; padding: .9rem 1.1rem;
  box-shadow: var(--shadow-sm);
}

/* CTA banner */
.cta-banner {
  background: linear-gradient(180deg, color-mix(in srgb, var(--color-primary) 8%, transparent), transparent);
  padding: var(--space-10) 0;
  border-top: 1px solid var(--color-border);
}
.cta-banner .btn--contrast { box-shadow: var(--shadow-md); }

/* Article / Prose */
.article__hero { max-width: var(--container-narrow); }
.article__cover { margin: var(--space-6) 0; }
.toc { max-width: var(--container-narrow); margin-bottom: var(--space-6); border: 1px solid var(--color-border); background: var(--color-surface); border-radius: var(--radius); padding: var(--space-4); }

.prose {
  max-width: var(--container-narrow);
}
.prose h2 { font-size: var(--fs-2xl); margin: 2rem 0 .75rem; line-height: var(--lh-tight); }
.prose h3 { font-size: var(--fs-xl); margin: 1.25rem 0 .5rem; }
.prose p { margin: .8rem 0; }
.prose ul, .prose ol { padding-left: 1.1rem; }
.prose .checklist { list-style: "✓  "; }
.prose code { font-family: var(--font-mono); background: var(--color-surface-2); padding: .15rem .35rem; border-radius: .35rem; border: 1px solid var(--color-border); }
.refs { font-size: var(--fs-sm); }

/* Footer */
.footer { padding: var(--space-10) 0; background: var(--color-surface); border-top: 1px solid var(--color-border); }
.footer__grid { display: grid; gap: var(--space-6); }
.footer__brand p { margin: .3rem 0; }
.footer__nav ul { list-style: none; padding: 0; margin: 0; display: grid; gap: .4rem; }
.footer__nav a { color: var(--color-text); text-decoration: none; }
.footer__nav a:hover { text-decoration: underline; }
.footer__cta { display: flex; align-items: center; }
@media (min-width: 820px) {
  .footer__grid { grid-template-columns: 1.2fr 1fr .8fr; align-items: start; }
}

/* Cookie banner (opt-in) */
.cookie[hidden] { display: none !important; }
.cookie {
  position: fixed; inset: auto 0 0 0; z-index: var(--z-cookie);
  background: color-mix(in srgb, var(--color-bg) 85%, transparent);
  border-top: 1px solid var(--color-border);
  box-shadow: 0 -6px 30px rgba(0,0,0,.12);
  padding: var(--space-3);
}
.cookie__box {
  width: min(100%, var(--container)); margin: 0 auto;
  background: var(--color-bg); border: 1px solid var(--color-border); border-radius: var(--radius);
  padding: var(--space-4); box-shadow: var(--shadow-sm);
}
.cookie__form { display: grid; gap: var(--space-3); }
.cookie__actions { display: flex; gap: .5rem; flex-wrap: wrap; }
.switch { display: inline-flex; gap: .5rem; align-items: center; user-select: none; }

/* Header badge in footer note */
.footer .affiliate-badge { opacity: .75; }

/* Accessibility: reduced motion */
@media (prefers-reduced-motion: reduce) {
  * { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; scroll-behavior: auto !important; }
}

/* Print */
@media print {
  .nav__toggle, .nav__menu, .cta-row, .video-thumb, .cookie, .cta-banner { display: none !important; }
  a::after { content: " (" attr(href) ")"; font-size: .85em; color: var(--color-text-muted); }
  .header, .footer { position: static; box-shadow: none; background: transparent; }
}

/* Misc small tweaks */
.header--sticky { will-change: transform; }
.table .note { border: 0; background: transparent; padding: 0; }
.hero h1 { font-size: var(--fs-3xl); line-height: var(--lh-tight); margin: 0 0 .5rem; }
.section h2 { font-size: var(--fs-2xl); margin: 0 0 .75rem; }

/* Year placeholder */
#year { white-space: nowrap; }

/* --- Fix contraste/logo header --- */
.header {
  background: rgba(12, 20, 18, .55); /* fond plus lisible sur hero sombre */
  backdrop-filter: blur(8px);
  box-shadow: 0 1px 0 var(--color-border);
}

.header__brand img {
  height: 38px; /* + lisible */
  filter: drop-shadow(0 1px 1px rgba(0,0,0,.35)) brightness(1.12) contrast(1.08);
}

/* Sur scroll, garder la lisibilité */
@media (prefers-reduced-transparency: no-preference) {
  .header.header--sticky { background: rgba(12, 20, 18, .7); }
}

/* ==========================================================================
   HERO ENHANCEMENTS
   ========================================================================== */

/* -------------------------------
   Improved Hero Section
----------------------------------*/
.hero {
  position: relative;
  overflow: hidden;
  padding: var(--space-16) 0 var(--space-12);
  background: 
    radial-gradient(1200px 800px at 20% -10%, color-mix(in srgb, var(--color-primary) 12%, transparent) 0%, transparent 70%),
    radial-gradient(1000px 1000px at 80% 20%, color-mix(in srgb, var(--color-accent) 8%, transparent) 0%, transparent 70%),
    linear-gradient(180deg, var(--color-bg) 0%, color-mix(in srgb, var(--color-surface) 40%, transparent) 100%);
}

.hero__grid {
  display: grid;
  gap: var(--space-12);
  align-items: center;
}

@media (min-width: 960px) {
  .hero__grid {
    grid-template-columns: 1.1fr 0.9fr;
    gap: var(--space-16);
  }
  
  .hero__content {
    padding-right: var(--space-8);
  }
}

/* Improved Hero Typography */
.hero h1 {
  font-size: var(--fs-4xl);
  line-height: var(--lh-tight);
  margin: 0 0 1rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  background: linear-gradient(135deg, var(--color-text) 0%, var(--color-primary) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  text-wrap: balance;
}

.hero .lead {
  font-size: var(--fs-xl);
  line-height: var(--lh-relaxed);
  margin-bottom: 2rem;
  max-width: 42ch;
  opacity: 0.9;
}

/* Media container improvements */
.hero__media {
  position: relative;
  border-radius: var(--radius-2xl);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  transform: perspective(1000px) rotateY(-5deg) rotateX(2deg);
  transition: transform 0.5s var(--ease), box-shadow 0.5s var(--ease);
}

.hero__media:hover {
  transform: perspective(1000px) rotateY(0) rotateX(0);
  box-shadow: var(--shadow-lg), 0 25px 50px -12px rgba(0, 0, 0, 0.25);
}

.hero__shot {
  border-radius: var(--radius-2xl);
  overflow: hidden;
}

.hero__shot img {
  width: 100%;
  height: auto;
  transition: transform 0.5s var(--ease);
}

.hero__media:hover .hero__shot img {
  transform: scale(1.03);
}

/* Enhanced Video thumbnail */
.video-thumb {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border-radius: var(--radius-2xl);
  overflow: hidden;
  background: transparent;
}

.video-thumb__play {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: rgba(255, 255, 255, 0.95);
  color: var(--color-primary);
  width: 80px;
  height: 80px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  backdrop-filter: blur(4px);
  transition: all 0.3s var(--ease);
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.15);
}

.video-thumb:hover .video-thumb__play {
  background: var(--color-primary);
  color: white;
  transform: translate(-50%, -50%) scale(1.1);
  box-shadow: 0 15px 30px rgba(0, 128, 96, 0.3);
}

/* Enhanced Trust List */
.trust-list {
  display: flex;
  flex-wrap: wrap;
  gap: 1.5rem;
  align-items: center;
  margin-top: var(--space-8);
  padding-top: var(--space-6);
  border-top: 1px solid var(--color-border);
}

.trust-list li {
  position: relative;
  font-weight: 600;
  color: var(--color-text-muted);
  padding-left: 0;
  opacity: 0.8;
  transition: opacity 0.3s var(--ease);
}

.trust-list li:hover {
  opacity: 1;
}

.trust-list li:not(:last-child)::after {
  content: '•';
  position: absolute;
  right: -0.9rem;
  color: var(--color-border);
}

/* Hero Banner CTA */
.hero__banner-cta {
  margin-top: var(--space-8);
  text-align: center;
}

/* Animations */
@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.hero__content > * {
  animation: fadeInUp 0.8s var(--ease) forwards;
  opacity: 0;
}

.hero h1 { animation-delay: 0.1s; }
.hero .lead { animation-delay: 0.2s; }
.hero .cta-row { animation-delay: 0.3s; }
.hero .trust-list { animation-delay: 0.4s; }

/* Responsive improvements */
@media (max-width: 959px) {
  .hero {
    padding: var(--space-12) 0 var(--space-10);
    text-align: center;
  }
  
  .hero__content {
    order: 1;
  }
  
  .hero__media {
    order: 0;
    margin-bottom: var(--space-8);
    max-width: 600px;
    margin-left: auto;
    margin-right: auto;
    transform: none;
  }
  
  .hero h1 {
    font-size: var(--fs-3xl);
  }
  
  .hero .lead {
    font-size: var(--fs-lg);
  }
  
  .cta-row {
    justify-content: center;
  }
  
  .trust-list {
    justify-content: center;
  }
}

@media (max-width: 600px) {
  .hero h1 {
    font-size: var(--fs-2xl);
  }
  
  .trust-list li:not(:last-child)::after {
    display: none;
  }
  
  .trust-list li {
    flex: 0 0 calc(50% - 0.75rem);
    text-align: center;
  }
}

/* Accessibility */
@media (prefers-reduced-motion: reduce) {
  .hero__media,
  .hero__media:hover,
  .hero__shot img,
  .video-thumb__play,
  .hero__content > * {
    transition: none;
    animation: none;
    transform: none;
  }
  
  .hero__content > * {
    opacity: 1;
  }
}

/* ==========================================================================
   AMÉLIORATIONS CSS - EasyShopBuilder
   Corrections de lisibilité, centrage et améliorations visuelles
   ========================================================================== */

/* -------------------------------
   CORRECTIONS DE LISIBILITÉ
----------------------------------*/

/* Amélioration du contraste pour le texte principal */
body {
  color: #1a1a1a;
  line-height: 1.7;
}

/* Textes avec meilleur contraste */
.lead, .muted, .card__excerpt, .card__meta,
.testimonial blockquote, .post-meta {
  color: #4a5568 !important;
}

/* Amélioration contraste liens */
a {
  color: #006a4f;
  font-weight: 500;
}
a:hover {
  color: #004c3f;
}

/* Amélioration de la visibilité en mode sombre */
@media (prefers-color-scheme: dark) {
  body {
    color: #e2e8f0;
  }
  .lead, .muted, .card__excerpt, .card__meta {
    color: #a0aec0 !important;
  }
}

/* -------------------------------
   CENTRAGE DES ÉLÉMENTS
----------------------------------*/

/* Centrage des titres de section */
.section h2 {
  text-align: center;
  margin-bottom: 2.5rem;
}

/* Centrage des grilles de contenu */
.benefits, .features, .usecases, .testimonials {
  justify-content: center;
}

/* Centrage des CTA */
.cta-row {
  justify-content: center;
  margin: 2rem 0;
}

/* Centrage du formulaire de newsletter */
.form {
  margin: 0 auto;
}

/* Centrage des cartes du blog */
.blog-grid {
  justify-items: center;
}

/* Centrage spécifique pour la page d'article */
.article__hero, .prose {
  margin-left: auto;
  margin-right: auto;
}

/* Centrage de la barre de recherche */
.search {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin: 2rem 0;
}
.search input[type="search"] {
  width: 100%;
  max-width: 500px;
}

/* -------------------------------
   AMÉLIORATIONS VISUELLES GÉNÉRALES
----------------------------------*/

/* Amélioration des cartes */
.card {
  transition: all 0.3s ease;
  border: 1px solid var(--color-border);
  overflow: hidden;
}
.card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-lg);
}

/* Amélioration des boutons */
.btn {
  font-weight: 600;
  border-radius: 8px;
  transition: all 0.2s ease;
}
.btn:hover {
  transform: translateY(-2px);
}

/* En-tête plus contrasté */
.header {
  background: rgba(255, 255, 255, 0.95) !important;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
}

/* Amélioration de la section hero */
.hero {
  text-align: center;
}
.hero h1 {
  margin-bottom: 1.5rem;
}

/* Meilleure séparation des sections */
.section {
  padding: 4rem 0;
}
.section--alt {
  background: var(--color-surface);
  border-top: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
}

/* Amélioration du footer */
.footer {
  text-align: center;
}
.footer__grid {
  gap: 2rem;
}

/* Amélioration des tableaux */
.table {
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}
.table th {
  background: var(--color-surface-2);
  font-weight: 600;
}

/* -------------------------------
   RESPONSIVE AMÉLIORÉ
----------------------------------*/

@media (max-width: 768px) {
  /* Meilleur espacement sur mobile */
  .hero {
    padding: 2rem 0;
  }
  .section {
    padding: 2.5rem 0;
  }
  
  /* Centrage amélioré sur mobile */
  .hero__grid, 
  .benefits, 
  .features, 
  .usecases {
    grid-template-columns: 1fr;
    text-align: center;
  }
  
  /* Meilleur espacement des cartes */
  .card {
    margin-bottom: 1.5rem;
  }
  
  /* Boutons en pleine largeur sur mobile */
  .btn {
    width: 100%;
    margin-bottom: 0.5rem;
  }
}

/* Amélioration de l'accessibilité */
@media (prefers-reduced-motion: reduce) {
  .card, .btn {
    transition: none;
  }
}

/* Correction pour les écrans très larges */
@media (min-width: 1600px) {
  .container {
    width: min(100% - 4rem, 1400px);
  }
}

/* ==========================================================================
   CORRECTIONS SPÉCIFIQUES POUR LA FAQ
   ========================================================================== */

/* Correction de la couleur du texte dans la FAQ */
.faq__q, .faq__a, .faq__a p {
  color: var(--color-text) !important;
}

/* Amélioration de la lisibilité des éléments de liste */
.refs li, .refs li a {
  color: var(--color-text) !important;
}

/* Correction pour les textes dans les tableaux */
.table th, .table td {
  color: var(--color-text);
}

/* Assurer la visibilité du texte dans les cartes */
.card__title, .card__excerpt, .card__meta {
  color: var(--color-text) !important;
}

/* Correction pour le formulaire de newsletter */
.form__row label {
  color: var(--color-text);
}

/* Amélioration du contraste pour les textes en mode sombre */
@media (prefers-color-scheme: dark) {
  .disclaimer, .disclaimer p, .disclaimer strong {
    color: #e2e8f0 !important;
  }
  
  .note, .tip {
    color: var(--color-text);
  }
}

/* Correction spécifique pour les textes noirs illisibles */
.faq__item, .post-meta, .trust-list li {
  color: var(--color-text);
}

/* Amélioration de la visibilité des textes dans les sections */
.section h2, .section h3, .section p {
  color: var(--color-text);
}

/* ==========================================================================
   CORRECTION HEADER - Retour au fond noir
   ========================================================================== */

/* Rétablir le fond noir semi-transparent */
.header {
  background: rgba(12, 20, 18, 0.85) !important;
  backdrop-filter: blur(8px);
}

/* Rétablir la couleur du texte du menu en blanc */
.nav__menu a {
  color: #f5f7f6 !important;
}

.nav__menu a:hover, 
.nav__menu a[aria-current="page"] {
  color: #ffffff !important;
  background: rgba(255, 255, 255, 0.1);
}

/* Correction du bouton menu hamburger */
.nav__toggle-bar,
.nav__toggle-bar::before,
.nav__toggle-bar::after {
  background: #f5f7f6 !important;
}

.nav__toggle-label {
  color: #f5f7f6 !important;
}

/* Assurer la visibilité du sélecteur de langue */
.lang-switch__item {
  color: #9fb3ac !important;
}

.lang-switch__item.is-active {
  color: #f5f7f6 !important;
}

/* Correction pour le mode sombre */
@media (prefers-color-scheme: dark) {
  .header {
    background: rgba(12, 20, 18, 0.9) !important;
  }
}