/**
 * Getting Started Page — CSS Module
 *
 * Dark gamer-oriented design with full-bleed hero, section numbers,
 * dynamic cards, and responsive grid layouts.
 *
 * Class prefix: ne-gs-*
 *
 * @package NuevaEscocia
 * @see Issue #164
 */

html {
	scroll-behavior: smooth;
}

/* ================================================================
   Hero
   ================================================================ */
.ne-gs-hero {
	position: relative;
	min-height: 90vh;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	overflow: hidden;
	padding: var(--ne-space-8) var(--ne-space-6);
}

.ne-gs-hero__bg {
	position: absolute;
	inset: 0;
	z-index: 0;
}

.ne-gs-hero__gradient {
	position: absolute;
	inset: 0;
	background:
		radial-gradient(ellipse at 50% 30%, rgba(139, 127, 232, 0.2) 0%, transparent 50%),
		radial-gradient(ellipse at 20% 80%, rgba(61, 214, 140, 0.08) 0%, transparent 40%),
		linear-gradient(180deg, var(--ne-bg) 0%, var(--ne-surface) 100%);
}

.ne-gs-hero__scanlines {
	position: absolute;
	inset: 0;
	background: repeating-linear-gradient(
		0deg,
		transparent,
		transparent 2px,
		rgba(255, 255, 255, 0.015) 2px,
		rgba(255, 255, 255, 0.015) 4px
	);
	pointer-events: none;
}

.ne-gs-hero__content {
	position: relative;
	z-index: 1;
	max-width: 720px;
}

.ne-gs-hero__eyebrow {
	font-family: var(--ne-font-mono);
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 3px;
	color: var(--ne-accent);
	margin-bottom: var(--ne-space-4);
}

.ne-gs-hero__title {
	font-family: var(--ne-font-display);
	font-size: clamp(2.5rem, 6vw, 4rem);
	color: var(--ne-text);
	margin: 0 0 var(--ne-space-5);
	letter-spacing: -1px;
	line-height: 1.05;
}

.ne-gs-hero__subtitle {
	font-size: 1.15rem;
	color: var(--ne-text-muted);
	line-height: 1.7;
	margin: 0 0 var(--ne-space-7);
}

/* Stats row */
.ne-gs-hero__stats {
	display: flex;
	justify-content: center;
	gap: var(--ne-space-7);
	margin-bottom: var(--ne-space-6);
}

.ne-gs-hero__stat-value {
	display: block;
	font-family: var(--ne-font-mono);
	font-size: 1.8rem;
	color: var(--ne-accent);
	font-weight: 700;
}

.ne-gs-hero__stat-label {
	font-size: 0.75rem;
	color: var(--ne-text-subtle);
	text-transform: uppercase;
	letter-spacing: 1px;
}

/* Scroll CTA */
.ne-gs-hero__scroll-cta {
	display: inline-flex;
	align-items: center;
	gap: var(--ne-space-2);
	font-size: 0.85rem;
	color: var(--ne-text-subtle);
	text-decoration: none;
	transition: color var(--ne-duration) var(--ne-ease);
}

.ne-gs-hero__scroll-cta:hover {
	color: var(--ne-accent);
}

.ne-gs-hero__scroll-cta svg {
	animation: ne-gs-bounce 2s infinite;
}

@keyframes ne-gs-bounce {
	0%, 100% { transform: translateY(0); }
	50% { transform: translateY(4px); }
}

/* ================================================================
   Sections
   ================================================================ */
.ne-gs-section {
	padding: var(--ne-space-8) 0;
}

.ne-gs-section--alt {
	background: var(--ne-surface);
}

.ne-gs-section__header {
	margin-bottom: var(--ne-space-6);
}

.ne-gs-section__number {
	display: block;
	font-family: var(--ne-font-mono);
	font-size: 0.7rem;
	color: var(--ne-accent);
	text-transform: uppercase;
	letter-spacing: 2px;
	margin-bottom: var(--ne-space-2);
}

.ne-gs-section__title {
	font-family: var(--ne-font-display);
	font-size: clamp(1.8rem, 4vw, 2.4rem);
	color: var(--ne-text);
	margin: 0;
	letter-spacing: -0.5px;
}

.ne-gs-section__text {
	font-size: 1rem;
	color: var(--ne-text-muted);
	line-height: 1.7;
	max-width: 640px;
	margin-bottom: var(--ne-space-6);
}

.ne-gs-section__cta {
	margin-top: var(--ne-space-6);
}

/* ================================================================
   Feature cards (Section 2)
   ================================================================ */
.ne-gs-features {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--ne-space-5);
}

.ne-gs-feature {
	padding: var(--ne-space-5);
	background: var(--ne-surface);
	border: 1px solid var(--ne-border);
	border-radius: var(--ne-radius-lg);
	transition: border-color var(--ne-duration) var(--ne-ease);
}

.ne-gs-section--alt .ne-gs-feature {
	background: var(--ne-elevated);
}

.ne-gs-feature:hover {
	border-color: var(--ne-accent-glow);
}

.ne-gs-feature__icon {
	width: 40px;
	height: 40px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--ne-accent-glow);
	border-radius: var(--ne-radius-md);
	color: var(--ne-accent);
	margin-bottom: var(--ne-space-3);
}

.ne-gs-feature__title {
	font-size: 0.95rem;
	color: var(--ne-text);
	margin: 0 0 var(--ne-space-2);
}

.ne-gs-feature__desc {
	font-size: 0.85rem;
	color: var(--ne-text-subtle);
	line-height: 1.5;
	margin: 0;
}

/* ================================================================
   Federation cards (Section 3)
   ================================================================ */
.ne-gs-fed-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--ne-space-3);
}

.ne-gs-fed-card {
	display: flex;
	align-items: center;
	gap: var(--ne-space-3);
	padding: var(--ne-space-3) var(--ne-space-4);
	background: var(--ne-elevated);
	border: 1px solid var(--ne-border);
	border-radius: var(--ne-radius-md);
	text-decoration: none;
	transition: border-color var(--ne-duration) var(--ne-ease);
}

.ne-gs-fed-card:hover {
	border-color: var(--ne-border-s);
}

.ne-gs-fed-card__logo {
	width: 36px;
	height: 36px;
	border-radius: var(--ne-radius-sm);
	object-fit: cover;
}

.ne-gs-fed-card__info {
	display: flex;
	flex-direction: column;
}

.ne-gs-fed-card__name {
	font-size: 0.85rem;
	color: var(--ne-text);
	font-weight: 500;
}

.ne-gs-fed-card__meta {
	font-size: 0.7rem;
	color: var(--ne-text-subtle);
}

/* ================================================================
   Step cards (Section 4)
   ================================================================ */
.ne-gs-steps-visual {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--ne-space-3);
	margin-bottom: var(--ne-space-6);
}

.ne-gs-step-card {
	text-align: center;
	padding: var(--ne-space-5) var(--ne-space-3);
	background: var(--ne-surface);
	border: 1px solid var(--ne-border);
	border-radius: var(--ne-radius-lg);
	position: relative;
}

.ne-gs-step-card__number {
	display: block;
	font-family: var(--ne-font-mono);
	font-size: 1.6rem;
	color: var(--ne-accent);
	font-weight: 700;
	margin-bottom: var(--ne-space-2);
}

.ne-gs-step-card__text {
	font-size: 0.85rem;
	color: var(--ne-text-muted);
	line-height: 1.4;
}

/* ================================================================
   Events preview (Section 4)
   ================================================================ */
.ne-gs-events-preview {
	margin-top: var(--ne-space-5);
}

.ne-gs-events-preview__title {
	font-size: 0.85rem;
	color: var(--ne-text-subtle);
	text-transform: uppercase;
	letter-spacing: 1px;
	margin: 0 0 var(--ne-space-3);
	font-family: var(--ne-font-mono);
}

.ne-gs-events-preview__list {
	display: flex;
	flex-direction: column;
	gap: var(--ne-space-2);
}

.ne-gs-event-row {
	display: flex;
	align-items: center;
	gap: var(--ne-space-3);
	padding: var(--ne-space-3) var(--ne-space-4);
	background: var(--ne-surface);
	border: 1px solid var(--ne-border);
	border-radius: var(--ne-radius-md);
	text-decoration: none;
	transition: border-color var(--ne-duration) var(--ne-ease);
}

.ne-gs-event-row:hover {
	border-color: var(--ne-border-s);
}

.ne-gs-event-row__name {
	font-size: 0.85rem;
	color: var(--ne-text);
	font-weight: 500;
	flex: 1;
}

.ne-gs-event-row__fed {
	font-size: 0.75rem;
	color: var(--ne-text-subtle);
}

.ne-gs-event-row__date {
	font-size: 0.75rem;
	color: var(--ne-accent);
	font-family: var(--ne-font-mono);
}

/* ================================================================
   Ranking pillars (Section 5)
   ================================================================ */
.ne-gs-pillars {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--ne-space-4);
}

.ne-gs-pillar {
	padding: var(--ne-space-5);
	background: var(--ne-elevated);
	border: 1px solid var(--ne-border);
	border-radius: var(--ne-radius-lg);
	text-align: center;
}

.ne-gs-pillar__icon {
	width: 48px;
	height: 48px;
	margin: 0 auto var(--ne-space-3);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.4rem;
}

.ne-gs-pillar__icon--elo     { background: rgba(139, 127, 232, 0.15); color: var(--ne-accent); }
.ne-gs-pillar__icon--sr      { background: rgba(61, 214, 140, 0.15); color: var(--ne-green); }
.ne-gs-pillar__icon--license { background: rgba(255, 184, 0, 0.15); color: var(--ne-yellow); }
.ne-gs-pillar__icon--respect { background: rgba(0, 118, 190, 0.15); color: var(--ne-text-muted); }

.ne-gs-pillar__title {
	font-size: 0.95rem;
	color: var(--ne-text);
	font-weight: 600;
	margin: 0 0 var(--ne-space-2);
}

.ne-gs-pillar__desc {
	font-size: 0.8rem;
	color: var(--ne-text-subtle);
	line-height: 1.5;
	margin: 0;
}

/* ================================================================
   Setup list (Section 6)
   ================================================================ */
.ne-gs-setup-list {
	display: flex;
	flex-direction: column;
	gap: var(--ne-space-3);
}

.ne-gs-setup-item {
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	gap: var(--ne-space-2) var(--ne-space-3);
	padding: var(--ne-space-4);
	background: var(--ne-surface);
	border: 1px solid var(--ne-border);
	border-radius: var(--ne-radius-md);
}

.ne-gs-setup-item__badge {
	font-family: var(--ne-font-mono);
	font-size: 0.65rem;
	text-transform: uppercase;
	letter-spacing: 1px;
	padding: 2px 8px;
	border-radius: var(--ne-radius-pill);
	background: rgba(139, 127, 232, 0.15);
	color: var(--ne-accent);
}

.ne-gs-setup-item__badge--rec {
	background: rgba(61, 214, 140, 0.15);
	color: var(--ne-green);
}

.ne-gs-setup-item__badge--opt {
	background: rgba(255, 255, 255, 0.05);
	color: var(--ne-text-subtle);
}

.ne-gs-setup-item__title {
	font-size: 0.95rem;
	color: var(--ne-text);
	font-weight: 600;
	margin: 0;
}

.ne-gs-setup-item__desc {
	flex-basis: 100%;
	font-size: 0.85rem;
	color: var(--ne-text-muted);
	margin: 0;
	line-height: 1.5;
}

/* ================================================================
   Tips (Section 7)
   ================================================================ */
.ne-gs-tips {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--ne-space-4);
}

.ne-gs-tip {
	display: flex;
	gap: var(--ne-space-3);
	padding: var(--ne-space-4);
	background: var(--ne-elevated);
	border: 1px solid var(--ne-border);
	border-radius: var(--ne-radius-md);
}

.ne-gs-tip__icon {
	flex-shrink: 0;
	color: var(--ne-accent);
}

.ne-gs-tip__text {
	font-size: 0.85rem;
	color: var(--ne-text-muted);
	line-height: 1.5;
	margin: 0;
}

/* ================================================================
   Reference cards (Section 8)
   ================================================================ */
.ne-gs-ref-grid {
	margin-bottom: var(--ne-space-8);
}

.ne-gs-ref-card {
	background: var(--ne-surface);
	border: 1px solid var(--ne-border);
	border-radius: var(--ne-radius-lg);
	overflow: hidden;
}

.ne-gs-ref-card__header {
	display: flex;
	align-items: center;
	gap: var(--ne-space-3);
	padding: var(--ne-space-4);
	background: var(--ne-elevated);
	border-bottom: 1px solid var(--ne-border);
}

.ne-gs-ref-card__icon {
	color: var(--ne-accent);
}

.ne-gs-ref-card__title {
	font-size: 1rem;
	color: var(--ne-text);
	margin: 0;
}

.ne-gs-ref-card__body {
	padding: var(--ne-space-4);
}

.ne-gs-ref-card__list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--ne-space-2);
	font-size: 0.85rem;
	color: var(--ne-text-muted);
}

.ne-gs-ref-card__list li::before {
	content: '\25B8';
	color: var(--ne-accent);
	margin-right: var(--ne-space-2);
}

.ne-gs-ref-card__list--ordered {
	counter-reset: ref-step;
}

.ne-gs-ref-card__list--ordered li::before {
	counter-increment: ref-step;
	content: counter(ref-step) '.';
	color: var(--ne-accent);
	font-family: var(--ne-font-mono);
	font-weight: 600;
}

/* ================================================================
   CTA Footer
   ================================================================ */
.ne-gs-cta {
	text-align: center;
	padding: var(--ne-space-8) 0;
	background:
		radial-gradient(ellipse at 50% 100%, rgba(139, 127, 232, 0.1) 0%, transparent 60%),
		var(--ne-bg);
}

.ne-gs-cta__title {
	font-family: var(--ne-font-display);
	font-size: clamp(1.8rem, 4vw, 2.8rem);
	color: var(--ne-text);
	margin: 0 0 var(--ne-space-3);
}

.ne-gs-cta__subtitle {
	font-size: 1rem;
	color: var(--ne-text-muted);
	margin: 0 0 var(--ne-space-6);
}

.ne-gs-cta__actions {
	display: flex;
	justify-content: center;
	gap: var(--ne-space-3);
	flex-wrap: wrap;
}

/* ================================================================
   Responsive — Tablet (768px)
   ================================================================ */
@media (max-width: 768px) {
	.ne-gs-hero {
		min-height: 80vh;
	}

	.ne-gs-hero__stats {
		gap: var(--ne-space-5);
	}

	.ne-gs-features,
	.ne-gs-fed-grid,
	.ne-gs-tips {
		grid-template-columns: 1fr;
	}

	.ne-gs-steps-visual {
		grid-template-columns: repeat(2, 1fr);
	}

	.ne-gs-pillars {
		grid-template-columns: repeat(2, 1fr);
	}

	.ne-gs-ref-grid {
		grid-template-columns: 1fr !important;
	}
}

/* ================================================================
   Responsive — Mobile (480px)
   ================================================================ */
@media (max-width: 480px) {
	.ne-gs-hero__stats {
		flex-direction: column;
		gap: var(--ne-space-3);
	}

	.ne-gs-steps-visual {
		grid-template-columns: 1fr;
	}

	.ne-gs-pillars {
		grid-template-columns: 1fr;
	}
}

/* === Steam Link Page (#164) === */

.ne-steam-link {
	max-width: 520px;
	margin: 0 auto;
	padding: var(--ne-space-8) var(--ne-space-4);
}

.ne-steam-link__header {
	text-align: center;
	margin-bottom: var(--ne-space-6);
}

.ne-steam-link__icon {
	color: var(--ne-text-subtle);
	margin-bottom: var(--ne-space-4);
}

.ne-steam-link__title {
	font-family: var(--ne-font-display);
	font-size: 1.5rem;
	color: var(--ne-text);
	margin: 0 0 var(--ne-space-3);
}

.ne-steam-link__desc {
	font-size: 0.9rem;
	color: var(--ne-text-muted);
	line-height: 1.6;
	margin: 0;
}

.ne-steam-link__back {
	text-align: center;
	margin-top: var(--ne-space-5);
}

.ne-steam-link__back-link {
	font-size: 0.85rem;
	color: var(--ne-text-subtle);
	text-decoration: none;
	transition: color var(--ne-duration) var(--ne-ease);
}

.ne-steam-link__back-link:hover {
	color: var(--ne-accent);
}
