/* ===========================================
   Sånn Tour Styles (Shepherd.js customization)
   =========================================== */

/* Modal Overlay - dims everything except the highlighted element */
.shepherd-modal-overlay-container {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 9998;
	pointer-events: none;
}

.shepherd-modal-overlay-container.shepherd-modal-is-visible path {
	fill: rgba(0, 0, 0, 0.55);
	transition: fill 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

/* ===========================================
   Tour Popup (scoped to .sann-tour)
   =========================================== */

/* Tour Element (Shepherd renders this as a <dialog>) */
.sann-tour.shepherd-element {
	background: var(--md-sys-color-surface);
	border: none !important;
	border-radius: var(--md-sys-shape-corner-medium);
	box-shadow:
		0 8px 32px rgba(0, 0, 0, 0.18),
		0 2px 8px rgba(0, 0, 0, 0.1);
	margin: 0 !important;
	outline: none !important;
	padding: 0 !important;
	max-width: 500px;
	width: 90%;
	z-index: 9999;
	animation: sann-tour-pop-in 0.3s cubic-bezier(0.16, 1, 0.3, 1);
	transform-origin: center;
	overflow: visible;
	position: relative;
}

.sann-tour.shepherd-element:focus,
.sann-tour.shepherd-element:focus-visible {
	border: none !important;
	outline: none !important;
}

/* Content wrapper clips to border-radius (arrow is a sibling, so it stays visible) */
.sann-tour .shepherd-content {
	outline: none;
	padding: 0;
	overflow: hidden;
	border-radius: var(--md-sys-shape-corner-medium);
}

/* Center modal when no element is attached (no attachTo property) */
.sann-tour.shepherd-element[style*='left: 50%'] {
	position: fixed !important;
	left: 50% !important;
	top: 50% !important;
	transform: translate(-50%, -50%) !important;
	margin: 0 !important;
}

@keyframes sann-tour-pop-in {
	0% {
		opacity: 0;
		transform: scale(0.95) translateY(8px);
	}
	100% {
		opacity: 1;
		transform: scale(1) translateY(0);
	}
}

/* Header - Uses action color for space-independent styling */
.sann-tour .shepherd-header {
	padding: var(--md-sys-spacing-4) var(--md-sys-spacing-5);
	background-color: var(--md-sys-color-action);
	border-radius: var(--md-sys-shape-corner-medium)
		var(--md-sys-shape-corner-medium) 0 0;
	display: flex;
	align-items: center;
	justify-content: space-between;
	position: relative;
	width: 100%;
	box-sizing: border-box;
}

/* Remove lightbulb icon */
.sann-tour .shepherd-header::before {
	display: none;
}

.sann-tour .shepherd-title {
	font-size: var(--md-sys-typescale-title-medium-size);
	font-weight: 600;
	color: var(--md-sys-color-on-action);
	margin: 0;
	flex: 1;
	text-align: left;
	letter-spacing: 0;
}

/* Cancel Icon - Hidden (replaced with "Skip tour" button) */
.sann-tour .shepherd-cancel-icon {
	display: none !important;
}

/* Text - Content area */
.sann-tour .shepherd-text {
	padding: var(--md-sys-spacing-4) var(--md-sys-spacing-5);
	font-size: var(--md-sys-typescale-body-medium-size);
	color: var(--md-sys-color-on-surface);
	line-height: var(--md-sys-typescale-body-medium-line-height);
}

/* Footer */
.sann-tour .shepherd-footer {
	padding: var(--md-sys-spacing-3) var(--md-sys-spacing-5)
		var(--md-sys-spacing-4);
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--md-sys-spacing-2);
	border-top: none;
	margin-top: 0;
}

/* Footer button group (Back/Next buttons) */
.sann-tour .shepherd-footer > .shepherd-buttons {
	display: flex;
	gap: var(--md-sys-spacing-2);
	margin-left: auto;
}

/* Buttons */
.sann-tour .shepherd-button {
	border: none;
	border-radius: var(--md-sys-shape-corner-small);
	cursor: pointer;
	padding: var(--md-sys-spacing-2) var(--md-sys-spacing-5);
	min-height: 36px;
	font-weight: 500;
	font-size: var(--md-sys-typescale-label-large-size);
	transition: all 0.2s ease;
	letter-spacing: 0;
}

.sann-tour .shepherd-button:active {
	transform: scale(0.98);
}

/* Primary Button - Uses action color */
.sann-tour .shepherd-button-primary {
	background-color: var(--md-sys-color-action);
	color: var(--md-sys-color-on-action);
	border: none;
}

.sann-tour .shepherd-button-primary:hover {
	background-color: var(--md-sys-color-action-hover);
}

.sann-tour .shepherd-button-primary:active {
	opacity: 0.9;
}

/* Secondary Button - Outlined with action color */
.sann-tour .shepherd-button-secondary {
	background-color: transparent;
	color: var(--md-sys-color-action);
	border: 1px solid var(--md-sys-color-action-outline);
}

.sann-tour .shepherd-button-secondary:hover {
	background-color: var(--md-sys-color-selection);
	border-color: var(--md-sys-color-action-outline-hover);
}

.sann-tour .shepherd-button-secondary:active {
	background-color: var(--md-sys-color-selection);
}

/* Skip Button - Text link style */
.sann-tour .shepherd-button-skip {
	background-color: transparent;
	color: var(--md-sys-color-on-surface-variant);
	border: none;
	font-weight: 400;
	padding: var(--md-sys-spacing-2);
	min-height: auto;
}

.sann-tour .shepherd-button-skip:hover {
	background-color: transparent;
	color: var(--md-sys-color-on-surface);
	text-decoration: underline;
}

.sann-tour .shepherd-button-skip:active {
	opacity: 0.8;
}

/* Arrow - Reset Shepherd defaults and use border triangles */
.sann-tour .shepherd-arrow {
	display: block !important;
	width: 0;
	height: 0;
	position: absolute;
	z-index: 1;
	background: none;
}

.sann-tour .shepherd-arrow::before {
	content: '';
	position: absolute;
	width: 0;
	height: 0;
	border-style: solid;
	background: none;
	transform: none;
}

/* Arrow pointing up (modal below element) */
.sann-tour[data-popper-placement^='top'] .shepherd-arrow {
	bottom: -12px;
	left: 50%;
	transform: translateX(-50%);
}

.sann-tour[data-popper-placement^='top'] .shepherd-arrow::before {
	border-left: 12px solid transparent;
	border-right: 12px solid transparent;
	border-top: 12px solid var(--md-sys-color-surface);
	border-bottom: none;
}

/* Arrow pointing down (modal above element) - matches header color */
.sann-tour[data-popper-placement^='bottom'] .shepherd-arrow {
	top: -12px;
	left: 50%;
	transform: translateX(-50%);
}

.sann-tour[data-popper-placement^='bottom'] .shepherd-arrow::before {
	border-left: 12px solid transparent;
	border-right: 12px solid transparent;
	border-bottom: 12px solid var(--md-sys-color-action);
	border-top: none;
}

/* Arrow pointing left (modal to the right of element) */
.sann-tour[data-popper-placement^='right'] .shepherd-arrow {
	right: -12px;
	top: 50%;
	transform: translateY(-50%);
}

.sann-tour[data-popper-placement^='right'] .shepherd-arrow::before {
	border-top: 12px solid transparent;
	border-bottom: 12px solid transparent;
	border-right: 12px solid var(--md-sys-color-action);
	border-left: none;
}

/* Arrow pointing right (modal to the left of element) */
.sann-tour[data-popper-placement^='left'] .shepherd-arrow {
	left: -12px;
	top: 50%;
	transform: translateY(-50%);
}

.sann-tour[data-popper-placement^='left'] .shepherd-arrow::before {
	border-top: 12px solid transparent;
	border-bottom: 12px solid transparent;
	border-left: 12px solid var(--md-sys-color-action);
	border-right: none;
}

/* Hide arrow when modal is centered (no attachTo) */
.sann-tour.shepherd-element[style*='left: 50%'] .shepherd-arrow {
	display: none !important;
}

/* Progress indicator - Percentage bar */
.sann-tour .shepherd-progress {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--md-sys-spacing-1);
	padding: 0 var(--md-sys-spacing-5) var(--md-sys-spacing-2);
}

.sann-tour .shepherd-progress-bar-container {
	width: 100%;
	height: 6px;
	background-color: var(--md-sys-color-surface-container-high);
	border-radius: var(--md-sys-shape-corner-full);
	overflow: hidden;
	position: relative;
}

.sann-tour .shepherd-progress-bar-fill {
	height: 100%;
	background-color: var(--md-sys-color-action);
	border-radius: var(--md-sys-shape-corner-full);
	transition: width 0.3s ease;
}

.sann-tour .shepherd-progress-percentage {
	font-size: var(--md-sys-typescale-label-medium-size);
	font-weight: 600;
	color: var(--md-sys-color-on-surface-variant);
	margin-top: 0;
}
