/* =============================================================================
   ic-onboarding.css — styles for the in-app guided-tour engine + the help
   launcher + the welcome modal + the dashboard onboarding widget.

   All sizing uses --ic-* tokens with --bs-* fallbacks so it picks up
   whatever theme is in scope. Works on dark theme (default) and light
   theme (system pref) without overrides.

   Z-index strategy:
     - tour overlay sits BELOW the IC main overlay (icMainOverlay sits at
       200000+ per project memory) so a long-running progress task can
       always pre-empt a tour. The tour engine doesn't compete with the
       loader.
     - tour overlay sits ABOVE all sidebars, navs, modals.
   ============================================================================= */

/* -------------------- SVG overlay + spotlight cutout -------------------- */

.ic-tour-overlay {
	position: fixed;
	inset: 0;
	z-index: 100050;
	pointer-events: none;
}

.ic-tour-overlay__svg {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	display: block;
	pointer-events: none;
}

/* The dim rect itself has pointer-events: auto so clicks on dimmed area
   are absorbed (preventing the user from clicking through to elements
   outside the spotlight). The cutout area is transparent + masked out so
   it doesn't block the spotlighted target. */
.ic-tour-overlay__dim {
	pointer-events: auto;
}

body.ic-tour-active {
	overflow: hidden;
}

body.ic-tour-active .ic-tour-overlay {
	pointer-events: auto;
}

/* -------------------- Popover -------------------- */

.ic-tour-popover {
	position: fixed;
	z-index: 100051;
	min-width: 280px;
	max-width: 380px;
	padding: 16px 18px 14px;
	background: var(--ic-card-bg, var(--bs-body-bg, #1c1f26));
	color: var(--ic-body-color, var(--bs-body-color, #e6e6e6));
	border: 1px solid var(--ic-border-color, var(--bs-border-color, rgba(255,255,255,0.10)));
	border-radius: 14px;
	box-shadow:
		0 18px 40px -8px rgba(0,0,0,0.55),
		0 0 0 1px rgba(255,255,255,0.03);
	font-size: 0.8125rem; /* fs-9 equivalent */
	line-height: 1.45;
	transition: opacity 120ms ease, transform 120ms ease;
}

.ic-tour-popover__head {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 8px;
	margin-bottom: 6px;
}

.ic-tour-popover__meta {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 6px;
	font-size: 0.6875rem; /* fs-10 */
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--ic-text-secondary, var(--bs-secondary-color, #9aa1ad));
}

.ic-tour-popover__step  { font-weight: 600; color: var(--ic-text-primary, var(--bs-emphasis-color, #fff)); }
.ic-tour-popover__sep   { opacity: 0.5; }
.ic-tour-popover__tour  { font-weight: 500; max-width: 18ch; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.ic-tour-popover__replay-badge {
	display: inline-block;
	padding: 2px 6px;
	border-radius: 999px;
	background: rgba(120,140,255,0.18);
	color: #b9c4ff;
	font-size: 0.625rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin-left: 4px;
}

.ic-tour-popover__close {
	background: transparent;
	border: none;
	color: var(--ic-text-secondary, var(--bs-secondary-color, #9aa1ad));
	padding: 2px 6px;
	border-radius: 6px;
	cursor: pointer;
	font-size: 0.875rem;
	line-height: 1;
}
.ic-tour-popover__close:hover {
	background: rgba(255,255,255,0.05);
	color: var(--ic-text-primary, var(--bs-emphasis-color, #fff));
}

.ic-tour-popover__title {
	font-size: 1rem;
	font-weight: 600;
	color: var(--ic-text-primary, var(--bs-emphasis-color, #fff));
	margin: 0 0 4px;
	line-height: 1.3;
}

.ic-tour-popover__body {
	font-size: 0.8125rem;
	color: var(--ic-body-color, var(--bs-body-color, #d8dce4));
	margin: 0;
}

.ic-tour-popover__more {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	background: transparent;
	border: none;
	padding: 8px 0 4px;
	margin-top: 6px;
	color: var(--ic-link-color, var(--bs-primary, #6f8cff));
	font-size: 0.75rem;
	font-weight: 600;
	cursor: pointer;
}
.ic-tour-popover__more:hover {
	text-decoration: underline;
}

.ic-tour-popover__detail {
	margin-top: 8px;
	padding: 10px 12px;
	background: rgba(255,255,255,0.025);
	border: 1px solid var(--ic-border-color, rgba(255,255,255,0.06));
	border-radius: 8px;
	font-size: 0.75rem;
	color: var(--ic-text-secondary, var(--bs-secondary-color, #adb2ba));
	line-height: 1.5;
}

.ic-tour-popover__progress {
	height: 3px;
	margin: 12px 0 10px;
	background: rgba(255,255,255,0.06);
	border-radius: 999px;
	overflow: hidden;
}
.ic-tour-popover__progress-bar {
	display: block;
	height: 100%;
	background: linear-gradient(90deg, #6f8cff 0%, #a37bff 100%);
	border-radius: 999px;
	transition: width 200ms ease;
}

.ic-tour-popover__actions {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-top: 8px;
	flex-wrap: wrap;
}
.ic-tour-popover__actions > .btn { font-size: 0.75rem; padding: 5px 12px; }
.ic-tour-popover__actions > .btn:last-child { margin-left: auto; }

/* -------------------- Help launcher (floating ?) -------------------- */

.ic-help-launcher {
	position: fixed;
	right: 18px;
	bottom: 18px;
	z-index: 100040;
	width: 48px;
	height: 48px;
	border-radius: 50%;
	border: none;
	background: linear-gradient(135deg, #6f8cff 0%, #a37bff 100%);
	color: #fff;
	box-shadow:
		0 8px 22px -4px rgba(80,90,200,0.45),
		0 0 0 1px rgba(255,255,255,0.10);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	font-size: 1.05rem;
	transition: transform 140ms ease, box-shadow 140ms ease;
}
/* When the help launcher lives inside the global .ic-fab-stack (the
   normal authenticated layout), the stack handles positioning so the
   ? button stacks vertically with back-to-top + feedback. The fixed
   declarations above stay as a fallback for surfaces that don't
   include the stack (e.g. the welcome page during signup). */
.ic-fab-stack > .ic-help-launcher {
	position: static;
	right: auto;
	bottom: auto;
	z-index: auto;
}
.ic-help-launcher:hover {
	transform: translateY(-2px);
	box-shadow:
		0 12px 28px -4px rgba(80,90,200,0.55),
		0 0 0 1px rgba(255,255,255,0.12);
}
.ic-help-launcher:focus-visible {
	outline: 2px solid #b9c4ff;
	outline-offset: 2px;
}
/* Desktop-only: the floating ? button competes with thumb-zone content on
   phones/tablets. Below lg it's hidden — help stays reachable via the
   sidebar "Help & Docs" link, and the "open guides" buttons on Getting
   Started / the onboarding widget still open the panel programmatically. */
@media (max-width: 991.98px) {
	.ic-help-launcher { display: none; }
}

/* Slide-in panel */

.ic-help-panel {
	position: fixed;
	right: 1.5rem;
	bottom: 5.5rem; /* matches stack bottom (1.5rem) + launcher height (3rem) + ~1rem gap */
	z-index: 100041;
	width: min(380px, calc(100vw - 36px));
	max-height: min(580px, calc(100vh - 110px));
	background: var(--ic-card-bg, var(--bs-body-bg, #1c1f26));
	color: var(--ic-body-color, var(--bs-body-color, #e6e6e6));
	border: 1px solid var(--ic-border-color, var(--bs-border-color, rgba(255,255,255,0.10)));
	border-radius: 14px;
	box-shadow:
		0 20px 50px -10px rgba(0,0,0,0.55),
		0 0 0 1px rgba(255,255,255,0.03);
	display: none;
	flex-direction: column;
	overflow: hidden;
	transform: translateY(8px);
	opacity: 0;
	transition: opacity 160ms ease, transform 160ms ease;
}
.ic-help-panel.is-open {
	display: flex;
	transform: translateY(0);
	opacity: 1;
}

.ic-help-panel__head {
	padding: 12px 14px 10px;
	border-bottom: 1px solid var(--ic-border-color, rgba(255,255,255,0.06));
}
.ic-help-panel__title {
	font-size: 0.9375rem;
	font-weight: 600;
	color: var(--ic-text-primary, var(--bs-emphasis-color, #fff));
	margin: 0 0 2px;
}
.ic-help-panel__sub {
	font-size: 0.75rem;
	color: var(--ic-text-secondary, var(--bs-secondary-color, #9aa1ad));
}
.ic-help-panel__search {
	margin-top: 10px;
	position: relative;
}
.ic-help-panel__search input {
	width: 100%;
	padding: 8px 12px 8px 32px;
	border-radius: 8px;
	border: 1px solid var(--ic-border-color, rgba(255,255,255,0.10));
	background: rgba(255,255,255,0.03);
	color: var(--ic-body-color, var(--bs-body-color, #e6e6e6));
	font-size: 0.8125rem;
}
.ic-help-panel__search input:focus {
	outline: none;
	border-color: #6f8cff;
	box-shadow: 0 0 0 2px rgba(111,140,255,0.20);
}
.ic-help-panel__search i {
	position: absolute;
	left: 10px;
	top: 50%;
	transform: translateY(-50%);
	color: var(--ic-text-secondary, #9aa1ad);
	font-size: 0.75rem;
	pointer-events: none;
}

.ic-help-panel__body {
	flex: 1 1 auto;
	overflow-y: auto;
	padding: 4px 0;
}
.ic-help-panel__section-label {
	padding: 10px 14px 4px;
	font-size: 0.625rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--ic-text-secondary, #9aa1ad);
}

.ic-help-panel__tour {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	padding: 10px 14px;
	cursor: pointer;
	border: none;
	background: transparent;
	color: inherit;
	width: 100%;
	text-align: left;
	border-radius: 0;
	transition: background 100ms ease;
}
.ic-help-panel__tour:hover {
	background: rgba(255,255,255,0.04);
}
.ic-help-panel__tour-icon {
	flex-shrink: 0;
	width: 32px;
	height: 32px;
	border-radius: 8px;
	background: rgba(111,140,255,0.12);
	color: #b9c4ff;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 0.875rem;
}
.ic-help-panel__tour-body {
	flex: 1 1 auto;
	min-width: 0;
}
.ic-help-panel__tour-title {
	font-size: 0.8125rem;
	font-weight: 600;
	color: var(--ic-text-primary, var(--bs-emphasis-color, #fff));
	margin: 0 0 2px;
}
.ic-help-panel__tour-summary {
	font-size: 0.75rem;
	color: var(--ic-text-secondary, #9aa1ad);
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.ic-help-panel__tour-meta {
	display: flex;
	align-items: center;
	gap: 6px;
	margin-top: 4px;
	font-size: 0.625rem;
	color: var(--ic-text-tertiary, #7f868f);
}
.ic-help-panel__tour-status-done {
	color: #6ee19f;
	font-weight: 600;
	text-transform: uppercase;
}
.ic-help-panel__tour-status-skipped {
	color: #c0c0c0;
	font-weight: 600;
	text-transform: uppercase;
}

.ic-help-panel__foot {
	padding: 10px 14px;
	border-top: 1px solid var(--ic-border-color, rgba(255,255,255,0.06));
	font-size: 0.75rem;
	color: var(--ic-text-secondary, #9aa1ad);
	text-align: center;
}
.ic-help-panel__foot a {
	color: #b9c4ff;
}

.ic-help-panel__empty {
	padding: 20px 14px;
	text-align: center;
	font-size: 0.8125rem;
	color: var(--ic-text-secondary, #9aa1ad);
}

/* -------------------- Welcome modal touches -------------------- */

.ic-welcome-modal .modal-content {
	overflow: hidden;
	border-radius: 16px;
}
.ic-welcome-modal__hero {
	padding: 28px 28px 18px;
	background: linear-gradient(135deg, rgba(111,140,255,0.22) 0%, rgba(163,123,255,0.18) 100%);
	border-bottom: 1px solid var(--ic-border-color, rgba(255,255,255,0.08));
}
.ic-welcome-modal__title {
	font-size: 1.5rem;
	font-weight: 700;
	margin: 4px 0 6px;
	color: var(--ic-text-primary, var(--bs-emphasis-color, #fff));
}
.ic-welcome-modal__sub {
	font-size: 0.9rem;
	color: var(--ic-body-color, var(--bs-body-color, #d4d8de));
	margin: 0;
}
.ic-welcome-modal__list {
	padding: 18px 28px 12px;
	list-style: none;
	margin: 0;
}
.ic-welcome-modal__list li {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	padding: 8px 0;
	font-size: 0.85rem;
}
.ic-welcome-modal__list li i {
	color: #b9c4ff;
	margin-top: 2px;
	flex-shrink: 0;
}
.ic-welcome-modal__cta-row {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
	padding: 12px 28px 24px;
}

/* -------------------- Dashboard onboarding widget -------------------- */

.ic-onboarding-widget {
	border-radius: 14px;
	overflow: hidden;
	border: 1px solid var(--ic-border-color, var(--bs-border-color, rgba(255,255,255,0.10)));
	background:
		linear-gradient(135deg, rgba(111,140,255,0.08) 0%, rgba(163,123,255,0.05) 100%),
		var(--ic-card-bg, var(--bs-body-bg, #1c1f26));
}
.ic-onboarding-widget__head {
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 14px 16px;
	border-bottom: 1px solid var(--ic-border-color, rgba(255,255,255,0.05));
}
.ic-onboarding-widget__ring {
	flex-shrink: 0;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background:
		conic-gradient(#6f8cff calc(var(--ic-pct, 0) * 1%), rgba(255,255,255,0.08) 0deg);
	position: relative;
}
.ic-onboarding-widget__ring::after {
	content: "";
	position: absolute;
	inset: 4px;
	border-radius: 50%;
	background: var(--ic-card-bg, var(--bs-body-bg, #1c1f26));
}
.ic-onboarding-widget__ring-pct {
	position: relative;
	z-index: 1;
	font-size: 0.625rem;
	font-weight: 700;
	color: var(--ic-text-primary, var(--bs-emphasis-color, #fff));
}
.ic-onboarding-widget__title  { font-size: 0.95rem; font-weight: 600; margin: 0; color: var(--ic-text-primary, #fff); }
.ic-onboarding-widget__sub    { font-size: 0.75rem; color: var(--ic-text-secondary, #9aa1ad); margin: 0; }
.ic-onboarding-widget__toggle {
	margin-left: auto;
	background: transparent;
	border: none;
	color: var(--ic-text-secondary, #9aa1ad);
	cursor: pointer;
	padding: 4px 8px;
	border-radius: 6px;
	font-size: 0.75rem;
}
.ic-onboarding-widget__toggle:hover { background: rgba(255,255,255,0.05); }

.ic-onboarding-widget__next {
	padding: 14px 16px;
	display: flex;
	flex-direction: column;
	gap: 6px;
}
.ic-onboarding-widget__next-label {
	font-size: 0.625rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: #b9c4ff;
}
.ic-onboarding-widget__next-title {
	font-size: 0.95rem;
	font-weight: 600;
	color: var(--ic-text-primary, #fff);
}
.ic-onboarding-widget__next-summary {
	font-size: 0.8125rem;
	color: var(--ic-text-secondary, #9aa1ad);
}
.ic-onboarding-widget__next-actions {
	display: flex;
	gap: 8px;
	margin-top: 8px;
	flex-wrap: wrap;
}

.ic-onboarding-widget__done {
	padding: 18px 16px;
	text-align: center;
	font-size: 0.85rem;
}
.ic-onboarding-widget__done i {
	color: #6ee19f;
	font-size: 1.5rem;
	display: block;
	margin-bottom: 6px;
}

.ic-onboarding-widget--collapsed .ic-onboarding-widget__next { display: none; }

/* -------------------- Empty-state nudge card -------------------- */

.ic-tour-empty-nudge {
	margin-top: 14px;
	padding: 12px 14px;
	border: 1px dashed rgba(111,140,255,0.45);
	border-radius: 12px;
	background: rgba(111,140,255,0.06);
	display: inline-flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	font-size: 0.8125rem;
	color: var(--ic-text-secondary, #9aa1ad);
	max-width: 460px;
}
.ic-tour-empty-nudge__title {
	font-weight: 600;
	color: var(--ic-text-primary, #fff);
	font-size: 0.9rem;
}
.ic-tour-empty-nudge .btn {
	font-size: 0.75rem;
}

/* -------------------- Getting Started page -------------------- */

.ic-onboarding-page__module-head {
	margin: 24px 0 10px;
	padding-bottom: 6px;
	border-bottom: 1px solid var(--ic-border-color, rgba(255,255,255,0.08));
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--ic-text-secondary, #9aa1ad);
}

.ic-onboarding-page__tour-card {
	display: flex;
	gap: 14px;
	padding: 14px 16px;
	border: 1px solid var(--ic-border-color, rgba(255,255,255,0.08));
	background: var(--ic-card-bg, var(--bs-body-bg, #1c1f26));
	border-radius: 12px;
	transition: border-color 140ms ease, transform 140ms ease;
}
.ic-onboarding-page__tour-card:hover {
	border-color: rgba(111,140,255,0.45);
}
.ic-onboarding-page__tour-card.is-done {
	opacity: 0.86;
}
.ic-onboarding-page__tour-card-icon {
	flex-shrink: 0;
	width: 44px;
	height: 44px;
	border-radius: 10px;
	background: rgba(111,140,255,0.12);
	color: #b9c4ff;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 1.1rem;
}
.ic-onboarding-page__tour-card-body { flex: 1 1 auto; min-width: 0; }
.ic-onboarding-page__tour-card-title { font-size: 0.95rem; font-weight: 600; color: var(--ic-text-primary, #fff); margin: 0 0 4px; }
.ic-onboarding-page__tour-card-summary { font-size: 0.8125rem; color: var(--ic-text-secondary, #9aa1ad); margin: 0 0 8px; }
.ic-onboarding-page__tour-card-meta {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 0.6875rem;
	color: var(--ic-text-tertiary, #7f868f);
}
.ic-onboarding-page__tour-card-actions {
	display: flex;
	flex-direction: column;
	gap: 6px;
	flex-shrink: 0;
}

/* -------------------- Mobile tuning -------------------- */

@media (max-width: 575.98px) {
	.ic-tour-popover { min-width: calc(100vw - 28px); max-width: calc(100vw - 28px); }
	.ic-help-panel   { right: 14px; left: 14px; width: auto; bottom: 70px; }
}
