/* =========================================================================
   Supermarchés FR — Design system
   ─────────────────────────────────────────────────────────────────────────
   Tokens, base, typography, layout primitives, components, utilities.
   ========================================================================= */

/* ---------- Tokens ---------- */
:root {
  /* Color — surfaces & ink */
  --color-bg:            #F7F5EE;
  --color-bg-elev:       #FAF9F4;
  --color-surface:       #FFFFFF;
  --color-surface-soft:  #F4F2EC;
  --color-ink:           #0F1419;
  --color-ink-soft:      #3D4451;
  --color-muted:         #6B7280;
  --color-muted-soft:    #9CA3AF;
  --color-border:        #E6E2D8;
  --color-border-strong: #CFC9BA;

  /* Color — brand */
  --color-primary:       #0F766E;       /* teal-700 */
  --color-primary-hover: #0B5C56;
  --color-primary-ink:   #134E48;       /* foreground on tinted bg */
  --color-primary-tint:  #DCFBF6;       /* subtle bg */
  --color-primary-tint-2:#B5F1E8;
  --color-accent:        #D97706;       /* amber-600, warmer & more modern than 500 */
  --color-accent-hover:  #B45309;
  --color-accent-tint:   #FEF3C7;

  /* Status */
  --color-success:       #15803D;
  --color-success-tint:  #DCFCE7;
  --color-danger:        #BE123C;
  --color-danger-tint:   #FFE4E6;

  /* Typography */
  --font-sans:    'Inter', system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --font-display: 'DM Sans', var(--font-sans);
  --font-mono:    ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;

  /* Type scale */
  --fs-12: 0.75rem;
  --fs-14: 0.875rem;
  --fs-16: 1rem;
  --fs-18: 1.125rem;
  --fs-20: 1.25rem;
  --fs-24: 1.5rem;
  --fs-30: 1.875rem;
  --fs-36: 2.25rem;
  --fs-48: clamp(2.25rem, 5vw, 3rem);
  --fs-hero: clamp(2.5rem, 6vw, 4rem);

  --lh-tight: 1.15;
  --lh-snug: 1.3;
  --lh-base: 1.55;
  --lh-relaxed: 1.7;

  --tracking-tight: -0.02em;
  --tracking-snug: -0.01em;
  --tracking-normal: 0;
  --tracking-wide: 0.02em;

  /* Spacing */
  --s-1: 0.25rem;
  --s-2: 0.5rem;
  --s-3: 0.75rem;
  --s-4: 1rem;
  --s-5: 1.5rem;
  --s-6: 2rem;
  --s-7: 3rem;
  --s-8: 4rem;
  --s-9: 6rem;

  /* Radii */
  --radius-xs: 4px;
  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 18px;
  --radius-xl: 28px;
  --radius-pill: 999px;

  /* Shadows */
  --shadow-xs: 0 1px 2px rgba(15, 20, 25, 0.04);
  --shadow-sm: 0 2px 4px rgba(15, 20, 25, 0.04), 0 1px 2px rgba(15, 20, 25, 0.04);
  --shadow-md: 0 4px 12px rgba(15, 20, 25, 0.06), 0 2px 4px rgba(15, 20, 25, 0.04);
  --shadow-lg: 0 24px 48px -12px rgba(15, 20, 25, 0.18), 0 4px 12px rgba(15, 20, 25, 0.06);
  --shadow-focus: 0 0 0 3px rgba(15, 118, 110, 0.22);

  /* Motion */
  --ease: cubic-bezier(0.2, 0.8, 0.2, 1);
  --ease-bounce: cubic-bezier(0.34, 1.56, 0.64, 1);
  --t-fast: 120ms;
  --t-base: 200ms;
  --t-slow: 360ms;

  /* Layout */
  --container-max: 1200px;
  --container-narrow: 760px;
  --header-h: 68px;
}

/* ---------- Reset & base ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
@media (prefers-reduced-motion: no-preference) {
  html { scroll-behavior: smooth; }
}
body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--fs-16);
  line-height: var(--lh-base);
  color: var(--color-ink);
  background: var(--color-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}
img, svg, video { display: block; max-width: 100%; }
button { font: inherit; color: inherit; cursor: pointer; }

/* Typography */
h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 700;
  letter-spacing: var(--tracking-tight);
  line-height: var(--lh-tight);
  color: var(--color-ink);
  margin: 0 0 var(--s-3);
}
h1 { font-size: var(--fs-48); }
h2 { font-size: var(--fs-30); margin-top: var(--s-7); letter-spacing: var(--tracking-snug); }
h3 { font-size: var(--fs-20); letter-spacing: var(--tracking-snug); }
h4 { font-size: var(--fs-18); }
p  { margin: 0 0 var(--s-4); line-height: var(--lh-relaxed); color: var(--color-ink-soft); }

a {
  color: var(--color-primary);
  text-decoration: none;
  text-underline-offset: 0.2em;
  transition: color var(--t-fast) var(--ease);
}
a:hover { color: var(--color-primary-hover); text-decoration: underline; }

/* Focus accessibility */
:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
  border-radius: var(--radius-sm);
}

::selection { background: var(--color-primary-tint); color: var(--color-primary-ink); }

/* Utilities */
.container       { width: 100%; max-width: var(--container-max); margin: 0 auto; padding: 0 var(--s-5); }
.container--narrow { max-width: var(--container-narrow); }
.visually-hidden {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}
.skip-link {
  position: absolute; top: 0; left: 0; padding: var(--s-3) var(--s-4);
  background: var(--color-primary); color: #fff; font-weight: 600;
  transform: translateY(-110%); transition: transform var(--t-base) var(--ease);
  z-index: 1000;
}
.skip-link:focus-visible { transform: translateY(0); }

/* ---------- Header ---------- */
.site-header {
  position: sticky; top: 0; z-index: 50;
  height: var(--header-h);
  background: rgba(247, 245, 238, 0.85);
  backdrop-filter: saturate(160%) blur(12px);
  -webkit-backdrop-filter: saturate(160%) blur(12px);
  border-bottom: 1px solid var(--color-border);
}
.header-inner {
  display: flex; align-items: center; justify-content: space-between;
  height: 100%; gap: var(--s-5);
}
.brand {
  display: inline-flex; align-items: center; gap: var(--s-2);
  font-family: var(--font-display);
  font-weight: 700; font-size: var(--fs-18);
  color: var(--color-ink);
  letter-spacing: var(--tracking-tight);
}
.brand:hover { color: var(--color-ink); text-decoration: none; }
.brand-mark {
  width: 32px; height: 32px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--color-primary);
  color: #fff;
  border-radius: var(--radius-sm);
  flex-shrink: 0;
}
.brand-mark svg { width: 18px; height: 18px; }
.brand-name { font-size: var(--fs-18); }
.brand-name .tld { color: var(--color-primary); }

.primary-nav {
  display: flex; gap: var(--s-2);
  align-items: center;
  overflow-x: auto;
  scrollbar-width: none;
}
.primary-nav::-webkit-scrollbar { display: none; }
.primary-nav a {
  color: var(--color-ink-soft);
  font-size: var(--fs-14);
  font-weight: 500;
  padding: var(--s-2) var(--s-3);
  border-radius: var(--radius-sm);
  white-space: nowrap;
  transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
}
.primary-nav a:hover {
  background: var(--color-surface-soft);
  color: var(--color-ink);
  text-decoration: none;
}
.primary-nav a.is-active {
  color: var(--color-primary-ink);
  background: var(--color-primary-tint);
}

/* ---------- Live (Ouvert maintenant) ---------- */
.live-dot {
  display: inline-block;
  width: 8px; height: 8px;
  background: var(--color-success);
  border-radius: 50%;
  position: relative;
  flex-shrink: 0;
}
.live-dot::after {
  content: '';
  position: absolute; inset: -4px;
  border-radius: 50%;
  background: var(--color-success);
  opacity: 0.35;
  animation: live-pulse 1.6s ease-out infinite;
}
@keyframes live-pulse {
  0%   { transform: scale(0.6); opacity: 0.5; }
  100% { transform: scale(2);   opacity: 0;   }
}
@media (prefers-reduced-motion: reduce) {
  .live-dot::after { animation: none; }
}

.primary-nav a.nav-live {
  display: inline-flex; align-items: center; gap: var(--s-2);
  background: var(--color-success-tint);
  color: var(--color-success);
  font-weight: 600;
  padding: var(--s-2) var(--s-3) var(--s-2) var(--s-3);
  border-radius: var(--radius-pill);
}
.primary-nav a.nav-live:hover {
  background: var(--color-success);
  color: #fff;
}
.primary-nav a.nav-live:hover .live-dot { background: #fff; }
.primary-nav a.nav-live:hover .live-dot::after { background: #fff; }

/* ---------- Breadcrumb ---------- */
.breadcrumb {
  background: transparent;
  border-bottom: 1px solid var(--color-border);
}
.breadcrumb ol {
  list-style: none; margin: 0; padding: var(--s-3) 0;
  display: flex; flex-wrap: wrap; gap: var(--s-2);
  font-size: var(--fs-14);
}
.breadcrumb li { color: var(--color-muted); display: inline-flex; align-items: center; gap: var(--s-2); }
.breadcrumb li:not(:last-child)::after { content: '›'; color: var(--color-muted-soft); margin-left: var(--s-2); }
.breadcrumb a { color: var(--color-muted); }
.breadcrumb a:hover { color: var(--color-primary); }
.breadcrumb [aria-current="page"] { color: var(--color-ink); font-weight: 500; }

/* ---------- Hero ---------- */
.hero {
  position: relative;
  margin: var(--s-6) 0 var(--s-7);
  padding: var(--s-9) var(--s-5);
  border-radius: var(--radius-xl);
  background:
    radial-gradient(ellipse 80% 60% at 30% 0%, rgba(217, 119, 6, 0.12) 0%, transparent 60%),
    radial-gradient(ellipse 70% 50% at 100% 100%, rgba(15, 118, 110, 0.18) 0%, transparent 70%),
    linear-gradient(180deg, var(--color-surface) 0%, var(--color-bg-elev) 100%);
  overflow: hidden;
  border: 1px solid var(--color-border);
}
.hero::before {
  content: '';
  position: absolute; inset: 0;
  background-image:
    radial-gradient(circle at 1px 1px, rgba(15, 20, 25, 0.06) 1px, transparent 0);
  background-size: 24px 24px;
  opacity: 0.5;
  mask: radial-gradient(ellipse 80% 60% at 50% 50%, black 30%, transparent 75%);
  pointer-events: none;
}
.hero-inner {
  position: relative;
  max-width: 720px; margin: 0 auto;
  text-align: center;
}
.hero-eyebrow {
  display: inline-flex; align-items: center; gap: var(--s-2);
  padding: var(--s-1) var(--s-3);
  background: var(--color-primary-tint);
  color: var(--color-primary-ink);
  border-radius: var(--radius-pill);
  font-size: var(--fs-12);
  font-weight: 600;
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  margin-bottom: var(--s-4);
}
.hero h1 {
  font-size: var(--fs-hero);
  letter-spacing: -0.025em;
  line-height: 1.05;
  margin-bottom: var(--s-4);
}
.hero .lead {
  font-size: var(--fs-18);
  color: var(--color-ink-soft);
  max-width: 540px;
  margin: 0 auto var(--s-6);
}

.hero-search {
  display: flex; gap: var(--s-2);
  max-width: 600px; margin: 0 auto;
  background: var(--color-surface);
  padding: var(--s-2);
  border-radius: var(--radius-pill);
  box-shadow: var(--shadow-md);
  border: 1px solid var(--color-border);
  flex-wrap: wrap;
}
.hero-search input {
  flex: 1 1 240px; min-width: 0;
  border: 0; outline: 0;
  padding: var(--s-3) var(--s-5);
  font: inherit; font-size: var(--fs-16);
  color: var(--color-ink);
  background: transparent;
}
.hero-search input::placeholder { color: var(--color-muted); }
.hero-search button {
  padding: var(--s-3) var(--s-5);
  border: 0; border-radius: var(--radius-pill);
  font-weight: 600; font-size: var(--fs-14);
  transition: background var(--t-fast) var(--ease), transform var(--t-fast) var(--ease);
}
.hero-search [type="submit"] {
  background: var(--color-primary); color: #fff;
}
.hero-search [type="submit"]:hover { background: var(--color-primary-hover); }
.hero-search .btn-secondary {
  background: var(--color-surface-soft); color: var(--color-ink);
}
.hero-search .btn-secondary:hover { background: var(--color-bg); }

@media (max-width: 600px) {
  .hero { padding: var(--s-7) var(--s-4); }
  .hero-search { padding: var(--s-1); border-radius: var(--radius-md); }
  .hero-search input, .hero-search button {
    width: 100%; flex: 1 1 100%; border-radius: var(--radius-sm);
  }
}

/* ---------- Stats block ---------- */
.stats-block {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--s-4);
  margin: var(--s-7) 0;
}
.stat-card {
  background: var(--color-surface);
  padding: var(--s-5);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  text-align: left;
  position: relative;
  overflow: hidden;
}
.stat-card::after {
  content: ''; position: absolute; right: -12px; top: -12px;
  width: 64px; height: 64px;
  background: var(--color-primary-tint);
  border-radius: 50%;
  opacity: 0.5;
}
.stat-number {
  font-family: var(--font-display);
  font-size: var(--fs-36);
  font-weight: 700;
  color: var(--color-ink);
  line-height: 1;
  font-variant-numeric: tabular-nums;
  letter-spacing: var(--tracking-tight);
}
.stat-label {
  color: var(--color-muted);
  font-size: var(--fs-14);
  margin-top: var(--s-2);
}

/* ---------- Sections ---------- */
.section { margin: var(--s-8) 0; }
.section h2 { margin-top: 0; }
.page-header {
  margin: var(--s-6) 0 var(--s-6);
  max-width: var(--container-narrow);
}
.page-header h1 { letter-spacing: -0.02em; }
.page-header .lead {
  font-size: var(--fs-18);
  color: var(--color-ink-soft);
  margin: 0;
}
.link-more {
  display: inline-flex; align-items: center; gap: var(--s-1);
  font-weight: 600; font-size: var(--fs-14);
}
.link-more::after { content: '→'; transition: transform var(--t-fast) var(--ease); }
.link-more:hover::after { transform: translateX(3px); }

/* ---------- Brand chips (grid) ---------- */
.brand-grid {
  list-style: none; padding: 0; margin: 0;
  display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: var(--s-2);
}
.brand-grid--large { grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); }
.brand-chip {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--s-2);
  padding: var(--s-3) var(--s-4);
  background: var(--color-surface);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  color: var(--color-ink);
  font-weight: 500;
  font-size: var(--fs-14);
  transition: border-color var(--t-fast) var(--ease),
              transform var(--t-fast) var(--ease),
              box-shadow var(--t-fast) var(--ease),
              background var(--t-fast) var(--ease);
}
.brand-chip:hover {
  text-decoration: none;
  border-color: var(--color-primary);
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm);
  background: var(--color-bg-elev);
}
.brand-chip-name { font-weight: 600; }
.brand-chip-name small { color: var(--color-muted); font-weight: 500; font-size: var(--fs-12); }
.brand-chip-count {
  color: var(--color-muted);
  font-size: var(--fs-12);
  font-variant-numeric: tabular-nums;
  background: var(--color-surface-soft);
  padding: 2px var(--s-2);
  border-radius: var(--radius-pill);
}
.brand-chip:hover .brand-chip-count {
  background: var(--color-primary-tint);
  color: var(--color-primary-ink);
}

/* ---------- Feature blocks ---------- */
.features {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--s-4);
}
.feature {
  background: var(--color-surface);
  padding: var(--s-5);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
}
.feature-icon {
  width: 44px; height: 44px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--color-primary-tint);
  color: var(--color-primary-ink);
  border-radius: var(--radius-md);
  margin-bottom: var(--s-3);
}
.feature-icon svg { width: 22px; height: 22px; }
.feature h3 { margin-bottom: var(--s-2); font-size: var(--fs-18); }
.feature p { color: var(--color-ink-soft); margin: 0; font-size: var(--fs-14); line-height: var(--lh-relaxed); }

/* ---------- Cards (results) ---------- */
.results-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: var(--s-4);
  margin-top: var(--s-4);
}
.card {
  position: relative;
  background: var(--color-surface);
  padding: var(--s-5);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  transition: border-color var(--t-fast) var(--ease),
              box-shadow var(--t-fast) var(--ease),
              transform var(--t-fast) var(--ease);
}
.card:hover {
  border-color: var(--color-border-strong);
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}
.card-header {
  display: flex; justify-content: space-between; gap: var(--s-2);
  align-items: flex-start;
  margin-bottom: var(--s-2);
}
.card-title {
  font-size: var(--fs-18);
  font-family: var(--font-display);
  font-weight: 600;
  margin: 0;
  letter-spacing: var(--tracking-snug);
}
.card-title a { color: var(--color-ink); }
.card-title a:hover { color: var(--color-primary); text-decoration: none; }
.card-title a::after {
  content: ''; position: absolute; inset: 0;
  border-radius: var(--radius-lg);
}
.card-brand {
  display: inline-flex; align-items: center;
  font-size: var(--fs-12);
  font-weight: 600;
  color: var(--color-primary-ink);
  background: var(--color-primary-tint);
  padding: 2px var(--s-2);
  border-radius: var(--radius-pill);
  margin-bottom: var(--s-3);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
}
.card-line {
  display: flex; align-items: flex-start; gap: var(--s-2);
  margin: var(--s-2) 0;
  color: var(--color-ink-soft);
  font-size: var(--fs-14);
  line-height: var(--lh-snug);
}
.card-line svg {
  width: 16px; height: 16px;
  color: var(--color-muted);
  flex-shrink: 0;
  margin-top: 2px;
}
.card-meta {
  margin-top: var(--s-3);
  display: flex; flex-wrap: wrap; gap: var(--s-2);
}
.distance {
  position: absolute; top: var(--s-4); right: var(--s-4);
  background: var(--color-ink); color: #fff;
  padding: 2px var(--s-2);
  border-radius: var(--radius-pill);
  font-size: var(--fs-12);
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  letter-spacing: var(--tracking-wide);
}
.tag {
  display: inline-flex; align-items: center; gap: var(--s-1);
  padding: 2px var(--s-2);
  border-radius: var(--radius-pill);
  font-size: var(--fs-12);
  font-weight: 500;
  background: var(--color-surface-soft);
  color: var(--color-ink-soft);
  border: 1px solid var(--color-border);
}
.tag-good {
  background: var(--color-success-tint);
  color: var(--color-success);
  border-color: transparent;
}
.tag-accent {
  background: var(--color-accent-tint);
  color: var(--color-accent-hover);
  border-color: transparent;
}

/* ---------- Search form ---------- */
.search-form {
  background: var(--color-surface);
  padding: var(--s-5);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  margin-bottom: var(--s-5);
}
.form-row {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--s-3);
  align-items: end;
  margin-bottom: var(--s-3);
}
.form-row label {
  display: flex; flex-direction: column; gap: var(--s-1);
  font-size: var(--fs-14);
  font-weight: 500;
  color: var(--color-ink-soft);
}
.form-row input {
  font: inherit; font-size: var(--fs-14);
  padding: var(--s-3) var(--s-4);
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius-sm);
  background: var(--color-surface);
  color: var(--color-ink);
  outline: 0;
  transition: border-color var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);
}
.form-row input:focus {
  border-color: var(--color-primary);
  box-shadow: var(--shadow-focus);
}
.form-row input::placeholder { color: var(--color-muted-soft); }
.form-row button {
  padding: var(--s-3) var(--s-5);
  border: 0; border-radius: var(--radius-sm);
  background: var(--color-primary); color: #fff;
  font-weight: 600; font-size: var(--fs-14);
  height: fit-content;
  transition: background var(--t-fast) var(--ease);
}
.form-row button:hover { background: var(--color-primary-hover); }
.form-row-actions { align-items: center; }
.btn-secondary {
  background: var(--color-surface) !important;
  color: var(--color-ink) !important;
  border: 1px solid var(--color-border-strong) !important;
}
.btn-secondary:hover { background: var(--color-surface-soft) !important; }
.hint { color: var(--color-muted); font-size: var(--fs-14); margin: 0; }

/* ---------- Map ---------- */
.map-container {
  height: 380px;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--color-border);
  margin: var(--s-4) 0;
  background: var(--color-surface-soft);
  box-shadow: var(--shadow-sm);
}
.leaflet-container { font-family: var(--font-sans); }
.leaflet-popup-content-wrapper {
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-md);
}

/* ---------- Detail page ---------- */
.detail-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: var(--s-5);
  margin-top: var(--s-4);
}
@media (max-width: 768px) { .detail-grid { grid-template-columns: 1fr; } }
.detail-info, .detail-map {
  background: var(--color-surface);
  padding: var(--s-5);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
}
.info-list {
  display: grid; grid-template-columns: max-content 1fr;
  gap: var(--s-2) var(--s-4);
  margin: 0;
}
.info-list dt {
  color: var(--color-muted);
  font-size: var(--fs-14);
  font-weight: 500;
}
.info-list dd { margin: 0; color: var(--color-ink); font-size: var(--fs-14); }
.info-list dd code {
  font-family: var(--font-mono);
  font-size: var(--fs-12);
  background: var(--color-surface-soft);
  padding: 1px 6px;
  border-radius: var(--radius-xs);
}
.detail-actions {
  margin-top: var(--s-4);
  display: flex; gap: var(--s-2); flex-wrap: wrap;
}

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: var(--s-2);
  padding: var(--s-3) var(--s-4);
  border-radius: var(--radius-sm);
  background: var(--color-primary);
  color: #fff !important;
  font-weight: 600;
  font-size: var(--fs-14);
  border: 1px solid var(--color-primary);
  transition: background var(--t-fast) var(--ease), transform var(--t-fast) var(--ease);
}
.btn:hover { background: var(--color-primary-hover); border-color: var(--color-primary-hover); text-decoration: none; }
.btn:active { transform: scale(0.98); }
.btn.btn-secondary {
  background: var(--color-surface) !important;
  color: var(--color-ink) !important;
  border-color: var(--color-border-strong) !important;
}
.btn.btn-secondary:hover { background: var(--color-surface-soft) !important; }

/* Header de la fiche détail — centré, hiérarchisé */
.detail-header {
  text-align: center;
  max-width: 720px;
  margin: var(--s-7) auto var(--s-6);
  padding-bottom: var(--s-6);
  border-bottom: 1px solid var(--color-border);
}
.detail-header h1 {
  font-size: clamp(2.25rem, 5.5vw, 3.5rem);
  letter-spacing: -0.03em;
  line-height: 1.05;
  margin: 0 0 var(--s-3);
}
.detail-eyebrow-brand {
  display: inline-flex; align-items: center;
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: var(--fs-12);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  background: var(--color-primary-tint);
  color: var(--color-primary-ink);
  padding: var(--s-1) var(--s-3);
  border-radius: var(--radius-pill);
  margin-bottom: var(--s-4);
  transition: background var(--t-fast) var(--ease);
}
.detail-eyebrow-brand:hover {
  background: var(--color-primary-tint-2);
  text-decoration: none;
}
.detail-subtitle {
  font-size: var(--fs-18);
  color: var(--color-muted);
  margin: 0 0 var(--s-4);
  font-weight: 400;
}
.detail-status {
  margin: 0;
  display: flex;
  justify-content: center;
}
.detail-brand { color: var(--color-muted); font-size: var(--fs-14); }
.status-pill {
  display: inline-flex; align-items: center; gap: var(--s-1);
  padding: var(--s-1) var(--s-3);
  border-radius: var(--radius-pill);
  font-size: var(--fs-14);
  font-weight: 600;
}
.status-pill::before {
  content: '';
  width: 8px; height: 8px;
  border-radius: 50%;
  background: currentColor;
  box-shadow: 0 0 0 3px color-mix(in srgb, currentColor 25%, transparent);
}
.status-pill.is-open {
  background: var(--color-success-tint);
  color: var(--color-success);
}
.status-pill.is-closed {
  background: var(--color-surface-soft);
  color: var(--color-muted);
}

.hours-list {
  list-style: none; padding: 0; margin: 0;
  display: grid; gap: 2px;
}
.hours-list li {
  font-size: var(--fs-14);
  color: var(--color-ink);
  padding: 2px 0;
}

/* ---------- Departments / cities grid ---------- */
.dept-grid {
  list-style: none; padding: 0; margin: 0;
  display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: var(--s-2);
}
.dept-grid a {
  display: grid;
  grid-template-columns: 2.75rem 1fr auto;
  align-items: center;
  gap: var(--s-3);
  padding: var(--s-3) var(--s-4);
  background: var(--color-surface);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  color: var(--color-ink);
  transition: border-color var(--t-fast) var(--ease), transform var(--t-fast) var(--ease);
}
.dept-grid a:hover {
  border-color: var(--color-primary);
  text-decoration: none;
  transform: translateY(-1px);
}
.dept-code {
  background: var(--color-ink);
  color: #fff;
  padding: var(--s-1) var(--s-2);
  border-radius: var(--radius-xs);
  font-weight: 700;
  font-family: var(--font-mono);
  text-align: center;
  font-size: var(--fs-12);
  letter-spacing: var(--tracking-wide);
}
.dept-name { font-weight: 500; font-size: var(--fs-14); }
.dept-count {
  color: var(--color-muted);
  font-size: var(--fs-12);
  font-variant-numeric: tabular-nums;
}

/* ---------- Prose (guide / api docs) ---------- */
.prose {
  background: var(--color-surface);
  padding: var(--s-7) var(--s-7);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  max-width: var(--container-narrow);
  margin: 0 auto;
}
.prose h2 { margin-top: var(--s-6); font-size: var(--fs-24); }
.prose h2:first-child { margin-top: 0; }
.prose ul { padding-left: var(--s-5); }
.prose li { margin: var(--s-2) 0; color: var(--color-ink-soft); }
.prose code {
  font-family: var(--font-mono);
  background: var(--color-surface-soft);
  padding: 0.1rem 0.4rem;
  border-radius: var(--radius-xs);
  font-size: 0.92em;
}
.prose pre {
  background: var(--color-ink);
  color: #E5E7EB;
  padding: var(--s-4);
  border-radius: var(--radius-md);
  overflow-x: auto;
  font-size: var(--fs-14);
}
.prose pre code { background: transparent; color: inherit; padding: 0; }

.legal-list {
  display: grid;
  grid-template-columns: max-content 1fr;
  gap: var(--s-2) var(--s-5);
  margin: var(--s-4) 0;
  padding: var(--s-4) var(--s-5);
  background: var(--color-bg);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
}
.legal-list dt {
  color: var(--color-muted);
  font-size: var(--fs-14);
  font-weight: 500;
  align-self: center;
}
.legal-list dd {
  margin: 0;
  color: var(--color-ink);
  font-size: var(--fs-14);
  align-self: center;
}
.legal-list dd code {
  font-family: var(--font-mono);
  background: var(--color-surface);
  padding: 2px var(--s-2);
  border-radius: var(--radius-xs);
  font-size: 0.92em;
  border: 1px solid var(--color-border);
}
@media (max-width: 600px) {
  .legal-list { grid-template-columns: 1fr; gap: var(--s-1) 0; }
  .legal-list dt { margin-top: var(--s-3); font-size: var(--fs-12); text-transform: uppercase; letter-spacing: var(--tracking-wide); }
}

/* ---------- Open now ---------- */
.open-now-header { text-align: center; max-width: 720px; margin: var(--s-7) auto var(--s-5); }
.open-now-header h1 {
  font-size: clamp(2rem, 5vw, 3rem);
  letter-spacing: -0.025em;
  line-height: 1.1;
}
.open-now-eyebrow {
  display: inline-flex; align-items: center; gap: var(--s-2);
  padding: var(--s-1) var(--s-3);
  background: var(--color-success-tint);
  color: var(--color-success);
  border-radius: var(--radius-pill);
  font-size: var(--fs-12);
  font-weight: 700;
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  margin-bottom: var(--s-4);
}

.open-now-form {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: var(--s-3);
  max-width: 720px;
  margin: 0 auto var(--s-6);
  box-shadow: var(--shadow-sm);
}
.open-now-form-row {
  display: flex; align-items: center; gap: var(--s-2);
  flex-wrap: wrap;
}
.open-now-form-icon {
  font-size: 1.25rem;
  padding: 0 var(--s-2) 0 var(--s-3);
}
.open-now-form input[type="search"] {
  flex: 1 1 240px; min-width: 0;
  border: 0; outline: 0;
  font: inherit; font-size: var(--fs-16);
  padding: var(--s-3) var(--s-2);
  background: transparent;
  color: var(--color-ink);
}
.open-now-form input[type="search"]::placeholder { color: var(--color-muted); }
.open-now-form button[type="submit"] {
  padding: var(--s-3) var(--s-5);
  background: var(--color-primary);
  color: #fff;
  border: 0; border-radius: var(--radius-pill);
  font-weight: 600; font-size: var(--fs-14);
  cursor: pointer;
  transition: background var(--t-fast) var(--ease);
}
.open-now-form button[type="submit"]:hover { background: var(--color-primary-hover); }
.open-now-form-aux {
  display: flex; justify-content: center;
  padding: var(--s-2) var(--s-2) var(--s-1);
}
.btn-link {
  background: transparent;
  border: 0;
  color: var(--color-primary);
  font: inherit;
  font-size: var(--fs-14);
  font-weight: 500;
  cursor: pointer;
  padding: var(--s-1) var(--s-2);
}
.btn-link:hover { text-decoration: underline; }
@media (max-width: 600px) {
  .open-now-form-icon { display: none; }
  .open-now-form input[type="search"] { padding-left: var(--s-3); }
  .open-now-form button[type="submit"] { width: 100%; flex: 1 1 100%; }
}

.open-now-meta {
  color: var(--color-muted);
  font-size: var(--fs-14);
}
.open-now-radius { color: var(--color-muted-soft); }

/* ---------- News ---------- */
.section-header {
  display: flex; justify-content: space-between; align-items: baseline;
  gap: var(--s-3); flex-wrap: wrap;
  margin-bottom: var(--s-4);
}
.section-header h2 { margin: 0; }
.section-eyebrow {
  display: inline-block;
  font-size: var(--fs-12);
  font-weight: 600;
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--color-primary);
  margin-bottom: var(--s-1);
}
.section-header-center {
  display: block;
  text-align: center;
  margin-bottom: var(--s-5);
}
.section-header-center h2 { margin: 0; }
.section-header-center .section-eyebrow { margin-bottom: var(--s-2); }

/* CTA centré sous une section (« Toutes les actus », « Voir toutes les enseignes »...) */
.section-cta {
  display: flex; justify-content: center;
  margin-top: var(--s-5);
}
.btn-cta {
  display: inline-flex; align-items: center; gap: var(--s-2);
  padding: var(--s-3) var(--s-5);
  border-radius: var(--radius-pill);
  background: var(--color-surface);
  color: var(--color-ink) !important;
  border: 1px solid var(--color-border-strong);
  font-weight: 600;
  font-size: var(--fs-14);
  transition: background var(--t-fast) var(--ease),
              color var(--t-fast) var(--ease),
              border-color var(--t-fast) var(--ease),
              transform var(--t-fast) var(--ease);
}
.btn-cta::after {
  content: '→';
  transition: transform var(--t-fast) var(--ease);
}
.btn-cta:hover {
  background: var(--color-ink);
  color: #fff !important;
  border-color: var(--color-ink);
  text-decoration: none;
  transform: translateY(-1px);
}
.btn-cta:hover::after { transform: translateX(3px); }

/* ---------- News marquee (homepage) ---------- */
.news-slider-section { margin: var(--s-7) 0 var(--s-8); }
.news-slider-section .section-header { padding: 0 var(--s-1); }

.news-marquee {
  position: relative;
  overflow: hidden;
  /* Déborder le container parent pour effet immersif */
  margin-left: calc(-1 * var(--s-5));
  margin-right: calc(-1 * var(--s-5));
  padding: var(--s-3) 0 var(--s-5);
  /* Fade prononcé sur les côtés — env. 18% de chaque côté en transition douce */
  -webkit-mask-image: linear-gradient(
    to right,
    transparent 0,
    rgba(0,0,0,0.0) 2%,
    rgba(0,0,0,0.15) 6%,
    rgba(0,0,0,0.55) 12%,
    #000 22%,
    #000 78%,
    rgba(0,0,0,0.55) 88%,
    rgba(0,0,0,0.15) 94%,
    rgba(0,0,0,0.0) 98%,
    transparent 100%
  );
  mask-image: linear-gradient(
    to right,
    transparent 0,
    rgba(0,0,0,0.0) 2%,
    rgba(0,0,0,0.15) 6%,
    rgba(0,0,0,0.55) 12%,
    #000 22%,
    #000 78%,
    rgba(0,0,0,0.55) 88%,
    rgba(0,0,0,0.15) 94%,
    rgba(0,0,0,0.0) 98%,
    transparent 100%
  );
}
@media (min-width: 1240px) {
  .news-marquee {
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
  }
}

.news-marquee-track {
  display: flex;
  gap: var(--s-4);
  width: max-content;
  /* Animation : translation de -50% (la moitié, car cartes dupliquées) en boucle */
  animation: news-marquee-scroll var(--marquee-duration, 60s) linear infinite;
  will-change: transform;
}

/* Pause au hover ou focus pour permettre la lecture */
.news-marquee:hover .news-marquee-track,
.news-marquee:focus-within .news-marquee-track {
  animation-play-state: paused;
}

@keyframes news-marquee-scroll {
  from { transform: translate3d(0, 0, 0); }
  to   { transform: translate3d(-50%, 0, 0); }
}

@media (prefers-reduced-motion: reduce) {
  .news-marquee-track { animation: none; }
}

.news-slide {
  flex: 0 0 min(360px, 78vw);
  min-width: 0;
  display: flex;
}
.news-slide > .news-card {
  flex: 1 1 100%;
  min-width: 0;
}

.news-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: var(--s-5);
  margin-top: var(--s-3);
}
.news-grid--compact { grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); }

.news-card {
  display: flex; flex-direction: column;
  background: var(--color-surface);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  overflow: hidden;
  transition: border-color var(--t-fast) var(--ease),
              box-shadow var(--t-fast) var(--ease),
              transform var(--t-fast) var(--ease);
}
.news-card:hover {
  border-color: var(--color-border-strong);
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}
.news-cover {
  display: block;
  aspect-ratio: 16 / 9;
  background: var(--color-surface-soft);
  overflow: hidden;
}
.news-cover img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform var(--t-base) var(--ease);
}
.news-card:hover .news-cover img { transform: scale(1.03); }
.news-body { padding: var(--s-5); }
.news-header {
  display: flex; align-items: center; gap: var(--s-3);
  font-size: var(--fs-12);
  margin-bottom: var(--s-2);
  color: var(--color-muted);
}
.news-brand {
  display: inline-flex;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
  background: var(--color-primary-tint);
  color: var(--color-primary-ink);
  padding: 2px var(--s-2);
  border-radius: var(--radius-pill);
}
.news-brand:hover { background: var(--color-primary-tint-2); text-decoration: none; }
.news-meta { font-variant-numeric: tabular-nums; }
.news-title {
  font-size: var(--fs-20);
  font-family: var(--font-display);
  margin: 0 0 var(--s-2);
  line-height: var(--lh-snug);
}
.news-title a { color: var(--color-ink); }
.news-title a:hover { color: var(--color-primary); text-decoration: none; }
.news-excerpt {
  color: var(--color-ink-soft);
  font-size: var(--fs-14);
  margin: 0 0 var(--s-3);
  line-height: var(--lh-relaxed);
}
.news-readmore { margin: 0; font-size: var(--fs-14); font-weight: 600; }

/* ---------- Article (news detail) ---------- */
.article {
  max-width: var(--container-narrow);
  margin: 0 auto;
}
.article-header { margin: var(--s-6) 0 var(--s-5); }
.article-eyebrow {
  display: flex; gap: var(--s-3); align-items: center; flex-wrap: wrap;
  margin-bottom: var(--s-3);
  font-size: var(--fs-14);
  color: var(--color-muted);
}
.article-eyebrow-brand {
  display: inline-flex;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
  background: var(--color-primary-tint);
  color: var(--color-primary-ink);
  padding: 2px var(--s-2);
  border-radius: var(--radius-pill);
  font-size: var(--fs-12);
}
.article-eyebrow-date { font-variant-numeric: tabular-nums; }
.article h1 { font-size: clamp(2rem, 4.5vw, 2.75rem); letter-spacing: -0.025em; line-height: 1.1; }
.article-lead {
  font-size: var(--fs-20);
  color: var(--color-ink-soft);
  line-height: var(--lh-relaxed);
  margin-top: var(--s-4);
}
.article-author { color: var(--color-muted); font-size: var(--fs-14); }

.article-cta {
  display: flex; align-items: center; flex-wrap: wrap;
  gap: var(--s-3) var(--s-4);
  background: linear-gradient(135deg, var(--color-primary-tint) 0%, var(--color-primary-tint-2) 100%);
  border: 1px solid var(--color-primary-tint-2);
  border-radius: var(--radius-lg);
  padding: var(--s-4) var(--s-5);
  margin: var(--s-5) 0 var(--s-3);
}
.article-cta-btn {
  display: inline-flex; align-items: center; gap: var(--s-2);
  background: var(--color-primary);
  color: #fff !important;
  font-weight: 600;
  font-size: var(--fs-14);
  padding: var(--s-3) var(--s-5);
  border-radius: var(--radius-pill);
  border: 0;
  transition: background var(--t-fast) var(--ease), transform var(--t-fast) var(--ease);
}
.article-cta-btn:hover {
  background: var(--color-primary-hover);
  text-decoration: none;
  transform: translateY(-1px);
}
.article-cta-arrow {
  transition: transform var(--t-fast) var(--ease);
  display: inline-block;
}
.article-cta-btn:hover .article-cta-arrow { transform: translateX(3px); }
.article-cta-host {
  color: var(--color-primary-ink);
  font-size: var(--fs-14);
  font-weight: 500;
}
.article-cta-host::before {
  content: '↗';
  margin-right: var(--s-1);
  opacity: 0.6;
}
.article-cover {
  margin: var(--s-5) 0;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--color-border);
}
.article-cover img {
  width: 100%; height: auto;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}
.article-content {
  font-size: var(--fs-18);
  line-height: var(--lh-relaxed);
  color: var(--color-ink);
}
.article-content > * + * { margin-top: var(--s-4); }
.article-content h2 {
  font-size: var(--fs-24);
  margin-top: var(--s-7);
  margin-bottom: var(--s-2);
}
.article-content h3 {
  font-size: var(--fs-20);
  margin-top: var(--s-5);
  margin-bottom: var(--s-2);
}
.article-content p { margin: 0; line-height: var(--lh-relaxed); color: var(--color-ink); }
.article-content a { color: var(--color-primary); text-decoration: underline; }
.article-content blockquote {
  margin: 0;
  border-left: 3px solid var(--color-primary);
  padding-left: var(--s-4);
  color: var(--color-ink-soft);
  font-style: italic;
}
.article-content ul, .article-content ol {
  padding-left: var(--s-5);
  line-height: var(--lh-relaxed);
}
.article-content img {
  width: 100%; height: auto;
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
}
.article-content code {
  font-family: var(--font-mono);
  background: var(--color-surface-soft);
  padding: 0.1em 0.4em;
  border-radius: var(--radius-xs);
  font-size: 0.9em;
}
.article-content pre {
  background: var(--color-ink);
  color: #E5E7EB;
  padding: var(--s-4);
  border-radius: var(--radius-md);
  overflow-x: auto;
  font-size: var(--fs-14);
}
.article-content pre code { background: transparent; color: inherit; padding: 0; }
.article-footer {
  margin-top: var(--s-7);
  padding-top: var(--s-5);
  border-top: 1px solid var(--color-border);
  color: var(--color-muted);
  font-size: var(--fs-14);
}

/* ---------- Empty / hint states ---------- */
.empty {
  text-align: center;
  padding: var(--s-8) var(--s-4);
  color: var(--color-muted);
  background: var(--color-surface);
  border-radius: var(--radius-lg);
  border: 1px dashed var(--color-border-strong);
}

/* ---------- Footer ---------- */
.site-footer {
  margin-top: var(--s-9);
  padding: var(--s-7) 0 var(--s-5);
  background: var(--color-surface);
  border-top: 1px solid var(--color-border);
  color: var(--color-muted);
  font-size: var(--fs-14);
}
.footer-grid {
  display: grid;
  grid-template-columns: 2fr repeat(3, 1fr);
  gap: var(--s-7);
  margin-bottom: var(--s-6);
}
@media (max-width: 720px) {
  .footer-grid { grid-template-columns: 1fr 1fr; gap: var(--s-5); }
  .footer-about { grid-column: 1 / -1; }
}
.footer-about p { color: var(--color-ink-soft); font-size: var(--fs-14); max-width: 36ch; }
.footer-col h4 {
  font-size: var(--fs-12);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
  color: var(--color-muted);
  margin-bottom: var(--s-3);
}
.footer-col ul { list-style: none; padding: 0; margin: 0; }
.footer-col li { margin: var(--s-2) 0; }
.footer-col a { color: var(--color-ink-soft); }
.footer-col a:hover { color: var(--color-primary); }
.footer-bottom {
  padding-top: var(--s-5);
  border-top: 1px solid var(--color-border);
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: var(--s-3);
  font-size: var(--fs-12);
}

/* ---------- Responsive tweaks ---------- */
@media (max-width: 600px) {
  :root { --header-h: 60px; }
  h1 { font-size: var(--fs-30); }
  .stat-card { padding: var(--s-4); }
  .stat-number { font-size: var(--fs-30); }
  .prose { padding: var(--s-5); }
}
