@import url("ai_tokens.css");

/**
 * AI Theatre — display components (skeleton loaders, etc.)
 * Figma: Affino AI - Design System
 */

/* ── Theatre container (for carousel column/arrow queries) ── */

#chat-main,
.ao-search-ai_panel {
	container-type: inline-size;
	container-name: theatre;
}

/* ── Container ───────────────────────────────────────── */

.skeleton {
	display: flex;
	flex-direction: column;
	gap: var(--ai-spacing-4);
}

/* ── Bars ────────────────────────────────────────────── */

.skeleton__line {
	height: var(--ai-spacing-5);
	border-radius: var(--ai-radius-sm);
	background: var(--ai-skeleton-base);
}

/* ── Line widths (5-line text block pattern) ─────────── */

.skeleton__line:nth-child(5n+1) { width: 100%; }
.skeleton__line:nth-child(5n+2) { width: 50%; }
.skeleton__line:nth-child(5n+3) { width: 84%; }
.skeleton__line:nth-child(5n+4) { width: 73%; }
.skeleton__line:nth-child(5n+5) { width: 36%; }

/* ── Shimmer animation ───────────────────────────────── */

@keyframes skeleton-shimmer {
	0%   { background-position: 100% 0; }
	100% { background-position: -100% 0; }
}

.skeleton--active .skeleton__line {
	background:
		linear-gradient(
			90deg,
			var(--ai-skeleton-base) 0%,
			var(--ai-skeleton-base) 30%,
			var(--ai-skeleton-highlight) 50%,
			var(--ai-skeleton-base) 70%,
			var(--ai-skeleton-base) 100%
		);
	background-size: 300% 100%;
	animation: skeleton-shimmer 1.5s infinite ease-in-out;
}


/* ==========================================================================
   Sources Carousel
   Figma: Affino AI - Design System > SourcesCarousel
   ========================================================================== */

.sources-carousel {
	position: relative;
}

/* ── Scroll container ────────────────────────────────── */

.sources-carousel__track {
	display: flex;
	gap: var(--ai-spacing-3);
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	scroll-behavior: smooth;
	-ms-overflow-style: none;
	scrollbar-width: none;
	cursor: grab;
}

.sources-carousel__track::-webkit-scrollbar {
	display: none;
}

/* ── Card ────────────────────────────────────────────── */

.sources-card {
	container-type: inline-size;
	flex: 0 0 calc((100% / 1.5) - (var(--ai-spacing-3) * (0.5 / 1.5)));
	scroll-snap-align: start;
	min-width: 0;
	overflow: hidden;
	text-decoration: none;
	color: inherit;
}

.sources-card:hover {
	text-decoration: none;
}

.sources-card__inner {
	display: flex;
	flex-direction: column;
	gap: var(--ai-spacing-3);
	padding: var(--ai-spacing-4);
	background-color: var(--ai-src-carousel-card-bg);
	border-radius: var(--ai-radius-md);
	height: 100%;
}

/* ── Card text ───────────────────────────────────────── */

.sources-card__text {
	display: flex;
	flex-direction: column;
	gap: var(--ai-spacing-1);
	flex: 1;
	min-width: 0;
	line-height: var(--ai-leading-xs);
}

.sources-card__category {
	font-family: var(--ai-font-body);
	font-weight: var(--ai-font-medium);
	font-size: var(--ai-font-fixed-xxs);
	color: var(--ai-text-contrast);
	margin: 0;
}

.sources-card__title {
	font-family: var(--ai-font-title);
	font-weight: var(--ai-font-semibold);
	font-size: var(--ai-font-fixed-xs);
	color: var(--ai-text-primary);
	margin: 0;
	overflow: hidden;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
}

/* ── Card thumbnail ──────────────────────────────────── */

.sources-card__thumb {
	width: var(--ai-spacing-10);
	height: var(--ai-spacing-10);
	border-radius: var(--ai-radius-sm);
	object-fit: cover;
	flex-shrink: 0;
}

/* ── Container query: wide card → horizontal layout ──── */

@container (min-width: 14em) {
	.sources-card__inner {
		flex-direction: row;
		gap: var(--ai-spacing-5);
		align-items: center;
	}

	.sources-card__thumb {
		order: 1;
	}
}

/* ── Navigation arrows ───────────────────────────────── */

.sources-carousel__nav {
	display: none;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 1;
	width: var(--ai-spacing-7);
	height: var(--ai-spacing-7);
	padding: 0;
	align-items: center;
	justify-content: center;
	border: 1px solid var(--ai-btn-secondary-border);
	border-radius: var(--ai-radius-md);
	background: var(--ai-surface-primary);
	cursor: pointer;
	color: var(--ai-icon-primary);
}

.sources-carousel__nav:hover {
	background: var(--ai-btn-secondary-bg-hover);
}

.sources-carousel__nav svg {
	width: var(--ai-icon-size-sm);
	height: var(--ai-icon-size-sm);
}

.sources-carousel__nav--prev {
	left: calc(-1 * var(--ai-spacing-8));
}

.sources-carousel__nav--next {
	right: calc(-1 * var(--ai-spacing-8));
}

.sources-carousel__nav[disabled] {
	display: none;
}

/* ── Responsive: tablet — 2.5 columns ────────────────── */

@container theatre (min-width: 640px) {
	.sources-card {
		flex: 0 0 calc((100% / 2.5) - (var(--ai-spacing-3) * (1.5 / 2.5)));
	}
}

/* ── Responsive: desktop — 3 columns + arrows ────────── */

@container theatre (min-width: 1024px) {
	.sources-card {
		flex: 0 0 calc((100% / 3) - (var(--ai-spacing-3) * (2 / 3)));
	}

	.sources-carousel__nav {
		display: flex;
	}
}


/* ==========================================================================
   Working Intro
   Figma: Affino AI - Design System > WorkingIntro
   ========================================================================== */

.working-intro {
	display: flex;
	flex-direction: column;
	gap: var(--ai-spacing-3);
	margin-top: var(--ai-spacing-5);
}

/* ── Title row (logo + heading) ──────────────────────── */

.working-intro__title-row {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: var(--ai-spacing-3);
}

@media (min-width: 640px) {
	.working-intro__title-row {
		flex-direction: row;
		align-items: center;
	}
}

.working-intro__logo {
	width: var(--ai-icon-size-md);
	height: var(--ai-icon-size-md);
	flex-shrink: 0;
	color: var(--ai-icon-brand);
	animation: working-intro-pulse 2.4s ease-in-out infinite;
}

.working-intro__logo svg {
	width: 100%;
	height: 100%;
	display: block;
}

@keyframes working-intro-pulse {
	0%, 100% { opacity: 0.4; transform: scale(1); }
	50%      { opacity: 1;   transform: scale(1.2); }
}

.working-intro__title {
	font-family: var(--ai-font-title);
	font-weight: var(--ai-font-bold);
	font-size: var(--ai-font-fixed-md);
	color: var(--ai-text-primary);
	line-height: var(--ai-leading-md);
	letter-spacing: var(--ai-tracking-3);
	margin: 0;
	overflow: hidden;
	clip-path: inset(0);
}

/* ── Title char-by-char shimmer (applied by JS) ──────── */

.working-intro__title--shimmer span {
	animation: working-intro-char-pulse 1.775s infinite;
}

@keyframes working-intro-char-pulse {
	0%   { opacity: 0.2; }
	28%  { opacity: 1; }
	99%  { opacity: 1; }
	100% { opacity: 0.2; }
}

/* ── Subtitle ────────────────────────────────────────── */

.working-intro__subtitle {
	font-family: var(--ai-font-body);
	font-weight: var(--ai-font-regular);
	font-size: var(--ai-font-fixed-sm);
	color: var(--ai-text-secondary);
	line-height: var(--ai-leading-md);
	letter-spacing: var(--ai-tracking-4);
	margin: 0;
}

.working-intro__subtitle--medium {
	font-weight: var(--ai-font-medium);
}

/* ── Stopped state — halt all animations ─────────────── */

.working-intro--stopped .working-intro__logo {
	animation: none;
	opacity: 1;
}

.working-intro--stopped .working-intro__title--shimmer span {
	animation: none;
	opacity: 1;
}


/* ==========================================================================
   Chat Response (Theatre Orchestrator)
   Figma: Affino AI - Design System > ChatResponse
   ========================================================================== */

.chat-response {
	display: flex;
	flex-direction: column;
}

/* ── Sources slot ───────────────────────────────────── */

.chat-response__sources {
	margin-top: var(--ai-spacing-5);
	display: none;
}

/* ── Skeleton slot ──────────────────────────────────── */

.chat-response__skeletons {
	display: flex;
	flex-direction: column;
	gap: var(--ai-spacing-6);
	margin-top: var(--ai-spacing-8);
}

/* ── Answer slot ────────────────────────────────────── */

.chat-response__answer {
	margin-top: var(--ai-spacing-6);
	font-family: var(--ai-font-body);
	font-size: var(--ai-font-fixed-sm);
	color: var(--ai-text-primary);
	line-height: var(--ai-leading-md);
}

.chat-response__answer p {
	margin: 0 0 var(--ai-spacing-5);
}

.chat-response__answer p:last-child {
	margin-bottom: 0;
}

.chat-response a:not(.sources-link):not(.sources-card) {
	color: var(--ai-text-primary);
	font-weight: var(--ai-font-medium);
	text-decoration: underline;
	text-decoration-style: dotted;
	text-underline-offset: 4px;
	white-space: nowrap;
}

.chat-response a:not(.sources-link):not(.sources-card):hover {
	color: var(--ai-text-secondary);
}


/* ==========================================================================
   Suggested Prompts
   Figma: Affino AI - Design System > Prompt Templates
   ========================================================================== */

.suggested-prompts {
	display: flex;
	flex-wrap: wrap;
	gap: var(--ai-spacing-5, 8px);
}
.suggested-prompt {
	display: flex;
	flex-direction: column;
	gap: var(--ai-spacing-3, 8px);
	padding: var(--ai-spacing-5, 16px);
	background-color: var(--ai-chat-surface-tertiary, #f6f6f7);
	border-radius: var(--ai-radius-lg, 16px);
	width: 100%;
	cursor: pointer;
	transition: transform .2s ease;
}
.suggested-prompt:hover {
	transform: scale(1.02);
}
@container theatre (min-width: 600px) {
	.suggested-prompt {
		width: calc((100% - var(--ai-spacing-5, 8px) * 2) / 3);
	}
}
.suggested-prompt__icon {
	color: var(--ai-text-contrast, #67676c);
}
.suggested-prompt__text {
	display: flex;
	flex-direction: column;
	gap: var(--ai-spacing-1, 4px);
}
.suggested-prompt__title {
	font-family: var(--ai-font-title, sans-serif);
	font-weight: var(--ai-font-semibold, 600);
	font-size: var(--ai-font-fixed-xs, 14px);
	line-height: var(--ai-leading-sm, 20px);
	color: var(--ai-text-primary, #212123);
}
.suggested-prompt__teaser {
	font-family: var(--ai-font-body, sans-serif);
	font-weight: var(--ai-font-regular, 400);
	font-size: var(--ai-font-fixed-xxs, 12px);
	line-height: 1.5;
	color: var(--ai-text-contrast, #67676c);
}


/* ==========================================================================
   Quick Links
   Figma: Affino AI - Design System > QuickLinks
   ========================================================================== */

.quick-links {
	display: flex;
	flex-direction: column;
	gap: var(--ai-spacing-1);
	align-items: flex-start;
}

.quick-links__heading {
	font-family: var(--ai-font-body);
	font-weight: var(--ai-font-semibold);
	font-size: var(--ai-font-fixed-xs);
	line-height: var(--ai-leading-md);
	color: var(--ai-text-primary);
	font-feature-settings: 'case' 1;
	margin: 0;
}

.quick-links__list {
	display: flex;
	flex-wrap: wrap;
	gap: var(--ai-spacing-1);
	align-items: center;
	width: 100%;
}

.quick-links--full .sources-link {
	max-width: 100%;
}

.chat-response .quick-links {
	margin-bottom: var(--ai-spacing-4);
}


/* ==========================================================================
   Sources Link
   Figma: Affino AI - Design System > SourcesLink
   ========================================================================== */

.sources-link {
	display: inline-flex;
	align-items: center;
	gap: var(--ai-spacing-3);
	padding: var(--ai-spacing-3) var(--ai-spacing-5);
	max-width: 100%;
	border: 1px solid;
	border-radius: var(--ai-radius-full);
	font-family: var(--ai-font-title);
	font-weight: var(--ai-font-medium);
	font-size: var(--ai-font-fixed-xxs);
	line-height: var(--ai-leading-xs);
	text-decoration: none;
	cursor: pointer;
	white-space: nowrap;
	transition: background-color 0.15s ease,
	            border-color 0.15s ease;
}

.sources-link__text {
	flex: 1 0 0;
	min-width: 0;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.sources-link svg {
	width: var(--ai-icon-size-sm);
	height: var(--ai-icon-size-sm);
	flex-shrink: 0;
}

@media (min-width: 1024px) {
	.sources-link {
		max-width: 12rem;
	}
}

a.sources-link:hover {
	text-decoration: none;
}

/* ── Primary variant (brand-colored) ──────────────────── */

.sources-link--primary {
	background: var(--_brand-bg, color-mix(in srgb, var(--ai-chat-brand) 8%, var(--ai-surface-primary)));
	border-color: var(--_brand-border, color-mix(in srgb, var(--ai-chat-brand) 30%, var(--ai-surface-primary)));
	color: var(--_brand-text, var(--ai-chat-brand));
}

.sources-link--primary:hover {
	background: var(--_brand-bg-hover, color-mix(in srgb, var(--ai-chat-brand) 15%, var(--ai-surface-primary)));
	border-color: var(--_brand-border-hover, color-mix(in srgb, var(--ai-chat-brand) 50%, var(--ai-surface-primary)));
}

a.sources-link--primary:hover {
	color: var(--_brand-text, var(--ai-chat-brand));
}

/* Dark mode — stronger brand tint for readability */
[data-theme="dark"] .sources-link--primary,
.theme-dark .sources-link--primary {
	background: var(--_brand-bg, color-mix(in srgb, var(--ai-chat-brand) 15%, var(--ai-surface-primary)));
	border-color: var(--_brand-border, color-mix(in srgb, var(--ai-chat-brand) 40%, var(--ai-surface-primary)));
	color: var(--_brand-text, color-mix(in srgb, var(--ai-chat-brand) 45%, white));
}

[data-theme="dark"] .sources-link--primary:hover,
.theme-dark .sources-link--primary:hover {
	background: var(--_brand-bg-hover, color-mix(in srgb, var(--ai-chat-brand) 22%, var(--ai-surface-primary)));
	border-color: var(--_brand-border-hover, color-mix(in srgb, var(--ai-chat-brand) 55%, var(--ai-surface-primary)));
}

[data-theme="dark"] a.sources-link--primary:hover,
.theme-dark a.sources-link--primary:hover {
	color: var(--_brand-text, color-mix(in srgb, var(--ai-chat-brand) 45%, white));
}

/* ── Link variant (neutral) ───────────────────────────── */

.sources-link--link {
	background: var(--ai-surface-minimal);
	border-color: var(--ai-surface-contrast);
	color: var(--ai-text-primary);
}

.sources-link--link svg {
	color: var(--ai-icon-secondary);
}

.sources-link--link:hover {
	background: var(--ai-surface-contrast);
	border-color: var(--ai-surface-contrast);
}

a.sources-link--link:hover {
	color: var(--ai-text-primary);
}

