/* ===== FRANCEAVENUE — STYLES ===== */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;1,400&family=Caveat:wght@400;600&family=Inter:wght@300;400;500;600;700&display=swap');

/* ===== VARIABLES ===== */
:root {
  --primary: #2D6A4F;
  --primary-dark: #1B4332;
  --primary-light: #52B788;
  --secondary: #FFB703;
  --secondary-dark: #E09E00;
  --blue-fr: #1d3fa0;
  --red-fr: #e63946;
  --text: #1a1a1a;
  --text-light: #555;
  --text-muted: #888;
  --bg: #FAFAF8;
  --bg-card: #ffffff;
  --border: #E8E4DC;
  --shadow: 0 4px 24px rgba(0,0,0,0.08);
  --shadow-lg: 0 12px 48px rgba(0,0,0,0.12);
  --radius: 12px;
  --radius-lg: 20px;
  --font-serif: 'Playfair Display', Georgia, serif;
  --font-script: 'Caveat', cursive;
  --font-sans: 'Inter', system-ui, sans-serif;
  --max-width: 1200px;
  --nav-height: 72px;
}

/* ===== RESET ===== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.7;
  color: var(--text);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
}
img { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }
button { cursor: pointer; border: none; background: none; font-family: inherit; }

/* ===== TYPOGRAPHY ===== */
h1, h2, h3, h4 {
  font-family: var(--font-serif);
  line-height: 1.2;
  color: var(--text);
}
h1 { font-size: clamp(2rem, 5vw, 3.5rem); }
h2 { font-size: clamp(1.6rem, 3vw, 2.4rem); }
h3 { font-size: clamp(1.2rem, 2vw, 1.6rem); }
p { color: var(--text-light); }

.script-tag {
  font-family: var(--font-script);
  font-size: 1.3rem;
  color: var(--secondary-dark);
  display: block;
  margin-bottom: 0.3rem;
}

/* ===== LAYOUT ===== */
.container {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 24px;
}
.section { padding: 80px 0; }
.section-sm { padding: 48px 0; }

/* ===== NAVIGATION ===== */
.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: var(--nav-height);
  background: rgba(250,250,248,0.97);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
  z-index: 1000;
  transition: box-shadow 0.3s;
}
.nav.scrolled { box-shadow: var(--shadow); }
.nav-inner {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 24px;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

/* ===== LOGO FRANCEAVENUE — Hexagone Minimaliste ===== */

.nav-logo-svg {
  height: 44px;
  width: auto;
  flex-shrink: 0;
  filter: drop-shadow(0 2px 6px rgba(27,67,50,0.15));
  transition: filter 0.25s, transform 0.25s;
}

.nav-logo {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
  text-decoration: none;
  transition: opacity 0.2s, transform 0.2s;
}
.nav-logo:hover {
  opacity: 0.88;
  transform: translateY(-1px);
}

.nav-logo-icon {
  flex-shrink: 0;
  filter: drop-shadow(0 2px 6px rgba(27,67,50,0.2));
  transition: filter 0.25s, transform 0.25s;
}
.nav-logo:hover .nav-logo-icon {
  filter: drop-shadow(0 4px 12px rgba(27,67,50,0.3));
}

.nav-logo-text {
  display: flex;
  flex-direction: column;
  line-height: 1;
}

.nav-logo-name {
  display: flex;
  align-items: baseline;
  gap: 0;
  line-height: 1;
  white-space: nowrap;
}
.nav-logo-france {
  font-family: var(--font-sans);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--primary-dark);
  letter-spacing: -0.02em;
  line-height: 1;
}
.nav-logo-avenue {
  font-family: var(--font-sans);
  font-size: 1.25rem;
  font-weight: 300;
  color: var(--primary);
  letter-spacing: -0.01em;
  line-height: 1;
}

.nav-logo-tagline { display: none; }

/* ── Liens nav ── */
.nav-links {
  display: flex;
  align-items: center;
  gap: 4px;
}
.nav-links > li > a {
  padding: 8px 14px;
  border-radius: 8px;
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--text-light);
  transition: all 0.2s;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.nav-links > li > a:hover,
.nav-links > li > a.active {
  color: var(--primary);
  background: rgba(45,106,79,0.08);
}

/* ── Dropdown ── */
.nav-dropdown { position: relative; }
.nav-dropdown-toggle { cursor: pointer; user-select: none; }
.nav-dropdown-toggle svg { transition: transform 0.2s; flex-shrink: 0; }
.nav-dropdown:hover .nav-dropdown-toggle svg,
.nav-dropdown.open .nav-dropdown-toggle svg { transform: rotate(180deg); }
.nav-submenu {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  min-width: 220px;
  background: white;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-lg);
  padding: 8px;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px);
  transition: all 0.2s ease;
  z-index: 200;
}
.nav-dropdown:hover .nav-submenu,
.nav-dropdown.open .nav-submenu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.nav-submenu li a {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border-radius: 8px;
  font-size: 0.88rem;
  font-weight: 500;
  color: var(--text-light);
  transition: all 0.15s;
}
.nav-submenu li a:hover,
.nav-submenu li a.active {
  background: rgba(45,106,79,0.08);
  color: var(--primary);
}
.nav-submenu li a svg { flex-shrink: 0; stroke: var(--primary); }

.nav-cta {
  background: var(--primary) !important;
  color: white !important;
  padding: 8px 18px !important;
  border-radius: 8px !important;
}
.nav-cta:hover { background: var(--primary-dark) !important; }

.nav-burger {
  display: none;
  flex-direction: column;
  gap: 5px;
  padding: 8px;
  cursor: pointer;
}
.nav-burger span {
  display: block;
  width: 22px; height: 2px;
  background: var(--text);
  border-radius: 2px;
  transition: all 0.3s;
}

@media (max-width: 768px) {
  .nav-links { display: none; flex-direction: column; gap: 4px; align-items: stretch; }
  .nav-links.open {
    display: flex;
    position: absolute;
    top: var(--nav-height);
    left: 0; right: 0;
    background: white;
    border-bottom: 1px solid var(--border);
    padding: 16px 24px;
    box-shadow: var(--shadow);
  }
  .nav-links > li > a { padding: 10px 14px; }
  .nav-submenu {
    position: static;
    opacity: 1;
    visibility: visible;
    transform: none;
    box-shadow: none;
    border: none;
    background: var(--bg);
    padding: 4px 8px;
    display: none;
  }
  .nav-dropdown.open .nav-submenu { display: block; }
  .nav-burger { display: flex; }
}

/* ===== BUTTONS ===== */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 28px;
  border-radius: 10px;
  font-size: 0.95rem;
  font-weight: 600;
  transition: all 0.25s;
  cursor: pointer;
}
.btn-primary {
  background: var(--primary);
  color: white;
  box-shadow: 0 4px 16px rgba(45,106,79,0.3);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 28px;
  border-radius: 10px;
  font-size: 0.95rem;
  font-weight: 600;
  transition: all 0.25s;
}
.btn-primary:hover {
  background: var(--primary-dark);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(45,106,79,0.35);
}
.btn-secondary {
  background: var(--secondary);
  color: var(--text);
  box-shadow: 0 4px 16px rgba(255,183,3,0.3);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 28px;
  border-radius: 10px;
  font-size: 0.95rem;
  font-weight: 600;
  transition: all 0.25s;
}
.btn-secondary:hover {
  background: var(--secondary-dark);
  transform: translateY(-2px);
}
.btn-outline {
  background: transparent;
  color: white;
  border: 2px solid rgba(255,255,255,0.7);
}
.btn-outline:hover {
  background: white;
  color: var(--primary);
  transform: translateY(-2px);
}
.btn-sm { padding: 8px 18px; font-size: 0.85rem; }
.btn-full { width: 100%; justify-content: center; }

/* ===== HERO ===== */
.hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  overflow: hidden;
  padding: 0 24px;
}
.hero-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  filter: brightness(0.55);
  transform: scale(1.05);
  transition: transform 8s ease;
}
.hero-bg.loaded { transform: scale(1); }
.hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(27,67,50,0.65) 0%, rgba(0,0,0,0.2) 60%, transparent 100%);
}
.hero-content {
  position: relative;
  z-index: 2;
  max-width: 700px;
  color: white;
  padding-top: var(--nav-height);
  margin: 0 auto;
  width: 100%;
}
.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(255,183,3,0.2);
  border: 1px solid rgba(255,183,3,0.5);
  color: var(--secondary);
  padding: 6px 16px;
  border-radius: 100px;
  font-size: 0.85rem;
  font-weight: 600;
  margin-bottom: 20px;
  backdrop-filter: blur(8px);
}
.hero h1 { color: white; margin-bottom: 20px; text-shadow: 0 2px 20px rgba(0,0,0,0.3); }
.hero h1 em { font-style: italic; color: var(--secondary); }
.hero-sub {
  font-size: 1.15rem;
  color: rgba(255,255,255,0.9) !important;
  margin-bottom: 36px;
  max-width: 540px;
}
.hero-cta { display: flex; gap: 12px; flex-wrap: wrap; }
.hero-scroll {
  position: absolute;
  bottom: 32px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  color: rgba(255,255,255,0.7);
  font-size: 0.8rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  animation: bounce 2s infinite;
}
.hero-scroll svg { stroke: currentColor; fill: none; stroke-width: 2; }
@keyframes bounce { 0%, 100% { transform: translateX(-50%) translateY(0); } 50% { transform: translateX(-50%) translateY(6px); } }

/* ===== PAGE HERO ===== */
.page-hero {
  background: linear-gradient(135deg, var(--primary-dark), var(--primary));
  padding: calc(var(--nav-height) + 60px) 24px 60px;
  text-align: center;
  color: white;
}
.page-hero .tag { background: rgba(255,183,3,0.2); color: var(--secondary); border: 1px solid rgba(255,183,3,0.4); padding: 6px 16px; border-radius: 100px; font-size: 0.85rem; font-weight: 600; display: inline-block; margin-bottom: 16px; }
.page-hero h1 { color: white; margin-bottom: 12px; }
.page-hero p { color: rgba(255,255,255,0.8); max-width: 560px; margin: 0 auto; }

/* ===== SECTION HEADERS ===== */
.section-header { text-align: center; margin-bottom: 56px; padding: 0 16px; }
.section-header .tag { background: rgba(45,106,79,0.08); color: var(--primary); border: 1px solid rgba(45,106,79,0.2); padding: 6px 16px; border-radius: 100px; font-size: 0.82rem; font-weight: 600; display: inline-block; margin-bottom: 12px; }
.section-header h2 { margin-bottom: 12px; }
.section-header p { font-size: 1.05rem; max-width: 560px; margin: 0 auto; }
.section-footer { text-align: center; margin-top: 48px; }
.section-title { font-family: var(--font-serif); font-size: clamp(1.6rem, 3vw, 2.2rem); margin-bottom: 12px; }
.section-subtitle { color: var(--text-muted); font-size: 1rem; margin-bottom: 40px; }
.section-label {
  font-family: var(--font-sans);
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--primary);
  margin-bottom: 16px;
}

/* ===== INTRO ===== */
.intro { padding: 80px 0; background: white; }
.intro-grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 64px;
  align-items: center;
}
.intro-text .tag { background: rgba(45,106,79,0.08); color: var(--primary); border: 1px solid rgba(45,106,79,0.2); padding: 6px 16px; border-radius: 100px; font-size: 0.82rem; font-weight: 600; display: inline-block; margin-bottom: 16px; }
.intro-text h2 { margin-bottom: 20px; }
.intro-text p { margin-bottom: 16px; }
.intro-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.stat-card {
  background: var(--bg);
  border-radius: var(--radius);
  padding: 28px 20px;
  text-align: center;
  border: 1px solid var(--border);
}
.stat-number {
  display: block;
  font-family: var(--font-serif);
  font-size: 2.4rem;
  font-weight: 700;
  color: var(--primary);
  line-height: 1;
  margin-bottom: 6px;
}
.stat-label {
  font-size: 0.82rem;
  color: #555 !important;
  font-weight: 500;
  display: block;
}
@media (max-width: 768px) {
  .intro-grid { grid-template-columns: 1fr; gap: 40px; }
}

/* ===== DESTINATIONS GRID ===== */
.featured { padding: 80px 0; background: var(--bg); }
.destinations-grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  grid-template-rows: auto auto;
  gap: 20px;
}
.dest-card {
  background: white;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow);
  transition: transform 0.3s, box-shadow 0.3s;
  display: flex;
  flex-direction: column;
}
.dest-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.dest-card--large { grid-row: 1 / 3; }
.dest-card-img {
  background-size: cover;
  background-position: center;
  flex-shrink: 0;
}
.dest-card--large .dest-card-img { height: 320px; }
.dest-card:not(.dest-card--large) .dest-card-img { height: 180px; }
.dest-card-body { padding: 24px; flex: 1; display: flex; flex-direction: column; }
.dest-region { font-size: 0.75rem; color: var(--primary); font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em; display: block; margin-bottom: 8px; }
.dest-card-body h3 { margin-bottom: 8px; font-size: 1.15rem; }
.dest-card-body p { font-size: 0.88rem; flex: 1; margin-bottom: 16px; }
.dest-link { color: var(--primary); font-size: 0.88rem; font-weight: 600; transition: gap 0.2s; display: inline-flex; align-items: center; gap: 4px; margin-top: auto; }
.dest-link:hover { gap: 8px; }
@media (max-width: 768px) {
  .destinations-grid { grid-template-columns: 1fr; }
  .dest-card--large { grid-row: auto; }
  .dest-card--large .dest-card-img { height: 240px; }
}

/* ===== COUPS DE COEUR ===== */
.coups-coeur { padding: 80px 0; background: linear-gradient(135deg, var(--primary-dark), var(--primary)); }
.coups-coeur .section-header .tag { background: rgba(255,183,3,0.2); color: var(--secondary); border: 1px solid rgba(255,183,3,0.4); }
.coups-coeur .section-header h2 { color: white; }
.coups-coeur .section-header p { color: rgba(255,255,255,0.8); }
.coups-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
.coup-item {
  background: rgba(255,255,255,0.1);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: var(--radius-lg);
  padding: 32px 24px;
  text-align: center;
  transition: background 0.3s, transform 0.3s;
}
.coup-item:hover { background: rgba(255,255,255,0.18); transform: translateY(-4px); }
.coup-icon { font-size: 2.4rem; margin-bottom: 16px; display: block; }
.coup-item h3 { color: white; font-size: 1.1rem; margin-bottom: 10px; }
.coup-item p { color: rgba(255,255,255,0.75); font-size: 0.88rem; }
@media (max-width: 900px) { .coups-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .coups-grid { grid-template-columns: 1fr; } }

/* ===== BLOG PREVIEW (homepage) ===== */
.blog-preview { padding: 80px 0; background: white; }
.blog-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 24px;
}
.blog-card {
  background: var(--bg-card);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow);
  display: flex;
  flex-direction: column;
  transition: transform 0.3s, box-shadow 0.3s;
}
.blog-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.blog-card-img {
  background-size: cover;
  background-position: center;
  height: 280px;
  flex-shrink: 0;
}
.blog-card--featured .blog-card-img { height: 320px; }
.blog-card-body { padding: 28px; flex: 1; display: flex; flex-direction: column; }
.blog-cat { font-size: 0.75rem; color: var(--primary); font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; display: block; margin-bottom: 10px; }
.blog-card-body h3 { font-size: 1.2rem; margin-bottom: 12px; }
.blog-card-body p { font-size: 0.88rem; flex: 1; margin-bottom: 16px; }
.blog-meta { display: flex; gap: 16px; font-size: 0.8rem; color: var(--text-muted); margin-bottom: 16px; flex-wrap: wrap; }
.blog-side { display: flex; flex-direction: column; gap: 20px; }
.blog-card-sm {
  background: white;
  border-radius: var(--radius);
  overflow: hidden;
  display: flex;
  gap: 0;
  box-shadow: var(--shadow);
  transition: transform 0.2s;
  flex-direction: row;
}
.blog-card-sm:hover { transform: translateY(-2px); }
.blog-card-sm-img {
  width: 110px;
  min-width: 110px;
  background-size: cover;
  background-position: center;
}
.blog-card-sm-body { padding: 16px; display: flex; flex-direction: column; justify-content: space-between; flex: 1; }
.blog-card-sm-body h4 { font-size: 0.88rem; font-family: var(--font-serif); color: var(--text); line-height: 1.3; margin-bottom: 8px; }
@media (max-width: 900px) {
  .blog-grid { grid-template-columns: 1fr; }
  .blog-side { flex-direction: row; overflow-x: auto; }
  .blog-card-sm { min-width: 280px; flex-direction: column; }
  .blog-card-sm-img { width: 100%; min-width: unset; height: 120px; }
}

/* ===== BLOG PAGE ===== */
.blog-stats { padding: 32px 0; background: white; border-bottom: 1px solid var(--border); }
.blog-stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  text-align: center;
}
@media (max-width: 600px) { .blog-stats-grid { grid-template-columns: repeat(2, 1fr); } }
.blog-stat-number {
  display: block;
  font-family: var(--font-serif);
  font-size: 2rem;
  font-weight: 700;
  color: var(--primary);
  line-height: 1;
}
.blog-stat-label { font-size: 0.8rem; color: var(--text-muted); margin-top: 4px; display: block; }

.blog-featured { padding: 48px 0 0; background: white; }
.featured-card {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 0;
  background: white;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  transition: transform 0.3s, box-shadow 0.3s;
}
.featured-card:hover { transform: translateY(-4px); box-shadow: 0 20px 60px rgba(0,0,0,0.14); }
.featured-card-img {
  height: 380px;
  background-size: cover;
  background-position: center;
  position: relative;
}
.featured-card-tag {
  position: absolute;
  top: 16px; left: 16px;
  background: var(--secondary);
  color: var(--text);
  padding: 5px 14px;
  border-radius: 100px;
  font-size: 0.78rem;
  font-weight: 700;
}
.featured-card-body {
  padding: 40px 36px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  background: white;
}
.featured-card-body .article-cat { margin-bottom: 12px; }
.featured-card-body h2 { font-size: clamp(1.3rem, 2vw, 1.8rem); margin-bottom: 14px; line-height: 1.3; }
.featured-card-body p { font-size: 0.92rem; margin-bottom: 24px; }
.featured-card-body .featured-card-meta { display: flex; gap: 12px; font-size: 0.8rem; color: var(--text-muted); margin-bottom: 20px; flex-wrap: wrap; }
@media (max-width: 768px) {
  .featured-card { grid-template-columns: 1fr; }
  .featured-card-img { height: 240px; }
  .featured-card-body { padding: 24px; }
}

.blog-filters {
  padding: 20px 0;
  background: white;
  border-bottom: 1px solid var(--border);
  position: sticky;
  top: var(--nav-height);
  z-index: 99;
}
.filter-bar {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding-bottom: 4px;
}
.filter-bar::-webkit-scrollbar { display: none; }
.filter-btn {
  padding: 8px 20px;
  border-radius: 100px;
  font-size: 0.85rem;
  font-weight: 500;
  background: var(--bg);
  color: var(--text-light);
  border: 1px solid var(--border);
  white-space: nowrap;
  transition: all 0.2s;
  text-decoration: none;
  display: inline-block;
}
.filter-btn:hover, .filter-btn.active {
  background: var(--primary);
  color: white;
  border-color: var(--primary);
}
.blog-main { padding: 60px 0; }
.blog-articles-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
.article-card {
  background: white;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow);
  display: flex;
  flex-direction: column;
  transition: transform 0.3s, box-shadow 0.3s;
}
.article-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }
.article-card-img-link { display: block; overflow: hidden; }
.article-card-img {
  height: 220px;
  background-size: cover;
  background-position: center;
  transition: transform 0.5s;
  position: relative;
}
.article-card:hover .article-card-img { transform: scale(1.04); }
.article-tag {
  position: absolute;
  top: 14px; left: 14px;
  background: var(--secondary);
  color: var(--text);
  padding: 4px 12px;
  border-radius: 100px;
  font-size: 0.75rem;
  font-weight: 700;
}
.article-card-body { padding: 24px; flex: 1; display: flex; flex-direction: column; }
.article-card-meta { display: flex; gap: 10px; align-items: center; margin-bottom: 10px; flex-wrap: wrap; }
.article-cat { font-size: 0.72rem; color: var(--primary); font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; background: rgba(45,106,79,0.08); padding: 3px 10px; border-radius: 100px; }
.article-date, .article-read { font-size: 0.75rem; color: var(--text-muted); }
.article-card-title { font-size: 1rem; margin-bottom: 10px; line-height: 1.35; }
.article-card-title a { color: var(--text); transition: color 0.2s; }
.article-card-title a:hover { color: var(--primary); }
.article-card-excerpt { font-size: 0.85rem; color: var(--text-light); flex: 1; margin-bottom: 16px; }
.empty-state { text-align: center; padding: 80px 0; }
.empty-state p { font-size: 1.1rem; margin-bottom: 24px; }
@media (max-width: 900px) { .blog-articles-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .blog-articles-grid { grid-template-columns: 1fr; } }

/* ===== NEWSLETTER ===== */
.newsletter { padding: 80px 0; background: var(--bg); }
.newsletter-inner { max-width: 640px; margin: 0 auto; padding: 0 24px; }
.newsletter-content {
  background: white;
  border-radius: var(--radius-lg);
  padding: 60px 48px;
  text-align: center;
  box-shadow: var(--shadow);
}

.newsletter-emoji { font-size: 2.5rem; display: block; margin-bottom: 16px; }
.newsletter-content h2 { margin-bottom: 12px; }
.newsletter-content p { margin-bottom: 28px; }
.newsletter-form { display: flex; gap: 12px; max-width: 420px; margin: 0 auto; }
.newsletter-form input {
  flex: 1;
  padding: 14px 20px;
  border: 2px solid var(--border);
  border-radius: 10px;
  font-size: 0.95rem;
  font-family: inherit;
  outline: none;
  transition: border-color 0.2s;
}
.newsletter-form input:focus { border-color: var(--primary); }
.newsletter-legal { font-size: 0.78rem; color: var(--text-muted); margin-top: 12px; }
.newsletter-legal a { color: var(--primary); }
@media (max-width: 480px) {
  .newsletter-form { flex-direction: column; }
  .newsletter-content { padding: 36px 24px; }
}
.newsletter-box {
  background: white;
  border-radius: var(--radius-lg);
  padding: 60px 48px;
  max-width: 640px;
  margin: 0 auto;
  box-shadow: var(--shadow);
  text-align: center;
}

.newsletter-full {
  width: 95%;
  max-width: 1800px;
  margin: 0 auto;
  padding: 60px 24px;
}

.newsletter-icon {
  width: 64px;
  height: 64px;
  background: linear-gradient(135deg, var(--primary), var(--primary-light));
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 20px;
}
.newsletter-box h2 { margin-bottom: 12px; }
.newsletter-box p { margin-bottom: 28px; }

/* ===== FOOTER ===== */

.footer-tricolor {
  display: flex;
  height: 4px;
}
.footer-tricolor span { flex: 1; }
.tc-blue { background: var(--blue-fr); }
.tc-white { background: white; }
.tc-red { background: var(--red-fr); }

.footer-main {
  background: var(--primary-dark);
  padding: 64px 0 0;
}

.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1.2fr 1.2fr 1.4fr;
  gap: 40px;
  padding-bottom: 48px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}

.footer-brand { display: flex; flex-direction: column; gap: 0; }

.footer-logo {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  margin-bottom: 14px;
  transition: opacity 0.2s;
}
.footer-logo:hover { opacity: 0.85; }

.footer-logo-icon {
  flex-shrink: 0;
  filter: drop-shadow(0 2px 6px rgba(0,0,0,0.3));
}

.footer-logo-text {
  display: flex;
  flex-direction: column;
  line-height: 1;
}

.footer-logo-name {
  display: flex;
  align-items: baseline;
  gap: 0;
  line-height: 1;
  white-space: nowrap;
}
.footer-logo-france {
  font-family: var(--font-sans);
  font-size: 1.15rem;
  font-weight: 700;
  color: white;
  letter-spacing: -0.02em;
  line-height: 1;
}
.footer-logo-avenue {
  font-family: var(--font-sans);
  font-size: 1.15rem;
  font-weight: 300;
  color: var(--secondary);
  letter-spacing: -0.01em;
  line-height: 1;
}

.footer-logo-tagline { display: none; }

.footer-tagline-text {
  font-size: 0.88rem;
  color: rgba(255,255,255,0.55);
  line-height: 1.6;
  margin-bottom: 20px;
}

.footer-social {
  display: flex;
  gap: 8px;
  margin-bottom: 24px;
}
.social-link {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
  color: white;
  border: 1px solid rgba(255,255,255,0.15);
  background: rgba(255,255,255,0.07);
}
.social-link:hover { transform: translateY(-3px); border-color: transparent; }
.social-instagram:hover { background: linear-gradient(45deg, #f09433, #e6683c, #dc2743, #cc2366, #bc1888); }
.social-facebook:hover { background: #1877f2; }
.social-pinterest:hover { background: #E60023; }
.social-youtube:hover { background: #FF0000; }
.social-link svg { stroke: white; }

.footer-stats {
  display: flex;
  gap: 16px;
}
.footer-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 10px;
  padding: 10px 16px;
  text-align: center;
  flex: 1;
}
.footer-stat strong {
  font-family: var(--font-serif);
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--secondary);
  line-height: 1;
  display: block;
  margin-bottom: 2px;
}
.footer-stat span {
  font-size: 0.7rem;
  color: rgba(255,255,255,0.5);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.footer-col {}
.footer-col-title {
  font-family: var(--font-sans);
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: white;
  margin-bottom: 18px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.footer-col-title svg { stroke: var(--secondary); flex-shrink: 0; opacity: 0.8; }

.footer-links {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 24px;
}
.footer-links a {
  font-size: 0.88rem;
  color: rgba(255,255,255,0.55);
  transition: all 0.2s;
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 2px 0;
  border-bottom: 1px solid transparent;
}
.footer-links a:hover {
  color: var(--secondary);
  border-bottom-color: rgba(255,183,3,0.3);
  padding-left: 4px;
}

.footer-weather-widget {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 12px;
  padding: 16px;
  margin-bottom: 16px;
}
.footer-weather-title {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: rgba(255,255,255,0.5);
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.footer-weather-title svg { stroke: rgba(255,255,255,0.4); }
.footer-weather-cities { display: flex; flex-direction: column; gap: 6px; }
.fw-city {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.82rem;
}
.fw-city span:first-child { color: rgba(255,255,255,0.6); }
.fw-city span:last-child { color: white; font-weight: 500; font-size: 0.85rem; }

/* Bannière Booking dans le footer */
.footer-affiliation { margin-top: 0; }
.footer-booking-banner {
  display: flex;
  align-items: center;
  gap: 10px;
  background: rgba(0,53,128,0.4);
  border: 1px solid rgba(0,53,128,0.6);
  border-radius: 10px;
  padding: 12px 14px;
  transition: background 0.2s, transform 0.2s;
  text-decoration: none;
}
.footer-booking-banner:hover {
  background: rgba(0,53,128,0.6);
  transform: translateY(-2px);
}
.footer-booking-banner > span:first-child { font-size: 1.3rem; flex-shrink: 0; }
.footer-booking-banner div { flex: 1; }
.footer-booking-banner strong { display: block; font-size: 0.82rem; color: white; font-weight: 700; }
.footer-booking-banner small { font-size: 0.7rem; color: rgba(255,255,255,0.55); }
.footer-booking-arrow { font-size: 0.85rem; color: rgba(255,255,255,0.5); flex-shrink: 0; }

.footer-bottom {
  background: rgba(0,0,0,0.2);
  padding: 20px 0;
}
.footer-bottom-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}
.footer-copy {
  font-size: 0.78rem;
  color: rgba(255,255,255,0.35);
}
.footer-made {
  font-size: 0.78rem;
  color: rgba(255,255,255,0.35);
}
.footer-legal-links {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.78rem;
}
.footer-legal-links a {
  color: rgba(255,255,255,0.4);
  transition: color 0.2s;
}
.footer-legal-links a:hover { color: var(--secondary); }
.footer-legal-links span { color: rgba(255,255,255,0.2); }

@media (max-width: 1024px) {
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
}
@media (max-width: 600px) {
  .footer-grid { grid-template-columns: 1fr; gap: 28px; }
  .footer-bottom-inner { flex-direction: column; text-align: center; gap: 8px; }
  .footer-stats { gap: 8px; }
  .footer-made { display: none; }
}

/* ===== REVEAL ON SCROLL ===== */
.reveal-on-scroll {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}
.reveal-on-scroll.revealed { opacity: 1; transform: translateY(0); }
.reveal-on-scroll.delay-1 { transition-delay: 0.1s; }
.reveal-on-scroll.delay-2 { transition-delay: 0.2s; }
.reveal-on-scroll.delay-3 { transition-delay: 0.3s; }

/* ===== BREADCRUMB ===== */
.breadcrumb {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.85rem;
  color: rgba(255,255,255,0.75);
  flex-wrap: wrap;
}
.breadcrumb a { color: rgba(255,255,255,0.9); text-decoration: underline; text-decoration-color: rgba(255,255,255,0.3); }
.breadcrumb span { color: rgba(255,255,255,0.5); }

/* ===== TAGS ===== */
.tag {
  padding: 6px 16px;
  background: rgba(45,106,79,0.08);
  color: var(--primary);
  border-radius: 100px;
  font-size: 0.78rem;
  font-weight: 600;
  display: inline-block;
}
.tag-gold {
  background: rgba(255,183,3,0.15) !important;
  color: var(--secondary-dark) !important;
  border-color: rgba(255,183,3,0.3) !important;
}

/* ===== UTILITIES ===== */
.text-center { text-align: center; }
.text-primary { color: var(--primary); }
.text-secondary { color: var(--secondary-dark); }
.lead { font-size: 1.1rem; }
.mt-8 { margin-top: 8px; }
.mt-16 { margin-top: 16px; }
.mt-24 { margin-top: 24px; }
.mt-32 { margin-top: 32px; }
.mb-8 { margin-bottom: 8px; }
.mb-16 { margin-bottom: 16px; }
.mb-32 { margin-bottom: 32px; }

/* ============================================
   DESTINATIONS PAGE
   ============================================ */

.destinations-hero {
  position: relative;
  min-height: 55vh;
  display: flex;
  align-items: flex-end;
  padding-bottom: 60px;
  overflow: hidden;
}
.destinations-hero-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  filter: brightness(0.45);
}
.destinations-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(27,67,50,0.9) 0%, rgba(0,0,0,0.2) 70%);
}
.destinations-hero-content {
  position: relative;
  z-index: 2;
  color: white;
  padding-top: calc(var(--nav-height) + 40px);
}
.destinations-hero-content .breadcrumb { margin-bottom: 16px; }
.destinations-hero-content h1 {
  color: white;
  font-size: clamp(2rem, 4vw, 3rem);
  margin-bottom: 12px;
}
.destinations-hero-content h1 em { color: var(--secondary); font-style: italic; }
.destinations-hero-content .lead { color: rgba(255,255,255,0.85); margin-bottom: 32px; }
.hero-stats {
  display: flex;
  gap: 32px;
  flex-wrap: wrap;
}
.stat { display: flex; flex-direction: column; }
.stat-num {
  font-family: var(--font-serif);
  font-size: 2rem;
  font-weight: 700;
  color: var(--secondary);
  line-height: 1;
}
.stat-label { font-size: 0.78rem; color: rgba(255,255,255,0.7); font-weight: 500; margin-top: 4px; }

.regions-section { background: var(--bg); }
.regions-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
@media (max-width: 900px) { .regions-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .regions-grid { grid-template-columns: 1fr; } }

.region-card {
  background: white;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow);
  transition: transform 0.3s, box-shadow 0.3s;
}
.region-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }
.region-card-link { display: flex; flex-direction: column; height: 100%; }
.region-card-img {
  position: relative;
  overflow: hidden;
}
.region-card-img img {
  width: 100%;
  height: 200px;
  object-fit: cover;
  transition: transform 0.5s;
}
.region-card:hover .region-card-img img { transform: scale(1.05); }
.region-tag {
  position: absolute;
  top: 12px; right: 12px;
  background: var(--secondary);
  color: var(--text);
  padding: 4px 12px;
  border-radius: 100px;
  font-size: 0.72rem;
  font-weight: 700;
}
.region-card-body {
  padding: 20px 22px 22px;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.region-card-body h3 {
  font-size: 1.05rem;
  margin-bottom: 8px;
  color: var(--text);
}
.region-card-body p {
  font-size: 0.85rem;
  color: var(--text-light);
  flex: 1;
  margin-bottom: 14px;
}
.region-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.8rem;
}
.region-dept-count {
  display: flex;
  align-items: center;
  gap: 5px;
  color: var(--text-muted);
}
.region-dept-count svg { stroke: var(--primary); flex-shrink: 0; }
.region-cta { color: var(--primary); font-weight: 600; transition: color 0.2s; }
.region-card:hover .region-cta { color: var(--primary-dark); }

.travel-tips-section { background: white; }
.tips-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}
@media (max-width: 768px) { .tips-grid { grid-template-columns: 1fr; } }
.tips-content h2 { margin-bottom: 12px; }
.tips-content > p { margin-bottom: 32px; }
.tips-list { display: flex; flex-direction: column; gap: 20px; }
.tip-item {
  display: flex;
  gap: 16px;
  align-items: flex-start;
}
.tip-icon { font-size: 1.8rem; flex-shrink: 0; line-height: 1; }
.tip-item strong { display: block; color: var(--text); font-size: 0.95rem; margin-bottom: 4px; }
.tip-item p { font-size: 0.88rem; margin: 0; }
.tips-image img {
  width: 100%;
  height: 400px;
  object-fit: cover;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
}

/* ============================================
   REGION PAGE
   ============================================ */

.region-hero {
  position: relative;
  min-height: 60vh;
  display: flex;
  align-items: flex-end;
  padding-bottom: 60px;
  overflow: hidden;
}
.region-hero-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  filter: brightness(0.4);
}
.region-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(27,67,50,0.92) 0%, rgba(0,0,0,0.1) 70%);
}
.region-hero-content {
  position: relative;
  z-index: 2;
  color: white;
  padding-top: calc(var(--nav-height) + 40px);
}
.region-hero-emoji { font-size: 3rem; margin-bottom: 12px; display: block; }
.region-hero-content h1 { color: white; margin-bottom: 16px; }
.region-hero-content .lead {
  color: rgba(255,255,255,0.85);
  max-width: 680px;
  margin-bottom: 32px;
  font-size: 1.05rem;
}
.region-hero-stats {
  display: flex;
  gap: 40px;
  flex-wrap: wrap;
}
.region-hero-stats .stat-label { color: rgba(255,255,255,0.65); }

.region-body-container {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 24px;
}
.region-body-grid {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 48px;
  padding: 56px 0;
  align-items: start;
}
@media (max-width: 960px) {
  .region-body-grid { grid-template-columns: 1fr; gap: 32px; }
}
.region-body-sidebar {
  display: flex;
  flex-direction: column;
  gap: 20px;
  position: sticky;
  top: calc(var(--nav-height) + 24px);
}

.weather-region-label {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--primary);
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--border);
}
.weather-region-label i { width: 16px; height: 16px; }

.must-see-section { background: white; }
.must-see-section h2 { margin-bottom: 32px; }
.must-see-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 16px;
}
@media (max-width: 900px) { .must-see-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 560px) { .must-see-grid { grid-template-columns: repeat(2, 1fr); } }
.must-see-item {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 20px 16px;
  text-align: center;
  transition: border-color 0.2s, transform 0.2s;
}
.must-see-item:hover { border-color: var(--primary); transform: translateY(-2px); }
.must-see-num {
  display: block;
  font-family: var(--font-serif);
  font-size: 1.8rem;
  font-weight: 700;
  color: var(--primary);
  opacity: 0.3;
  line-height: 1;
  margin-bottom: 8px;
}
.must-see-name {
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--text);
}

.depts-section { background: var(--bg); }
.depts-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}
@media (max-width: 768px) { .depts-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 400px) { .depts-grid { grid-template-columns: 1fr; } }
.dept-card {
  display: flex;
  align-items: center;
  gap: 14px;
  background: white;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 14px 16px;
  transition: all 0.2s;
}
.dept-card:hover {
  border-color: var(--primary);
  background: rgba(45,106,79,0.04);
  transform: translateX(4px);
}
.dept-code {
  width: 44px;
  height: 44px;
  background: var(--primary);
  color: white;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.78rem;
  font-weight: 700;
  flex-shrink: 0;
  letter-spacing: 0.02em;
}
.dept-info { display: flex; flex-direction: column; flex: 1; min-width: 0; }
.dept-info strong { font-size: 0.88rem; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.dept-info span { font-size: 0.75rem; color: var(--primary); font-weight: 500; }

.cities-preview-section { background: white; }
.cities-cloud {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.city-tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 100px;
  padding: 6px 14px;
  font-size: 0.83rem;
  color: var(--text);
  transition: all 0.2s;
}
.city-tag:hover { border-color: var(--primary); color: var(--primary); }
.city-tag small { font-size: 0.72rem; color: var(--text-muted); }

.other-regions { background: var(--bg); }
.other-regions h2 { margin-bottom: 24px; }
.regions-nav-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.region-nav-link {
  background: white;
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 8px 18px;
  font-size: 0.88rem;
  color: var(--text);
  transition: all 0.2s;
}
.region-nav-link:hover {
  background: var(--primary);
  color: white;
  border-color: var(--primary);
}

/* ============================================
   DEPARTMENT PAGE
   ============================================ */

.dept-hero {
  background: linear-gradient(135deg, var(--primary-dark) 0%, var(--primary) 100%);
  padding: calc(var(--nav-height) + 48px) 0 48px;
  color: white;
}
.dept-hero .breadcrumb { margin-bottom: 32px; }
.dept-hero-inner {
  display: flex;
  align-items: flex-start;
  gap: 32px;
}
@media (max-width: 600px) { .dept-hero-inner { flex-direction: column; gap: 20px; } }
.dept-code-badge {
  width: 80px;
  height: 80px;
  background: rgba(255,255,255,0.15);
  border: 2px solid rgba(255,255,255,0.3);
  border-radius: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.3rem;
  font-weight: 700;
  color: white;
  flex-shrink: 0;
  backdrop-filter: blur(8px);
}
.dept-hero-text h1 { color: white; font-size: clamp(1.8rem, 3vw, 2.6rem); margin-bottom: 8px; }
.dept-region-link {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.9rem;
  color: rgba(255,255,255,0.75);
  margin-bottom: 24px;
}
.dept-region-link a { color: var(--secondary); }
.dept-region-link svg { stroke: var(--secondary); flex-shrink: 0; }
.dept-stats-row {
  display: flex;
  gap: 32px;
  flex-wrap: wrap;
}
.dept-stat { display: flex; flex-direction: column; }
.dept-stat strong { font-size: 1.8rem; font-family: var(--font-serif); color: var(--secondary); line-height: 1; }
.dept-stat span { font-size: 0.78rem; color: rgba(255,255,255,0.65); margin-top: 4px; }

.cities-section { background: var(--bg); }
.cities-filter { margin-bottom: 24px; }
.city-search-input {
  width: 100%;
  max-width: 400px;
  padding: 12px 20px;
  border: 2px solid var(--border);
  border-radius: 10px;
  font-size: 0.95rem;
  font-family: inherit;
  outline: none;
  background: white;
  transition: border-color 0.2s;
}
.city-search-input:focus { border-color: var(--primary); }

.cities-table-wrap {
  background: white;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow);
}
.cities-table {
  width: 100%;
  border-collapse: collapse;
}
.cities-table thead tr {
  background: var(--primary);
}
.cities-table th {
  padding: 14px 20px;
  text-align: left;
  font-size: 0.78rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: rgba(255,255,255,0.85);
}
.cities-table tbody tr {
  border-bottom: 1px solid var(--border);
  transition: background 0.15s;
}
.cities-table tbody tr:last-child { border-bottom: none; }
.cities-table tbody tr:hover { background: rgba(45,106,79,0.04); }
.cities-table td { padding: 12px 20px; }
.city-name { font-weight: 500; color: var(--text); font-size: 0.92rem; }
.zip-badge {
  background: rgba(45,106,79,0.08);
  color: var(--primary);
  padding: 3px 10px;
  border-radius: 100px;
  font-size: 0.8rem;
  font-weight: 600;
}
.city-link-btn {
  display: inline-block;
  padding: 4px 14px;
  background: var(--primary);
  color: white;
  border-radius: 6px;
  font-size: 0.78rem;
  font-weight: 600;
  transition: background 0.2s;
}
.city-link-btn:hover { background: var(--primary-dark); }

.pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin-top: 32px;
  flex-wrap: wrap;
}
.page-numbers { display: flex; gap: 6px; }
.page-btn {
  padding: 8px 16px;
  border: 1px solid var(--border);
  border-radius: 8px;
  font-size: 0.85rem;
  color: var(--text);
  background: white;
  transition: all 0.2s;
}
.page-btn:hover, .page-btn.active {
  background: var(--primary);
  color: white;
  border-color: var(--primary);
}

.siblings-section { background: white; }
.siblings-section h2 { margin-bottom: 24px; }
.siblings-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 12px;
  margin-bottom: 0;
}
@media (max-width: 768px) { .siblings-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 420px) { .siblings-grid { grid-template-columns: repeat(2, 1fr); } }
.sibling-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 16px 12px;
  text-align: center;
  transition: all 0.2s;
}
.sibling-card:hover {
  border-color: var(--primary);
  background: rgba(45,106,79,0.04);
  transform: translateY(-2px);
}
.sibling-code {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--primary);
}
.sibling-name {
  font-size: 0.78rem;
  color: var(--text-light);
}

/* ============================================
   CITY PAGE
   ============================================ */

.city-hero {
  position: relative;
  min-height: 60vh;
  display: flex;
  align-items: flex-end;
  background-size: cover;
  background-position: center;
  overflow: hidden;
}
.city-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(27,67,50,0.95) 0%, rgba(0,0,0,0.15) 70%);
  z-index: 1;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: calc(var(--nav-height) + 20px) 0 56px;
  width: 100%;
}
.city-hero-overlay > * {
  position: relative;
  z-index: 2;
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 24px;
  width: 100%;
}
.breadcrumb-nav { margin-bottom: 20px; }

.city-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(255,183,3,0.2);
  border: 1px solid rgba(255,183,3,0.4);
  color: var(--secondary);
  padding: 6px 16px;
  border-radius: 100px;
  font-size: 0.85rem;
  font-weight: 600;
  margin-bottom: 16px;
}
.city-badge i { width: 14px; height: 14px; }
.city-hero-content h1 {
  color: white;
  font-size: clamp(2.2rem, 5vw, 3.8rem);
  margin-bottom: 12px;
  line-height: 1.1;
}
.city-hero-sub {
  color: rgba(255,255,255,0.8) !important;
  font-size: 1.05rem;
  margin-bottom: 24px;
}
.city-hero-tags {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.city-hero-tags .tag {
  background: rgba(255,255,255,0.12);
  color: white;
  border: 1px solid rgba(255,255,255,0.2);
  backdrop-filter: blur(8px);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.82rem;
}
.city-hero-tags .tag i { width: 12px; height: 12px; }
.city-hero-tags .tag-gold {
  background: rgba(255,183,3,0.2) !important;
  color: var(--secondary) !important;
  border-color: rgba(255,183,3,0.4) !important;
}

.city-container {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 24px;
}
.city-grid {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 48px;
  padding: 56px 0;
  align-items: start;
}
@media (max-width: 900px) {
  .city-grid { grid-template-columns: 1fr; gap: 32px; }
}

.city-section {
  margin-bottom: 48px;
}
.city-section h2 {
  font-size: clamp(1.4rem, 2.5vw, 1.9rem);
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 2px solid var(--border);
}
.city-intro-text {
  font-size: 1.05rem;
  line-height: 1.8;
  margin-bottom: 16px;
}

.city-tip-box {
  display: flex;
  gap: 16px;
  background: rgba(45,106,79,0.06);
  border: 1px solid rgba(45,106,79,0.2);
  border-left: 4px solid var(--primary);
  border-radius: var(--radius);
  padding: 20px 24px;
  margin-bottom: 48px;
  align-items: flex-start;
}
.tip-icon {
  width: 40px;
  height: 40px;
  background: var(--primary);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.tip-icon i { color: white; width: 20px; height: 20px; }
.city-tip-box strong {
  display: block;
  font-size: 0.85rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--primary);
  margin-bottom: 6px;
}
.city-tip-box p { font-size: 0.92rem; margin: 0; }

.activity-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
@media (max-width: 600px) { .activity-grid { grid-template-columns: 1fr; } }
.activity-card {
  background: white;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 24px;
  transition: transform 0.2s, box-shadow 0.2s;
}
.activity-card:hover { transform: translateY(-3px); box-shadow: var(--shadow); }
.activity-icon {
  width: 48px;
  height: 48px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 14px;
}
.activity-icon i { width: 22px; height: 22px; }
.activity-card h3 {
  font-size: 1rem;
  margin-bottom: 8px;
}
.activity-card p { font-size: 0.85rem; margin: 0; }

.info-table {
  background: white;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
}
.info-row {
  display: flex;
  align-items: center;
  padding: 14px 20px;
  border-bottom: 1px solid var(--border);
  gap: 16px;
}
.info-row:last-child { border-bottom: none; }
.info-label {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.85rem;
  color: var(--text-muted);
  font-weight: 500;
  min-width: 150px;
  flex-shrink: 0;
}
.info-label i { width: 16px; height: 16px; color: var(--primary); }
.info-value {
  font-size: 0.92rem;
  color: var(--text);
}
.info-value a { color: var(--primary); font-weight: 500; }
.info-value a:hover { text-decoration: underline; }

.seasons-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}
@media (max-width: 700px) { .seasons-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 380px) { .seasons-grid { grid-template-columns: 1fr; } }
.season-card {
  background: white;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 20px 16px;
  text-align: center;
}
.season-emoji { font-size: 2rem; display: block; margin-bottom: 10px; }
.season-card h3 { font-size: 0.95rem; margin-bottom: 8px; }
.season-card p { font-size: 0.8rem; margin-bottom: 12px; }
.season-rating {
  display: inline-block;
  padding: 3px 12px;
  border-radius: 100px;
  font-size: 0.72rem;
  font-weight: 700;
}
.rating-great { background: #e8f5e9; color: #2e7d32; }
.rating-good  { background: #fff8e1; color: #e65100; }
.rating-ok    { background: #f3e5f5; color: #7b1fa2; }

.faq-list { display: flex; flex-direction: column; gap: 8px; }
.faq-item {
  background: white;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  transition: border-color 0.2s;
}
.faq-item summary {
  padding: 16px 20px;
  font-size: 0.92rem;
  font-weight: 600;
  color: var(--text);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  list-style: none;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item[open] { border-color: var(--primary); }
.faq-item[open] summary { color: var(--primary); background: rgba(45,106,79,0.04); }
.faq-item p { padding: 0 20px 16px; font-size: 0.88rem; line-height: 1.7; }

/* ── SIDEBAR (city & article) ── */
.city-sidebar,
.article-sidebar {
  display: flex;
  flex-direction: column;
  gap: 20px;
  position: sticky;
  top: calc(var(--nav-height) + 24px);
}
.sidebar-card {
  background: white;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 24px;
  box-shadow: var(--shadow);
}
.sidebar-sticky { }
.sidebar-card--weather {
  padding: 0;
  overflow: hidden;
  border: none;
}
.sidebar-title {
  font-size: 0.85rem !important;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-muted);
  margin-bottom: 16px !important;
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-sans) !important;
}
.sidebar-title i { width: 16px; height: 16px; color: var(--primary); }

.quick-info-list { display: flex; flex-direction: column; gap: 12px; }
.quick-info-list li {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.88rem;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--border);
}
.quick-info-list li:last-child { border-bottom: none; padding-bottom: 0; }
.qi-label { color: var(--text-muted); }
.qi-value { font-weight: 600; color: var(--text); }

.parent-links { display: flex; flex-direction: column; gap: 8px; }
.parent-link {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  transition: all 0.2s;
}
.parent-link:hover {
  border-color: var(--primary);
  background: rgba(45,106,79,0.04);
  transform: translateX(4px);
}
.parent-link > i:first-child { width: 18px; height: 18px; color: var(--primary); flex-shrink: 0; }
.parent-link div {
  flex: 1;
  display: flex;
  flex-direction: column;
}
.pl-label { font-size: 0.72rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.04em; }
.pl-name { font-size: 0.88rem; font-weight: 600; color: var(--text); }
.pl-arrow { width: 16px; height: 16px; color: var(--text-muted); flex-shrink: 0; }

.nearby-list { display: flex; flex-direction: column; gap: 4px; margin-bottom: 16px; }
.nearby-list li a {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 8px;
  font-size: 0.85rem;
  transition: background 0.2s;
}
.nearby-list li a:hover { background: var(--bg); }
.nearby-list li a i { width: 14px; height: 14px; color: var(--primary); flex-shrink: 0; }
.nearby-list li a span { flex: 1; color: var(--text); font-weight: 500; }
.nearby-list li a small { font-size: 0.75rem; color: var(--text-muted); }
.btn-see-more {
  display: block;
  text-align: center;
  padding: 10px;
  background: var(--bg);
  border-radius: var(--radius);
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--primary);
  transition: background 0.2s;
}
.btn-see-more:hover { background: rgba(45,106,79,0.1); }

.sidebar-cta {
  background: linear-gradient(135deg, var(--primary-dark), var(--primary));
  border-radius: var(--radius-lg);
  padding: 28px 24px;
  text-align: center;
  color: white;
}
.cta-icon { font-size: 2rem; margin-bottom: 12px; }
.sidebar-cta h3 { color: white; font-size: 1rem; margin-bottom: 8px; }
.sidebar-cta p { color: rgba(255,255,255,0.75); font-size: 0.85rem; margin-bottom: 16px; }
.btn-cta-sidebar {
  display: inline-block;
  background: var(--secondary);
  color: var(--text);
  padding: 10px 20px;
  border-radius: 8px;
  font-size: 0.88rem;
  font-weight: 700;
  transition: background 0.2s, transform 0.2s;
}
.btn-cta-sidebar:hover { background: var(--secondary-dark); transform: translateY(-2px); }

.dept-cities-section {
  padding: 56px 0;
  border-top: 1px solid var(--border);
}
.dept-cities-section h2 { margin-bottom: 8px; font-size: clamp(1.3rem, 2vw, 1.7rem); }
.dept-cities-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 32px;
}
.dept-city-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  background: white;
  border: 1px solid var(--border);
  border-radius: 100px;
  font-size: 0.85rem;
  color: var(--text);
  transition: all 0.2s;
}
.dept-city-pill:hover {
  border-color: var(--primary);
  color: var(--primary);
  background: rgba(45,106,79,0.04);
  transform: translateY(-2px);
}
.dept-city-pill i { width: 12px; height: 12px; color: var(--primary); }
.dept-city-pill span { font-weight: 500; }
.dept-city-pill small { font-size: 0.75rem; color: var(--text-muted); }
.see-all-dept { text-align: center; }

/* ============================================
   WIDGET MÉTÉO — Open-Meteo
   ============================================ */

.weather-widget {
  background: white;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow);
  font-family: var(--font-sans);
}

.weather-unavailable {
  padding: 32px 24px;
  text-align: center;
  border: 1px solid var(--border);
}
.weather-unavail-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}
.weather-unavail-icon { font-size: 2rem; }
.weather-unavailable p { font-size: 0.85rem; color: var(--text-muted); }

.weather-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 18px 12px;
  background: linear-gradient(135deg, var(--primary-dark), var(--primary));
  flex-wrap: wrap;
  gap: 6px;
}
.weather-title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: white;
}
.weather-title svg { stroke: rgba(255,255,255,0.8); flex-shrink: 0; }
.weather-updated {
  font-size: 0.7rem;
  color: rgba(255,255,255,0.6);
}

.weather-current {
  padding: 20px 18px;
  border-bottom: 1px solid var(--border);
}
.weather-main {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 16px;
}
.weather-icon-big { font-size: 3rem; line-height: 1; }
.weather-temp-block { display: flex; flex-direction: column; }
.weather-temp {
  font-family: var(--font-serif);
  font-size: 2.6rem;
  font-weight: 700;
  color: var(--text);
  line-height: 1;
}
.weather-label {
  font-size: 0.85rem;
  color: var(--text-muted);
  margin-top: 4px;
}

.weather-details {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px 12px;
}
.weather-detail {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.78rem;
  color: var(--text-light);
}
.wd-icon { font-size: 0.85rem; flex-shrink: 0; }
.weather-detail strong { color: var(--text); font-weight: 600; }

.weather-forecast {
  padding: 16px 18px 18px;
}
.weather-forecast-title {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-muted);
  margin-bottom: 12px;
}
.weather-days {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
}
@media (max-width: 400px) {
  .weather-days { grid-template-columns: repeat(4, 1fr); }
}
.weather-day {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3px;
  padding: 8px 4px;
  border-radius: 8px;
  background: var(--bg);
  border: 1px solid transparent;
  transition: border-color 0.2s;
  text-align: center;
}
.weather-day:hover { border-color: var(--primary); }
.weather-day--today {
  background: rgba(45,106,79,0.08);
  border-color: rgba(45,106,79,0.3);
}
.wd-name {
  font-size: 0.62rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--text-muted);
}
.wd-date { font-size: 0.6rem; color: var(--text-muted); }
.wd-ico { font-size: 1.2rem; line-height: 1; }
.wd-max { font-size: 0.75rem; font-weight: 700; color: var(--text); }
.wd-min { font-size: 0.7rem; color: var(--text-muted); }
.wd-rain { font-size: 0.6rem; color: #1565C0; font-weight: 500; }

.weather-tip {
  padding: 14px 18px;
  background: rgba(45,106,79,0.04);
  border-top: 1px solid var(--border);
  font-size: 0.8rem;
  color: var(--text-light);
  line-height: 1.5;
}
.weather-tip strong { color: var(--primary); font-weight: 700; }

/* ============================================
   BUDGET CALCULATEUR
   ============================================ */

.budget-hero {
  position: relative;
  min-height: 52vh;
  display: flex;
  align-items: flex-end;
  padding-bottom: 60px;
  overflow: hidden;
}
.budget-hero__bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  filter: brightness(0.45);
}
.budget-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(27,67,50,0.92) 0%, rgba(0,0,0,0.2) 70%);
}
.budget-hero__content {
  position: relative;
  z-index: 2;
  color: white;
  padding-top: calc(var(--nav-height) + 40px);
}
.budget-hero__badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(255,183,3,0.2);
  border: 1px solid rgba(255,183,3,0.4);
  color: var(--secondary);
  padding: 6px 16px;
  border-radius: 100px;
  font-size: 0.85rem;
  font-weight: 600;
  margin-bottom: 16px;
}
.budget-hero__content h1 { color: white; margin-bottom: 12px; }
.budget-hero__content p { color: rgba(255,255,255,0.85); max-width: 600px; font-size: 1.05rem; margin-bottom: 32px; }
.budget-hero__stats {
  display: flex;
  gap: 40px;
  flex-wrap: wrap;
}
.budget-hero__stat { display: flex; flex-direction: column; }
.budget-hero__stat .stat-number {
  font-family: var(--font-serif);
  font-size: 2rem;
  font-weight: 700;
  color: var(--secondary);
  line-height: 1;
  display: block;
  margin-bottom: 4px;
}
.budget-hero__stat .stat-label { font-size: 0.78rem; color: rgba(255,255,255,0.65); }

.budget-section { padding: 64px 0; background: var(--bg); }
.budget-layout {
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: 32px;
  align-items: start;
}
@media (max-width: 1024px) { .budget-layout { grid-template-columns: 1fr; } }

.budget-form-card {
  background: white;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow);
  overflow: hidden;
}
.budget-form-header {
  background: linear-gradient(135deg, var(--primary-dark), var(--primary));
  padding: 28px 32px;
  color: white;
}
.budget-form-header h2 { color: white; font-size: 1.3rem; margin-bottom: 4px; }
.budget-form-header p { color: rgba(255,255,255,0.75); font-size: 0.88rem; }
.budget-form { padding: 28px 32px; display: flex; flex-direction: column; gap: 28px; }

.form-group { display: flex; flex-direction: column; gap: 10px; }
.form-group label {
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--text);
  display: flex;
  align-items: center;
  gap: 6px;
}
.form-group select {
  padding: 12px 16px;
  border: 2px solid var(--border);
  border-radius: 10px;
  font-size: 0.92rem;
  font-family: inherit;
  color: var(--text);
  background: white;
  outline: none;
  transition: border-color 0.2s;
  cursor: pointer;
}
.form-group select:focus { border-color: var(--primary); }
.region-badge {
  display: inline-block;
  padding: 4px 12px;
  background: rgba(45,106,79,0.08);
  color: var(--primary);
  border-radius: 100px;
  font-size: 0.75rem;
  font-weight: 600;
  margin-top: 4px;
  width: fit-content;
}

.range-wrapper {
  display: flex;
  align-items: center;
  gap: 16px;
}
.range-wrapper input[type="range"] {
  flex: 1;
  height: 6px;
  accent-color: var(--primary);
  cursor: pointer;
}
.range-display {
  min-width: 70px;
  text-align: right;
  font-family: var(--font-serif);
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--primary);
  line-height: 1;
  display: flex;
  align-items: baseline;
  gap: 4px;
}
.range-unit { font-family: var(--font-sans); font-size: 0.8rem; color: var(--text-muted); }
.range-labels {
  display: flex;
  justify-content: space-between;
  font-size: 0.7rem;
  color: var(--text-muted);
}

.counter-group {
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
}
.counter-item {
  display: flex;
  align-items: center;
  gap: 12px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 10px 16px;
  flex: 1;
  min-width: 160px;
}
.counter-label { font-size: 0.88rem; color: var(--text-light); flex: 1; }
.counter-controls { display: flex; align-items: center; gap: 10px; }
.counter-btn {
  width: 32px; height: 32px;
  background: var(--primary);
  color: white;
  border-radius: 8px;
  font-size: 1.2rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  transition: background 0.2s;
}
.counter-btn:hover { background: var(--primary-dark); }
.counter-value {
  font-family: var(--font-serif);
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--text);
  min-width: 24px;
  text-align: center;
}

/* ── Style de voyage ── */
.style-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  width: 100%;
}
@media (max-width: 480px) { .style-grid { grid-template-columns: 1fr; } }

.style-card { display: block; width: 100%; }
.style-card input { display: none; }
.style-card__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 20px 16px;
  border: 2px solid var(--border);
  border-radius: 14px;
  cursor: pointer;
  transition: all 0.25s;
  text-align: center;
  background: var(--bg);
  width: 100%;
  min-height: 130px;
  box-sizing: border-box;
}
.style-card input:checked + .style-card__inner {
  border-color: var(--primary);
  background: rgba(45,106,79,0.07);
  box-shadow: 0 0 0 3px rgba(45,106,79,0.12);
}
.style-card:hover .style-card__inner {
  border-color: var(--primary-light);
  background: rgba(45,106,79,0.04);
  transform: translateY(-2px);
  box-shadow: var(--shadow);
}
.style-icon { font-size: 2rem; line-height: 1; display: block; }
.style-name { font-size: 0.92rem; font-weight: 700; color: var(--text); display: block; }
.style-desc { font-size: 0.75rem; color: var(--text-muted); display: block; line-height: 1.3; }
.style-price { font-size: 0.85rem; font-weight: 700; color: var(--primary); display: block; background: rgba(45,106,79,0.1); padding: 3px 10px; border-radius: 100px; margin-top: 2px; }

/* ── Transport ── */
.transport-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  width: 100%;
}
@media (max-width: 480px) { .transport-grid { grid-template-columns: repeat(2, 1fr); } }

.transport-option { display: block; width: 100%; }
.transport-option input { display: none; }
.transport-option__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 16px 8px;
  border: 2px solid var(--border);
  border-radius: 12px;
  cursor: pointer;
  transition: all 0.25s;
  text-align: center;
  background: var(--bg);
  width: 100%;
  min-height: 90px;
  box-sizing: border-box;
}
.transport-option__inner > span:first-child { font-size: 1.8rem; line-height: 1; display: block; }
.transport-option__inner > span:last-child { font-size: 0.78rem; font-weight: 600; color: var(--text-light); display: block; line-height: 1.2; }
.transport-option input:checked + .transport-option__inner {
  border-color: var(--primary);
  background: rgba(45,106,79,0.07);
  color: var(--primary);
  box-shadow: 0 0 0 3px rgba(45,106,79,0.12);
}
.transport-option input:checked + .transport-option__inner > span:last-child { color: var(--primary); font-weight: 700; }
.transport-option:hover .transport-option__inner { border-color: var(--primary-light); background: rgba(45,106,79,0.04); transform: translateY(-2px); box-shadow: var(--shadow); }

/* ── Activités ── */
.activities-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
}
.activity-check {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  border: 1px solid var(--border);
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.2s;
  font-size: 0.85rem;
  color: var(--text-light);
  background: var(--bg);
}
.activity-check:hover { border-color: var(--primary); color: var(--primary); }
.activity-check input { accent-color: var(--primary); }
.activity-check input:checked ~ span { color: var(--primary); font-weight: 600; }

/* ── Saison ── */
.saison-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  width: 100%;
}
@media (max-width: 380px) { .saison-grid { grid-template-columns: 1fr; } }

.saison-option { display: block; width: 100%; }
.saison-option input { display: none; }
.saison-option__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 5px;
  padding: 20px 12px;
  border: 2px solid var(--border);
  border-radius: 14px;
  cursor: pointer;
  transition: all 0.25s;
  text-align: center;
  background: var(--bg);
  width: 100%;
  min-height: 110px;
  box-sizing: border-box;
}
.saison-option__inner > span:first-child { font-size: 2rem; line-height: 1; display: block; }
.saison-option__inner > span:nth-child(2) { font-size: 0.88rem; font-weight: 700; color: var(--text); display: block; line-height: 1.2; }
.saison-option__inner > small { font-size: 0.72rem; color: var(--text-muted); display: block; line-height: 1.3; }
.saison-option input:checked + .saison-option__inner { border-color: var(--primary); background: rgba(45,106,79,0.07); box-shadow: 0 0 0 3px rgba(45,106,79,0.12); }
.saison-option input:checked + .saison-option__inner > span:nth-child(2) { color: var(--primary); }
.saison-option:hover .saison-option__inner { border-color: var(--primary-light); background: rgba(45,106,79,0.04); transform: translateY(-2px); box-shadow: var(--shadow); }

/* ── Résultats budget ── */
.budget-results { display: flex; flex-direction: column; gap: 20px; position: sticky; top: calc(var(--nav-height) + 24px); }
.budget-total-card { background: linear-gradient(135deg, var(--primary-dark), var(--primary)); border-radius: var(--radius-lg); padding: 28px; color: white; box-shadow: 0 8px 32px rgba(45,106,79,0.35); }
.budget-total-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 16px; flex-wrap: wrap; gap: 8px; }
.budget-total-header h3 { color: white; font-size: 1rem; }
.budget-label { background: rgba(255,183,3,0.2); border: 1px solid rgba(255,183,3,0.4); color: var(--secondary); padding: 4px 12px; border-radius: 100px; font-size: 0.78rem; font-weight: 700; }
.budget-total-amount { display: flex; align-items: baseline; gap: 4px; margin-bottom: 12px; }
.currency { font-family: var(--font-serif); font-size: 1.8rem; color: rgba(255,255,255,0.7); }
.amount { font-family: var(--font-serif); font-size: 3.5rem; font-weight: 700; color: white; line-height: 1; }
.budget-range { font-size: 0.82rem; color: rgba(255,255,255,0.7); margin-bottom: 8px; }
.budget-range strong { color: white; }
.budget-per-day { font-size: 0.85rem; color: rgba(255,255,255,0.75); padding-top: 12px; border-top: 1px solid rgba(255,255,255,0.15); }
.budget-per-day strong { color: var(--secondary); }
.budget-season-alert { display: none; margin-top: 12px; padding: 8px 14px; background: rgba(255,255,255,0.1); border-radius: 8px; font-size: 0.82rem; color: white; }
.budget-breakdown-card, .budget-tips-card { background: white; border-radius: var(--radius-lg); padding: 24px; box-shadow: var(--shadow); }
.budget-breakdown-card h3, .budget-tips-card h3 { font-size: 1rem; margin-bottom: 16px; color: var(--text); }
.breakdown-item { margin-bottom: 14px; }
.breakdown-item:last-child { margin-bottom: 0; }
.breakdown-item-info { display: flex; justify-content: space-between; align-items: center; margin-bottom: 6px; }
.breakdown-label { font-size: 0.85rem; color: var(--text); font-weight: 500; }
.breakdown-amount { font-size: 0.85rem; font-weight: 700; color: var(--primary); }
.breakdown-bar-wrap { display: flex; align-items: center; gap: 8px; }
.breakdown-bar { height: 6px; background: linear-gradient(90deg, var(--primary), var(--primary-light)); border-radius: 100px; transition: width 0.5s ease; min-width: 4px; }
.breakdown-percent { font-size: 0.72rem; color: var(--text-muted); min-width: 30px; }
.tips-list { padding-left: 0; display: flex; flex-direction: column; gap: 10px; }
.tips-list li { padding: 10px 14px; background: rgba(45,106,79,0.05); border-left: 3px solid var(--primary); border-radius: 0 8px 8px 0; font-size: 0.85rem; color: var(--text-light); line-height: 1.5; }
.budget-cta-card { display: flex; gap: 12px; flex-wrap: wrap; }
.btn-print, .btn-reset { flex: 1; padding: 12px 16px; border-radius: 10px; font-size: 0.88rem; font-weight: 600; transition: all 0.2s; text-align: center; }
.btn-print { background: var(--primary); color: white; box-shadow: 0 4px 12px rgba(45,106,79,0.25); }
.btn-print:hover { background: var(--primary-dark); }
.btn-reset { background: white; color: var(--text); border: 2px solid var(--border); }
.btn-reset:hover { border-color: var(--primary); color: var(--primary); }

.budget-info-section { padding: 80px 0; background: white; }
.budget-info-section .section-title { text-align: center; margin-bottom: 8px; }
.budget-info-section .section-subtitle { text-align: center; margin-bottom: 48px; }
.budget-info-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
@media (max-width: 1024px) { .budget-info-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .budget-info-grid { grid-template-columns: 1fr; } }
.budget-info-card { border-radius: var(--radius-lg); overflow: hidden; border: 1px solid var(--border); display: flex; flex-direction: column; }
.info-card-header { padding: 24px 20px 16px; text-align: center; }
.info-icon { font-size: 2rem; display: block; margin-bottom: 8px; }
.info-card-header h3 { font-size: 1rem; margin-bottom: 6px; }
.info-range { display: inline-block; padding: 4px 12px; border-radius: 100px; font-size: 0.78rem; font-weight: 700; }
.budget-info-card.econome .info-card-header { background: #e8f5e9; }
.budget-info-card.econome .info-range { background: #c8e6c9; color: #2e7d32; }
.budget-info-card.confort .info-card-header { background: #fff8e1; }
.budget-info-card.confort .info-range { background: #ffecb3; color: #e65100; }
.budget-info-card.premium .info-card-header { background: #e3f2fd; }
.budget-info-card.premium .info-range { background: #bbdefb; color: #1565c0; }
.budget-info-card.luxe .info-card-header { background: #fce4ec; }
.budget-info-card.luxe .info-range { background: #f8bbd9; color: #880e4f; }
.budget-info-card ul { padding: 16px 20px; display: flex; flex-direction: column; gap: 8px; flex: 1; }
.budget-info-card ul li { font-size: 0.82rem; color: var(--text-light); display: flex; align-items: flex-start; gap: 6px; }
.info-tip { padding: 12px 20px 16px; font-size: 0.78rem; color: var(--primary); font-weight: 500; border-top: 1px solid var(--border); background: rgba(45,106,79,0.03); }

.budget-faq-section { padding: 80px 0; background: var(--bg); }
.budget-faq-section .section-title { text-align: center; margin-bottom: 40px; }

.budget-cta-section { padding: 80px 0; background: white; }
.budget-cta-banner { display: flex; align-items: center; gap: 48px; background: linear-gradient(135deg, var(--primary-dark), var(--primary)); border-radius: var(--radius-lg); padding: 48px; overflow: hidden; }
@media (max-width: 768px) { .budget-cta-banner { flex-direction: column; gap: 24px; padding: 32px 24px; } .budget-cta-banner img { width: 100%; height: 200px; object-fit: cover; border-radius: var(--radius); } }
.cta-banner-content { flex: 1; }
.cta-banner-content h2 { color: white; margin-bottom: 12px; }
.cta-banner-content p { color: rgba(255,255,255,0.8); margin-bottom: 24px; }
.cta-banner-btns { display: flex; gap: 12px; flex-wrap: wrap; }
.budget-cta-banner img { width: 360px; height: 240px; object-fit: cover; border-radius: var(--radius); flex-shrink: 0; opacity: 0.85; }

@media print {
  .nav, .budget-form-card, .budget-cta-card, .budget-info-section, .budget-faq-section, .budget-cta-section, .footer { display: none !important; }
  .budget-results { position: static !important; }
  .budget-layout { grid-template-columns: 1fr !important; }
}

/* ============================================
   ARTICLE PAGE — article.php
   ============================================ */

/* ── Hero ── */
.article-hero {
  position: relative;
  min-height: 70vh;
  background-size: cover;
  background-position: center;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
}
.article-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(10,30,20,0.97) 0%, rgba(0,0,0,0.3) 55%, transparent 100%);
  display: flex;
  align-items: flex-end;
  width: 100%;
  padding-bottom: 56px;
}
.article-hero-overlay .container { padding-top: calc(var(--nav-height) + 40px); }
.article-breadcrumb {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.8rem;
  color: rgba(255,255,255,0.6);
  flex-wrap: wrap;
  margin-bottom: 16px;
}
.article-breadcrumb a { color: rgba(255,255,255,0.8); transition: color 0.2s; }
.article-breadcrumb a:hover { color: var(--secondary); }
.article-breadcrumb span { color: rgba(255,255,255,0.35); }
.article-hero-tag {
  display: inline-block;
  background: var(--secondary);
  color: var(--text);
  padding: 5px 16px;
  border-radius: 100px;
  font-size: 0.78rem;
  font-weight: 700;
  margin-bottom: 14px;
}
.article-hero-title {
  color: white;
  font-size: clamp(1.8rem, 4vw, 3rem);
  line-height: 1.2;
  margin-bottom: 20px;
  max-width: 820px;
  text-shadow: 0 2px 20px rgba(0,0,0,0.4);
}
.article-hero-meta {
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
}
.article-hero-meta span {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.85rem;
  color: rgba(255,255,255,0.75);
}
.article-hero-meta svg { flex-shrink: 0; stroke: rgba(255,255,255,0.5); }
.article-hero-author { color: white !important; font-weight: 600; }

/* ── Layout ── */
.article-layout {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 48px;
  padding: 56px 24px;
  max-width: var(--max-width);
  margin: 0 auto;
  align-items: start;
}
@media (max-width: 960px) {
  .article-layout { grid-template-columns: 1fr; gap: 32px; }
  .article-sidebar { position: static; }
}

/* ── Contenu ── */
.article-chapeau {
  font-family: var(--font-serif);
  font-size: clamp(1.05rem, 2vw, 1.25rem);
  color: var(--text);
  line-height: 1.75;
  margin-bottom: 40px;
  padding-bottom: 32px;
  border-bottom: 2px solid var(--border);
  font-style: italic;
}
.article-section {
  margin-bottom: 48px;
}
.article-section-title {
  font-size: clamp(1.3rem, 2.5vw, 1.7rem);
  margin-bottom: 16px;
  color: var(--text);
  padding-bottom: 10px;
  border-bottom: 2px solid var(--border);
}
.article-section-text {
  font-size: 1rem;
  line-height: 1.85;
  color: var(--text-light);
  margin-bottom: 16px;
}
.article-conseil {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  background: rgba(255,183,3,0.06);
  border: 1px solid rgba(255,183,3,0.25);
  border-left: 4px solid var(--secondary);
  border-radius: var(--radius);
  padding: 16px 20px;
  margin-top: 16px;
}
.article-conseil-icon { font-size: 1.3rem; flex-shrink: 0; line-height: 1.4; }
.article-conseil p {
  font-size: 0.9rem;
  color: var(--text-light);
  margin: 0;
  line-height: 1.6;
}
.article-conseil p strong { color: var(--text); }

/* ── Infos pratiques ── */
.article-infos {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 32px;
  margin-bottom: 48px;
}
.article-infos-title {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 1.3rem;
  margin-bottom: 24px;
  padding-bottom: 16px;
  border-bottom: 2px solid var(--border);
}
.article-infos-title svg { stroke: var(--primary); flex-shrink: 0; }
.article-infos-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-bottom: 24px;
}
@media (max-width: 560px) { .article-infos-grid { grid-template-columns: 1fr; } }
.article-info-item {
  display: flex;
  gap: 14px;
  align-items: flex-start;
}
.article-info-icon { font-size: 1.5rem; flex-shrink: 0; line-height: 1.2; }
.article-info-item strong { display: block; font-size: 0.85rem; color: var(--text); font-weight: 700; margin-bottom: 4px; }
.article-info-item p { font-size: 0.85rem; color: var(--text-light); margin: 0; line-height: 1.5; }
.article-infos-cta {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  padding-top: 16px;
  border-top: 1px solid var(--border);
}
.article-infos-cta .btn { padding: 10px 20px; font-size: 0.88rem; }
.article-infos-cta .btn-outline {
  background: transparent;
  color: var(--primary);
  border: 2px solid var(--primary);
}
.article-infos-cta .btn-outline:hover {
  background: var(--primary);
  color: white;
  transform: translateY(-2px);
}

/* ── FAQ ── */
.article-faq { margin-bottom: 48px; }
.article-faq-title { font-size: clamp(1.3rem, 2vw, 1.7rem); margin-bottom: 20px; }

/* ── Share ── */
.article-share {
  background: white;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 28px;
  text-align: center;
  margin-bottom: 48px;
}
.article-share p { font-size: 1rem; color: var(--text); font-weight: 600; margin-bottom: 16px; }
.share-buttons {
  display: flex;
  gap: 10px;
  justify-content: center;
  flex-wrap: wrap;
}
.share-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 20px;
  border-radius: 8px;
  font-size: 0.85rem;
  font-weight: 600;
  transition: all 0.2s;
  cursor: pointer;
  border: none;
}
.share-fb { background: #1877f2; color: white; }
.share-fb:hover { background: #166fe5; transform: translateY(-2px); }
.share-tw { background: #1da1f2; color: white; }
.share-tw:hover { background: #1a91da; transform: translateY(-2px); }
.share-copy { background: var(--bg); color: var(--text); border: 1px solid var(--border); }
.share-copy:hover { border-color: var(--primary); color: var(--primary); transform: translateY(-2px); }

/* ── Sidebar article ── */
.sidebar-card h3 {
  font-size: 1rem;
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-color: rgba(255,255,255,0.2);
  color: var(--text);
}
.sidebar-card h4 {
  font-size: 0.82rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-muted);
  margin: 16px 0 10px;
}
.sidebar-quick-list { display: flex; flex-direction: column; gap: 10px; }
.sidebar-quick-list li {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 0.88rem;
  color: var(--text-light);
}
.sq-icon { font-size: 1rem; flex-shrink: 0; }
.sidebar-sommaire { display: flex; flex-direction: column; gap: 4px; padding-left: 0; counter-reset: sommaire; }
.sidebar-sommaire li { counter-increment: sommaire; }
.sidebar-sommaire li a {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 6px 8px;
  border-radius: 6px;
  font-size: 0.82rem;
  color: var(--text-light);
  transition: all 0.15s;
  line-height: 1.4;
}
.sidebar-sommaire li a::before {
  content: counter(sommaire);
  min-width: 20px;
  height: 20px;
  background: var(--primary);
  color: white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.65rem;
  font-weight: 700;
  flex-shrink: 0;
  margin-top: 1px;
}
.sidebar-sommaire li a:hover { background: var(--bg); color: var(--primary); }

/* ============================================
   NEWSLETTER SIDEBAR — article.php (fix)
   ============================================ */

.sidebar-newsletter {
  background: linear-gradient(135deg, var(--primary-dark), var(--primary)) !important;
  border: none !important;
  text-align: center;
  padding: 22px 20px !important;
}

.sidebar-nl-icon {
  width: 44px;
  height: 44px;
  background: rgba(255,255,255,0.15);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 12px;
}
.sidebar-nl-icon svg { stroke: white; }

.sidebar-newsletter h3 {
  color: white !important;
  font-size: 0.95rem !important;
  margin-bottom: 8px !important;
  padding-bottom: 0 !important;
  border-bottom: none !important;
}

.sidebar-newsletter p {
  color: rgba(255,255,255,0.75);
  font-size: 0.82rem;
  margin-bottom: 14px;
  line-height: 1.5;
}

.sidebar-nl-form {
  display: flex;
  flex-direction: column;
  gap: 8px;
  width: 100%;
}

.sidebar-nl-form input {
  width: 100%;
  padding: 9px 12px;
  border: 1px solid rgba(255,255,255,0.3);
  border-radius: 8px;
  background: rgba(255,255,255,0.12);
  color: white;
  font-size: 0.82rem;
  font-family: inherit;
  outline: none;
  transition: border-color 0.2s;
  box-sizing: border-box;
}
.sidebar-nl-form input::placeholder { color: rgba(255,255,255,0.5); }
.sidebar-nl-form input:focus { border-color: rgba(255,255,255,0.7); background: rgba(255,255,255,0.18); }

.sidebar-nl-form button {
  width: 100%;
  padding: 10px 16px;
  background: var(--secondary);
  color: var(--text);
  border: none;
  border-radius: 8px;
  font-size: 0.85rem;
  font-weight: 700;
  font-family: inherit;
  cursor: pointer;
  transition: background 0.2s, transform 0.2s;
  box-sizing: border-box;
}
.sidebar-nl-form button:hover {
  background: var(--secondary-dark);
  transform: translateY(-1px);
}

.sidebar-nl-note {
  display: block;
  font-size: 0.72rem;
  color: rgba(255,255,255,0.5);
  margin-top: 8px;
}

/* ── Articles connexes ── */
.related-articles {
  background: var(--bg);
  padding: 64px 0;
}
.related-title {
  font-size: clamp(1.4rem, 2.5vw, 1.9rem);
  margin-bottom: 28px;
}
.related-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
@media (max-width: 900px) { .related-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .related-grid { grid-template-columns: 1fr; } }
.related-card {
  background: white;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow);
  display: flex;
  flex-direction: column;
  transition: transform 0.3s, box-shadow 0.3s;
}
.related-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }
.related-card-img {
  height: 180px;
  background-size: cover;
  background-position: center;
  position: relative;
  transition: transform 0.5s;
  overflow: hidden;
}
.related-card:hover .related-card-img { transform: scale(1.04); }
.related-card-tag {
  position: absolute;
  top: 12px; left: 12px;
  background: var(--secondary);
  color: var(--text);
  padding: 3px 10px;
  border-radius: 100px;
  font-size: 0.72rem;
  font-weight: 700;
}
.related-card-body {
  padding: 18px 20px 20px;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.related-card-cat {
  font-size: 0.7rem;
  color: var(--primary);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.related-card-body h3 {
  font-size: 0.92rem;
  line-height: 1.4;
  color: var(--text);
  flex: 1;
}
.related-card:hover h3 { color: var(--primary); }
.related-card-read {
  font-size: 0.75rem;
  color: var(--text-muted);
}

/* ============================================
   DATA.GOUV.FR — Monuments & Offices de tourisme
   ============================================ */

.gov-data-banner {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  background: rgba(29,63,160,0.05);
  border: 1px solid rgba(29,63,160,0.2);
  border-left: 4px solid var(--blue-fr);
  border-radius: var(--radius);
  padding: 16px 20px;
  margin-top: 20px;
}
.gov-banner-icon { font-size: 1.6rem; flex-shrink: 0; line-height: 1.2; }
.gov-data-banner strong { display: block; font-size: 0.88rem; font-weight: 700; color: var(--blue-fr); margin-bottom: 4px; }
.gov-data-banner p { font-size: 0.83rem; color: var(--text-muted); margin: 0; }

.gov-section { }
.gov-section-header {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  margin-bottom: 24px;
  padding-bottom: 16px;
  border-bottom: 2px solid var(--border);
}
.gov-section-icon { font-size: 2rem; flex-shrink: 0; line-height: 1; }
.gov-section-header h2 {
  margin-bottom: 4px;
  padding-bottom: 0;
  border-bottom: none;
  font-size: clamp(1.3rem, 2.5vw, 1.7rem);
}
.gov-source {
  font-size: 0.75rem;
  color: var(--text-muted);
  margin: 0;
}
.gov-source a { color: var(--primary); font-weight: 500; }
.gov-source a:hover { text-decoration: underline; }

.monuments-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
  margin-bottom: 20px;
}
@media (max-width: 600px) { .monuments-grid { grid-template-columns: 1fr; } }

.monument-card {
  background: white;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 18px 20px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  transition: border-color 0.2s, box-shadow 0.2s, transform 0.2s;
}
.monument-card:hover {
  border-color: var(--primary);
  box-shadow: var(--shadow);
  transform: translateY(-2px);
}
.monument-card-header {
  display: flex;
  align-items: flex-start;
  gap: 12px;
}
.monument-icon {
  width: 42px;
  height: 42px;
  background: rgba(45,106,79,0.08);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--primary);
}
.monument-info { flex: 1; min-width: 0; }
.monument-info h3 {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 4px;
  line-height: 1.35;
  font-family: var(--font-sans);
}
.monument-commune {
  font-size: 0.78rem;
  color: var(--text-muted);
  display: flex;
  align-items: center;
  gap: 4px;
  margin: 0;
}
.monument-card-footer {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  padding-top: 10px;
  border-top: 1px solid var(--border);
}
.monument-badge {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 100px;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.03em;
}
.badge-classe { background: rgba(29,63,160,0.1); color: var(--blue-fr); }
.badge-inscrit { background: rgba(255,183,3,0.15); color: var(--secondary-dark); }
.badge-protege { background: rgba(45,106,79,0.1); color: var(--primary); }
.monument-date { font-size: 0.72rem; color: var(--text-muted); }

.gov-data-note {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 12px 16px;
  background: var(--bg);
  border-radius: var(--radius);
  font-size: 0.78rem;
  color: var(--text-muted);
  line-height: 1.5;
}
.gov-data-note i { width: 14px; height: 14px; flex-shrink: 0; margin-top: 2px; color: var(--primary); }

.gov-empty-state {
  text-align: center;
  padding: 40px 24px;
  background: var(--bg);
  border-radius: var(--radius-lg);
  border: 2px dashed var(--border);
}
.gov-empty-icon { font-size: 2.5rem; margin-bottom: 12px; display: block; }
.gov-empty-state p { font-size: 0.88rem; color: var(--text-muted); margin-bottom: 8px; }
.gov-empty-state p:last-child { margin-bottom: 0; }
.gov-empty-state a { color: var(--primary); font-weight: 500; }

.offices-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
}
@media (max-width: 600px) { .offices-grid { grid-template-columns: 1fr; } }

.office-card {
  background: white;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 18px 20px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: border-color 0.2s, box-shadow 0.2s, transform 0.2s;
}
.office-card:hover {
  border-color: var(--primary);
  box-shadow: var(--shadow);
  transform: translateY(-2px);
}
.office-card-top {
  display: flex;
  align-items: flex-start;
  gap: 12px;
}
.office-avatar {
  width: 42px;
  height: 42px;
  background: rgba(255,183,3,0.1);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--secondary-dark);
}
.office-card-top h3 {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 4px;
  line-height: 1.35;
  font-family: var(--font-sans);
}
.office-commune {
  font-size: 0.78rem;
  color: var(--text-muted);
  display: flex;
  align-items: center;
  gap: 4px;
  margin: 0;
}
.office-contacts {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding-top: 12px;
  border-top: 1px solid var(--border);
}
.office-contact-row {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.8rem;
  color: var(--text-light);
}
.office-contact-row a {
  color: var(--primary);
  font-weight: 500;
  transition: text-decoration 0.15s;
}
.office-contact-row a:hover { text-decoration: underline; }

.unesco-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.unesco-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  background: white;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  font-size: 0.9rem;
  color: var(--text);
  transition: border-color 0.2s;
}
.unesco-item:hover { border-color: var(--primary); }
.unesco-dot {
  width: 10px;
  height: 10px;
  background: var(--secondary);
  border-radius: 50%;
  flex-shrink: 0;
}

.sidebar-monuments { }
.sidebar-monuments-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.sidebar-monuments-list li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
}
.sm-dot {
  width: 8px;
  height: 8px;
  background: var(--primary);
  border-radius: 50%;
  flex-shrink: 0;
  margin-top: 6px;
}
.sm-name {
  font-size: 0.82rem;
  font-weight: 500;
  color: var(--text);
  line-height: 1.4;
  display: block;
  margin-bottom: 3px;
}
.sidebar-monuments-list .monument-badge { font-size: 0.65rem; }

/* ============================================
   TRAVELPAYOUTS — Widgets Affiliation
   ============================================ */

/* ── Widget principal (Booking, Activités, Transport, Location) ── */
.tp-widget {
  background: white;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  margin-bottom: 32px;
  box-shadow: var(--shadow);
  transition: box-shadow 0.2s;
}
.tp-widget:hover { box-shadow: var(--shadow-lg); }

.tp-widget__header {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 18px 22px;
  border-bottom: 1px solid var(--border);
  background: var(--bg);
}
.tp-widget__icon {
  font-size: 1.8rem;
  flex-shrink: 0;
  line-height: 1;
}
.tp-widget__title {
  font-size: 1rem !important;
  font-weight: 700;
  color: var(--text) !important;
  margin-bottom: 2px !important;
  font-family: var(--font-sans) !important;
  padding-bottom: 0 !important;
  border-bottom: none !important;
}
.tp-widget__sub {
  font-size: 0.8rem;
  color: var(--text-muted);
  margin: 0 !important;
}

.tp-widget__body {
  padding: 20px 22px;
}

/* ── Formulaire recherche Booking ── */
.tp-search-form {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.tp-search-field {
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.tp-search-field label {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.tp-search-field input {
  padding: 10px 14px;
  border: 1.5px solid var(--border);
  border-radius: 8px;
  font-size: 0.9rem;
  font-family: inherit;
  color: var(--text);
  background: white;
  outline: none;
  transition: border-color 0.2s;
  width: 100%;
}
.tp-search-field input:focus { border-color: var(--primary); }
.tp-search-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

/* ── Boutons widgets ── */
.tp-widget__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  padding: 12px 20px;
  border-radius: 10px;
  font-size: 0.9rem;
  font-weight: 700;
  font-family: var(--font-sans);
  transition: all 0.25s;
  text-decoration: none;
  cursor: pointer;
  text-align: center;
}
.tp-widget__btn--booking {
  background: #003580;
  color: white;
  box-shadow: 0 4px 12px rgba(0,53,128,0.3);
}
.tp-widget__btn--booking:hover {
  background: #00266b;
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(0,53,128,0.4);
}
.tp-widget__btn--activities {
  background: #FF5533;
  color: white;
  box-shadow: 0 4px 12px rgba(255,85,51,0.3);
}
.tp-widget__btn--activities:hover {
  background: #e64a2a;
  transform: translateY(-2px);
}
.tp-widget__btn--viator {
  background: white;
  color: #FF5533;
  border: 2px solid #FF5533;
  margin-top: 8px;
}
.tp-widget__btn--viator:hover {
  background: #FF5533;
  color: white;
  transform: translateY(-2px);
}
.tp-widget__btn--car {
  background: var(--primary);
  color: white;
  box-shadow: 0 4px 12px rgba(45,106,79,0.3);
}
.tp-widget__btn--car:hover {
  background: var(--primary-dark);
  transform: translateY(-2px);
}
.tp-widget__btn--car-alt {
  background: white;
  color: var(--primary);
  border: 2px solid var(--primary);
  margin-top: 8px;
}
.tp-widget__btn--car-alt:hover {
  background: var(--primary);
  color: white;
  transform: translateY(-2px);
}

.tp-widget__partner {
  font-size: 0.72rem;
  color: var(--text-muted);
  text-align: center;
  margin-top: 10px !important;
  margin-bottom: 0 !important;
}
.tp-widget__partner strong { color: var(--text-light); }

/* ── Pills activités ── */
.tp-activities-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 16px;
}
.tp-activity-pill {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 6px 14px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 100px;
  font-size: 0.82rem;
  color: var(--text);
  font-weight: 500;
  transition: all 0.2s;
  text-decoration: none;
}
.tp-activity-pill:hover {
  background: var(--primary);
  color: white;
  border-color: var(--primary);
  transform: translateY(-1px);
}
.tp-activities-cta {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

/* ── Transport grid ── */
.tp-transport-grid {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.tp-transport-card {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  text-decoration: none;
  transition: all 0.2s;
}
.tp-transport-card:hover {
  border-color: var(--primary);
  background: rgba(45,106,79,0.04);
  transform: translateX(4px);
}
.tp-transport-icon {
  font-size: 1.5rem;
  flex-shrink: 0;
  width: 40px;
  text-align: center;
}
.tp-transport-card div { flex: 1; }
.tp-transport-card strong {
  display: block;
  font-size: 0.9rem;
  color: var(--text);
  font-weight: 600;
}
.tp-transport-card small {
  font-size: 0.75rem;
  color: var(--text-muted);
}
.tp-transport-arrow {
  font-size: 1.2rem;
  color: var(--primary);
  flex-shrink: 0;
}

/* ── Location voiture brands ── */
.tp-carrental-cta {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 14px;
}
.tp-carrental-brands {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  padding: 10px 0;
  border-top: 1px solid var(--border);
  margin-top: 4px;
}
.tp-carrental-brands span {
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  background: var(--bg);
  padding: 3px 8px;
  border-radius: 4px;
}

/* ── Bannière sidebar affiliation ── */
.tp-sidebar-banner {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  border-radius: var(--radius);
  text-decoration: none;
  transition: all 0.2s;
  box-shadow: var(--shadow);
}
.tp-sidebar-banner:hover { transform: translateY(-2px); box-shadow: var(--shadow-lg); }

.tp-banner--booking {
  background: linear-gradient(135deg, #003580, #0053a0);
}
.tp-banner--activities {
  background: linear-gradient(135deg, #e63000, #FF5533);
}
.tp-banner--car {
  background: linear-gradient(135deg, var(--primary-dark), var(--primary));
}

.tp-banner-icon {
  font-size: 1.5rem;
  flex-shrink: 0;
}
.tp-banner-content {
  flex: 1;
  min-width: 0;
}
.tp-banner-content strong {
  display: block;
  font-size: 0.85rem;
  color: white;
  font-weight: 700;
  line-height: 1.2;
}
.tp-banner-content small {
  font-size: 0.72rem;
  color: rgba(255,255,255,0.7);
}
.tp-banner-btn {
  display: inline-block;
  background: rgba(255,255,255,0.15);
  color: white;
  padding: 6px 12px;
  border-radius: 6px;
  font-size: 0.75rem;
  font-weight: 700;
  white-space: nowrap;
  flex-shrink: 0;
  transition: background 0.2s;
  text-decoration: none;
}
.tp-banner-btn:hover { background: rgba(255,255,255,0.25); }

/* ── Bannière inline dans les articles ── */
.tp-inline-banner {
  display: flex;
  align-items: center;
  gap: 16px;
  background: white;
  border: 1px solid var(--border);
  border-left: 4px solid var(--tp-color, var(--primary));
  border-radius: var(--radius);
  padding: 16px 20px;
  margin: 24px 0;
  box-shadow: var(--shadow);
  transition: box-shadow 0.2s, transform 0.2s;
}
.tp-inline-banner:hover { box-shadow: var(--shadow-lg); transform: translateY(-1px); }
.tp-inline-icon {
  font-size: 1.8rem;
  flex-shrink: 0;
  line-height: 1;
}
.tp-inline-content {
  flex: 1;
  min-width: 0;
}
.tp-inline-content strong {
  display: block;
  font-size: 0.92rem;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 3px;
}
.tp-inline-content p {
  font-size: 0.82rem;
  color: var(--text-muted);
  margin: 0 !important;
  line-height: 1.4;
}
.tp-inline-btn {
  display: inline-flex;
  align-items: center;
  padding: 10px 18px;
  background: var(--tp-color, var(--primary));
  color: white;
  border-radius: 8px;
  font-size: 0.82rem;
  font-weight: 700;
  white-space: nowrap;
  flex-shrink: 0;
  text-decoration: none;
  transition: filter 0.2s, transform 0.2s;
}
.tp-inline-btn:hover {
  filter: brightness(0.9);
  transform: translateY(-1px);
}

@media (max-width: 560px) {
  .tp-inline-banner { flex-direction: column; align-items: flex-start; gap: 12px; }
  .tp-inline-btn { width: 100%; justify-content: center; }
  .tp-search-row { grid-template-columns: 1fr; }
  .tp-sidebar-banner { flex-wrap: wrap; }
}