/* =========================================================================
 * Nexim News — front page
 * Hero + metric strip + featured mentions + list + verticals + press kit.
 * Si appoggia ai token CSS di nexim-foundation (--nx-*).
 * ====================================================================== */

/* HERO ------------------------------------------------------------------- */
.nxn-hero {
	position: relative;
	overflow: hidden;
	padding: 120px 0 80px;
	background: var(--nx-bg);
	border-bottom: 1px solid var(--nx-line);
}
.nxn-hero__bg {
	position: absolute; inset: 0; pointer-events: none;
	background:
		radial-gradient(900px 600px at 88% -10%, rgba(67, 224, 255, .14), transparent 60%),
		radial-gradient(1100px 800px at 10% 100%, rgba(62, 139, 255, .18), transparent 65%),
		linear-gradient(180deg, transparent 0%, rgba(0,0,0,.35) 100%);
}
.nxn-hero__bg::before {
	content: ""; position: absolute; inset: 0;
	background-image:
		linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
	background-size: 56px 56px;
	mask-image: radial-gradient(1200px 700px at 50% 30%, #000 30%, transparent 75%);
	-webkit-mask-image: radial-gradient(1200px 700px at 50% 30%, #000 30%, transparent 75%);
}
.nxn-hero__inner { position: relative; z-index: 1; }

.nxn-hero__eyebrow {
	display: inline-flex; align-items: center; gap: 10px;
	padding: 7px 14px;
	border: 1px solid var(--nx-line-2);
	border-radius: 999px;
	background: rgba(255,255,255,.03);
	font-family: var(--nx-font-mono);
	font-size: 11px; letter-spacing: .14em; text-transform: uppercase;
	color: var(--nx-ink-soft);
	backdrop-filter: blur(8px);
}
.nxn-dot {
	width: 8px; height: 8px; border-radius: 50%;
	background: #43e0a8;
	box-shadow: 0 0 0 4px rgba(67, 224, 168, .18);
	animation: nxn-pulse 2s ease-in-out infinite;
}
@keyframes nxn-pulse {
	0%, 100% { box-shadow: 0 0 0 4px rgba(67, 224, 168, .18); }
	50%      { box-shadow: 0 0 0 8px rgba(67, 224, 168, .05); }
}

.nxn-hero__title {
	font-family: var(--nx-font-display);
	font-size: clamp(40px, 6vw, 84px);
	line-height: 1.02;
	letter-spacing: -.02em;
	color: var(--nx-ink);
	margin: 28px 0 22px;
	max-width: 17ch;
	font-weight: 600;
}
.nxn-hero__title-accent {
	display: block;
	background: linear-gradient(96deg, #3e8bff 0%, #43e0ff 60%, #b48bff 100%);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}
.nxn-hero__sub {
	max-width: 62ch;
	font-size: clamp(15.5px, 1.4vw, 18.5px);
	line-height: 1.6;
	color: var(--nx-ink-2);
	margin: 0 0 36px;
}

.nxn-hero__cta {
	display: flex; align-items: center; gap: 14px; flex-wrap: wrap;
	margin-bottom: 64px;
}
.nxn-hero__mail {
	font-family: var(--nx-font-mono);
	font-size: 13px;
	color: var(--nx-ink-soft);
	letter-spacing: .04em;
	padding-left: 6px;
}
.nxn-hero__mail:hover { color: var(--nx-accent); }

/* STAT STRIP ------------------------------------------------------------- */
.nxn-stats {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 0;
	margin: 0;
	border-top: 1px solid var(--nx-line);
	border-bottom: 1px solid var(--nx-line);
	padding: 28px 0;
	background: rgba(255,255,255,.015);
}
.nxn-stat {
	padding: 0 28px;
	border-right: 1px solid var(--nx-line);
}
.nxn-stat:last-child { border-right: 0; }
.nxn-stat dt {
	font-family: var(--nx-font-mono);
	font-size: 11px;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--nx-ink-soft);
	margin-bottom: 10px;
}
.nxn-stat dd {
	margin: 0;
	font-family: var(--nx-font-display);
	font-size: clamp(28px, 3vw, 40px);
	line-height: 1;
	color: var(--nx-ink);
	font-weight: 600;
	font-variant-numeric: tabular-nums;
	letter-spacing: -.01em;
}

/* SECTION HEADERS -------------------------------------------------------- */
.nxn-sec-head { max-width: 760px; margin-bottom: 56px; }
.nxn-sec-head--row {
	max-width: none;
	display: flex; align-items: flex-end; justify-content: space-between;
	gap: 24px; flex-wrap: wrap;
}
.nxn-sec-eyebrow {
	display: inline-block;
	font-family: var(--nx-font-mono);
	font-size: 11.5px;
	letter-spacing: .18em;
	text-transform: uppercase;
	color: var(--nx-brand);
	margin-bottom: 16px;
}
.nxn-sec-eyebrow--light { color: var(--nx-accent); }
.nxn-sec-title {
	font-family: var(--nx-font-display);
	font-size: clamp(28px, 3.4vw, 44px);
	line-height: 1.1;
	color: var(--nx-ink);
	letter-spacing: -.015em;
	margin: 0 0 14px;
	font-weight: 600;
}
.nxn-sec-title--sm { font-size: clamp(22px, 2.2vw, 28px); margin: 0; }
.nxn-sec-sub {
	margin: 0;
	font-size: 16px;
	line-height: 1.6;
	color: var(--nx-ink-soft);
}

/* FEATURED MENTIONS GRID ------------------------------------------------- */
.nxn-feat { background: var(--nx-bg); }
.nxn-feat-grid {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	gap: 1px;
	background: var(--nx-line);
	border: 1px solid var(--nx-line);
}
.nxn-card {
	position: relative;
	grid-column: span 3;
	background: var(--nx-bg-2);
	padding: 36px 32px;
	display: flex; flex-direction: column; gap: 18px;
	min-height: 240px;
	transition: background .2s, transform .2s;
	color: var(--nx-ink);
}
.nxn-card--xl {
	grid-column: span 6;
	min-height: 280px;
	background: linear-gradient(135deg, rgba(62,139,255,.08), rgba(67,224,255,.02) 60%, var(--nx-bg-2));
}
.nxn-card:hover {
	background: var(--nx-bg-soft);
	transform: translateY(-2px);
}
.nxn-card--xl:hover {
	background: linear-gradient(135deg, rgba(62,139,255,.12), rgba(67,224,255,.04) 60%, var(--nx-bg-soft));
}

.nxn-card__top { display: flex; gap: 8px; flex-wrap: wrap; }
.nxn-badge {
	display: inline-block;
	padding: 4px 10px;
	border-radius: 2px;
	font-family: var(--nx-font-mono);
	font-size: 10.5px;
	letter-spacing: .14em;
	text-transform: uppercase;
	font-weight: 500;
}
.nxn-badge--src {
	background: rgba(62,139,255,.14);
	color: #93c0ff;
	border: 1px solid rgba(62,139,255,.3);
}
.nxn-badge--ent {
	background: rgba(255,255,255,.04);
	color: var(--nx-ink-2);
	border: 1px solid var(--nx-line-2);
}
.nxn-card__title {
	font-family: var(--nx-font-display);
	font-size: 20px;
	line-height: 1.3;
	color: var(--nx-ink);
	margin: 0;
	font-weight: 500;
	letter-spacing: -.005em;
	flex: 1;
}
.nxn-card--xl .nxn-card__title { font-size: 28px; line-height: 1.2; max-width: 24ch; }
.nxn-card__meta {
	display: flex; align-items: center; gap: 10px;
	font-family: var(--nx-font-mono);
	font-size: 11.5px;
	letter-spacing: .08em;
	color: var(--nx-ink-soft);
	text-transform: uppercase;
}
.nxn-card__sep { color: var(--nx-ink-dim); }
.nxn-card__host { color: var(--nx-ink-2); }
.nxn-card__arrow {
	position: absolute; top: 28px; right: 28px;
	font-size: 18px;
	color: var(--nx-ink-soft);
	transition: color .15s, transform .15s;
}
.nxn-card:hover .nxn-card__arrow {
	color: var(--nx-accent);
	transform: translate(2px, -2px);
}

/* LIST SECTION ----------------------------------------------------------- */
.nxn-list-sec { background: var(--nx-bg); }
.nxn-chips { display: flex; gap: 8px; flex-wrap: wrap; }
.nxn-chip {
	display: inline-flex; align-items: center; gap: 8px;
	padding: 7px 12px 7px 14px;
	border: 1px solid var(--nx-line-2);
	border-radius: 999px;
	background: rgba(255,255,255,.025);
	font-family: var(--nx-font-mono);
	font-size: 11.5px;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: var(--nx-ink-2);
}
.nxn-chip:hover { border-color: var(--nx-brand); color: var(--nx-ink); }
.nxn-chip__num {
	padding: 1px 6px;
	border-radius: 999px;
	background: rgba(62,139,255,.18);
	color: #cfe1ff;
	font-size: 10.5px;
}

.nxn-list {
	list-style: none; margin: 0; padding: 0;
	border-top: 1px solid var(--nx-line);
}
.nxn-list__row {
	display: grid;
	grid-template-columns: 140px 130px 1fr 24px;
	align-items: center;
	gap: 24px;
	padding: 20px 4px;
	border-bottom: 1px solid var(--nx-line);
	transition: background .15s;
}
.nxn-list__row:hover { background: rgba(255,255,255,.02); }
.nxn-list__date {
	font-family: var(--nx-font-mono);
	font-size: 12px;
	letter-spacing: .08em;
	color: var(--nx-ink-soft);
	text-transform: uppercase;
}
.nxn-list__src {
	font-family: var(--nx-font-mono);
	font-size: 11px;
	letter-spacing: .14em;
	color: var(--nx-brand);
	font-weight: 500;
}
.nxn-list__title {
	font-family: var(--nx-font-display);
	font-size: 17px;
	color: var(--nx-ink);
	font-weight: 500;
	line-height: 1.4;
}
.nxn-list__title:hover { color: var(--nx-accent); }
.nxn-list__arrow {
	color: var(--nx-ink-dim);
	font-size: 16px;
	text-align: right;
}
.nxn-list__row:hover .nxn-list__arrow { color: var(--nx-accent); }

/* VERTICALS -------------------------------------------------------------- */
.nxn-verticals { background: linear-gradient(180deg, var(--nx-bg) 0%, var(--nx-bg-2) 100%); border-top: 1px solid var(--nx-line); }
.nxn-vert-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1px;
	background: var(--nx-line);
	border: 1px solid var(--nx-line);
}
.nxn-vert {
	background: var(--nx-bg);
	padding: 32px 28px;
	transition: background .2s;
}
.nxn-vert:hover { background: var(--nx-bg-soft); }
.nxn-vert__title {
	font-family: var(--nx-font-display);
	font-size: 19px;
	color: var(--nx-ink);
	margin: 0 0 10px;
	font-weight: 600;
	letter-spacing: -.005em;
}
.nxn-vert__desc {
	margin: 0;
	font-size: 13.5px;
	line-height: 1.55;
	color: var(--nx-ink-soft);
}

/* PRESS KIT -------------------------------------------------------------- */
.nxn-press {
	background:
		radial-gradient(700px 500px at 12% 0%, rgba(62,139,255,.18), transparent 60%),
		radial-gradient(900px 700px at 95% 100%, rgba(180,139,255,.14), transparent 60%),
		var(--nx-bg);
	border-top: 1px solid var(--nx-line);
}
.nxn-press__inner {
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	gap: 56px;
	align-items: start;
}
.nxn-press__lead {
	font-size: 17px;
	line-height: 1.6;
	color: var(--nx-ink-2);
	max-width: 56ch;
	margin: 0 0 32px;
}
.nxn-press__cta { display: flex; gap: 12px; flex-wrap: wrap; }
.nxn-press__card {
	background: rgba(255,255,255,.03);
	border: 1px solid var(--nx-line-2);
	border-radius: var(--nx-radius-lg);
	padding: 28px;
	backdrop-filter: blur(10px);
}
.nxn-press__row {
	display: flex; justify-content: space-between; gap: 16px;
	padding: 14px 0;
	border-bottom: 1px solid var(--nx-line);
	font-size: 13.5px;
}
.nxn-press__row:last-child { border-bottom: 0; padding-bottom: 0; }
.nxn-press__row:first-child { padding-top: 0; }
.nxn-press__row span {
	font-family: var(--nx-font-mono);
	font-size: 11px;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: var(--nx-ink-soft);
}
.nxn-press__row strong {
	color: var(--nx-ink);
	font-weight: 500;
	font-family: var(--nx-font-body);
	text-align: right;
}
.nxn-press__row strong a { color: var(--nx-accent); }

/* RESPONSIVE ------------------------------------------------------------- */
@media (max-width: 1024px) {
	.nxn-stats { grid-template-columns: repeat(2, 1fr); }
	.nxn-stat { padding: 18px 24px; border-bottom: 1px solid var(--nx-line); }
	.nxn-stat:nth-child(2) { border-right: 0; }
	.nxn-stat:nth-child(3), .nxn-stat:nth-child(4) { border-bottom: 0; }
	.nxn-vert-grid { grid-template-columns: repeat(2, 1fr); }
	.nxn-press__inner { grid-template-columns: 1fr; gap: 36px; }
	.nxn-feat-grid { grid-template-columns: 1fr; }
	.nxn-card, .nxn-card--xl { grid-column: span 1; }
}
@media (max-width: 640px) {
	.nxn-hero { padding: 80px 0 56px; }
	.nxn-hero__cta { margin-bottom: 40px; }
	.nxn-list__row {
		grid-template-columns: 1fr;
		gap: 6px;
		padding: 18px 4px;
	}
	.nxn-list__arrow { display: none; }
	.nxn-vert-grid { grid-template-columns: 1fr; }
	.nxn-stats { grid-template-columns: 1fr; }
	.nxn-stat { border-right: 0; border-bottom: 1px solid var(--nx-line); }
	.nxn-stat:last-child { border-bottom: 0; }
}
