/* Clube de Vídeos — front-end. Tudo dentro de .cv-app para não afetar o resto do tema. */
.cv-app {
	--cv-bg: #0d0d11;
	--cv-surface: #16161d;
	--cv-surface-2: #1d1d27;
	--cv-line: #2a2a36;
	--cv-text: #f4f1ea;
	--cv-muted: #9a96a6;
	--cv-accent: #ff5436;
	--cv-accent-2: #ffb33a;
	--cv-radius: 18px;

	background: var(--cv-bg);
	color: var(--cv-text);
	font-family: "Hanken Grotesk", system-ui, sans-serif;
	line-height: 1.55;
	border-radius: 24px;
	overflow: hidden;
	margin: 0 auto;
	max-width: 1180px;
	padding: clamp(20px, 4vw, 56px);
	box-sizing: border-box;
}

.cv-app * { box-sizing: border-box; }

/* ---------- HERO ---------- */
.cv-hero {
	position: relative;
	text-align: center;
	padding: clamp(28px, 6vw, 80px) clamp(12px, 3vw, 40px) clamp(24px, 5vw, 56px);
	isolation: isolate;
}
.cv-hero__glow {
	position: absolute;
	inset: -40% 10% auto 10%;
	height: 360px;
	background: radial-gradient(60% 60% at 50% 30%, rgba(255, 84, 54, 0.35), transparent 70%);
	filter: blur(20px);
	z-index: -1;
}
.cv-eyebrow {
	text-transform: uppercase;
	letter-spacing: 0.28em;
	font-size: 12px;
	font-weight: 600;
	color: var(--cv-accent-2);
	margin: 0 0 14px;
}
.cv-hero__title {
	font-family: "Bricolage Grotesque", serif;
	font-weight: 800;
	font-size: clamp(2rem, 5.4vw, 4rem);
	line-height: 0.98;
	letter-spacing: -0.02em;
	margin: 0 auto 18px;
	max-width: 16ch;
	color: var(--cv-text);
}
.cv-hero__sub {
	color: var(--cv-muted);
	font-size: clamp(1rem, 1.6vw, 1.25rem);
	max-width: 52ch;
	margin: 0 auto 28px;
}
.cv-hero__cta {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
	align-items: center;
	justify-content: center;
}

/* ---------- BOTÕES / LINKS ---------- */
.cv-btn {
	display: inline-block;
	background: var(--cv-accent);
	color: #fff;
	font-weight: 600;
	text-decoration: none;
	border-radius: 999px;
	padding: 14px 26px;
	transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
	box-shadow: 0 10px 30px -10px rgba(255, 84, 54, 0.7);
}
.cv-btn:hover { transform: translateY(-2px); background: #ff6a4f; box-shadow: 0 16px 40px -12px rgba(255, 84, 54, 0.85); color: #fff; }
.cv-btn--lg { font-size: 1.05rem; padding: 17px 34px; }
.cv-btn--small { padding: 9px 18px; font-size: 0.9rem; }
.cv-link { color: var(--cv-text); text-decoration: none; border-bottom: 1px solid var(--cv-line); padding-bottom: 2px; font-weight: 500; }
.cv-link:hover { color: var(--cv-accent-2); border-color: var(--cv-accent-2); }

/* ---------- SEÇÕES ---------- */
.cv-section { padding: clamp(16px, 3vw, 32px) 0; }
.cv-section__title {
	font-family: "Bricolage Grotesque", serif;
	font-weight: 700;
	font-size: clamp(1.4rem, 3vw, 2rem);
	letter-spacing: -0.01em;
	margin: 0 0 22px;
	color: var(--cv-text);
}
.cv-muted { color: var(--cv-muted); }

/* ---------- CATEGORIA ---------- */
.cv-cat { margin-bottom: 40px; }
.cv-cat__title {
	font-family: "Bricolage Grotesque", serif;
	font-size: 1.25rem;
	font-weight: 700;
	display: flex;
	align-items: center;
	gap: 12px;
	margin: 0 0 18px;
	padding-bottom: 12px;
	border-bottom: 1px solid var(--cv-line);
}
.cv-cat__count {
	font-family: "Hanken Grotesk", sans-serif;
	font-size: 0.75rem;
	font-weight: 600;
	color: var(--cv-accent-2);
	background: rgba(255, 179, 58, 0.12);
	border-radius: 999px;
	padding: 2px 10px;
}

/* ---------- GRID DE CARTÕES (stories 9:16) ---------- */
.cv-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
	gap: clamp(14px, 2vw, 22px);
}
.cv-card {
	background: var(--cv-surface);
	border: 1px solid var(--cv-line);
	border-radius: var(--cv-radius);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: transform 0.2s ease, border-color 0.2s ease;
}
.cv-card:hover { transform: translateY(-4px); border-color: rgba(255, 84, 54, 0.5); }
.cv-card__media {
	position: relative;
	aspect-ratio: 9 / 16;
	background: var(--cv-surface-2);
	overflow: hidden;
}
.cv-card__cover, .cv-card__video {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.cv-card__cover--empty {
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--cv-muted);
	font-size: 2rem;
}
.cv-card__body { padding: 14px 14px 16px; display: flex; flex-direction: column; gap: 8px; flex: 1; }
.cv-card__title { font-size: 1rem; font-weight: 600; margin: 0; line-height: 1.25; }
.cv-card__desc { font-size: 0.85rem; color: var(--cv-muted); margin: 0; flex: 1; }
.cv-card .cv-btn { align-self: flex-start; margin-top: 4px; }

/* ---------- FAIXA DE CTA ---------- */
.cv-cta-band {
	margin-top: 24px;
	text-align: center;
	padding: clamp(32px, 5vw, 56px);
	border-radius: var(--cv-radius);
	background:
		radial-gradient(80% 120% at 50% 0%, rgba(255, 84, 54, 0.18), transparent 60%),
		var(--cv-surface);
	border: 1px solid var(--cv-line);
}
.cv-cta-band h2 {
	font-family: "Bricolage Grotesque", serif;
	font-weight: 800;
	font-size: clamp(1.5rem, 3.4vw, 2.4rem);
	letter-spacing: -0.02em;
	margin: 0 0 22px;
}

/* ---------- GATE (bloqueio) ---------- */
.cv-gate {
	text-align: center;
	padding: clamp(40px, 8vw, 90px) 20px;
	max-width: 520px;
	margin: 0 auto;
}
.cv-gate__icon { font-size: 3rem; margin-bottom: 14px; }
.cv-gate__msg { color: var(--cv-muted); font-size: 1.15rem; margin: 0 0 26px; }
