/* =========================================================
   VIVI Policy / Guidelines Pages
   Scope: /website-usage-guidelines/ and related policy routes
   Purpose: 接回網站基礎設定的字級、按鈕、卡片、色票與 RWD
========================================================= */

.vivi-policy-page {
	background: var(--vivi-color-bg);
	color: var(--vivi-color-text);
	font-family: var(--vivi-font-main);
}

.vivi-policy-main {
	min-height: 70vh;
}

.vivi-policy-hero {
	padding: var(--vivi-page-main-padding-top) var(--vivi-page-padding-x) var(--vivi-space-2xl);
	background: linear-gradient(180deg, var(--vivi-color-card) 0%, var(--vivi-color-bg) 100%);
	border-bottom: 1px solid var(--vivi-color-border);
}

.vivi-policy-hero-inner {
	width: min(100% - 20px, var(--vivi-container));
	margin-inline: auto;
	text-align: center;
}

.vivi-policy-kicker {
	margin: 0 0 var(--vivi-space-xs);
	color: var(--vivi-color-orange);
	font-size: var(--vivi-fs-xs);
	font-weight: var(--vivi-fw-bold);
	line-height: var(--vivi-lh-compact);
	letter-spacing: .18em;
	text-transform: uppercase;
}

.vivi-policy-hero h1 {
	margin: 0;
	color: var(--vivi-color-heading);
	font-size: var(--vivi-fs-h1);
	font-weight: var(--vivi-fw-heading);
	line-height: var(--vivi-lh-heading);
	letter-spacing: .04em;
}

.vivi-policy-hero p:not(.vivi-policy-kicker) {
	width: min(760px, 100%);
	margin: var(--vivi-space-md) auto 0;
	color: var(--vivi-color-text-muted);
	font-size: var(--vivi-fs-body);
	font-weight: var(--vivi-fw-regular);
	line-height: var(--vivi-lh-body);
}

.vivi-policy-shell {
	width: min(100% - 20px, var(--vivi-container-wide));
	margin: var(--vivi-page-top-gap) auto var(--vivi-page-main-padding-bottom);
	display: grid;
	grid-template-columns: 280px minmax(0, 1fr);
	gap: var(--vivi-space-xl);
	align-items: start;
}

.vivi-policy-nav {
	position: sticky;
	top: calc(var(--vivi-header-height) + var(--vivi-space-md));
	z-index: 10;
}

.vivi-policy-nav-card {
	display: grid;
	gap: var(--vivi-space-xs);
	padding: var(--vivi-space-xs);
	border: 1px solid var(--vivi-color-border);
	border-radius: var(--vivi-radius-xl);
	background: var(--vivi-color-card);
	box-shadow: var(--vivi-shadow-card);
}

.vivi-policy-tab {
	display: flex;
	flex-direction: column;
	gap: var(--vivi-space-2xs);
	width: 100%;
	padding: var(--vivi-space-md);
	border: 1px solid transparent;
	border-radius: var(--vivi-radius-lg);
	background: transparent;
	color: var(--vivi-page-tab-color);
	text-align: left;
	transition:
		background-color var(--vivi-transition),
		border-color var(--vivi-transition),
		color var(--vivi-transition),
		transform var(--vivi-transition);
}

.vivi-policy-tab:hover,
.vivi-policy-tab:focus-visible {
	background: var(--vivi-page-tab-hover-bg);
	color: var(--vivi-page-tab-hover-color);
	outline: none;
}

.vivi-policy-tab.is-active {
	background: var(--vivi-page-tab-active-bg);
	border-color: var(--vivi-page-tab-active-border);
	color: var(--vivi-page-tab-active-color);
}

.vivi-policy-tab span {
	font-size: var(--vivi-fs-button);
	font-weight: var(--vivi-fw-button);
	line-height: var(--vivi-lh-compact);
}

.vivi-policy-tab small {
	color: currentColor;
	font-size: var(--vivi-fs-xs);
	font-weight: var(--vivi-fw-regular);
	line-height: var(--vivi-lh-compact);
	opacity: .72;
}

.vivi-policy-content {
	min-width: 0;
}

.vivi-policy-panel {
	overflow: hidden;
	border: 1px solid var(--vivi-color-border);
	border-radius: var(--vivi-radius-xl);
	background: var(--vivi-color-card);
	box-shadow: var(--vivi-shadow-card);
}

.vivi-policy-panel-head {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: var(--vivi-space-lg);
	padding: var(--vivi-space-xl) var(--vivi-space-xl) var(--vivi-space-lg);
	border-bottom: 1px solid var(--vivi-color-border);
	background: linear-gradient(180deg, var(--vivi-color-card) 0%, var(--vivi-color-bg-soft) 100%);
}

.vivi-policy-panel-head h2 {
	margin: 0;
	color: var(--vivi-color-heading);
	font-size: var(--vivi-fs-h2);
	font-weight: var(--vivi-fw-heading);
	line-height: var(--vivi-lh-heading);
	letter-spacing: .03em;
}

.vivi-policy-panel-head p:not(.vivi-policy-kicker) {
	max-width: 680px;
	margin: var(--vivi-space-sm) 0 0;
	color: var(--vivi-color-text-muted);
	font-size: var(--vivi-fs-body);
	font-weight: var(--vivi-fw-regular);
	line-height: var(--vivi-lh-body);
}

.vivi-policy-panel-head time {
	flex: 0 0 auto;
	display: inline-flex;
	align-items: center;
	min-height: 32px;
	padding: 0 var(--vivi-space-sm);
	border: 1px solid color-mix(in srgb, var(--vivi-color-orange) 28%, transparent);
	border-radius: var(--vivi-radius-pill);
	background: color-mix(in srgb, var(--vivi-color-orange) 9%, transparent);
	color: var(--vivi-color-orange);
	font-size: var(--vivi-fs-xs);
	font-weight: var(--vivi-fw-bold);
	line-height: 1;
	white-space: nowrap;
}

.vivi-policy-article {
	padding: var(--vivi-space-xl);
}

.vivi-policy-article h2 {
	margin: var(--vivi-space-xl) 0 var(--vivi-space-sm);
	padding-top: var(--vivi-space-lg);
	border-top: 1px solid var(--vivi-color-border);
	color: var(--vivi-color-heading);
	font-size: var(--vivi-fs-h3);
	font-weight: var(--vivi-fw-heading);
	line-height: var(--vivi-lh-compact);
	letter-spacing: .02em;
}

.vivi-policy-article h2:first-child {
	margin-top: 0;
	padding-top: 0;
	border-top: 0;
}

.vivi-policy-article h3 {
	margin: var(--vivi-space-lg) 0 var(--vivi-space-xs);
	color: var(--vivi-color-heading);
	font-size: var(--vivi-fs-body-lg);
	font-weight: var(--vivi-fw-heading);
	line-height: var(--vivi-lh-compact);
}

.vivi-policy-article p {
	margin: 0 0 var(--vivi-space-sm);
	color: var(--vivi-color-text-muted);
	font-size: var(--vivi-fs-small);
	font-weight: var(--vivi-fw-regular);
	line-height: 1.9;
}

.vivi-policy-article p strong {
	color: var(--vivi-color-heading);
	font-weight: var(--vivi-fw-bold);
}

.vivi-policy-article h2 + p,
.vivi-policy-article h3 + p {
	margin-top: 0;
}

.vivi-policy-bullet {
	position: relative;
	padding-left: 1.35em;
}

.vivi-policy-bullet::before {
	content: "";
	position: absolute;
	left: .25em;
	top: .85em;
	width: 6px;
	height: 6px;
	border-radius: var(--vivi-radius-pill);
	background: var(--vivi-color-orange);
}

.vivi-policy-inline-link {
	color: var(--vivi-color-orange);
	font-weight: var(--vivi-fw-bold);
	border-bottom: 1px solid currentColor;
	transition: opacity var(--vivi-transition);
}

.vivi-policy-inline-link:hover,
.vivi-policy-inline-link:focus-visible {
	opacity: .72;
	outline: none;
}

.vivi-policy-panel-actions {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
	gap: var(--vivi-space-sm);
	padding: 0 var(--vivi-space-xl) var(--vivi-space-xl);
}

@media (max-width: 1024px) {
	.vivi-policy-shell {
		width: min(100% - 20px, 760px);
		display: block;
		margin-top: var(--vivi-space-xl);
	}

	.vivi-policy-nav {
		position: sticky;
		top: var(--vivi-header-height-mobile);
		margin-bottom: var(--vivi-space-md);
	}

	.vivi-policy-nav-card {
		display: flex;
		gap: var(--vivi-page-tab-gap-mobile);
		overflow-x: auto;
		padding: var(--vivi-page-tab-list-padding);
		border-radius: var(--vivi-page-tab-radius);
		scrollbar-width: none;
	}

	.vivi-policy-nav-card::-webkit-scrollbar {
		display: none;
	}

	.vivi-policy-tab {
		flex: 0 0 auto;
		width: auto;
		min-width: 138px;
		min-height: var(--vivi-page-tab-height);
		padding: var(--vivi-space-sm) var(--vivi-space-md);
		align-items: center;
		justify-content: center;
		text-align: center;
		border-radius: var(--vivi-page-tab-radius);
	}

	.vivi-policy-panel-head {
		display: block;
		padding: var(--vivi-space-lg);
	}

	.vivi-policy-panel-head time {
		margin-top: var(--vivi-space-md);
	}

	.vivi-policy-article {
		padding: var(--vivi-space-lg);
	}

	.vivi-policy-panel-actions {
		padding-inline: var(--vivi-space-lg);
		padding-bottom: var(--vivi-space-lg);
	}
}

@media (max-width: 640px) {
	.vivi-policy-hero {
		padding: var(--vivi-mobile-page-main-padding-top) var(--vivi-mobile-padding-x) var(--vivi-space-lg);
	}

	.vivi-policy-hero h1 {
		font-size: var(--vivi-fs-h2);
	}

	.vivi-policy-hero p:not(.vivi-policy-kicker) {
		font-size: var(--vivi-fs-small);
		line-height: var(--vivi-lh-body);
	}

	.vivi-policy-shell {
		width: calc(100% - 20px);
		margin: var(--vivi-mobile-page-top-gap) auto var(--vivi-mobile-page-main-padding-bottom);
	}

	.vivi-policy-nav {
		top: var(--vivi-header-height-mobile);
		margin-inline: -2px;
	}

	.vivi-policy-tab span {
		font-size: var(--vivi-fs-small);
	}

	.vivi-policy-panel {
		border-radius: var(--vivi-radius-lg);
	}

	.vivi-policy-panel-head h2 {
		font-size: var(--vivi-fs-h3);
		line-height: var(--vivi-lh-compact);
	}

	.vivi-policy-panel-head p:not(.vivi-policy-kicker) {
		font-size: var(--vivi-fs-small);
	}

	.vivi-policy-article h2 {
		font-size: var(--vivi-fs-body-lg);
	}

	.vivi-policy-article h3 {
		font-size: var(--vivi-fs-body);
	}

	.vivi-policy-panel-actions {
		display: grid;
		grid-template-columns: 1fr;
	}

	.vivi-policy-panel-actions .vivi-btn {
		width: 100%;
	}
}
