/* Style des pages SEO statiques AutoBudget (servies hors SPA par Cloudflare Pages).
   DA reprise de TripBudget mais palette propre : bleu (#2563eb) + ambre (#f59e0b),
   ambiance "route / auto". NB : les noms de variables --indigo/--teal sont conservés
   (= primaire/accent) pour réutiliser tout le CSS sans churn ; seules les VALEURS changent. */
/* Noto Color Emoji : Windows (Chrome/Edge) affiche sinon les drapeaux en initiales. */
@import url("https://fonts.googleapis.com/css2?family=Noto+Color+Emoji&display=swap");
:root {
  --indigo: #2563eb;   /* primaire — bleu */
  --indigo-d: #1d4ed8;
  --teal: #f59e0b;     /* accent — ambre (prix, "Budget", marqueurs FAQ) */
  --ink: #0f172a;
  --slate: #475569;
  --line: #e2e8f0;
  --bg: #f8fafc;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial,
    sans-serif, "Noto Color Emoji";
  color: var(--ink);
  background: var(--bg);
  line-height: 1.65;
}
a { color: var(--indigo); }
.wrap { max-width: 820px; margin: 0 auto; padding: 0 20px; }

/* En-tête / nav */
header.site {
  background: transparent;
  border: 0;
  position: fixed; top: 0; left: 0; right: 0; z-index: 30;
}
header.site .wrap { display: flex; align-items: center; justify-content: flex-start; gap: 10px; max-width: none; height: auto; padding: 12px 16px; }
.brand { font-weight: 900; font-size: 20px; color: var(--ink); text-decoration: none; }
.brand span { color: var(--teal); }
.nav a { margin-left: 18px; font-weight: 600; font-size: 14px; text-decoration: none; color: var(--slate); }

/* Héros */
.hero {
  background:
    radial-gradient(680px 280px at 85% -20%, rgba(245,158,11,.12), transparent 60%),
    linear-gradient(160deg, #172554 0%, #1e3a8a 55%, #0f172a 100%);
  color: #fff;
  padding: 66px 0 60px;
}
.hero h1 { font-size: clamp(28px, 5vw, 44px); line-height: 1.15; margin: 0 0 14px; font-weight: 900; }
.hero p { font-size: 18px; opacity: .92; margin: 0 0 26px; max-width: 620px; }
.btn {
  display: inline-block; background: #fff; color: var(--indigo); font-weight: 900;
  padding: 16px 32px; border-radius: 14px; text-decoration: none; font-size: 17px;
  box-shadow: 0 10px 30px rgba(2,6,23,.25); transition: transform .14s ease, box-shadow .14s ease;
  animation: ctaGlow 2.6s ease-in-out infinite; will-change: transform, box-shadow;
}
.btn:hover { transform: translateY(-2px) scale(1.03); animation: none; box-shadow: 0 16px 40px rgba(37,99,235,.55); }
.btn:active { transform: translateY(0) scale(.99); }
.btn.alt { background: var(--indigo); color: #fff; }
/* Pulsation douce qui attire l'œil sur le CTA (halo bleu). Désactivée au survol
   et pour les utilisateurs qui réduisent les animations (accessibilité). */
@keyframes ctaGlow {
  0%, 100% { box-shadow: 0 10px 30px rgba(2,6,23,.20); }
  50% { box-shadow: 0 12px 34px rgba(37,99,235,.50); }
}
@media (prefers-reduced-motion: reduce) { .btn { animation: none; } }

/* Contenu */
main { padding: 40px 0 64px; }
main h2 { font-size: 26px; margin: 40px 0 14px; }
main h3 { font-size: 19px; margin: 26px 0 6px; }
main p { color: #1e293b; }

/* Cartes destinations */
.dest {
  display: flex; gap: 14px; align-items: flex-start;
  background: #fff; border: 1px solid var(--line); border-radius: 16px;
  padding: 16px 18px; margin: 12px 0;
}
.dest .flag { font-size: 30px; line-height: 1; }
.dest .body { flex: 1; }
.dest .body strong { font-size: 17px; }
.dest .price { color: var(--teal); font-weight: 800; white-space: nowrap; }
.dest .body p { margin: 4px 0 0; font-size: 14px; color: var(--slate); }

/* Liens entre pages budget */
.budgets { display: flex; flex-wrap: wrap; gap: 10px; margin: 16px 0; }
.budgets a {
  background: #eef2ff; color: var(--indigo); font-weight: 700; text-decoration: none;
  padding: 8px 14px; border-radius: 999px; font-size: 14px;
}

/* Sélecteur de budget (page Bons plans) — pills cliquables, état actif teal. */
.budget-picker { display: flex; flex-wrap: wrap; gap: 10px; margin: 8px 0 24px; }
.budget-picker button {
  background: #eef2ff; color: var(--indigo); font-weight: 800; border: 0; cursor: pointer;
  padding: 10px 18px; border-radius: 999px; font-size: 15px; font-family: inherit;
  transition: transform .1s ease;
}
.budget-picker button:hover { transform: translateY(-1px); }
.budget-picker button[aria-pressed="true"] { background: var(--teal); color: #fff; }

/* Grille de cartes « bons plans » (chargées en live depuis /deals). */
.deals-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 16px; margin: 18px 0; }
.deal-card {
  display: flex; flex-direction: column; background: #fff; border: 1px solid var(--line);
  border-radius: 16px; overflow: hidden; text-decoration: none; color: inherit;
  transition: transform .12s ease, box-shadow .12s ease;
}
.deal-card:hover { transform: translateY(-3px); box-shadow: 0 12px 28px rgba(2,6,23,.12); }
.deal-card .dc-img { width: 100%; height: 150px; object-fit: cover; background: #e2e8f0; display: block; }
.deal-card .dc-body { padding: 14px 16px; flex: 1; display: flex; flex-direction: column; }
.deal-card .dc-dest { font-weight: 800; font-size: 17px; }
.deal-card .dc-country { font-size: 13px; color: var(--slate); margin: 2px 0 10px; }
.deal-card .dc-price { color: var(--teal); font-weight: 900; font-size: 22px; line-height: 1; }
.deal-card .dc-price small { font-size: 13px; font-weight: 700; color: var(--slate); }
.deal-card .dc-save {
  align-self: flex-start; margin-top: 10px; background: #ecfdf5; color: #047857;
  font-weight: 800; font-size: 12px; padding: 4px 10px; border-radius: 999px;
}
.deal-card .dc-ctas { margin-top: 12px; display: flex; flex-direction: column; gap: 8px; }
.deal-card .dc-book {
  background: linear-gradient(135deg, var(--indigo), #7c3aed); color: #fff; text-align: center;
  padding: 11px 12px; border-radius: 10px; font-weight: 800; font-size: 14px; text-decoration: none;
  box-shadow: 0 6px 16px rgba(79,70,229,.35); transition: transform .12s ease, box-shadow .12s ease;
}
.deal-card .dc-book:hover { transform: translateY(-1px); box-shadow: 0 10px 22px rgba(79,70,229,.5); }
.deal-card .dc-detail { text-align: center; font-size: 13px; font-weight: 700; color: var(--slate); text-decoration: none; }
.deal-card .dc-detail:hover { color: var(--indigo); }
.deals-status { color: var(--slate); font-size: 15px; padding: 8px 0; }
html.dark .deal-card { background: #0f172a; border-color: var(--line); }
html.dark .deal-card .dc-dest { color: #f1f5f9; }
html.dark .deal-card .dc-save { background: #064e3b; color: #6ee7b7; }
html.dark .budget-picker button { background: #1e293b; color: #c7d2fe; }
html.dark .budget-picker button[aria-pressed="true"] { background: var(--teal); color: #fff; }

.cta-band {
  background: #fff; border: 1px solid var(--line); border-radius: 20px;
  padding: 28px; text-align: center; margin: 40px 0;
}
.cta-band h2 { margin: 0 0 8px; }
.cta-band p { color: var(--slate); margin: 0 0 18px; }

.note { font-size: 13px; color: #94a3b8; }

/* Bloc alerte baisse de prix (page Bons plans) — carte mise en avant */
.alert-box {
  position: relative; overflow: hidden;
  background:
    radial-gradient(420px 160px at 12% 0%, rgba(45,212,191,.20), transparent 70%),
    linear-gradient(135deg, rgba(79,70,229,.20), rgba(124,58,237,.14));
  border: 1px solid rgba(99,102,241,.35); border-radius: 22px;
  padding: 30px 30px; margin: 34px 0; box-shadow: 0 16px 44px rgba(2,6,23,.20);
}
.alert-box h2 { margin: 0 0 8px; font-size: 24px; }
.alert-box > p { margin: 0 0 20px; color: var(--slate); max-width: 580px; }
.alert-box > p strong { color: var(--teal); }
.alert-form { display: flex; gap: 12px; flex-wrap: wrap; max-width: 540px; }
.alert-form input {
  flex: 1; min-width: 220px; padding: 16px 18px; border-radius: 14px;
  border: 1.5px solid var(--line); background: #fff; color: var(--ink); font-size: 16px; font-family: inherit;
  transition: border-color .15s ease, box-shadow .15s ease;
}
.alert-form input::placeholder { color: #94a3b8; }
.alert-form input:focus {
  outline: none; border-color: var(--indigo); box-shadow: 0 0 0 4px rgba(79,70,229,.20);
}
.alert-form button {
  background: linear-gradient(135deg, var(--indigo), #7c3aed); color: #fff; font-weight: 800;
  border: 0; cursor: pointer; padding: 16px 28px; border-radius: 14px; font-size: 16px; font-family: inherit;
  white-space: nowrap; box-shadow: 0 10px 26px rgba(79,70,229,.45);
  transition: transform .12s ease, box-shadow .12s ease;
}
.alert-form button:hover { transform: translateY(-2px); box-shadow: 0 14px 32px rgba(79,70,229,.6); }
.alert-form button:active { transform: translateY(0); }
.alert-form button:disabled { opacity: .6; cursor: default; transform: none; }
#alertMsg { margin: 14px 0 0; font-weight: 600; color: var(--ink); }
html.dark .alert-form input { background: #0b1220; color: #f1f5f9; border-color: #1e293b; }
html.dark .alert-box { border-color: rgba(129,140,248,.4); }

/* Footer riche multi-colonnes (toutes les pages accessibles depuis le bas) */
.foot-cols { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 22px; margin-bottom: 18px; }
.foot-cols strong { display: block; color: var(--ink); font-size: 14px; margin: 0 0 10px; }
.foot-cols a { display: block; margin: 0 0 7px; font-size: 13px; color: var(--slate); }
.foot-cols a:hover { color: var(--indigo); }
.foot-tag { color: var(--slate); font-size: 13px; margin: 6px 0 0; }
html.dark .foot-cols strong { color: #f1f5f9; }

/* FAQ : accordéon natif <details> (zéro JS, contenu indexable par Google). */
.faq { margin: 16px 0; }
.faq details {
  background: #fff; border: 1px solid var(--line); border-radius: 14px;
  padding: 0 18px; margin: 10px 0;
}
.faq summary {
  cursor: pointer; font-weight: 700; font-size: 16px; color: var(--ink);
  padding: 16px 0; list-style: none; display: flex; justify-content: space-between; gap: 14px;
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: "+"; color: var(--teal); font-weight: 800; font-size: 22px; line-height: 1; }
.faq details[open] summary::after { content: "–"; }
.faq details p { margin: 0 0 16px; color: var(--slate); font-size: 15px; }
html.dark .faq details { background: #0f172a; border-color: var(--line); }
html.dark .faq summary { color: #f1f5f9; }

footer.site { border-top: 1px solid var(--line); background: #fff; padding: 28px 0; margin-top: 40px; }
footer.site p { color: var(--slate); font-size: 13px; margin: 6px 0; }
footer.site a { color: var(--slate); margin-right: 16px; font-size: 13px; }

/* Mode sombre : la classe `dark` est posée sur <html> par le script inline de
   chaque page (qui lit le thème choisi dans l'app via localStorage). Le héros en
   dégradé reste identique (beau sur fond clair comme sombre). */
html.dark {
  --ink: #f1f5f9;
  --slate: #94a3b8;
  --line: #1e293b;
  --bg: #0b1220;
}
html.dark body { background: var(--bg); color: var(--ink); }
html.dark header.site,
html.dark footer.site,
html.dark .dest,
html.dark .cta-band { background: #0f172a; border-color: var(--line); }
html.dark .brand,
html.dark .dest .body strong,
html.dark main h2,
html.dark main h3 { color: #f1f5f9; }
html.dark main p,
html.dark .cta-band p { color: #cbd5e1; }
html.dark .budgets a { background: #1e293b; color: #93c5fd; }

/* --- AutoBudget : encart de recherche / widget partenaire --- */
.searchbox {
  background: #fff; border: 1px solid var(--line); border-radius: 20px;
  padding: 22px; margin: -34px 0 8px; position: relative; z-index: 5;
  box-shadow: 0 16px 44px rgba(2,6,23,.16);
}
.searchbox h2 { margin: 0 0 4px; font-size: 20px; }
.searchbox p { margin: 0 0 16px; color: var(--slate); font-size: 14px; }
.searchbox .btn { width: 100%; text-align: center; }
/* Emplacement du widget officiel DiscoverCars/Travelpayouts (iframe/script). */
.widget-slot { min-height: 60px; }
html.dark .searchbox { background: #0f172a; border-color: var(--line); }

/* Mention affiliée discrète sous les CTA */
.aff-note { font-size: 12px; color: #94a3b8; margin: 8px 0 0; }

/* Grille de "raisons / avantages" (cartes simples) */
.perks { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; margin: 18px 0; }
@media (min-width: 760px) { .perks { grid-template-columns: repeat(4, 1fr); } }
/* Étapes "Comment ça marche" — alignées en ligne */
.steps { display: grid; grid-template-columns: 1fr; gap: 14px; margin: 18px 0; }
@media (min-width: 760px) { .steps { grid-template-columns: repeat(3, 1fr); } }
.step { background: #fff; border: 1px solid var(--line); border-radius: 16px; padding: 18px; }
.step .n { display: inline-flex; align-items: center; justify-content: center; width: 30px; height: 30px; border-radius: 9px; background: var(--indigo); color: #fff; font-weight: 900; font-size: 15px; }
.step strong { display: block; margin: 10px 0 4px; font-size: 16px; }
.step p { margin: 0; font-size: 14px; color: var(--slate); }
html.dark .step { background: #0f172a; border-color: var(--line); }
.perk { background: #fff; border: 1px solid var(--line); border-radius: 16px; padding: 18px; }
.perk .ic { font-size: 26px; }
.perk strong { display: block; margin: 8px 0 4px; font-size: 16px; }
.perk p { margin: 0; font-size: 14px; color: var(--slate); }
html.dark .perk { background: #0f172a; border-color: var(--line); }

/* --- Menu burger + drawer paramètres (injecté par app.js) --- */
.burger {
  display: inline-flex; align-items: center; justify-content: center;
  width: 44px; height: 44px; margin: 0; padding: 0;
  background: rgba(15,23,42,.55); border: 1px solid rgba(255,255,255,.16); border-radius: 12px;
  cursor: pointer; color: #fff; -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px);
  transition: background .15s ease;
}
.burger:hover { background: rgba(15,23,42,.78); }
.burger:focus-visible { outline: 2px solid var(--indigo); outline-offset: 2px; }
.burger svg { width: 24px; height: 24px; }
html.dark .burger { color: #f1f5f9; }

.drawer-backdrop {
  position: fixed; inset: 0; background: rgba(2,6,23,.5); z-index: 40;
  opacity: 0; visibility: hidden; transition: opacity .2s ease, visibility .2s ease;
}
.drawer-backdrop.open { opacity: 1; visibility: visible; }

.drawer {
  position: fixed; top: 0; left: 0; height: 100%; width: min(86vw, 330px); z-index: 50;
  background: var(--bg); border-right: 1px solid var(--line);
  box-shadow: 16px 0 44px rgba(2,6,23,.3);
  transform: translateX(-100%); transition: transform .24s ease-out;
  display: flex; flex-direction: column; overflow-y: auto;
}
.drawer.open { transform: translateX(0); }
.drawer-head { display: flex; align-items: center; justify-content: space-between; padding: 14px 18px; border-bottom: 1px solid var(--line); }
.drawer-head .brand { font-size: 18px; }
.drawer-close { width: 40px; height: 40px; border: 0; background: transparent; border-radius: 10px; cursor: pointer; color: var(--ink); font-size: 26px; line-height: 1; }
.drawer-close:hover { background: rgba(100,116,139,.12); }
.drawer-close:focus-visible { outline: 2px solid var(--indigo); outline-offset: 2px; }
.drawer nav { display: flex; flex-direction: column; padding: 10px 8px; }
.drawer nav a { display: flex; align-items: center; gap: 12px; padding: 12px 14px; border-radius: 10px; text-decoration: none; color: var(--ink); font-weight: 600; font-size: 15px; }
.drawer nav a .mi { width: 22px; text-align: center; font-size: 18px; line-height: 1; }
.drawer nav a:hover { background: rgba(100,116,139,.10); color: var(--indigo); }
.drawer .grp { padding: 14px 18px; border-top: 1px solid var(--line); }
.drawer .grp h4 { margin: 0 0 10px; font-size: 13px; text-transform: uppercase; letter-spacing: .04em; color: var(--slate); }
.drawer .grp .lbl { font-size: 13px; color: var(--slate); margin: 0 0 6px; }
.seg { display: flex; gap: 6px; flex-wrap: wrap; margin: 0 0 14px; }
.seg button {
  flex: 1; min-width: 64px; padding: 10px; border: 1.5px solid var(--line); background: transparent;
  color: var(--ink); border-radius: 10px; cursor: pointer; font-weight: 700; font-size: 14px; font-family: inherit;
  transition: background .15s ease, border-color .15s ease, color .15s ease;
}
.seg button:hover { border-color: var(--indigo); }
.seg button[aria-pressed="true"] { background: var(--indigo); border-color: var(--indigo); color: #fff; }
.seg button:focus-visible { outline: 2px solid var(--indigo); outline-offset: 2px; }
html.dark .drawer nav a:hover,
html.dark .burger:hover,
html.dark .drawer-close:hover { background: rgba(148,163,184,.14); }

@media (max-width: 640px) { header.site .nav { display: none; } }
@media (prefers-reduced-motion: reduce) { .drawer, .drawer-backdrop { transition: none; } }

/* --- Formulaire de recherche (injecté dans .widget-slot par app.js) --- */
.cs-form { display: flex; flex-direction: column; gap: 12px; margin: 2px 0 14px; }
.cs-form label { display: flex; flex-direction: column; gap: 6px; font-size: 11px; font-weight: 800; letter-spacing: .05em; text-transform: uppercase; color: var(--slate); }
.cs-form input {
  padding: 14px; border: 1.5px solid var(--line); border-radius: 12px;
  background: #f8fafc; color: var(--ink); font-size: 15px; font-weight: 600; font-family: inherit;
  transition: border-color .15s ease, box-shadow .15s ease, background .15s ease;
}
.cs-form input::-webkit-calendar-picker-indicator { cursor: pointer; opacity: .6; }
.cs-form input:hover { border-color: #cbd5e1; }
.cs-form input:focus { outline: none; border-color: var(--indigo); box-shadow: 0 0 0 4px rgba(37,99,235,.18); background: #fff; }
.cs-form input[readonly] { background: #eef2f7; cursor: default; }
.cs-row { display: flex; gap: 10px; }
.cs-row > label:first-child { flex: 1; }
.cs-time { flex: 0 0 108px; }
.cs-form .btn { width: 100%; text-align: center; margin-top: 6px; padding: 16px; }
html.dark .cs-form input { background: #0b1220; color: #f1f5f9; border-color: #1e293b; }
html.dark .cs-form input:focus { background: #0b1220; }
html.dark .cs-form input[readonly] { background: #1e293b; }
html.dark .cs-form input::-webkit-calendar-picker-indicator { filter: invert(1); opacity: .75; }
/* Contrôles natifs lisibles en sombre (flèches/icônes claires) */
html.dark .cs-form input, html.dark .cs-form select { color-scheme: dark; }

/* Heures = menus déroulants */
.cs-form select {
  padding: 14px; border: 1.5px solid var(--line); border-radius: 12px;
  background: #f8fafc; color: var(--ink); font-size: 15px; font-weight: 600; font-family: inherit; cursor: pointer;
}
.cs-form select:focus { outline: none; border-color: var(--indigo); box-shadow: 0 0 0 4px rgba(37,99,235,.18); }
html.dark .cs-form select { background: #0b1220; color: #f1f5f9; border-color: #1e293b; }

/* Calendrier custom (sélection de plage) */
.cs-dates { position: relative; }
.cs-datebtn {
  width: 100%; display: flex; align-items: center; gap: 10px; padding: 13px 14px;
  border: 1.5px solid var(--line); border-radius: 12px; background: #f8fafc; color: var(--ink);
  font-family: inherit; font-size: 15px; cursor: pointer; text-align: left;
}
.cs-datebtn:hover { border-color: #cbd5e1; }
.cs-datebtn .cal-ic { font-size: 18px; }
.cs-datebtn .cv { font-weight: 800; }
.cs-datebtn .cs-sep { color: var(--slate); margin: 0 2px; }
html.dark .cs-datebtn { background: #0b1220; color: #f1f5f9; border-color: #1e293b; }
.cs-cal {
  position: absolute; z-index: 30; top: calc(100% + 6px); left: 0; right: auto;
  width: 320px; max-width: calc(100vw - 32px);
  background: #fff; border: 1px solid var(--line); border-radius: 14px; padding: 14px;
  box-shadow: 0 18px 44px rgba(2,6,23,.28);
}
.cs-cal[hidden] { display: none; }
.cs-cal-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 8px; }
.cs-cal-head strong { font-size: 15px; }
.cs-cal-head button { background: transparent; border: 0; cursor: pointer; font-size: 22px; line-height: 1; color: var(--ink); width: 34px; height: 34px; border-radius: 8px; }
.cs-cal-head button:hover { background: rgba(100,116,139,.14); }
.cs-cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 2px; }
.cs-cal-grid .dow { text-align: center; font-size: 11px; color: var(--slate); padding: 4px 0; font-weight: 700; }
.cs-cal-grid button { height: 38px; border: 0; background: transparent; border-radius: 8px; cursor: pointer; color: var(--ink); font-size: 14px; font-weight: 600; font-family: inherit; }
.cs-cal-grid button:hover:not(:disabled) { background: rgba(37,99,235,.16); }
.cs-cal-grid button:disabled { color: #cbd5e1; cursor: default; }
.cs-cal-grid button.in { background: rgba(37,99,235,.14); border-radius: 0; }
.cs-cal-grid button.sel { background: var(--indigo); color: #fff; }
html.dark .cs-cal { background: #0f172a; border-color: #1e293b; }
html.dark .cs-cal-head button { color: #f1f5f9; }
html.dark .cs-cal-grid button { color: #f1f5f9; }
html.dark .cs-cal-grid button:disabled { color: #475569; }

/* --- Héros premium (accueil) : 2 colonnes + carrousel destinations --- */
.hero-grid { display: grid; grid-template-columns: 1fr; gap: 28px; align-items: center; }
@media (min-width: 880px) { .hero-grid { grid-template-columns: 1.1fr .9fr; gap: 40px; } }
.badge {
  display: inline-block; background: rgba(255,255,255,.15); border: 1px solid rgba(255,255,255,.28);
  color: #fff; font-weight: 700; font-size: 13px; padding: 7px 14px; border-radius: 999px;
  margin-bottom: 18px; backdrop-filter: blur(6px);
}
.hero-feats { display: flex; flex-wrap: wrap; gap: 8px 18px; margin-top: 22px; }
.hero-feats span { color: #fff; opacity: .92; font-size: 14px; font-weight: 600; }

.hero-card {
  background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.22); border-radius: 20px;
  padding: 18px; backdrop-filter: blur(12px); box-shadow: 0 20px 50px rgba(2,6,23,.30);
}
.hc-head { display: flex; justify-content: space-between; align-items: center; color: #fff; font-size: 12px; font-weight: 800; letter-spacing: .06em; opacity: .85; margin-bottom: 6px; }
.hc-slides { position: relative; }
.hc-slide { display: none; }
.hc-slide.on { display: block; animation: hcFade .4s ease; }
@keyframes hcFade { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }
.hc-row { display: flex; align-items: center; gap: 12px; padding: 13px 14px; margin: 8px 0; background: rgba(255,255,255,.10); border: 1px solid rgba(255,255,255,.14); border-radius: 13px; text-decoration: none; transition: background .15s ease, transform .15s ease; }
.hc-row:hover { background: rgba(255,255,255,.20); transform: translateX(2px); }
.hc-row .flag { font-size: 24px; line-height: 1; }
.hc-name { flex: 1; color: #fff; font-weight: 800; font-size: 16px; }
.hc-price { color: #fde68a; font-weight: 800; font-size: 14px; white-space: nowrap; }
.hc-dots { display: flex; gap: 7px; justify-content: center; margin-top: 12px; }
.hc-dots span { width: 7px; height: 7px; border-radius: 999px; background: rgba(255,255,255,.35); cursor: pointer; transition: background .2s ease, width .2s ease; }
.hc-dots span.on { background: #fff; width: 20px; }

/* Bord lumineux animé autour de la carte de recherche (accueil) */
.searchbox.glow::before {
  content: ""; position: absolute; inset: -2px; border-radius: 22px; z-index: 0;
  background: linear-gradient(120deg, #6366f1, #14b8a6, #f59e0b);
  background-size: 300% 300%; animation: borderFlow 14s ease infinite; opacity: .6;
}
.searchbox.glow > * { position: relative; z-index: 1; }
@keyframes borderFlow { 0% { background-position: 0% 50%; } 50% { background-position: 100% 50%; } 100% { background-position: 0% 50%; } }
@media (prefers-reduced-motion: reduce) { .searchbox.glow::before { animation: none; } }

/* Page Paramètres (dédiée) */
.settings-box { background: #fff; border: 1px solid var(--line); border-radius: 18px; padding: 22px; max-width: 460px; }
.settings-box .lbl { font-size: 13px; color: var(--slate); margin: 0 0 7px; font-weight: 700; }
.settings-box .seg { margin: 0 0 18px; }
.settings-box .note { margin: 4px 0 0; }
html.dark .settings-box { background: #0f172a; border-color: var(--line); }

/* Header transparent (le burger flotte sur le dégradé du héros, comme TripBudget) */
html.dark header.site { background: transparent; border: 0; }
