/* ===== EarthWeave — Terms & Conditions page ===== */

/* keep space so the fixed header doesn't overlap the first section */
.terms-main {
	padding-top: clamp(84px, 10vw, 120px);
}

/* Title style */
.terms-title {
	font-family: 'Playfair Display', serif;
	font-weight: 700;
	font-size: clamp(34px, 6vw, 56px);
	line-height: 1.06;
	letter-spacing: 0.2px;
	margin: 0 auto 12px;
	width: min(1100px, 92vw);
	background: linear-gradient(180deg, #ffffff, #d9c4a3);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}
.terms-title::after {
	content: '';
	display: block;
	width: 72px;
	height: 3px;
	margin-top: 8px;
	border-radius: 999px;
	background: linear-gradient(90deg, var(--brand), rgba(198, 165, 114, 0.2));
}

/* Layout */
.sec-terms {
	padding: 56px 0;
	border-top: 1px solid var(--line);
}
.terms-wrap {
	display: grid;
	gap: 16px;
	align-items: start;
	grid-template-columns: 0.34fr 1.66fr;
}
.terms-aside {
	position: sticky;
	top: 84px;
	align-self: start;
}
.terms-toc {
	display: grid;
	gap: 8px;
	background: var(--card);
	border: 1px solid var(--line);
	border-radius: 16px;
	padding: 12px;
}
.terms-toc a {
	text-decoration: none;
	color: var(--muted);
	border: 1px solid transparent;
	border-radius: 10px;
	padding: 6px 8px;
	transition: color 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
}
.terms-toc a:hover {
	color: var(--brand);
	border-color: var(--brand);
	transform: translateY(-1px);
}

.terms-content {
	background: var(--card);
	border: 1px solid var(--line);
	border-radius: 18px;
	padding: 16px;
}
.terms-content h2 {
	font-size: clamp(18px, 2.4vw, 22px);
	margin: 10px 0 8px;
	font-family: 'Playfair Display', serif;
	scroll-margin-top: 96px; /* anchor offset for fixed header */
}
.terms-content p {
	color: var(--muted);
	margin: 0 0 12px;
	line-height: 1.55;
}
.terms-content .updated {
	color: var(--ink);
	margin-top: 14px;
	font-weight: 600;
}

/* Responsive */
@media (max-width: 980px) {
	.terms-wrap {
		grid-template-columns: 1fr;
	}
	.terms-aside {
		position: static;
	}
}
