/* === driver.js 1.3.6 base (self-hosted, MIT) === */
.driver-active .driver-overlay,.driver-active *{pointer-events:none}.driver-active .driver-active-element,.driver-active .driver-active-element *,.driver-popover,.driver-popover *{pointer-events:auto}@keyframes animate-fade-in{0%{opacity:0}to{opacity:1}}.driver-fade .driver-overlay{animation:animate-fade-in .2s ease-in-out}.driver-fade .driver-popover{animation:animate-fade-in .2s}.driver-popover{all:unset;box-sizing:border-box;color:#2d2d2d;margin:0;padding:15px;border-radius:5px;min-width:250px;max-width:300px;box-shadow:0 1px 10px #0006;z-index:1000000000;position:fixed;top:0;right:0;background-color:#fff}.driver-popover *{font-family:Helvetica Neue,Inter,ui-sans-serif,"Apple Color Emoji",Helvetica,Arial,sans-serif}.driver-popover-title{font:19px/normal sans-serif;font-weight:700;display:block;position:relative;line-height:1.5;zoom:1;margin:0}.driver-popover-close-btn{all:unset;position:absolute;top:0;right:0;width:32px;height:28px;cursor:pointer;font-size:18px;font-weight:500;color:#d2d2d2;z-index:1;text-align:center;transition:color;transition-duration:.2s}.driver-popover-close-btn:hover,.driver-popover-close-btn:focus{color:#2d2d2d}.driver-popover-title[style*=block]+.driver-popover-description{margin-top:5px}.driver-popover-description{margin-bottom:0;font:14px/normal sans-serif;line-height:1.5;font-weight:400;zoom:1}.driver-popover-footer{margin-top:15px;text-align:right;zoom:1;display:flex;align-items:center;justify-content:space-between}.driver-popover-progress-text{font-size:13px;font-weight:400;color:#727272;zoom:1}.driver-popover-footer button{all:unset;display:inline-block;box-sizing:border-box;padding:3px 7px;text-decoration:none;text-shadow:1px 1px 0 #fff;background-color:#fff;color:#2d2d2d;font:12px/normal sans-serif;cursor:pointer;outline:0;zoom:1;line-height:1.3;border:1px solid #ccc;border-radius:3px}.driver-popover-footer .driver-popover-btn-disabled{opacity:.5;pointer-events:none}:not(body):has(>.driver-active-element){overflow:hidden!important}.driver-no-interaction,.driver-no-interaction *{pointer-events:none!important}.driver-popover-footer button:hover,.driver-popover-footer button:focus{background-color:#f7f7f7}.driver-popover-navigation-btns{display:flex;flex-grow:1;justify-content:flex-end}.driver-popover-navigation-btns button+button{margin-left:4px}.driver-popover-arrow{content:"";position:absolute;border:5px solid #fff}.driver-popover-arrow-side-over{display:none}.driver-popover-arrow-side-left{left:100%;border-right-color:transparent;border-bottom-color:transparent;border-top-color:transparent}.driver-popover-arrow-side-right{right:100%;border-left-color:transparent;border-bottom-color:transparent;border-top-color:transparent}.driver-popover-arrow-side-top{top:100%;border-right-color:transparent;border-bottom-color:transparent;border-left-color:transparent}.driver-popover-arrow-side-bottom{bottom:100%;border-left-color:transparent;border-top-color:transparent;border-right-color:transparent}.driver-popover-arrow-side-center{display:none}.driver-popover-arrow-side-left.driver-popover-arrow-align-start,.driver-popover-arrow-side-right.driver-popover-arrow-align-start{top:15px}.driver-popover-arrow-side-top.driver-popover-arrow-align-start,.driver-popover-arrow-side-bottom.driver-popover-arrow-align-start{left:15px}.driver-popover-arrow-align-end.driver-popover-arrow-side-left,.driver-popover-arrow-align-end.driver-popover-arrow-side-right{bottom:15px}.driver-popover-arrow-side-top.driver-popover-arrow-align-end,.driver-popover-arrow-side-bottom.driver-popover-arrow-align-end{right:15px}.driver-popover-arrow-side-left.driver-popover-arrow-align-center,.driver-popover-arrow-side-right.driver-popover-arrow-align-center{top:50%;margin-top:-5px}.driver-popover-arrow-side-top.driver-popover-arrow-align-center,.driver-popover-arrow-side-bottom.driver-popover-arrow-align-center{left:50%;margin-left:-5px}.driver-popover-arrow-none{display:none}


/* CARMONY — Tutoriel guidé : thème driver.js + bandeau + menu (web & mobile) */

/* ---------- Popover driver.js, tokens CARMONY ---------- */
.driver-popover.carmony-tour {
  background: #ffffff;
  color: #1a1a1a;
  border-radius: 20px;
  box-shadow: 0 24px 60px -16px rgba(26,26,26,0.40), 0 2px 8px rgba(26,26,26,0.08);
  padding: 20px 20px 16px;
  max-width: 360px;
  font-family: 'Inter', system-ui, sans-serif;
}
.driver-popover.carmony-tour .driver-popover-title {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 22px;
  font-weight: 600;
  line-height: 1.15;
  color: #1a1a1a;
  margin: 0 0 8px;
}
.driver-popover.carmony-tour .driver-popover-description {
  font-size: 13.5px;
  font-weight: 300;
  line-height: 1.55;
  color: #3a3a3a;
}
.driver-popover.carmony-tour .driver-popover-progress-text {
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #9a9a9a;
  font-weight: 500;
}
.driver-popover.carmony-tour .driver-popover-footer { margin-top: 14px; gap: 8px; }
.driver-popover.carmony-tour .driver-popover-footer button {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 13px;
  font-weight: 400;
  letter-spacing: 0.02em;
  border-radius: 9999px;
  padding: 9px 18px;
  min-height: 40px;
  text-shadow: none;
  transition: background-color .2s ease, color .2s ease, box-shadow .2s ease;
}
.driver-popover.carmony-tour .driver-popover-next-btn,
.driver-popover.carmony-tour .driver-popover-footer button.driver-popover-next-btn {
  background: #1a1a1a;
  color: #ffffff;
  border: 1px solid #1a1a1a;
}
.driver-popover.carmony-tour .driver-popover-next-btn:hover { background: #000; box-shadow: 0 8px 20px -8px rgba(26,26,26,0.5); }
.driver-popover.carmony-tour .driver-popover-prev-btn {
  background: transparent;
  color: #1a1a1a;
  border: 1px solid rgba(26,26,26,0.18);
}
.driver-popover.carmony-tour .driver-popover-prev-btn:hover { background: rgba(26,26,26,0.05); }
.driver-popover.carmony-tour .driver-popover-close-btn { color: #9a9a9a; font-size: 22px; }
.driver-popover.carmony-tour .driver-popover-close-btn:hover { color: #1a1a1a; }
.driver-popover.carmony-tour .driver-popover-arrow { border-color: #ffffff; }

/* Spotlight focus ring (WCAG 2.4.7-ish) */
.driver-active .driver-overlay { transition: opacity .3s ease; }

/* ---------- Bandeau 1ère visite ---------- */
#cm-tour-banner {
  position: fixed;
  z-index: 9990;
  right: 20px; bottom: 20px; left: auto;
  max-width: 380px;
  opacity: 0; transform: translateY(14px);
  transition: opacity .35s ease, transform .35s ease;
  pointer-events: none;
}
#cm-tour-banner.cm-show { opacity: 1; transform: translateY(0); pointer-events: auto; }
#cm-tour-banner .cm-tour-banner-card {
  background: #1a1a1a; color: #fff;
  border-radius: 22px;
  padding: 18px 20px;
  box-shadow: 0 24px 60px -16px rgba(0,0,0,0.5);
}
#cm-tour-banner .cm-tour-banner-title { font-family:'Cormorant Garamond',serif; font-size: 20px; font-weight: 600; margin-bottom: 4px; }
#cm-tour-banner .cm-tour-banner-sub { font-size: 13px; font-weight: 300; color: #d8d8d8; line-height: 1.5; }
#cm-tour-banner .cm-tour-banner-actions { display: flex; gap: 8px; margin-top: 14px; justify-content: flex-end; }
#cm-tour-banner button { border-radius: 9999px; padding: 9px 18px; font-size: 13px; min-height: 40px; cursor: pointer; transition: background-color .2s ease, color .2s ease; border: 1px solid transparent; }
#cm-tour-banner .cm-tour-btn-later { background: transparent; color: #d8d8d8; border-color: rgba(255,255,255,0.25); }
#cm-tour-banner .cm-tour-btn-later:hover { background: rgba(255,255,255,0.08); color:#fff; }
#cm-tour-banner .cm-tour-btn-start { background: #fff; color: #1a1a1a; font-weight: 500; }
#cm-tour-banner .cm-tour-btn-start:hover { background: #e8e8e8; }

/* ---------- Bouton « ? Aide » ---------- */
#cm-help-btn { cursor: pointer; }

/* ---------- Menu des tours ---------- */
#cm-tour-menu {
  position: fixed; z-index: 9991;
  background: #fff; border: 1px solid rgba(0,0,0,0.06);
  border-radius: 18px; box-shadow: 0 24px 60px -16px rgba(26,26,26,0.30);
  padding: 8px; min-width: 240px; max-width: 320px;
  opacity: 0; transform: translateY(-6px); transition: opacity .18s ease, transform .18s ease;
}
#cm-tour-menu.cm-show { opacity: 1; transform: translateY(0); }
#cm-tour-menu .cm-tour-menu-head { font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: #9a9a9a; padding: 6px 10px 8px; }
#cm-tour-menu .cm-tour-menu-item {
  display: block; width: 100%; text-align: left;
  padding: 11px 12px; border-radius: 12px; font-size: 14px; font-weight: 300; color: #1a1a1a;
  background: transparent; border: 0; cursor: pointer; min-height: 44px;
  transition: background-color .15s ease;
}
#cm-tour-menu .cm-tour-menu-item:hover { background: #f0f0f0; }

/* ---------- Mobile (web & mobile : priorité) ---------- */
@media (max-width: 767px) {
  .driver-popover.carmony-tour {
    max-width: calc(100vw - 24px);
    width: calc(100vw - 24px);
  }
  /* Bandeau → bottom-sheet pleine largeur, au-dessus de la bottom-nav */
  #cm-tour-banner {
    right: 12px; left: 12px; bottom: calc(88px + env(safe-area-inset-bottom, 0px));
    max-width: none;
  }
  /* Menu des tours → bottom-sheet */
  #cm-tour-menu.cm-sheet {
    left: 12px; right: 12px; bottom: calc(12px + env(safe-area-inset-bottom, 0px));
    top: auto !important; max-width: none; min-width: 0;
    transform: translateY(16px);
  }
  #cm-tour-menu.cm-sheet.cm-show { transform: translateY(0); }
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion: reduce) {
  #cm-tour-banner, #cm-tour-menu, .driver-active .driver-overlay { transition: none !important; }
}
