/* =============================================================================
   CZSBRASIL HOMEPAGE
   =============================================================================
   "Lobby Brasileiro do Servidor": dark deep, azul-Discord pontual, sem grid
   de cards iguais, sem hero-metric template, sem eyebrow em toda secao.
   Tokens consumidos de tokens.css.
============================================================================= */


/* --- ANIMATIONS ---------------------------------------------------------- */

@keyframes homeHeroIn {
	from { opacity: 0; translate: 0 12px; }
	to   { opacity: 1; translate: 0 0;    }
}

@keyframes homeBgFloat {
	0%, 100% { translate: 0 0; }
	50%      { translate: -2% 2%; }
}

@keyframes homeStatusPulse {
	0%, 100% { opacity: 1;    }
	50%      { opacity: 0.55; }
}


/* --- SECTION: HERO ------------------------------------------------------- */

.home-hero {
	position: relative;
	isolation: isolate;
	min-height: clamp(560px, 78vh, 820px);
	background: var(--czs-bg-base);
	overflow: hidden;
	padding-block: clamp(3rem, 7vh, 6rem);
	display: grid;
	align-items: center;
}

/* Atmospheric radial drift: azul-Discord 20/20 + magenta 80/80 */
.home-hero::before {
	content: '';
	position: absolute;
	inset: -25% -10%;
	background:
		radial-gradient(ellipse at 22% 18%, rgb(var(--czs-brand-primary-rgb) / 0.14) 0%, transparent 55%),
		radial-gradient(ellipse at 82% 78%, rgb(var(--czs-brand-accent-rgb) / 0.08) 0%, transparent 50%);
	animation: homeBgFloat 24s ease-in-out infinite;
	pointer-events: none;
	z-index: -1;
}

/* Subtle masked grid texture */
.home-hero::after {
	content: '';
	position: absolute;
	inset: 0;
	background-image:
		linear-gradient(var(--czs-overlay-subtle) 1px, transparent 1px),
		linear-gradient(90deg, var(--czs-overlay-subtle) 1px, transparent 1px);
	background-size: 72px 72px;
	mask-image: radial-gradient(ellipse at center, black 25%, transparent 75%);
	-webkit-mask-image: radial-gradient(ellipse at center, black 25%, transparent 75%);
	pointer-events: none;
	z-index: -1;
}

.home-hero__inner {
	position: relative;
	display: grid;
	grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
	gap: clamp(2rem, 5vw, 4rem);
	align-items: center;
	max-width: 1280px;
	margin-inline: auto;
	padding-inline: clamp(1rem, 4vw, 2.5rem);
	width: 100%;
}

.home-hero__text {
	z-index: 1;
	animation: homeHeroIn 800ms var(--czs-ease) both;
}

.home-hero__kicker {
	display: inline-flex;
	align-items: center;
	gap: 0.55rem;
	margin: 0 0 1.25rem;
	font: 600 0.75rem var(--czs-font-body);
	color: var(--czs-text-secondary);
	letter-spacing: 0.14em;
	text-transform: uppercase;
}

.home-hero__kicker-dot {
	width: 7px;
	height: 7px;
	border-radius: 50%;
	background: var(--czs-neon-green);
	box-shadow: 0 0 10px rgb(var(--czs-success-rgb) / 0.55);
}

.home-hero__title {
	font: 700 clamp(2.75rem, 7vw, 5rem) / 1 var(--czs-font-display);
	color: var(--czs-text-primary);
	margin: 0 0 1.25rem;
	letter-spacing: -0.025em;
	text-wrap: balance;
}

.home-hero__tagline {
	font: 400 clamp(1rem, 1.35vw, 1.15rem) / 1.55 var(--czs-font-body);
	color: var(--czs-text-secondary);
	margin: 0 0 2rem;
	max-width: 52ch;
	text-wrap: pretty;
}
.home-hero__tagline strong {
	color: var(--czs-text-primary);
	font-weight: 600;
}

.home-hero__actions {
	display: flex;
	flex-direction: column;
	align-items: start;
	gap: 0.75rem;
	animation: homeHeroIn 700ms 140ms var(--czs-ease) both;
}

/* Chip de presenca live: campainha do lobby. Aparece quando widget API
   retorna presence_count > 0; some quando volta a zero ou da erro. */
.home-cta__live {
	display: inline-flex;
	align-items: center;
	gap: 0.55rem;
	margin: 0;
	padding: 0.4rem 0.85rem 0.4rem 0.7rem;
	background: rgb(6 7 11 / 0.92);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	border: 1px solid var(--czs-border);
	border-radius: 999px;
	font: 600 0.75rem var(--czs-font-body);
	color: var(--czs-text-secondary);
	letter-spacing: 0.03em;
	box-shadow: 0 4px 12px rgb(0 0 0 / 0.4);
	white-space: nowrap;
	opacity: 0;
	transition: opacity 360ms var(--czs-ease-out);
	pointer-events: none;
}
.home-cta__live[data-live="true"] {
	opacity: 1;
}

.home-cta__live-dot {
	width: 7px;
	height: 7px;
	border-radius: 50%;
	background: var(--czs-neon-green);
	box-shadow: 0 0 8px rgb(var(--czs-success-rgb) / 0.7);
	animation: homeCtaLivePulse 2.4s ease-in-out infinite;
	flex-shrink: 0;
}

.home-cta__live-count {
	color: var(--czs-neon-green);
	font-weight: 700;
	font-variant-numeric: tabular-nums;
}

@keyframes homeCtaLivePulse {
	0%, 100% { opacity: 1; transform: scale(1); }
	50%      { opacity: 0.55; transform: scale(0.82); }
}


/* CTA button (single primary; o hero comita num CTA, Discord e o ponto) */
.home-cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.75rem;
	padding: 1rem 2rem;
	text-decoration: none;
	border-radius: var(--czs-radius-md);
	cursor: pointer;
	transition:
		translate 180ms var(--czs-ease-out),
		background-color 180ms var(--czs-ease-out),
		box-shadow 220ms var(--czs-ease-out);
}

/* "Porta do servidor": cor de marca solida, top-light fisico, halo denso de
   marca. Sem gradient 135o, sem lift no hover (Discord brilha, nao levanta).
   Goldman 700 uppercase carrega a energia de raid que DESIGN.md descreve. */
.home-cta--primary {
	background: var(--czs-brand-primary);
	color: var(--czs-text-on-brand);
	border: none;
	font: 700 0.875rem/1 var(--czs-font-display);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	box-shadow:
		inset 0 1px 0 rgb(255 255 255 / 0.22),
		inset 0 -1px 0 rgb(0 0 0 / 0.28),
		0 1px 0 rgb(0 0 0 / 0.3),
		0 18px 40px rgb(var(--czs-brand-primary-rgb) / 0.45);
}
.home-cta--primary:hover {
	background: var(--czs-brand-primary-bright);
	box-shadow:
		inset 0 1px 0 rgb(255 255 255 / 0.32),
		inset 0 -1px 0 rgb(0 0 0 / 0.28),
		0 1px 0 rgb(0 0 0 / 0.3),
		0 22px 50px rgb(var(--czs-brand-primary-rgb) / 0.55);
}
.home-cta--primary:focus-visible {
	outline: 2px solid var(--czs-text-on-brand);
	outline-offset: 3px;
	box-shadow:
		inset 0 1px 0 rgb(255 255 255 / 0.22),
		inset 0 -1px 0 rgb(0 0 0 / 0.28),
		0 1px 0 rgb(0 0 0 / 0.3),
		0 0 0 5px rgb(var(--czs-brand-primary-rgb) / 0.45),
		0 18px 40px rgb(var(--czs-brand-primary-rgb) / 0.45);
}
/* Press fisico: afunda 1px e perde o halo, como botao real. */
.home-cta--primary:active {
	translate: 0 1px;
	box-shadow:
		inset 0 1px 0 rgb(0 0 0 / 0.18),
		inset 0 -1px 0 rgb(255 255 255 / 0.05),
		0 8px 18px rgb(var(--czs-brand-primary-rgb) / 0.35);
}

.home-cta__icon {
	width: 1rem;
	height: 1rem;
	flex-shrink: 0;
}


/* Hero visual (character PNG) */
.home-hero__visual {
	position: relative;
	z-index: 1;
	display: flex;
	justify-content: center;
	align-items: end;
	animation: homeHeroIn 1000ms 160ms var(--czs-ease) both;
}

.home-hero__character {
	max-width: min(100%, 540px);
	height: auto;
	display: block;
	/* Floor fade so the PNG ground doesnt show as a hard edge */
	mask-image: linear-gradient(to bottom, black 70%, transparent 100%);
	-webkit-mask-image: linear-gradient(to bottom, black 70%, transparent 100%);
	filter: drop-shadow(var(--czs-shadow-xl));
}

@media (max-width: 880px) {
	.home-hero__inner {
		grid-template-columns: 1fr;
		text-align: center;
	}
	.home-hero__kicker     { justify-content: center; }
	.home-hero__tagline    { margin-inline: auto; }
	.home-hero__visual     { display: none; }
	.home-hero__actions    { align-items: center; }
}

/* Em telefone, a CTA ocupa thumb zone (cap em 22rem pra nao parecer barra). */
@media (max-width: 480px) {
	.home-cta--primary {
		width: min(100%, 22rem);
	}
}


/* --- SECTION: LIVE STATUS STRIP ----------------------------------------- */

.home-status {
	background: var(--czs-bg-base);
	padding-block: clamp(1.5rem, 3vh, 2.25rem);
	border-block: 1px solid var(--czs-border);
}

.home-status__inner {
	max-width: 1280px;
	margin-inline: auto;
	padding-inline: clamp(1rem, 4vw, 2.5rem);
	display: flex;
	flex-wrap: wrap;
	gap: clamp(1rem, 3vw, 2.5rem);
	align-items: center;
	justify-content: space-between;
	font: 500 0.95rem var(--czs-font-body);
	color: var(--czs-text-secondary);
}

.home-status__live {
	display: inline-flex;
	align-items: center;
	gap: 0.7rem;
	color: var(--czs-text-primary);
}

.home-status__dot {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: var(--czs-neon-green);
	box-shadow: 0 0 12px rgb(var(--czs-success-rgb) / 0.6);
	animation: homeStatusPulse 2.4s ease-in-out infinite;
	flex-shrink: 0;
}

.home-status__number {
	font: 700 1.4rem var(--czs-font-display);
	color: var(--czs-text-primary);
	margin-right: 0.3rem;
	font-variant-numeric: tabular-nums;
	letter-spacing: -0.01em;
}

.home-status__metric {
	display: inline-flex;
	align-items: baseline;
	gap: 0.35rem;
}

.home-status__divider {
	width: 1px;
	height: 1.5rem;
	background: var(--czs-border-strong);
	align-self: center;
	flex-shrink: 0;
}

.home-status__games {
	list-style: none;
	padding: 0;
	margin: 0;
	display: inline-flex;
	flex-wrap: wrap;
	gap: 0.5rem 1.25rem;
	font: 500 0.85rem var(--czs-font-body);
	color: var(--czs-text-muted);
	letter-spacing: 0.02em;
}
@media (max-width: 720px) {
	.home-status__inner {
		gap: 0.85rem 1.25rem;
		justify-content: flex-start;
	}
	.home-status__divider { display: none; }
}


/* --- SECTION: SERVIDOR DESTAQUE ----------------------------------------- */

.home-servers {
	background: var(--czs-bg-base);
	padding-block: clamp(4rem, 8vh, 6.5rem);
}

.home-servers__inner {
	max-width: 1280px;
	margin-inline: auto;
	padding-inline: clamp(1rem, 4vw, 2.5rem);
}

.home-servers__title {
	font: 600 clamp(1.6rem, 2.6vw, 2.35rem) / 1.15 var(--czs-font-display);
	color: var(--czs-text-primary);
	margin: 0 0 0.4rem;
	letter-spacing: -0.015em;
	text-wrap: balance;
}
.home-servers__subtitle {
	font: 400 1rem / 1.55 var(--czs-font-body);
	color: var(--czs-text-secondary);
	margin: 0 0 2.5rem;
	max-width: 56ch;
	text-wrap: pretty;
}

.home-servers__layout {
	display: grid;
	grid-template-columns: minmax(0, 1.55fr) minmax(220px, 1fr);
	gap: clamp(1.5rem, 3vw, 3rem);
	align-items: start;
}

/* Featured server card */
.home-server-feature {
	position: relative;
	background: linear-gradient(145deg, var(--czs-bg-elevated), var(--czs-bg-base));
	border: 1px solid var(--czs-border);
	border-radius: var(--czs-radius-xl);
	padding: clamp(1.5rem, 3vw, 2.25rem);
	overflow: hidden;
	display: grid;
	grid-template-columns: clamp(80px, 14vw, 110px) 1fr;
	gap: clamp(1rem, 2vw, 1.5rem);
	align-items: center;
}

/* Top glow line — luz do canal de voz, mesmo padrao do login card */
.home-server-feature::before {
	content: '';
	position: absolute;
	top: 0;
	left: 50%;
	translate: -50% 0;
	width: 180px;
	height: 1px;
	background: linear-gradient(90deg, transparent, var(--czs-brand-primary), transparent);
}

.home-server-feature__thumb {
	width: 100%;
	aspect-ratio: 1;
	border-radius: var(--czs-radius-lg);
	background: var(--czs-bg-input);
	border: 1px solid var(--czs-border);
	display: grid;
	place-items: center;
	overflow: hidden;
}
.home-server-feature__thumb img {
	width: 70%;
	height: 70%;
	object-fit: contain;
}

.home-server-feature__body { min-width: 0; }

.home-server-feature__name {
	font: 700 clamp(1.15rem, 1.7vw, 1.45rem) / 1.2 var(--czs-font-display);
	color: var(--czs-text-primary);
	margin: 0 0 0.4rem;
	text-wrap: balance;
}

.home-server-feature__desc {
	font: 400 0.95rem / 1.55 var(--czs-font-body);
	color: var(--czs-text-secondary);
	margin: 0 0 1.25rem;
}

.home-server-feature__meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.75rem 1.25rem;
}

/* Status badges (semantic vocabulary) */
.home-server-status {
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
	padding: 0.32rem 0.75rem;
	border-radius: var(--czs-radius-full);
	font: 600 0.72rem var(--czs-font-body);
	text-transform: uppercase;
	letter-spacing: 0.09em;
}
.home-server-status::before {
	content: '';
	width: 7px;
	height: 7px;
	border-radius: 50%;
}
.home-server-status--online {
	background: var(--czs-success-soft);
	color: var(--czs-neon-green);
	border: 1px solid var(--czs-success-border);
}
.home-server-status--online::before {
	background: var(--czs-neon-green);
	box-shadow: 0 0 8px rgb(var(--czs-success-rgb) / 0.6);
}
.home-server-status--lotado {
	background: var(--czs-warning-soft);
	color: var(--czs-warning);
	border: 1px solid var(--czs-warning-border);
}
.home-server-status--lotado::before {
	background: var(--czs-warning);
	box-shadow: 0 0 8px rgb(var(--czs-warning-rgb) / 0.6);
}
.home-server-status--manutencao {
	background: var(--czs-overlay-light);
	color: var(--czs-text-secondary);
	border: 1px solid var(--czs-border);
}
.home-server-status--manutencao::before {
	background: var(--czs-text-secondary);
}
.home-server-status--offline {
	background: var(--czs-overlay-light);
	color: var(--czs-text-secondary);
	border: 1px solid var(--czs-border);
}
.home-server-status--offline::before {
	background: var(--czs-text-muted);
}


/* Others list (typographic, no cards) */
.home-server-others {
	display: flex;
	flex-direction: column;
	gap: 0.4rem;
}

.home-server-others__title {
	font: 600 0.7rem var(--czs-font-body);
	color: var(--czs-text-muted);
	letter-spacing: 0.14em;
	text-transform: uppercase;
	margin: 0 0 0.5rem;
}

.home-server-others__list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 0.4rem;
}

.home-server-other {
	display: flex;
	align-items: center;
	gap: 0.85rem;
	padding: 0.65rem 0.85rem;
	border-radius: var(--czs-radius-md);
	color: var(--czs-text-secondary);
	transition:
		background-color 200ms var(--czs-ease),
		color 200ms var(--czs-ease);
}
.home-server-other:hover {
	background: var(--czs-overlay-light);
	color: var(--czs-text-primary);
}

.home-server-other__logo {
	width: 34px;
	height: 34px;
	border-radius: var(--czs-radius-sm);
	background: var(--czs-bg-input);
	display: grid;
	place-items: center;
	flex-shrink: 0;
}
.home-server-other__logo img {
	width: 22px;
	height: 22px;
	object-fit: contain;
}

.home-server-other__name {
	flex: 1;
	min-width: 0;
	font: 500 0.95rem var(--czs-font-body);
	color: inherit;
	overflow-wrap: anywhere;
}

.home-server-other__status {
	font: 500 0.72rem var(--czs-font-body);
	color: var(--czs-text-muted);
	letter-spacing: 0.06em;
	text-transform: uppercase;
}
.home-server-other--online .home-server-other__status {
	color: var(--czs-neon-green);
}

@media (max-width: 880px) {
	.home-servers__layout {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 540px) {
	.home-server-feature {
		grid-template-columns: 1fr;
		text-align: center;
	}
	.home-server-feature__meta { justify-content: center; }
	.home-server-feature__thumb { width: 88px; margin-inline: auto; }
}


/* --- SECTION: COMUNIDADE EDITORIAL -------------------------------------- */

.home-community {
	background: var(--czs-bg-section);
	padding-block: clamp(3.5rem, 7vh, 6rem);
	border-block: 1px solid var(--czs-border);
}

.home-community__inner {
	max-width: 1280px;
	margin-inline: auto;
	padding-inline: clamp(1rem, 4vw, 2.5rem);
	display: grid;
	grid-template-columns: minmax(0, 1.55fr) minmax(0, 1fr);
	gap: clamp(2rem, 5vw, 4rem);
	align-items: center;
}

.home-community__body { max-width: 60ch; }

.home-community__title {
	font: 600 clamp(1.6rem, 2.6vw, 2.4rem) / 1.15 var(--czs-font-display);
	color: var(--czs-text-primary);
	margin: 0 0 1.25rem;
	letter-spacing: -0.015em;
	text-wrap: balance;
}

.home-community__lead {
	font: 400 clamp(1rem, 1.15vw, 1.125rem) / 1.7 var(--czs-font-body);
	color: var(--czs-text-secondary);
	margin: 0;
	text-wrap: pretty;
}
.home-community__lead strong {
	color: var(--czs-text-primary);
	font-weight: 600;
}

.home-community__highlight {
	position: relative;
	padding: clamp(1.5rem, 3vw, 2rem);
	border: 1px solid var(--czs-border);
	border-radius: var(--czs-radius-xl);
	background: linear-gradient(150deg, rgb(var(--czs-brand-primary-rgb) / 0.06), var(--czs-bg-base));
}

.home-community__highlight-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font: 600 0.72rem var(--czs-font-body);
	color: var(--czs-neon-green);
	letter-spacing: 0.14em;
	text-transform: uppercase;
	margin: 0 0 0.75rem;
}

.home-community__highlight-title {
	font: 600 1.25rem / 1.3 var(--czs-font-display);
	color: var(--czs-text-primary);
	margin: 0 0 0.75rem;
	text-wrap: balance;
}

.home-community__highlight-text {
	font: 400 0.95rem / 1.6 var(--czs-font-body);
	color: var(--czs-text-secondary);
	margin: 0;
}

@media (max-width: 880px) {
	.home-community__inner {
		grid-template-columns: 1fr;
	}
}


/* --- REDUCED MOTION ------------------------------------------------------
   O safety net global em global.css ja cobre o caso geral. Aqui sobrescreve
   especificamente o que esta home introduz, pra ser explicito:
   - hero entrance crossfade instantaneo
   - bg float congela
   - status pulse para
   - hover translates somem
*/
@media (prefers-reduced-motion: reduce) {
	.home-hero__text,
	.home-hero__visual,
	.home-hero__actions {
		animation: none;
		opacity: 1;
		translate: none;
	}
	.home-hero::before,
	.home-status__dot {
		animation: none;
	}
	.home-cta--primary:active {
		translate: none;
	}
	.home-cta__live {
		transition: none;
	}
	.home-cta__live-dot {
		animation: none;
	}
}
