/* MAGICIENS-PRO-V2-TEST-OK */

/* ============================================================
   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   : 56px 0 52px;
  text-align: left;
}
.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-group { display: flex; gap: 12px; flex-wrap: wrap; align-items: center; }
/* ── CTA hero ── */
.btn--hero{display:inline-block;font-size:.78rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;text-decoration:none;padding:14px 36px;border:1px solid rgba(232,224,212,.6);color:var(--lin-clair);background:rgba(255,255,255,.08);transition:background var(--transition),color var(--transition),border-color var(--transition);line-height:1;margin-top:28px}
.btn--hero:hover{background:rgba(255,255,255,.18);color:#fff;border-color:rgba(232,224,212,.9);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  { 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) {
  .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:#e8e0d4;color:#5c3a2a}


.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}
.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:#8b2020;color:#fff;text-align:center;padding:11px;font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;text-decoration:none}
.mob-cta:hover{background:#5c1a1a;text-decoration:none;color:#fff}
@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}}
@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)}
.breadcrumb{background:#f0e6d4;border-bottom:1px solid #d8c8b0;padding:8px 0}
.breadcrumb__inner{width:94%;max-width:var(--max-w-wide);margin:0 auto;font-size:.72rem;color:#2a1a1a}
.breadcrumb__inner a{color:#8b2020;text-decoration:none}
.breadcrumb__inner a:hover{color:#5c1a1a;text-decoration:none}
.breadcrumb__sep { margin: 0 6px; color: #b0906a; }
.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-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) {
.hub-grid{grid-template-columns:1fr}
}
@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}
.hub-grid{grid-template-columns:repeat(2,1fr)}
}
@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-nav__item{display:none}.site-nav__btn{display:none}.site-nav__cta{display:none!important}.site-nav__burger{display:flex}
.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}

@media (max-width:900px) {
.devis-hero__grid{grid-template-columns:1fr;gap:32px}
.hub-grid{grid-template-columns:repeat(3,1fr)}
}

/* ── Hub cards (pages villes, régions, départements) ── */
.hub-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:1.8em}
.hub-card{display:block;background:var(--blanc);border-left:3px solid var(--bordeaux-accent);padding:18px 20px;text-decoration:none;transition:background var(--transition),border-color var(--transition)}
.hub-card:hover{background:var(--lin-clair);border-color:var(--bordeaux-hero);text-decoration:none}
.hub-card__num{font-size:.65rem;letter-spacing:.25em;text-transform:uppercase;color:var(--texte-tres-clair);display:block;margin-bottom:5px}
.hub-card__name{font-family:var(--font-serif);font-size:1.05rem;font-weight:normal;color:var(--texte-fonce);display:block;line-height:1.25}
.hub-card__region{font-size:.75rem;color:var(--texte-tres-clair);display:block;margin-top:4px}

/* ── Superhub (pages hub de hub) ── */
.superhub-bloc{margin-bottom:3em}
.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}
