
/* ============================================================
   MAGICIENS.PRO
   Palette : Bordeaux et lin — Polices système
   Typographie : titres serif / corps sans-serif (Option B)
   ============================================================ */

:root {
  --bordeaux-profond : #2a1010;
  --bordeaux-hero    : #6b1e1e;
  --bordeaux-header  : #3d1010;
  --bordeaux-moyen   : #5c1a1a;
  --bordeaux-clair   : #5a1818;
  --bordeaux-accent  : #8b2020;
  --lin              : #c8c0b0;
  --lin-clair        : #e8e0d4;
  --lin-pale         : #f5ecd8;
  --creme            : #f7f2ec;
  --blanc            : #ffffff;
  --texte-fonce      : #2a1a1a;
  --texte-clair      : #3a2a1a;
  --texte-tres-clair : #b0a090;
  --separateur       : #3a2020;
  --separateur-clair : #e8e0d8;
  --font-serif : Georgia, 'Times New Roman', 'Book Antiqua', Palatino, serif;
  --font-ui    : 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
  --rayon-card : 3px;
  --transition : .22s ease;
  --max-w-wide : 1080px;
}

/* ── Reset ─────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px;
  background: var(--bordeaux-profond);
}
body {
  background    : var(--creme);
  color         : var(--texte-fonce);
  font-family   : var(--font-ui);
  font-size     : 1rem;
  line-height   : 1.85;
  min-height    : 100vh;
  display       : flex;
  flex-direction: column;
}
img { max-width: 100%; height: auto; display: block; }
a   { color: var(--bordeaux-accent); text-decoration: none; transition: color var(--transition); }
a:hover { color: var(--bordeaux-hero); text-decoration: none; }
ul, ol { padding-left: 1.4em; }
li { margin-bottom: .35em; }

/* ── Typographie ───────────────────────────────────────────── */
h1, h2 {
  font-family  : var(--font-serif);
  color        : var(--texte-fonce);
  line-height  : 1.2;
  margin-bottom: .6em;
}
h3, h4, h5 {
  font-family  : var(--font-ui);
  color        : var(--texte-fonce);
  line-height  : 1.2;
  margin-bottom: .6em;
}
h1 { font-size: clamp(1.75rem, 4vw, 2.6rem); font-weight: normal; }
h2 { font-size: clamp(1.45rem, 2.8vw, 2rem); font-weight: normal; }
h3 { font-size: 1.05rem; font-weight: 700; }
h4 { font-size: 1rem; font-weight: 700; }
p  { margin-bottom: 1.1em; }
p:last-child { margin-bottom: 0; }
strong { font-weight: bold; }

/* ── Conteneur ─────────────────────────────────────────────── */
.container--wide {
  width    : 94%;
  max-width: var(--max-w-wide);
  margin   : 0 auto;
}
main { flex: 1; }

/* ── En-tête ───────────────────────────────────────────────── */
.site-header {
  background   : var(--bordeaux-header);
  border-bottom: 2px solid var(--bordeaux-moyen);
  position     : sticky;
  top          : 0;
  z-index      : 100;
}
.site-header__inner {
  display        : flex;
  align-items    : center;
  justify-content: space-between;
  padding        : 14px 0;
  width          : 94%;
  max-width      : var(--max-w-wide);
  margin         : 0 auto;
  gap            : 24px;
}
.site-logo { display: inline-flex; flex-direction: column; text-decoration: none; width: max-content; }
.site-logo__name {
  font-family   : var(--font-serif);
  font-size     : 1.7rem;
  color         : #e8e0d4;
  letter-spacing: .04em;
  font-weight   : normal;
  line-height   : 1;
  display: flex;
  align-items   : center;
  gap           : 4px;
width: max-content; }
.site-logo__name .logo__dot {
  display      : inline-block;
  width        : 9px;
  height       : 9px;
  border-radius: 50%;
  background   : var(--bordeaux-hero);
  flex-shrink  : 0;
  margin-top   : 8px;
  vertical-align: middle;
}
.site-logo__name .logo__pro { color: var(--lin); }
.site-logo__baseline{font-size:.62rem;color:#7a5a5a;text-transform:uppercase;margin-top:3px;display:block;width:100%;letter-spacing:.2em;text-align:justify;text-align-last:justify}
.site-logo:hover .site-logo__name { color: var(--lin-clair); text-decoration: none; width: max-content; }

.site-nav { display: flex; align-items: center; gap: 6px; }
.site-nav a {
  font-size     : .8rem;
  color         : #7a5a5a;
  letter-spacing: .06em;
  padding       : 6px 12px;
  text-decoration: none;
  transition    : color var(--transition);
}
.site-nav a:hover { color: var(--lin); text-decoration: none; }
.site-nav a.is-active { color: var(--lin); }
.site-nav__cta {
  background    : rgba(255,255,255,.18) !important;
  border        : 1px solid rgba(255,255,255,.6) !important;
  color         : #ffffff !important;
  padding       : 8px 18px !important;
  font-weight   : 700;
  letter-spacing: .1em;
  font-size     : .75rem !important;
  transition    : background var(--transition), color var(--transition) !important;
}
.site-nav__cta:hover {
  background     : rgba(255,255,255,.32) !important;
  color          : #ffffff !important;
  text-decoration: none !important;
}

/* ── Hero ───────────────────────────────────────────────────── */
.hero {
  background: var(--bordeaux-hero);
  padding   : 52px 0;
  text-align: left;
}
.hero--compact { padding: 24px 0; }
.hero__eyebrow {
  font-size     : .6rem;
  letter-spacing: .35em;
  text-transform: uppercase;
  color         : rgba(255,255,255,.4);
  margin-bottom : 14px;
  display       : block;
}
.hero h1 {
  font-family  : var(--font-serif);
  color        : #ffffff;
  font-size    : clamp(1.9rem, 4.2vw, 2.9rem);
  font-weight  : normal;
  margin-bottom: .5em;
}
.hero h1 em { color: #d4b896; font-style: italic; }
.hero__intro {
  font-size  : .9rem;
  color      : rgba(255,255,255,.55);
  margin     : 0 0 28px;
  line-height: 1.85;
}

/* ── Boutons ───────────────────────────────────────────────── */
.btn {
  display       : inline-block;
  font-size     : .85rem;
  font-weight   : 700;
  letter-spacing: .15em;
  text-transform: uppercase;
  text-decoration: none;
  padding       : 16px 40px;
  transition    : background var(--transition), color var(--transition);
  line-height   : 1;
}
.btn--primary {
  background: transparent;
  color     : #ffffff;
  border    : 1px solid rgba(255,255,255,.55);
}
.btn--primary:hover {
  background    : rgba(255,255,255,.15);
  color         : #ffffff;
  text-decoration: none;
}
.btn--cta {
  background: rgba(255,255,255,.1);
  color     : #f5ecd8;
  border    : 1px solid rgba(245,236,216,.6);
}
.btn--cta:hover {
  background    : rgba(255,255,255,.2);
  color         : #ffffff;
  text-decoration: none;
}
.btn--cta--solid {
  background: var(--bordeaux-hero);
  color     : #f5ecd8;
  border    : 1px solid var(--bordeaux-moyen);
}
.btn--cta--solid:hover {
  background    : var(--bordeaux-moyen);
  color         : #ffffff;
  text-decoration: none;
}
.btn-group { display: flex; gap: 12px; flex-wrap: wrap; align-items: center; }
/* ── CTA hero — NE JAMAIS SUPPRIMER ── */
.btn--hero{display:inline-block;font-size:.78rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;text-decoration:none;padding:14px 36px;border:none;color:var(--bordeaux-hero);background:#e8e0d4;transition:background var(--transition),color var(--transition);line-height:1;margin-top:28px}
.btn--hero:hover{background:#c8c0b0;color:var(--bordeaux-profond);text-decoration:none}


/* ── Strip ──────────────────────────────────────────────────── */
.strip {
  background   : var(--bordeaux-header);
  border-top   : 1px solid var(--bordeaux-moyen);
  border-bottom: 1px solid var(--bordeaux-moyen);
}
.strip__inner {
  display  : flex;
  width    : 94%;
  max-width: var(--max-w-wide);
  margin   : 0 auto;
}
.strip__item {
  flex          : 1;
  text-align    : center;
  padding       : 18px 16px;
  border-right  : 1px solid rgba(200,192,176,.18);
  text-decoration: none;
  transition    : background var(--transition);
}
.strip__item:last-child { border-right: none; }
.strip__item:hover { background: rgba(255,255,255,.08); text-decoration: none; }
.strip__title {
  font-family: var(--font-ui);
  font-size  : 1rem;
  font-weight: 400;
  color      : var(--lin);
  margin-bottom: 4px;
  display    : block;
  line-height: 1.1;
}
.strip__desc {
  font-size    : .68rem;
  color        : rgba(200,192,176,.5);
  line-height  : 1.4;
  display      : block;
  letter-spacing: .02em;
}

/* ── Sections ──────────────────────────────────────────────── */
.section { padding: 56px 0; }
.section--creme { background: var(--creme); }
.section--blanc { background: var(--blanc); }
.section--dark  { background: var(--bordeaux-profond); }
.section--dark p  { color: #9a8a8a; }
.section--dark a  { color: var(--lin); }

/* Titres de section : filet bordeaux, label + h2 groupés */
.section__header {
  border-left  : 3px solid var(--bordeaux-accent);
  padding-left : 16px;
  margin-bottom: 1.8em;
}
.section__label {
  font-size     : .68rem;
  letter-spacing: .4em;
  text-transform: uppercase;
  color         : var(--texte-tres-clair);
  margin-bottom : 6px;
  display       : block;
}
.section--dark .section__label { color: #5a3a3a; }
.section__title {
  font-family: var(--font-serif);
  font-size  : clamp(1.45rem, 2.8vw, 2rem);
  font-weight: normal;
  color      : var(--texte-fonce);
  line-height: 1.2;
  margin     : 0;
}
.section--dark .section__title { color: var(--lin-pale); }
.section__title em { color: var(--bordeaux-accent); font-style: italic; }
.section--dark .section__title em { color: var(--lin); }

/* ── Grilles de cartes ─────────────────────────────────────── */
.cards {
  display              : grid;
  grid-template-columns: repeat(3, 1fr);
  gap                  : 20px;
  margin-top           : 1.8em;
}
.cards--4 { grid-template-columns: repeat(4, 1fr); }
.cards--2 { grid-template-columns: repeat(2, 1fr); }

.card {
  background   : var(--blanc);
  border-top   : 2px solid var(--lin);
  padding      : 28px 24px;
  border-radius: var(--rayon-card);
}
.card--dark {
  background   : var(--bordeaux-clair);
  border-top   : 2px solid var(--lin);
  padding      : 28px 24px;
  border-radius: var(--rayon-card);
}
.card--dark h3 { color: var(--lin-pale); }
.card--dark p  { color: #a07a6a; }

/* Cartes ressources style C : 2 colonnes, filet bordeaux gauche */
.cards--ressources {
  display              : grid;
  grid-template-columns: repeat(2, 1fr);
  gap                  : 14px;
  margin-top           : 1.8em;
}
.card--ressource {
  background   : var(--blanc);
  border-left  : 3px solid var(--bordeaux-accent);
  padding      : 24px;
  display      : flex;
  flex-direction: column;
  gap          : 8px;
}
.card--ressource__cat {
  font-size     : .65rem;
  letter-spacing: .3em;
  text-transform: uppercase;
  color         : var(--bordeaux-accent);
  display       : block;
}
.card--ressource h3 { font-size: .95rem; font-weight: 700; color: var(--texte-fonce); line-height: 1.35; margin: 0; }
.card--ressource h3 a { color: var(--texte-fonce); text-decoration: none; }
.card--ressource h3 a:hover { color: var(--bordeaux-accent);  text-decoration: none; }
.card--ressource p { font-size: .88rem; color: var(--texte-clair); line-height: 1.65; margin: 0; }

.card--engage {
  background   : var(--blanc);
  border-top   : 3px solid var(--bordeaux-accent);
  padding      : 28px 22px;
  border-radius: var(--rayon-card);
}
.card--engage__num {
  font-family: var(--font-serif);
  font-size  : 28px;
  color      : #dcc8b8;
  line-height: 1;
  margin-bottom: 14px;
}
.card--engage h3 { color: var(--texte-fonce); font-size: .95rem; margin-bottom: .4em; }
.card--engage p  { font-size: .88rem; color: var(--texte-clair); line-height: 1.7; }

.card__type {
  font-size     : .65rem;
  letter-spacing: .3em;
  text-transform: uppercase;
  color         : var(--texte-tres-clair);
  margin-bottom : 10px;
  display       : block;
}
.card h3    { margin-bottom: .4em; font-size: 1rem; }
.card p     { font-size: .93rem; color: var(--texte-clair); line-height: 1.7; margin-bottom: 14px; }
.card__link { font-size: .8rem; color: var(--bordeaux-accent); font-weight: 700; }
.card__link:hover { color: var(--bordeaux-hero); text-decoration: none; }

/* Cartes style D : horizontal, numéro à gauche */
.card--d {
  background  : #f8f2ee;
  border-top  : 2px solid #ddd0c4;
  padding     : 24px;
  display     : flex;
  gap         : 20px;
  align-items : flex-start;
  border-radius: var(--rayon-card);
}
.card--d__num {
  font-family: var(--font-serif);
  font-size  : 48px;
  color      : #d4b8a0;
  line-height: 1;
  flex-shrink: 0;
  margin-top : 2px;
  user-select: none;
}
.card--d__body { flex: 1; }
.card--d__type {
  font-size     : .65rem;
  letter-spacing: .3em;
  text-transform: uppercase;
  color         : #b0906a;
  margin-bottom : 6px;
  display       : block;
}
.card--d__body h3 { font-size: .95rem; margin-bottom: .35em; color: var(--texte-fonce); }
.card--d__body p  { font-size: .9rem; color: var(--texte-clair); line-height: 1.65; margin: 0; }
/* Cartes occasions style A : liste horizontale, fond alterné */
.cards--occasion { display: flex; flex-direction: column; gap: 0; margin-top: 1.8em; border: 1px solid #ddd0c4; }
.card--occasion {
  padding        : 24px 28px;
  display        : flex;
  justify-content: space-between;
  align-items    : center;
  gap            : 32px;
  border-left    : 3px solid transparent;
  border-bottom  : 1px solid #ddd0c4;
  transition     : border-left-color var(--transition);
}
.card--occasion:last-child { border-bottom: none; }
.card--occasion:nth-child(odd)  { background: #ffffff; }
.card--occasion:nth-child(even) { background: #fdf8f3; }
.card--occasion:hover { border-left-color: var(--bordeaux-accent); ;text-decoration:none}
.card--occasion__body { flex: 1; }
.card--occasion__type {
  font-size     : .65rem;
  letter-spacing: .3em;
  text-transform: uppercase;
  color         : #b0906a;
  margin-bottom : 5px;
  display       : block;
}
.card--occasion__body h3 { font-size: 1rem; font-weight: 700; color: var(--texte-fonce); margin-bottom: .3em; }
.card--occasion__body p  { font-size: .9rem; color: var(--texte-clair); line-height: 1.65; margin: 0; }
.card--occasion__link {
  font-size      : .72rem;
  font-weight    : 700;
  letter-spacing : .15em;
  text-transform : uppercase;
  color          : var(--bordeaux-accent);
  white-space    : nowrap;
  flex-shrink    : 0;
  text-decoration: none;
}
.card--occasion__link:hover { color: var(--bordeaux-hero); text-decoration: none; }

/* Cartes éditoriales (conservées pour usage futur) */
.card--editorial {
  background   : var(--blanc);
  border-top   : 2px solid var(--lin);
  padding      : 24px;
  border-radius: var(--rayon-card);
}
.card--editorial h3 { font-size: .95rem; margin-bottom: .3em; }
.card--editorial h3 a { color: var(--texte-fonce); }
.card--editorial h3 a:hover { color: var(--bordeaux-accent); ;text-decoration:none}
.card--editorial p { font-size: .88rem; color: var(--texte-clair); line-height: 1.65; }
.card__cat {
  font-size     : .62rem;
  letter-spacing: .25em;
  text-transform: uppercase;
  color         : var(--lin-pale);
  background    : var(--bordeaux-accent);
  padding       : 3px 10px;
  display       : inline-block;
  margin-bottom : 10px;
}

/* ── FAQ style 5 : cadre lin, coins bordeaux, fond blanc ─────── */
.faq { display: flex; flex-direction: column; gap: 0; margin-top: 1.8em; position: relative; border: 1px solid var(--lin); background: var(--blanc); }
.faq::before.faq::after.faq__corner-bl.faq__corner-tr { content: ''; position: absolute; width: 14px; height: 14px; border-color: var(--bordeaux-accent); border-style: solid; }
.faq::before  { top: -2px; left: -2px; border-width: 2px 0 0 2px; }
.faq::after   { bottom: -2px; right: -2px; border-width: 0 2px 2px 0; }
.faq__corner-bl { bottom: -2px; left: -2px; border-width: 0 0 2px 2px; }
.faq__corner-tr { top: -2px; right: -2px; border-width: 2px 2px 0 0; }
.faq__item { border-bottom: 1px solid var(--separateur-clair); }
.faq__item:last-child { border-bottom: none; }
.faq__question {
  font-family: var(--font-serif);
  font-size  : 1rem;
  font-weight: bold;
  color      : var(--texte-fonce);
  line-height: 1.35;
  padding    : 20px 52px 20px 22px;
  margin     : 0;
  cursor     : pointer;
  position   : relative;
  user-select: none;
}
.faq__question::after {
  content    : '+';
  position   : absolute;
  right      : 22px;
  top        : 50%;
  transform  : translateY(-50%);
  font-size  : 1.4rem;
  font-weight: 300;
  color      : var(--bordeaux-accent);
  line-height: 1;
  transition : transform var(--transition);
}
.faq__item.is-open .faq__question::after { transform: translateY(-50%) rotate(45deg); }
.faq__answer {
  overflow  : hidden;
  max-height: 0;
  padding   : 0 22px;
  transition: max-height .35s ease, padding .35s ease;
}
.faq__item.is-open .faq__answer {
  max-height: 400px;
  padding   : 0 22px 20px;
  border-top: 1px solid var(--separateur-clair);
}
.faq__answer p { font-size: .93rem; color: var(--texte-clair); line-height: 1.8; margin: 10px 0 0; }

/* ── Bloc CTA ──────────────────────────────────────────────── */
.cta-block {
  background : var(--bordeaux-hero);
  padding    : 56px 0;
  text-align : center;
  border-top : 1px solid var(--bordeaux-moyen);
}
.cta-block h2 {
  font-family  : var(--font-serif);
  font-size    : clamp(1.7rem, 3.5vw, 2.6rem);
  font-weight  : normal;
  color        : #ffffff;
  margin-bottom: .4em;
  line-height  : 1.2;
}
.cta-block h2 em { color: #d4b896; font-style: italic; }
.cta-block p { font-size: .95rem; color: rgba(255,255,255,.55); margin-bottom: 32px; }

/* ── Footer ─────────────────────────────────────────────────── */
.site-footer {
  background: var(--bordeaux-profond);
  border-top: 1px solid var(--separateur);
  padding   : 20px 0;
  margin-top: auto;
}
.site-footer__bottom {
  display        : flex;
  justify-content: center;
  align-items    : center;
  flex-wrap      : wrap;
}
.site-footer__copy { font-size: .75rem; color: #8a6a6a; }
.site-footer__copy a { color: #8a6a6a; text-decoration: none; }
.site-footer__copy a:hover { color: var(--lin); text-decoration: none; }

/* ── Responsive ────────────────────────────────────────────── */
/* ── Responsive ────────────────────────────────────────────── */
@media (max-width: 768px) {
  .site-footer__bottom{text-align:center;justify-content:center;padding:0 16px}
  .btn--hero{display:inline-block;font-size:.78rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;text-decoration:none;padding:14px 36px;border:none;color:var(--bordeaux-hero)!important;background:#e8e0d4!important;line-height:1;margin-top:28px}
  .hub-grid-2,.hub-grid-3,.hub-superhub,.hub-corpo-grid,.guide-grid{grid-template-columns:1fr}
  .site-header__inner { flex-wrap: wrap; gap: 12px; }
  .cards--4 { grid-template-columns: repeat(2, 1fr); }
  .cards--2 { grid-template-columns: 1fr; }
  .cards--ressources { grid-template-columns: 1fr; }
  .strip__inner { flex-wrap: wrap; }
  .strip__item  { flex: 0 0 50%; border-bottom: 1px solid rgba(200,192,176,.12); }
  .strip__item:nth-child(2) { border-right: none; }
  .strip__item:nth-child(3).strip__item:nth-child(4) { border-bottom: none; }
  .strip__item:nth-child(4) { border-right: none; }
  .card--occasion { flex-direction: column; align-items: flex-start; gap: 12px; }
  .card--occasion__link { align-self: flex-start; }
}
@media (max-width: 480px) {
  .cards--4 { grid-template-columns: 1fr; }
}
  
.tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:1.4em}
.tag{font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:4px 10px;background:transparent;color:rgba(255,255,255,.55);border:1px solid rgba(255,255,255,.55)}


.site-nav__item{position:relative}
.site-nav__btn{font-size:.78rem;color:#e8e0d4;padding:6px 12px;background:none;border:none;font-family:var(--font-ui);cursor:pointer;display:flex;align-items:center;gap:5px;transition:color var(--transition);white-space:nowrap;text-transform:uppercase;letter-spacing:.08em;font-weight:400}
.site-nav__btn:hover.site-nav__btn.is-open{color:var(--lin)}
.site-nav__chevron{font-size:.55rem;transition:transform var(--transition);display:inline-block;line-height:1}
.site-nav__btn.is-open .site-nav__chevron{transform:rotate(180deg)}
.mega-panel a{font-size:.62rem!important;font-weight:400!important;color:#e8e0d4!important;text-transform:uppercase!important;letter-spacing:.06em!important;text-decoration:none!important;line-height:1.6!important}.mega-panel a:hover{color:#c8c0b0!important;text-decoration:none!important}
.mega-panel{display:none;position:absolute;top:calc(100% + 2px);left:50%;transform:translateX(-50%);background:#3d1010;border:1px solid #5c1a1a;border-top:2px solid #8b2020;z-index:500;min-width:260px}
.mega-panel.is-open{display:block}
.mega-cols{display:grid}
.mega-col{padding:18px 24px}
.mega-col__label{font-size:.58rem;font-weight:700;letter-spacing:.28em;text-transform:uppercase;color:#e8e0d4;margin-bottom:10px;display:block;padding-bottom:8px;border-bottom:1px solid #5c1a1a}
.mega-link{display:block;padding:5px 0;font-size:.58rem;font-weight:600;color:#e8e0d4!important;text-decoration:none;line-height:1.6;transition:color var(--transition);text-transform:uppercase;letter-spacing:.06em}
.mega-link:hover{color:#c8c0b0!important;text-decoration:none}
.mega-link--hub{font-weight:700;color:#e8e0d4!important;margin-bottom:4px}
.mega-link--hub:hover{color:#c8c0b0!important}
.mega-link--more{font-size:.74rem;color:#e8e0d4;display:block;margin-top:8px;padding-top:8px;border-top:1px solid #5c1a1a;text-decoration:none;text-transform:uppercase;letter-spacing:.06em;opacity:.7}
.mega-link--more:hover{color:#c8c0b0!important;text-decoration:none}
.site-nav__burger{display:none;background:none;border:none;cursor:pointer;padding:6px;flex-direction:column;gap:5px}
.site-nav__burger span{display:block;width:22px;height:2px;background:var(--lin);transition:all .25s}
.site-nav__burger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.site-nav__burger.is-open span:nth-child(2){opacity:0}
.site-nav__burger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-drawer{display:none!important;background:#2a1010;border-top:1px solid #5c1a1a;position:fixed;top:80px;left:0;right:0;max-height:calc(100vh - 80px);overflow-y:auto;z-index:99}
.mobile-drawer.is-open{display:block!important}
.mob-section{border-bottom:1px solid rgba(200,192,176,.1)}
.mob-section__btn{width:100%;background:none;border:none;padding:13px 20px;font-size:.82rem;color:var(--lin);text-align:left;cursor:pointer;font-family:var(--font-ui);display:flex;justify-content:space-between;align-items:center}
.mob-section__btn .mob-ch{font-size:.6rem;transition:transform .2s;display:inline-block}
.mob-section__btn.is-open .mob-ch{transform:rotate(180deg)}
.mob-links{display:none;background:rgba(0,0,0,.2)}
.mob-links.is-open{display:block}
.mob-link{display:block;padding:9px 28px;font-size:.8rem;color:#9a8a7a;text-decoration:none;border-bottom:1px solid rgba(200,192,176,.06);line-height:1.4}
.mob-link:hover{color:var(--lin);text-decoration:none}
.mob-link--hub{color:var(--lin);font-weight:700;background:rgba(255,255,255,.04);padding-left:20px}
.mob-link--hub::before{content:'→ ';color:#8b2020}
.mob-cta{display:block;margin:14px 20px 16px;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.6);color:#ffffff;text-align:center;padding:11px;font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;text-decoration:none;transition:background var(--transition),color var(--transition)}
.mob-cta:hover{background:rgba(255,255,255,.32);color:#ffffff;text-decoration:none}
@media(max-width:768px){.site-nav__item{display:none}.site-nav__btn{display:none}.site-nav__cta{display:none!important}.site-nav__burger{display:flex!important;margin-left:auto}}
@media(min-width:769px){.mobile-drawer{display:none!important}.site-nav__burger{display:none!important}}

/* ══════════════════════════════════════════════
   Règles spécifiques pages et composants
   ══════════════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
h1,h2{font-family:var(--font-serif);color:var(--texte-fonce);line-height:1.2;margin-bottom:.6em}
h3,h4{font-family:var(--font-ui);color:var(--texte-fonce);line-height:1.2;margin-bottom:.6em}
.logo__dot{display:inline-block;width:9px;height:9px;border-radius:50%;background:var(--bordeaux-hero);flex-shrink:0;margin-top:8px}
.logo__pro{color:var(--lin)}
.cards--formats{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:2em}
.card--format{background:var(--blanc);border-top:3px solid var(--bordeaux-accent);padding:26px 22px}
.card--format h3{font-size:1rem;font-weight:700;margin-bottom:.8em}
.card--format p{font-size:.88rem;color:var(--texte-clair);line-height:1.65;margin:0 0 1em}
.card--format p:last-child{margin-bottom:0}
.niveau-badge{display:inline-flex;align-items:center;gap:8px;margin-bottom:14px}
.niveau-pastilles{display:flex;gap:3px}
.pastille{width:10px;height:10px;border-radius:50%;background:var(--bordeaux-accent)}
.pastille--off{background:var(--lin-clair)}
.niveau-label{font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--bordeaux-accent)}
.niveau-sub{font-size:.68rem;color:var(--texte-tres-clair);display:block;margin-top:1px}
.criteres{list-style:none;padding:0;margin-top:1.6em}
.critere{display:grid;grid-template-columns:46px 1fr;gap:18px;align-items:start;padding:20px 0;border-bottom:1px solid var(--separateur-clair)}
.critere:last-child{border-bottom:none}
.critere__num{width:46px;height:46px;border-radius:50%;background:var(--bordeaux-moyen);color:var(--lin-clair);font-family:var(--font-serif);font-size:1.15rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
.critere__body h4{margin-bottom:.3em}
.critere__body p{font-size:.9rem;color:var(--texte-clair);line-height:1.7;margin:0}
.timeline{display:flex;flex-direction:column;gap:0;margin-top:1.8em;position:relative}
.timeline::before{content:'';position:absolute;left:23px;top:8px;bottom:8px;width:2px;background:var(--lin-clair)}
.timeline__step{display:grid;grid-template-columns:46px 1fr;gap:22px;padding:0 0 30px;position:relative}
.timeline__step:last-child{padding-bottom:0}
.timeline__dot{width:46px;height:46px;border-radius:50%;background:var(--bordeaux-accent);color:#fff;font-family:var(--font-serif);font-size:1.1rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;z-index:1}
.timeline__body{padding-top:9px}
.timeline__body h4{margin-bottom:.3em}
.timeline__body p{font-size:.9rem;color:var(--texte-clair);line-height:1.7;margin:0}
.zones{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:1.6em}
.zone{background:var(--lin-clair);padding:13px 15px;border-left:2px solid var(--bordeaux-accent)}
.zone__dept{font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:var(--texte-tres-clair);display:block;margin-bottom:3px}
.zone__nom{font-size:.88rem;font-weight:700;color:var(--texte-fonce)}
.faq::before,.faq::after,.faq__corner-bl,.faq__corner-tr{content:'';position:absolute;width:14px;height:14px;border-color:var(--bordeaux-accent);border-style:solid}
.site-nav__btn:hover,.site-nav__btn.is-open{color:var(--lin)}
ul,ol{padding-left:1.4em}
.devis-hero{background:var(--bordeaux-hero);padding:52px 0 48px}
.devis-hero__grid{display:grid;grid-template-columns:1fr 420px;gap:48px;align-items:start}
.devis-hero__left h1{font-family:var(--font-serif);color:#fff;font-size:clamp(1.75rem,3.5vw,2.4rem);font-weight:normal;margin-bottom:.5em;line-height:1.2}
.devis-hero__left h1 em{color:#d4b896;font-style:italic}
.devis-hero__left p{font-size:.9rem;color:rgba(255,255,255,.6);line-height:1.8;margin-bottom:0}
.devis-hero .form-card{background:#fff;border-radius:4px;padding:32px 28px;box-shadow:0 4px 24px rgba(0,0,0,.18)}
.devis-hero .form-card__title{font-family:var(--font-serif);font-size:1.2rem;font-weight:normal;color:var(--bordeaux-header);margin-bottom:4px}
.devis-hero .form-card__sub{font-size:.78rem;color:var(--texte-tres-clair);letter-spacing:.06em;margin-bottom:20px;display:block}
.devis-hero .form-steps{display:flex;gap:0;margin-bottom:24px;border:1px solid #d8cfc4;border-radius:3px;overflow:hidden}
.devis-hero .form-step{flex:1;padding:10px 6px;font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--texte-tres-clair);background:#f8f4f0;text-align:center;border-right:1px solid #d8cfc4}
.devis-hero .form-step:last-child{border-right:none}
.devis-hero .form-step.is-active{background:var(--bordeaux-hero);color:#fff}
.devis-hero .form-group{margin-bottom:14px}
.devis-hero .form-group label{display:block;font-size:.78rem;font-weight:700;color:var(--texte-clair);margin-bottom:5px;letter-spacing:.04em}
.devis-hero .form-group label .req{color:var(--bordeaux-accent)}
.devis-hero .form-group input, .devis-hero .form-group select, .devis-hero .form-group textarea{width:100%;border:1px solid #d8d0c8;border-radius:3px;padding:11px 14px;font-family:var(--font-ui);font-size:.88rem;color:var(--texte-fonce);background:#fdfaf7;transition:border-color var(--transition)}
.devis-hero .form-group input:focus, .devis-hero .form-group select:focus, .devis-hero .form-group textarea:focus{outline:none;border-color:var(--bordeaux-accent)}
.devis-hero .form-group select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23b0a090' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}
.devis-hero .form-group textarea{resize:vertical;min-height:80px}
.devis-hero .form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.devis-hero .btn-submit{width:100%;background:var(--bordeaux-hero);color:#fff;border:none;padding:16px;font-family:var(--font-ui);font-size:.9rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;border-radius:3px;transition:background var(--transition);margin-top:6px}
.devis-hero .btn-submit:hover{background:var(--bordeaux-moyen);text-decoration:none}
.devis-hero .form-legal{font-size:.7rem;color:var(--texte-tres-clair);line-height:1.6;margin-top:14px}
.devis-links{padding:24px 0;background:var(--bordeaux-header)}
.devis-links__inner{width:94%;max-width:var(--max-w-wide);margin:0 auto}
.devis-links__label{font-size:.65rem;letter-spacing:.35em;text-transform:uppercase;color:#6a4a3a;margin-bottom:10px;display:block}
.devis-links__grid{display:flex;flex-wrap:wrap;gap:8px}
.devis-links__grid a{display:inline-block;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);color:#b0a090;font-size:.73rem;padding:7px 12px;text-decoration:none;border-radius:2px;transition:background var(--transition),color var(--transition)}
.devis-links__grid a:hover{background:rgba(255,255,255,.14);color:#e8e0d4;text-decoration:none}
.devis-links__grid a.is-current{background:rgba(255,255,255,.2);color:#e8e0d4;border-color:rgba(255,255,255,.35)}
.card--tarif{background:var(--blanc);border-top:3px solid var(--bordeaux-accent);padding:24px 20px}
.card--tarif__type{font-size:.65rem;letter-spacing:.3em;text-transform:uppercase;color:var(--texte-tres-clair);margin-bottom:8px;display:block}
.card--tarif h3{font-size:.95rem;font-weight:700;color:var(--texte-fonce);margin-bottom:.5em}
.card--tarif__prix{font-family:var(--font-serif);font-size:1.4rem;color:var(--bordeaux-accent);margin-bottom:.4em}
.card--tarif p{font-size:.85rem;color:var(--texte-clair);line-height:1.65}
.devis-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:1.8em}
.devis-card{display:block;background:var(--blanc);border-top:3px solid var(--bordeaux-accent);padding:22px 20px;text-decoration:none;transition:background var(--transition)}
.devis-card:hover{background:var(--lin-clair);text-decoration:none}
.devis-card__cat{font-size:.65rem;letter-spacing:.3em;text-transform:uppercase;color:var(--bordeaux-accent);display:block;margin-bottom:6px}
.devis-card__name{font-family:var(--font-serif);font-size:1.05rem;font-weight:normal;color:var(--texte-fonce);display:block;margin-bottom:6px;line-height:1.3}
.devis-card__desc{font-size:.82rem;color:var(--texte-clair);display:block;line-height:1.5}
.form-wrap{background:var(--creme);padding:56px 0;border-top:1px solid var(--separateur-clair)}

.form-card{background:var(--blanc);padding:40px 36px;max-width:640px;margin:0 auto;border-top:3px solid var(--bordeaux-accent);border-left:1px solid var(--separateur-clair);border-right:1px solid var(--separateur-clair);border-bottom:1px solid var(--separateur-clair)}
.form-card__eyebrow{font-size:.6rem;letter-spacing:.4em;text-transform:uppercase;color:var(--texte-tres-clair);display:block;margin-bottom:8px;text-align:center}
.form-card__title{font-family:var(--font-serif);font-size:1.5rem;font-weight:normal;color:var(--texte-fonce);margin-bottom:28px;text-align:center;display:block}
.form-sep{font-size:.6rem;font-weight:700;letter-spacing:.3em;text-transform:uppercase;color:var(--texte-tres-clair);margin:24px 0 14px;display:block;padding-bottom:8px;border-bottom:1px solid var(--separateur-clair)}
.form-group{margin-bottom:14px}
.form-group label{display:block;font-size:.78rem;font-weight:700;color:var(--texte-clair);margin-bottom:5px}
.form-group label .req{color:var(--bordeaux-accent)}
.form-group label .opt{font-size:.7rem;font-weight:400;color:var(--texte-tres-clair)}
.form-group input,.form-group select,.form-group textarea{width:100%;border:1px solid #d8d0c8;border-radius:3px;padding:10px 12px;font-family:var(--font-ui);font-size:.88rem;color:var(--texte-fonce);background:#fff;transition:border-color var(--transition)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--bordeaux-accent)}
.form-group textarea{resize:vertical;min-height:100px}
.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.btn-submit{width:100%;background:var(--bordeaux-hero);color:#fff;border:none;padding:16px;font-family:var(--font-ui);font-size:.82rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;cursor:pointer;border-radius:3px;margin-top:8px}
.btn-submit:hover{background:var(--bordeaux-moyen)}
.form-legal{font-size:.63rem;color:var(--texte-tres-clair);line-height:1.5;margin-top:16px;text-align:center}
.form-msg{padding:14px;font-size:.88rem;margin-bottom:16px;display:none}
.form-msg--ok{background:#eaf3de;color:#3B6D11;border-left:3px solid #3B6D11}
.form-msg--err{background:#FCEBEB;color:#A32D2D;border-left:3px solid #A32D2D}
@media (max-width:380px) {
}
@media (max-width:480px) {
.zones{grid-template-columns:1fr}.cards--formats{grid-template-columns:1fr}
.cards--4 { grid-template-columns: 1fr; }
}
@media (max-width:600px) {
.strip__inner{flex-wrap:wrap}.strip__item{flex:0 0 50%;border-bottom:1px solid rgba(200,192,176,.12)}.strip__item:nth-child(2){border-right:none}.strip__item:nth-child(3).strip__item:nth-child(4){border-bottom:none}.strip__item:nth-child(4){border-right:none}
}
@media (max-width:768px) {
.site-header__inner{flex-wrap:wrap;gap:12px}.cards--formats{grid-template-columns:1fr}.zones{grid-template-columns:repeat(2,1fr)}.cards--ressources{grid-template-columns:1fr}.strip__inner{flex-wrap:wrap}.strip__item{flex:0 0 50%;border-bottom:1px solid rgba(200,192,176,.12)}.strip__item:nth-child(2){border-right:none}.strip__item:nth-child(3).strip__item:nth-child(4){border-bottom:none}.strip__item:nth-child(4){border-right:none}
.site-header__inner { flex-wrap: wrap; gap: 12px; } .cards--4 { grid-template-columns: repeat(2, 1fr); } .cards--2 { grid-template-columns: 1fr; } .cards--ressources { grid-template-columns: 1fr; } .strip__inner { flex-wrap: wrap; } .strip__item { flex: 0 0 50%; border-bottom: 1px solid rgba(200,192,176,.12); } .strip__item:nth-child(2) { border-right: none; } .strip__item:nth-child(3).strip__item:nth-child(4) { border-bottom: none; } .strip__item:nth-child(4) { border-right: none; } .card--occasion { flex-direction: column; align-items: flex-start; gap: 12px; } .card--occasion__link { align-self: flex-start; }
.site-header__inner { flex-wrap: wrap; gap: 12px; } .cards--4 { grid-template-columns: repeat(2, 1fr); } .cards--2 { grid-template-columns: 1fr; } .cards--ressources { grid-template-columns: 1fr; } .strip__inner { flex-wrap: wrap; } .card--occasion { flex-direction: column; align-items: flex-start; gap: 12px; } .card--occasion__link { align-self: flex-start; }
.site-header__inner { flex-wrap: wrap; gap: 12px; } .cards--4 { grid-template-columns: repeat(2, 1fr); } .cards--2 { grid-template-columns: 1fr; } .cards--ressources { grid-template-columns: 1fr; }
}

/* ── Hub corpo (page événements professionnels) ── */
.hub-corpo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:1.8em}
.hub-corpo-card{display:block;background:var(--blanc);border-top:3px solid var(--bordeaux-accent);padding:26px 22px;text-decoration:none;transition:background var(--transition)}
.hub-corpo-card:hover{background:var(--lin-clair);text-decoration:none}
.hub-corpo-card__cat{font-size:.65rem;letter-spacing:.3em;text-transform:uppercase;color:var(--bordeaux-accent);display:block;margin-bottom:8px}
.hub-corpo-card__name{font-family:var(--font-serif);font-size:1.1rem;font-weight:normal;color:var(--texte-fonce);display:block;margin-bottom:8px;line-height:1.25}
.hub-corpo-card__desc{font-size:.85rem;color:var(--texte-clair);display:block;line-height:1.6}


/* ── Guide cards (page guides et conseils) ── */
.guide-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:1.8em}
.guide-card{display:block;background:var(--blanc);border-top:3px solid var(--bordeaux-accent);padding:26px 22px;text-decoration:none;transition:background var(--transition)}
.guide-card:hover{background:var(--lin-clair);text-decoration:none}
.guide-card__cat{font-size:.65rem;letter-spacing:.3em;text-transform:uppercase;color:var(--bordeaux-accent);display:block;margin-bottom:8px}
.guide-card__name{font-family:var(--font-serif);font-size:1.05rem;font-weight:normal;color:var(--texte-fonce);display:block;margin-bottom:8px;line-height:1.3}
.guide-card__desc{font-size:.85rem;color:var(--texte-clair);display:block;line-height:1.6}


/* ── Blocs géo (pages France, régions, villes, départements) ── */
.geo-levels{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:2em}
.geo-level{background:var(--blanc);padding:32px 28px;border-top:3px solid var(--bordeaux-accent);display:flex;flex-direction:column;gap:16px}
.geo-level__num{font-family:var(--font-serif);font-size:2.8rem;color:var(--bordeaux-accent);line-height:1;opacity:.35}
.geo-level__title{font-family:var(--font-serif);font-size:1.15rem;font-weight:normal;color:var(--texte-fonce);margin:0}
.geo-level__desc{font-size:.85rem;color:var(--texte-clair);line-height:1.7;margin:0;flex:1}
.geo-level__list{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:6px}
.geo-level__list li{font-size:.7rem;color:var(--texte-tres-clair);background:var(--creme);padding:3px 8px;margin:0}
.geo-level__link{font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--bordeaux-accent);text-decoration:none;display:inline-flex;align-items:center;gap:6px;margin-top:auto;padding-top:16px;border-top:1px solid var(--separateur-clair)}
.geo-level__link:hover{color:var(--bordeaux-hero);text-decoration:none}
.reassurance{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--separateur-clair);margin-top:2em}
.reassurance__item{padding:28px 24px;border-right:1px solid var(--separateur-clair);display:flex;flex-direction:column;gap:10px}
.reassurance__item:nth-child(odd){background:var(--blanc)}
.reassurance__item:nth-child(even){background:var(--creme)}
.reassurance__item:last-child{border-right:none}
.reassurance__icon{font-size:1.4rem;line-height:1;color:var(--bordeaux-accent)}
.reassurance__title{font-family:var(--font-serif);font-size:1rem;font-weight:normal;color:var(--texte-fonce);margin:0;line-height:1.3}
.reassurance__desc{font-size:.82rem;color:var(--texte-clair);line-height:1.65;margin:0}
.process{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:2em}
.process__step{display:flex;flex-direction:column;gap:14px}
.process__num{width:64px;height:64px;border-radius:50%;background:var(--bordeaux-hero);color:#fff;font-family:var(--font-serif);font-size:1.4rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.process__title{font-size:.95rem;font-weight:700;color:var(--texte-fonce);margin:0}
.process__desc{font-size:.85rem;color:var(--texte-clair);line-height:1.7;margin:0}
.process__detail{font-size:.78rem;color:var(--texte-tres-clair);margin:0;font-style:italic}
.process__cta{text-align:center;margin-top:2.5em}
@media(max-width:768px){
.geo-levels{grid-template-columns:1fr;gap:2px}
.reassurance{grid-template-columns:1fr 1fr}
.reassurance__item:nth-child(2){border-right:none}
.reassurance__item:nth-child(3),.reassurance__item:nth-child(4){border-top:1px solid var(--separateur-clair)}
.process{grid-template-columns:1fr;gap:28px}
}
@media(max-width:480px){
.reassurance{grid-template-columns:1fr}
.reassurance__item{border-right:none;border-bottom:1px solid var(--separateur-clair)}
.reassurance__item:last-child{border-bottom:none}
}
.hub-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin-top:1.4em}
.hub-card{
background:var(--blanc);
border:1px solid var(--separateur-clair);
border-radius:4px;
padding:11px 12px 10px;
text-decoration:none;
display:flex;
flex-direction:column;
gap:2px;
position:relative;
overflow:hidden;
transition:border-color var(--transition);
}
.hub-card:hover{border-color:var(--bordeaux-accent);text-decoration:none}
.hub-card__bg{
position:absolute;
top:4px;right:8px;
font-family:var(--font-serif);
font-size:34px;
color:var(--separateur-clair);
line-height:1;
pointer-events:none;
font-weight:normal;
}
.hub-card__num{font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--texte-tres-clair);display:block;margin-bottom:3px}
.hub-card__name{font-size:.82rem;font-weight:700;color:var(--texte-fonce);position:relative;line-height:1.25}
.hub-card__region{font-size:.68rem;color:var(--texte-tres-clair);letter-spacing:.03em;position:relative}
.hub-card__dept{font-size:.62rem;color:var(--texte-tres-clair);letter-spacing:.02em;position:relative;margin-top:2px}
@media(max-width:768px){.hub-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}


/* ── Carte spectacle de magie (section formats) ── */
.sc-list{background:#faf7f2;border:1px solid var(--separateur-clair);margin-top:1.8em}
.sc-item{display:grid;grid-template-columns:80px 1fr;border-bottom:1px solid var(--separateur-clair)}
.sc-item:last-child{border-bottom:none}
.sc-left{display:flex;flex-direction:column;align-items:center;padding:28px 0 24px;border-right:1px solid var(--separateur-clair);gap:8px}
.sc-num{font-family:var(--font-serif);font-size:2rem;color:#d4b896;line-height:1;font-weight:normal}
.sc-vline{width:1px;background:var(--separateur-clair);flex:1;min-height:20px}
.sc-body{padding:24px 28px}
.sc-tag{font-size:.58rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--texte-tres-clair);display:block;margin-bottom:8px}
.sc-subtitle{font-family:var(--font-serif);font-size:1.05rem;font-weight:normal;color:var(--texte-fonce);margin-bottom:10px;line-height:1.35}
.sc-subtitle em{color:var(--bordeaux-accent);font-style:italic}
@media(max-width:768px){
.sc-item{grid-template-columns:56px 1fr}
.sc-left{padding:20px 0 20px;}
.sc-num{font-size:1.4rem}
.sc-body{padding:18px 16px}
}


/* ── Section Edito — sous-titre entre deux filets ── */
.edito-sub{display:flex;align-items:center;gap:20px;margin:1.8em 0 1.2em}
.edito-sub__line{flex:1;height:1px;background:var(--separateur-clair)}
.edito-sub__title{font-family:var(--font-serif);font-size:1.15rem;font-weight:normal;color:var(--bordeaux-accent);font-style:italic;order:-1}
@media(max-width:768px){.edito-sub__line{display:none}}


/* ── Processus (3 cartes côte à côte) ── */
.process-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:1.6em}
.process-card{background:var(--blanc);border:0.5px solid var(--separateur-clair);padding:24px 20px;text-align:center}
.process-card__num{font-family:var(--font-serif);font-size:3rem;color:#d4b896;line-height:1;font-weight:normal;margin-bottom:10px}
.process-card__sep{width:24px;height:2px;background:var(--bordeaux-accent);margin:0 auto 14px}
.process-card__title{font-family:var(--font-serif);font-size:.95rem;font-weight:normal;color:var(--texte-fonce);margin-bottom:10px;line-height:1.3}
.process-card__text{font-size:.82rem;color:var(--texte-clair);line-height:1.8;margin-bottom:8px;text-align:left}
.process-card__detail{font-size:.7rem;color:var(--texte-tres-clair);font-style:italic;display:block;text-align:center}
.process-cta{text-align:center;margin-top:2em}
.process-cta__sub{font-size:.72rem;color:var(--texte-tres-clair);margin-top:8px;display:block}
@media(max-width:768px){.process-grid{grid-template-columns:1fr}}


/* ── FAQ accordéon (design A) ── */
.faq-a{border:0.5px solid var(--separateur-clair)}
.faq-a__item{border-bottom:0.5px solid var(--separateur-clair)}
.faq-a__item:last-child{border-bottom:none}
.faq-a__q{padding:16px 48px 16px 20px;font-family:var(--font-serif);font-size:.95rem;font-weight:normal;color:var(--texte-fonce);cursor:pointer;position:relative;line-height:1.4;margin:0;user-select:none}
.faq-a__q::after{content:'+';position:absolute;right:18px;top:50%;transform:translateY(-50%);font-size:1.2rem;font-weight:300;color:var(--bordeaux-accent);transition:transform var(--transition)}
.faq-a__item.is-open .faq-a__q::after{transform:translateY(-50%) rotate(45deg)}
.faq-a__ans{display:none !important;padding:14px 20px 16px;border-top:0.5px solid var(--separateur-clair)}
.faq-a__item.is-open .faq-a__ans{display:block !important}
.faq-a__ans p{font-size:.85rem;color:var(--texte-clair);line-height:1.85;margin:0}


/* ── Formules (design C horizontal) ── */
.f-list{border:0.5px solid var(--separateur-clair);margin-top:1.6em}
.f-item{display:grid;grid-template-columns:160px 80px 1fr;border-bottom:0.5px solid var(--separateur-clair);align-items:center}
.f-item:last-child{border-bottom:none}
.f-item:nth-child(even){background:#faf7f2}
.f-left{padding:18px 16px;border-right:0.5px solid var(--separateur-clair);align-self:stretch;display:flex;flex-direction:column;justify-content:center}
.f-name{font-family:var(--font-serif);font-size:.95rem;font-weight:normal;color:var(--texte-fonce)}
.f-sub{font-size:.68rem;color:var(--texte-tres-clair);font-style:italic;display:block;margin-top:3px}
.f-mid{padding:18px 16px;border-right:0.5px solid var(--separateur-clair);display:flex;align-items:center;justify-content:center;align-self:stretch}
.f-right{padding:18px 20px}
.f-h3{font-family:var(--font-serif);font-size:.92rem;font-weight:normal;color:var(--bordeaux-accent);margin-bottom:8px}
.f-text{font-size:.82rem;color:var(--texte-clair);line-height:1.8;margin-bottom:.5em}
.f-text:last-child{margin-bottom:0}
/* ── Pastilles formules ── */
.dots{display:flex;flex-direction:row;gap:4px}
.dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.dot-on{background:var(--bordeaux-accent)}
.dot-off{background:var(--separateur-clair)}


/* ── Section Choisir (design A grille 2x2) ── */
.ch-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;margin-top:1.6em}
.ch-card{background:var(--blanc);border:0.5px solid var(--separateur-clair);padding:22px 20px;position:relative;overflow:hidden}
.ch-num{position:absolute;top:-8px;right:12px;font-family:var(--font-serif);font-size:4rem;color:#e0d8d0;line-height:1;font-weight:normal;user-select:none}
.ch-title{font-family:var(--font-serif);font-size:.95rem;font-weight:normal;color:var(--bordeaux-accent);margin-bottom:8px;position:relative}
.ch-text{font-size:.82rem;color:var(--texte-clair);line-height:1.8;position:relative}
@media(max-width:768px){.ch-grid{grid-template-columns:1fr}}

@media(max-width:768px){.f-item{grid-template-columns:1fr}.f-left{border-right:none;border-bottom:0.5px solid var(--separateur-clair);padding-bottom:12px}.f-mid{border-right:none;justify-content:flex-start;padding:12px 16px}.f-right{padding:0 16px 18px}}
}


/* ── Superhub (pages hub de hub) ── */
.superhub-bloc{margin-bottom:0}
.bloc-sep{height:25px}
.superhub-bloc+.superhub-bloc{padding-top:2.5em;border-top:1px solid var(--separateur-clair)}
.superhub-bloc .hub-grid{margin-top:.8em}
.superhub-bloc__header{display:flex;align-items:baseline;gap:16px;margin-bottom:1.2em;padding-bottom:.6em;border-bottom:1px solid var(--separateur-clair)}
.superhub-bloc__title{font-family:var(--font-serif);font-size:1.3rem;font-weight:normal;color:var(--texte-fonce);margin:0}
.superhub-bloc__count{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--texte-tres-clair)}
.superhub-bloc__link{font-size:.75rem;color:var(--bordeaux-accent);text-decoration:none;margin-left:auto}
.superhub-bloc__link:hover{color:var(--bordeaux-hero);text-decoration:none}


/* ── Hub grilles et cards riches (pages événements privés/pros) ── */
.hub-grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:1.8em}
.hub-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:1.8em}
.hub-card-rich{display:block;background:var(--blanc);border-top:3px solid var(--bordeaux-accent);padding:26px 22px;text-decoration:none;transition:background var(--transition)}
.hub-card-rich:hover{background:var(--lin-clair);text-decoration:none}
.hub-card-rich--soon{border-top-color:var(--lin);opacity:.7;cursor:default}
.hub-card-rich__cat{font-size:.65rem;letter-spacing:.3em;text-transform:uppercase;color:var(--bordeaux-accent);display:block;margin-bottom:8px}
.hub-card-rich--soon .hub-card-rich__cat{color:var(--texte-tres-clair)}
.hub-card-rich__name{font-family:var(--font-serif);font-size:1.1rem;font-weight:normal;color:var(--texte-fonce);display:block;margin-bottom:8px;line-height:1.25}
.hub-card-rich__desc{font-size:.85rem;color:var(--texte-clair);display:block;line-height:1.6}
.hub-card-rich__badge{font-size:.6rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--texte-tres-clair);display:inline-block;margin-top:10px;border:1px solid var(--separateur-clair);padding:3px 8px}

/* ── Page 404 ── */
.e404{position:relative;overflow:hidden;min-height:480px;display:flex;align-items:center;justify-content:center;text-align:center;background:var(--bordeaux-profond)}
.e404__bg{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.e404__star{position:absolute;width:3px;height:3px;border-radius:50%;background:#c8c0b0;opacity:0;animation:sparkle var(--d,2s) var(--delay,0s) infinite}
.e404__number{font-family:var(--font-serif);font-size:clamp(6rem,16vw,11rem);font-weight:normal;color:transparent;-webkit-text-stroke:1px rgba(200,192,176,.25);line-height:1;display:block;letter-spacing:.05em;position:relative;z-index:1;user-select:none}
.e404__wand{display:inline-block;animation:wand 3s ease-in-out infinite;transform-origin:bottom center;font-size:clamp(3.5rem,9vw,6.5rem);position:relative;z-index:2;filter:drop-shadow(0 0 24px rgba(200,192,176,.3))}
.e404__wand::after{content:'✦';position:absolute;top:-8px;right:-8px;font-size:1.2rem;color:#e8e0d4;animation:sparkle 1.5s .3s infinite}
.e404__inner{position:relative;z-index:3;padding:60px 24px}
.e404__title{font-family:var(--font-serif);font-size:clamp(1.4rem,3vw,2rem);color:var(--lin-clair);font-weight:normal;margin:1rem 0 .6rem;animation:reveal .7s .2s both}
.e404__sub{color:var(--texte-tres-clair);font-size:.95rem;line-height:1.8;max-width:440px;margin:0 auto 2.4rem;animation:reveal .7s .35s both}
.e404__quote{font-family:var(--font-serif);font-style:italic;color:rgba(200,192,176,.35);font-size:.85rem;margin-bottom:2.4rem;animation:reveal .7s .5s both}
.e404__links{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;animation:reveal .7s .6s both}
.e404__btn{display:inline-block;padding:10px 24px;text-decoration:none;font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;transition:all .25s}
.e404__btn--primary{background:var(--bordeaux-accent);color:#fff;border:1px solid var(--bordeaux-accent)}
.e404__btn--primary:hover{background:var(--bordeaux-moyen);border-color:var(--bordeaux-moyen);color:#fff;text-decoration:none}
.e404__btn--ghost{background:transparent;color:var(--lin);border:1px solid rgba(200,192,176,.25)}
.e404__btn--ghost:hover{background:rgba(200,192,176,.08);color:var(--lin-clair);border-color:rgba(200,192,176,.5);text-decoration:none}
.e404__divider{width:40px;height:1px;background:rgba(200,192,176,.2);margin:0 auto 1.4rem}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@keyframes sparkle{0%,100%{opacity:0;transform:scale(0) rotate(0deg)}50%{opacity:1;transform:scale(1) rotate(180deg)}}
@keyframes reveal{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
@keyframes wand{0%,100%{transform:rotate(-15deg)}50%{transform:rotate(5deg)}}
@keyframes trail{0%{opacity:1;transform:scale(1)}100%{opacity:0;transform:scale(0) translateY(-20px)}}

.e404{position:relative;overflow:hidden;min-height:480px;display:flex;align-items:center;justify-content:center;text-align:center;background:var(--bordeaux-profond)}
.e404__bg{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.e404__star{position:absolute;width:3px;height:3px;border-radius:50%;background:#c8c0b0;opacity:0;animation:sparkle var(--d,2s) var(--delay,0s) infinite}
.e404__number{font-family:var(--font-serif);font-size:clamp(6rem,16vw,11rem);font-weight:normal;color:transparent;-webkit-text-stroke:1px rgba(200,192,176,.25);line-height:1;display:block;letter-spacing:.05em;position:relative;z-index:1;user-select:none}
.e404__wand{display:inline-block;animation:wand 3s ease-in-out infinite;transform-origin:bottom center;font-size:clamp(3.5rem,9vw,6.5rem);position:relative;z-index:2;filter:drop-shadow(0 0 24px rgba(200,192,176,.3))}
.e404__wand::after{content:'✦';position:absolute;top:-8px;right:-8px;font-size:1.2rem;color:#e8e0d4;animation:sparkle 1.5s .3s infinite}
.e404__inner{position:relative;z-index:3;padding:60px 24px}
.e404__title{font-family:var(--font-serif);font-size:clamp(1.4rem,3vw,2rem);color:var(--lin-clair);font-weight:normal;margin:1rem 0 .6rem;animation:reveal .7s .2s both}
.e404__sub{color:var(--texte-tres-clair);font-size:.95rem;line-height:1.8;max-width:440px;margin:0 auto 2.4rem;animation:reveal .7s .35s both}
.e404__quote{font-family:var(--font-serif);font-style:italic;color:rgba(200,192,176,.35);font-size:.85rem;margin-bottom:2.4rem;animation:reveal .7s .5s both}
.e404__links{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;animation:reveal .7s .6s both}
.e404__btn{display:inline-block;padding:10px 24px;text-decoration:none;font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;transition:all .25s}
.e404__btn--primary{background:var(--bordeaux-accent);color:#fff;border:1px solid var(--bordeaux-accent)}
.e404__btn--primary:hover{background:var(--bordeaux-moyen);border-color:var(--bordeaux-moyen);color:#fff;text-decoration:none}
.e404__btn--ghost{background:transparent;color:var(--lin);border:1px solid rgba(200,192,176,.25)}
.e404__btn--ghost:hover{background:rgba(200,192,176,.08);color:var(--lin-clair);border-color:rgba(200,192,176,.5);text-decoration:none}
.e404__divider{width:40px;height:1px;background:rgba(200,192,176,.2);margin:0 auto 1.4rem}
  
/* 404 — overrides */
body{background:var(--bordeaux-profond)!important}
main{flex:1;background:var(--bordeaux-profond)}
.site-nav__cta{background:rgba(200,192,176,.15)!important;border:1px solid rgba(200,192,176,.5)!important;color:var(--lin-clair)!important}
.site-nav__cta:hover{background:rgba(200,192,176,.3)!important;color:#fff!important}

/* ── Mentions légales ──────────────────────────────────────── */
.mentions-block { margin-bottom: 2.5rem; }
.mentions-block:last-child { margin-bottom: 0; }
.mentions-h2 { font-size: 1rem; font-weight: 700; color: var(--bordeaux-accent); text-transform: uppercase; letter-spacing: .05em; margin-bottom: .75rem; padding-bottom: .5rem; border-bottom: 1px solid var(--separateur-clair); }
.mentions-block p { font-size: .88rem; color: var(--texte-clair); line-height: 1.7; margin-bottom: .75rem; }
.mentions-block p:last-child { margin-bottom: 0; }

/* ── Pages guides ───────────────────────────────────────── */
.guide-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 1rem; margin: 1.5rem 0; }
.guide-card { background: var(--blanc); border: 1px solid var(--separateur-clair); border-radius: var(--rayon-card); padding: 1rem 1.2rem; }
.guide-card__jauge { font-weight: 700; color: var(--bordeaux-accent); font-size: .85rem; text-transform: uppercase; letter-spacing: .04em; margin-bottom: .6rem; padding-bottom: .5rem; border-bottom: 1px solid var(--separateur-clair); }
.guide-card__row { display: flex; justify-content: space-between; align-items: baseline; gap: .5rem; padding: .3rem 0; }
.guide-card__label { font-size: .8rem; color: var(--texte-tres-clair); }
.guide-card__val { font-size: .85rem; font-weight: 600; color: var(--texte-fonce); white-space: nowrap; }
.guide-card__note { font-size: .78rem; color: var(--texte-tres-clair); font-style: italic; margin-top: .5rem; padding-top: .5rem; border-top: 1px solid var(--separateur-clair); }
.guide-list { margin: 1rem 0 1.5rem 1.2rem; }
.guide-list li { color: var(--texte-clair); font-size: .9rem; line-height: 1.7; margin-bottom: .6rem; }
.section--creme h2, .section--creme h3 { color: var(--texte-fonce); }

/* ── Formulaire devis — responsive mobile ── */
@media (max-width: 768px) {
  .form-wrap { padding: 24px 0; }
  .form-card  { padding: 20px 12px; }
}
