/* Dashboard de métricas e avaliações */
.site-dashboard {
	margin: var(--space-6) 0;
	padding: var(--space-5);
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-sm);
}

.site-dashboard__title {
	margin: 0 0 var(--space-4);
	font-family: var(--font-ui);
	font-size: var(--text-base);
	font-weight: 700;
	color: var(--color-primary);
	text-align: center;
}

.site-dashboard__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: var(--space-3);
	margin: 0;
	padding: 0;
	list-style: none;
	max-width: none;
	width: 100%;
}

.site-dashboard__grid > li {
	margin: 0;
	max-width: none;
}

.site-dashboard__card p {
	max-width: none;
	margin-bottom: 0;
}

@media (min-width: 640px) {
	.site-dashboard__grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

.site-dashboard__card {
	text-align: center;
	padding: var(--space-3);
	border-radius: var(--radius-md);
	background: var(--color-bg);
	border: 1px solid var(--color-border);
}

.site-dashboard__value {
	margin: 0;
	font-family: var(--font-ui);
	font-size: clamp(1.35rem, 4vw, 1.75rem);
	font-weight: 700;
	line-height: 1.1;
	color: var(--color-primary);
}

.site-dashboard__label {
	margin: var(--space-2) 0 0;
	font-size: var(--text-xs);
	line-height: 1.35;
	color: var(--color-text-muted);
}

/* Variante compacta (introdução) */
#introducao h2 {
	margin-bottom: var(--space-2);
	padding-bottom: var(--space-2);
}

.site-dashboard--compact {
	margin: var(--space-2) 0;
	padding: var(--space-2);
	background: color-mix(in srgb, var(--color-surface) 55%, var(--color-bg));
	border: 1px solid color-mix(in srgb, var(--color-border) 75%, transparent);
	border-radius: var(--radius-sm);
	box-shadow: none;
}

.site-dashboard--compact .site-dashboard__title,
.site-dashboard--compact .site-dashboard__title--compact {
	margin: 0 0 0.125rem;
	padding: 0;
	font-family: var(--font-ui);
	font-size: 0.75rem;
	font-weight: 600;
	color: var(--color-text-muted);
	text-align: left;
	line-height: 1.25;
	letter-spacing: 0.01em;
}

.site-dashboard--compact .site-dashboard__intro {
	margin: 0 0 var(--space-2);
	padding: 0;
	font-size: 0.6875rem;
	line-height: 1.35;
	color: var(--color-text-muted);
	text-align: left;
	max-width: none;
	opacity: 0.92;
}

.site-dashboard--compact .site-dashboard__grid {
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 0.25rem;
	margin: 0;
	padding: 0;
	border-top: none;
	max-width: none;
	width: 100%;
	box-sizing: border-box;
}

#introducao .site-dashboard--compact .site-dashboard__grid {
	padding-left: 0;
	padding-right: 0;
	margin-left: 0;
	margin-right: 0;
	max-width: none;
}

.site-dashboard--compact .site-dashboard__card {
	margin: 0;
	padding: 0.3rem 0.2rem;
	background: var(--color-surface);
	border: 1px solid color-mix(in srgb, var(--color-border) 80%, transparent);
	border-radius: 6px;
	box-shadow: none;
}

.site-dashboard--compact .site-dashboard__value {
	margin: 0;
	padding: 0;
	font-size: 0.8125rem;
	font-weight: 600;
	line-height: 1.1;
	color: color-mix(in srgb, var(--color-primary) 82%, var(--color-text-muted));
}

.site-dashboard--compact .site-dashboard__label {
	margin: 0.1rem 0 0;
	padding: 0;
	font-size: 0.5625rem;
	line-height: 1.15;
	color: var(--color-text-muted);
	opacity: 0.9;
}

.site-dashboard__countries {
	margin-top: var(--space-4);
	padding-top: var(--space-3);
	border-top: 1px solid var(--color-border);
	max-width: none;
}

.site-dashboard__countries--compact {
	margin-top: var(--space-2);
	padding-top: var(--space-2);
	border-top-color: color-mix(in srgb, var(--color-border) 65%, transparent);
}

.site-dashboard .site-dashboard__countries-title {
	margin: 0 0 var(--space-2);
	padding: 0;
	font-family: var(--font-ui);
	font-size: var(--text-sm);
	font-weight: 600;
	color: var(--color-primary);
	line-height: 1.3;
}

.site-dashboard--compact .site-dashboard__countries-title {
	margin: 0 0 var(--space-1);
	font-size: 0.6875rem;
	font-weight: 600;
	color: var(--color-text-muted);
}

/* Países: quantidade à esquerda, nome à direita */
.site-dashboard__card--country {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-2);
	text-align: left;
}

.site-dashboard__country-count {
	flex-shrink: 0;
	font-family: var(--font-ui);
	font-size: var(--text-sm);
	font-weight: 600;
	line-height: 1.1;
	color: var(--color-primary);
}

.site-dashboard__country-name {
	display: inline-flex;
	align-items: center;
	justify-content: flex-end;
	gap: 0.25rem;
	min-width: 0;
	max-width: 62%;
}

.site-dashboard__country-label {
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	font-size: var(--text-xs);
	line-height: 1.2;
	color: var(--color-text-muted);
}

.site-dashboard--compact .site-dashboard__countries-grid {
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 0.25rem;
}

.site-dashboard--compact .site-dashboard__card--country {
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	gap: 0.1rem;
	padding: 0.25rem 0.1rem;
	border-radius: 5px;
}

.site-dashboard--compact .site-dashboard__country-count {
	font-size: 0.75rem;
	font-weight: 600;
	color: color-mix(in srgb, var(--color-primary) 78%, var(--color-text-muted));
}

.site-dashboard--compact .site-dashboard__country-name {
	justify-content: center;
	max-width: none;
	gap: 0.1rem;
}

.site-dashboard--compact .site-dashboard__country-label {
	font-size: 0.5rem;
	line-height: 1.1;
}

.site-dashboard--compact .site-dashboard__country-flag {
	font-size: 0.85em;
	flex-shrink: 0;
	line-height: 1;
}

.site-dashboard:not(.site-dashboard--compact) .site-dashboard__card--country {
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	gap: var(--space-1);
}

.site-dashboard:not(.site-dashboard--compact) .site-dashboard__country-name {
	justify-content: center;
	max-width: none;
}

.site-dashboard:not(.site-dashboard--compact) .site-dashboard__country-label {
	white-space: normal;
	text-align: center;
}

.site-dashboard--compact .site-dashboard__stats-grid:not(.is-expanded) > li:nth-child(n + 4),
.site-dashboard--compact .site-dashboard__countries-grid:not(.is-expanded) > li:nth-child(n + 4) {
	display: none;
}

.site-dashboard:not(.site-dashboard--compact) .site-dashboard__countries-grid:not(.is-expanded) > li:nth-child(n + 7) {
	display: none;
}

.site-dashboard__country-flag {
	flex-shrink: 0;
	line-height: 1;
}

.site-dashboard__countries-actions {
	margin: var(--space-2) 0 0;
	padding: 0;
	text-align: right;
	max-width: none;
}

.site-dashboard .site-dashboard__countries-actions {
	margin-bottom: 0;
}

.site-dashboard .site-dashboard__countries-toggle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.2rem;
	min-height: 1.875rem;
	padding: 0.3rem 0.65rem;
	font-family: var(--font-ui);
	font-size: 0.6875rem;
	font-weight: 600;
	line-height: 1.2;
	color: var(--color-primary);
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	box-shadow: none;
	cursor: pointer;
	transition: border-color 0.15s ease, background 0.15s ease, color 0.15s ease;
	-webkit-tap-highlight-color: transparent;
}

.site-dashboard .site-dashboard__countries-toggle:hover,
.site-dashboard .site-dashboard__countries-toggle:focus-visible {
	color: var(--color-primary);
	background: var(--color-surface);
	border-color: var(--color-primary);
	outline: none;
}

/* Botões "Ver todos" na introdução */
.site-dashboard__stats-actions,
.site-dashboard__countries-actions {
	margin: 0.35rem 0 0;
	padding: 0;
	text-align: right;
	max-width: none;
}

.site-dashboard--compact .site-dashboard__stats-toggle,
.site-dashboard--compact .site-dashboard__countries-toggle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.15rem;
	min-height: 1.375rem;
	padding: 0.15rem 0.45rem;
	font-family: var(--font-ui);
	font-size: 0.625rem;
	font-weight: 500;
	line-height: 1.2;
	color: var(--color-text-muted);
	background: transparent;
	border: 1px solid color-mix(in srgb, var(--color-border) 85%, transparent);
	border-radius: var(--radius-full);
	box-shadow: none;
	cursor: pointer;
	transition: color 0.15s ease, border-color 0.15s ease, background 0.15s ease;
	-webkit-tap-highlight-color: transparent;
}

.site-dashboard--compact .site-dashboard__stats-toggle::after,
.site-dashboard--compact .site-dashboard__countries-toggle::after {
	content: '›';
	font-size: 1em;
	line-height: 1;
	opacity: 0.75;
}

.site-dashboard--compact .site-dashboard__stats-toggle[aria-expanded='true']::after,
.site-dashboard--compact .site-dashboard__countries-toggle[aria-expanded='true']::after {
	content: '‹';
}

.site-dashboard--compact .site-dashboard__stats-toggle:hover,
.site-dashboard--compact .site-dashboard__stats-toggle:focus-visible,
.site-dashboard--compact .site-dashboard__countries-toggle:hover,
.site-dashboard--compact .site-dashboard__countries-toggle:focus-visible {
	color: var(--color-primary);
	background: color-mix(in srgb, var(--color-primary) 6%, var(--color-surface));
	border-color: color-mix(in srgb, var(--color-primary) 28%, var(--color-border));
	outline: none;
}

.ratings-summary {
	margin-top: var(--space-6);
}

/* Página de avaliações — três blocos uniformes */
#avaliacoes .avaliacoes-panels {
	display: flex;
	flex-direction: column;
	gap: var(--space-5);
	margin: var(--space-5) 0 var(--space-4);
}

#avaliacoes .avaliacoes-panel__heading {
	margin: 0 0 var(--space-3);
	padding: 0;
	font-family: var(--font-ui);
	font-size: var(--text-base);
	font-weight: 700;
	color: var(--color-primary);
	text-align: center;
	line-height: 1.3;
}

#avaliacoes .avaliacoes-panel__meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: var(--space-2);
	margin: 0 0 var(--space-3);
	padding: 0;
	font-size: var(--text-sm);
	color: var(--color-text-muted);
	text-align: center;
	max-width: none;
}

#avaliacoes .avaliacoes-panel__meta-stars {
	color: #e6a700;
	font-size: 1.125rem;
	line-height: 1;
}

#avaliacoes .avaliacoes-panel__meta strong {
	font-family: var(--font-ui);
	font-weight: 700;
	color: var(--color-text);
}

#avaliacoes .avaliacoes-panel__cards {
	padding: var(--space-4);
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-sm);
}

#avaliacoes .avaliacoes-panel__cards .site-dashboard__grid {
	gap: var(--space-3);
}

#avaliacoes .avaliacoes-panel__cards .site-dashboard__card {
	text-align: center;
	padding: var(--space-3);
	border-radius: var(--radius-md);
	background: var(--color-bg);
	border: 1px solid var(--color-border);
}

#avaliacoes .avaliacoes-panel__cards .site-dashboard__value,
#avaliacoes .avaliacoes-panel__cards .site-dashboard__country-count {
	margin: 0;
	font-family: var(--font-ui);
	font-size: clamp(1.2rem, 3.5vw, 1.5rem);
	font-weight: 700;
	line-height: 1.1;
	color: var(--color-primary);
}

#avaliacoes .avaliacoes-panel__cards .site-dashboard__label,
#avaliacoes .avaliacoes-panel__cards .site-dashboard__country-label {
	margin: var(--space-2) 0 0;
	font-size: var(--text-xs);
	line-height: 1.35;
	color: var(--color-text-muted);
}

#avaliacoes .avaliacoes-panel__cards .site-dashboard__card--country {
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	gap: var(--space-1);
}

#avaliacoes .avaliacoes-panel__cards .site-dashboard__country-name {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.25rem;
	max-width: none;
	flex-wrap: wrap;
}

#avaliacoes .avaliacoes-panel__cards .site-dashboard__country-label {
	overflow: visible;
	text-overflow: unset;
	white-space: normal;
	text-align: center;
}

#avaliacoes .avaliacoes-panel__cards .ratings-summary__bars {
	margin: 0;
}

#avaliacoes .avaliacoes-panel__cards .ratings-summary__empty {
	margin: 0;
	text-align: center;
}

.ratings-summary__average {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--space-2);
	margin-bottom: var(--space-4);
	font-size: var(--text-base);
}

.ratings-summary__stars {
	color: #e6a700;
	font-size: 1.25rem;
}

.ratings-summary__bars {
	list-style: none;
	margin: 0 0 var(--space-5);
	padding: 0;
}

.ratings-summary__bar-row {
	display: grid;
	grid-template-columns: 2.5rem 1fr 2.5rem;
	align-items: center;
	gap: var(--space-2);
	margin-bottom: var(--space-2);
	font-size: var(--text-sm);
}

.ratings-summary__bar-track {
	height: 0.55rem;
	background: var(--color-border);
	border-radius: var(--radius-full);
	overflow: hidden;
}

.ratings-summary__bar-fill {
	display: block;
	height: 100%;
	background: var(--color-primary);
	border-radius: var(--radius-full);
}

.ratings-summary__bar-count {
	text-align: right;
	color: var(--color-text-muted);
}

.ratings-summary__empty {
	color: var(--color-text-muted);
}

/* Dialog de avaliação pós-resumo IA */
.rating-dialog {
	position: fixed;
	inset: 0;
	z-index: 1100;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: var(--space-4);
	background: rgba(15, 23, 42, 0.45);
}

.rating-dialog[hidden] {
	display: none;
}

.rating-dialog__panel {
	width: min(100%, 22rem);
	padding: var(--space-5);
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-lg);
	text-align: center;
}

.rating-dialog__title {
	margin: 0 0 var(--space-2);
	font-family: var(--font-ui);
	font-size: var(--text-lg);
	color: var(--color-primary);
}

.rating-dialog__text {
	margin: 0 0 var(--space-4);
	font-size: var(--text-sm);
	color: var(--color-text-muted);
	line-height: 1.5;
}

.rating-dialog__stars {
	display: flex;
	justify-content: center;
	gap: var(--space-1);
	margin-bottom: var(--space-4);
	border: 0;
	padding: 0;
}

.rating-dialog__star {
	font-size: 1.75rem;
	line-height: 1;
	padding: 0.15rem;
	background: none;
	border: none;
	cursor: pointer;
	color: var(--color-border);
	transition: color 0.15s ease, transform 0.15s ease;
	-webkit-tap-highlight-color: transparent;
}

.rating-dialog__star.is-active,
.rating-dialog__star:hover,
.rating-dialog__star:focus-visible {
	color: #e6a700;
	transform: scale(1.05);
	outline: none;
}

.rating-dialog__actions {
	display: flex;
	flex-direction: column;
	gap: var(--space-2);
}

.rating-dialog__thanks {
	margin: 0;
	font-size: var(--text-sm);
	color: var(--color-text);
	line-height: 1.5;
}
