.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
}

/* ═══════════════════════════════════════════════════════════════
 *  Manage Academy – Product Tour Styles
 *  Companion to /static/js/product-tour.js
 * ═══════════════════════════════════════════════════════════════ */

/* ── CSS custom properties (uses app brand tokens) ── */
:root {
  --mat-bg:    #ffffff;
  --mat-bg2:   #f8f9fa;
  --mat-text:  #1e293b;
  --mat-sub:   #64748b;
  --mat-muted: #94a3b8;
  --mat-line:  #e2e8f0;
  --mat-primary: #23346a;
  --mat-primary-light: #3a4f8f;
  --mat-card-shadow: 0 1px 3px rgba(0,0,0,.08);
}

/* ── Banner container ── */
.ma-tour-banner {
  display: none;
  position: fixed; right: 24px; top: 50%; transform: translateY(-50%);
  z-index: 1060; width: 320px;
  border-radius: 8px;
  background: var(--mat-bg);
  border: 1px solid var(--mat-line);
  box-shadow: 0 4px 16px rgba(0,0,0,.1);
  overflow: hidden;
  font-family: inherit;
  animation: maTourEntrance .35s ease-out;
}

@keyframes maTourEntrance {
  from { opacity: 0; transform: translateY(calc(-50% + 16px)); }
  to   { opacity: 1; transform: translateY(-50%); }
}

/* ── Header ── */
.ma-tour-banner-header {
  background: linear-gradient(135deg, #23346a 0%, #3a4f8f 100%);
  padding: 16px 18px 14px;
  color: #fff;
}
.ma-tour-banner-title {
  margin: 0; font-size: .95rem; font-weight: 600;
  line-height: 1.35;
}
.ma-tour-banner-sub {
  margin: 4px 0 0; font-size: .8rem; opacity: .85;
  line-height: 1.4;
}

/* ── Steps section ── */
.ma-tour-steps {
  padding: 12px 14px;
  display: flex; flex-direction: column; gap: 6px;
}

/* ── Individual step card ── */
.ma-tour-step-card {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 10px; border-radius: 6px;
  background: var(--mat-bg2);
  border: 1px solid var(--mat-line);
}

.ma-tour-step-num {
  width: 26px; height: 26px; border-radius: 50%; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  background: var(--mat-primary);
  color: #fff; font-size: .75rem; font-weight: 600;
}

.ma-tour-step-body { flex: 1; min-width: 0; }
.ma-tour-step-desc {
  font-size: .82rem; font-weight: 500; color: var(--mat-text);
  line-height: 1.35;
}

.ma-tour-step-badge {
  font-size: .65rem; font-weight: 600; text-transform: uppercase;
  letter-spacing: .3px; padding: 2px 6px; border-radius: 4px;
  background: #fef2f2; color: #dc2626; flex-shrink: 0;
}

/* ── Footer ── */
.ma-tour-banner-footer {
  padding: 0 14px 14px;
  display: flex; align-items: center; gap: 10px;
}
.ma-tour-cta {
  flex: 1;
  padding: 9px 16px; border: none; border-radius: 6px;
  background: linear-gradient(135deg, #23346a 0%, #3a4f8f 100%);
  color: #fff; font-size: .84rem; font-weight: 600;
  cursor: pointer;
  transition: opacity .15s;
}
.ma-tour-cta:hover { opacity: .9; }
.ma-tour-cta:active { opacity: .8; }

.ma-tour-dismiss {
  padding: 9px 12px; border: 1px solid var(--mat-line); border-radius: 6px;
  background: var(--mat-bg); color: var(--mat-sub);
  font-size: .82rem; font-weight: 500; cursor: pointer;
  transition: background .15s;
}
.ma-tour-dismiss:hover { background: var(--mat-bg2); }

/* ── Completion toast ── */
#ma-tour-toast {
  position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%);
  z-index: 9999;
  animation: maTourSlideUp .35s ease-out;
}
.ma-tour-toast-inner {
  display: flex; align-items: flex-start; gap: 12px;
  background: var(--mat-bg);
  border: 1px solid var(--mat-line);
  border-radius: 8px;
  padding: 14px 18px;
  box-shadow: 0 4px 16px rgba(0,0,0,.1);
  min-width: 340px; max-width: 480px;
}
.ma-tour-toast-icon {
  width: 36px; height: 36px; border-radius: 8px; flex-shrink: 0;
  background: #28a745;
  display: flex; align-items: center; justify-content: center;
}
.ma-tour-toast-text { display: flex; flex-direction: column; gap: 3px; flex: 1; }
.ma-tour-toast-text strong { font-size: .88rem; color: var(--mat-text); font-weight: 600; }
.ma-tour-toast-text span { font-size: .8rem; color: var(--mat-sub); line-height: 1.5; }
.ma-tour-toast-links {
  display: flex; flex-direction: column; gap: 4px; margin-top: 6px;
  padding-top: 6px; border-top: 1px solid var(--mat-line);
}
.ma-tour-toast-links a {
  font-size: .76rem; font-weight: 500; text-decoration: none;
  display: flex; align-items: center; gap: 4px;
}
.ma-tour-toast-links a:hover { opacity: .8; }
.ma-tour-toast-close {
  background: none; border: none; cursor: pointer;
  color: var(--mat-muted); padding: 2px; flex-shrink: 0;
  border-radius: 4px; transition: background .15s, color .15s;
  width: 26px; height: 26px;
  display: flex; align-items: center; justify-content: center;
}
.ma-tour-toast-close:hover {
  background: var(--mat-bg2); color: var(--mat-text);
}
@keyframes maTourSlideUp {
  from { opacity: 0; transform: translate(-50%, 16px); }
  to   { opacity: 1; transform: translate(-50%, 0); }
}

/* ── Driver.js popover theme ── */
.driver-popover.driverjs-theme {
  border-radius: 8px;
  border: 1px solid var(--mat-line);
  box-shadow: 0 4px 16px rgba(0,0,0,.12);
  padding: 18px 20px 14px;
  max-width: 380px;
  font-family: inherit;
  background: var(--mat-bg);
}
.driver-popover.driverjs-theme .driver-popover-title {
  font-size: .92rem;
  font-weight: 600;
  color: var(--mat-primary);
  margin-bottom: 8px;
  line-height: 1.35;
  display: flex;
  align-items: center;
  gap: 6px;
}
.driver-popover.driverjs-theme .driver-popover-description {
  font-size: .82rem;
  line-height: 1.6;
  color: var(--mat-sub);
}
.driver-popover.driverjs-theme .driver-popover-description strong {
  color: var(--mat-text);
  font-weight: 600;
}
.driver-popover.driverjs-theme .driver-popover-description ul {
  margin: 6px 0 4px 16px;
  padding: 0;
}
.driver-popover.driverjs-theme .driver-popover-description li {
  margin-bottom: 2px;
}
.driver-popover.driverjs-theme .driver-popover-footer {
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px solid var(--mat-line);
  gap: 8px;
}
.driver-popover.driverjs-theme .driver-popover-footer button {
  border-radius: 6px;
  font-size: .8rem;
  font-weight: 600;
  padding: 7px 14px;
  transition: opacity .15s;
}
.driver-popover.driverjs-theme .driver-popover-next-btn {
  background: linear-gradient(135deg, #23346a 0%, #3a4f8f 100%);
  border: none;
  color: #fff;
}
.driver-popover.driverjs-theme .driver-popover-next-btn:hover {
  opacity: .9;
}
.driver-popover.driverjs-theme .driver-popover-prev-btn {
  border: 1px solid var(--mat-line);
  color: var(--mat-sub);
  background: var(--mat-bg2);
}
.driver-popover.driverjs-theme .driver-popover-prev-btn:hover {
  background: var(--mat-bg);
}
.driver-popover.driverjs-theme .driver-popover-close-btn {
  color: var(--mat-muted);
}
.driver-popover.driverjs-theme .driver-popover-close-btn:hover {
  color: var(--mat-text);
}
.driver-popover.driverjs-theme .driver-popover-progress-text {
  font-size: .72rem;
  color: var(--mat-muted);
  font-weight: 600;
}

/* ── Floating tour trigger (FAB) ── */
.ma-tour-fab {
  display: none;
  position: fixed;
  right: 20px;
  bottom: 100px;
  z-index: 1050;
  width: 44px; height: 44px;
  border-radius: 50%;
  border: none; cursor: pointer;
  background: linear-gradient(135deg, #23346a 0%, #3a4f8f 100%);
  color: #fff;
  box-shadow: 0 2px 8px rgba(35,52,106,.3);
  transition: opacity .15s;
  align-items: center; justify-content: center;
}
.ma-tour-fab:hover { opacity: .9; }
.ma-tour-fab:active { opacity: .8; }
.ma-tour-fab svg { pointer-events: none; }

/* ── Responsive ── */
@media (max-width: 576px) {
  .ma-tour-banner {
    right: 10px; left: 10px; width: auto;
    top: auto; bottom: 10px; transform: none;
  }
  .ma-tour-fab {
    right: 14px;
    bottom: 90px;
    width: 40px; height: 40px;
  }
  @keyframes maTourEntrance {
    from { opacity: 0; transform: translateY(16px); }
    to   { opacity: 1; transform: translateY(0); }
  }
}
