/* ── Variables ────────────────────────────────────── */
:root {
	--nrm-teal: var(--ali-teal, #3DAABD);
	--nrm-teal-deep: var(--ali-teal-deep, #2B8A9A);
	--nrm-teal-glow: var(--ali-teal-glow, rgba(61, 170, 189, .15));
	--nrm-navy: var(--ali-navy, #1a2332);
	--nrm-navy-light: var(--ali-navy-light, #243044);
	--nrm-cream: var(--ali-cream, #faf9f7);
	--nrm-text: var(--ali-text, #2c2c2c);
	--nrm-text-secondary: var(--ali-text-secondary, #5a5a5a);
	--nrm-radius: 16px;
	--nrm-radius-sm: 10px;
}

/* ── Reset & base ─────────────────────────────────── */
.nrm-page *,
.nrm-page *::before,
.nrm-page *::after { box-sizing: border-box; }

.nrm-page {
	font-family: 'Karla', sans-serif;
	color: var(--nrm-text);
	line-height: 1.7;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	overflow-x: hidden;
	background: #fff;
}

.nrm-page h1, .nrm-page h2, .nrm-page h3, .nrm-page h4 {
	font-family: 'DM Serif Display', serif;
	font-weight: 400;
	line-height: 1.15;
}

.nrm-page a { color: var(--nrm-teal); text-decoration: none; transition: color .25s ease; }
.nrm-page a:hover { color: var(--nrm-teal-deep); }
.nrm-page img { max-width: 100%; height: auto; }

/* ── Animations ───────────────────────────────────── */
@keyframes nrmFadeInUp {
	from { opacity: 0; transform: translateY(44px); }
	to   { opacity: 1; transform: translateY(0); }
}
@keyframes nrmFadeIn {
	from { opacity: 0; }
	to   { opacity: 1; }
}
@keyframes nrmFloat {
	0%, 100% { transform: translateY(0); }
	50%      { transform: translateY(-8px); }
}

/* ── Label ────────────────────────────────────────── */
.nrm-label {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-family: 'Karla', sans-serif;
	font-size: .72rem;
	font-weight: 700;
	letter-spacing: .15em;
	text-transform: uppercase;
	color: var(--nrm-teal);
}
.nrm-label::before {
	content: '';
	width: 24px;
	height: 2px;
	background: var(--nrm-teal);
	border-radius: 1px;
}

/* ── Pill button ──────────────────────────────────── */
.nrm-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: var(--nrm-teal);
	color: #fff !important;
	font-family: 'Karla', sans-serif;
	font-size: .82rem;
	font-weight: 600;
	letter-spacing: .04em;
	padding: 12px 28px;
	border-radius: 50px;
	border: none;
	cursor: pointer;
	transition: all .3s cubic-bezier(.22,1,.36,1);
	text-decoration: none !important;
}
.nrm-btn::after {
	content: '\2192';
	transition: transform .3s ease;
}
.nrm-btn:hover {
	background: var(--nrm-teal-deep);
	color: #fff !important;
	transform: translateY(-2px);
	box-shadow: 0 6px 24px rgba(61,170,189,.3);
}
.nrm-btn:hover::after { transform: translateX(3px); }

.nrm-btn--outline {
	background: transparent;
	border: 1.5px solid var(--nrm-teal);
	color: var(--nrm-teal) !important;
}
.nrm-btn--outline::after {
	display: none;
}
.nrm-btn--outline:hover {
	background: var(--nrm-teal);
	border-color: var(--nrm-teal);
	color: #fff !important;
	box-shadow: 0 6px 24px rgba(0,0,0,.15);
}


/* ══════════════════════════════════════════════════════
   1. HERO
   ══════════════════════════════════════════════════════ */
.nrm-hero {
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding: 100px 24px 40px;
	background: var(--nrm-cream);
	overflow: hidden;
}

/* Layered radial gradients for depth */
.nrm-hero::before {
	content: '';
	position: absolute;
	inset: 0;
	background:
		radial-gradient(ellipse at 50% 20%, rgba(61,170,189,.08) 0%, transparent 55%),
		radial-gradient(ellipse at 80% 80%, rgba(61,170,189,.05) 0%, transparent 40%);
	pointer-events: none;
}

/* Decorative book/law watermark */
.nrm-hero::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 500px;
	height: 500px;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100' fill='none' stroke='rgba(26,35,50,0.06)' stroke-width='0.7'%3E%3Cpath d='M25 20 Q50 15 50 15 Q50 15 75 20 L75 80 Q50 75 50 75 Q50 75 25 80 Z'/%3E%3Cpath d='M50 15 L50 75'/%3E%3Cpath d='M30 25 L45 22'/%3E%3Cpath d='M30 35 L45 32'/%3E%3Cpath d='M30 45 L45 42'/%3E%3Cpath d='M30 55 L45 52'/%3E%3Cpath d='M55 22 L70 25'/%3E%3Cpath d='M55 32 L70 35'/%3E%3Cpath d='M55 42 L70 45'/%3E%3Cpath d='M55 52 L70 55'/%3E%3C/svg%3E");
	background-size: contain;
	background-repeat: no-repeat;
	pointer-events: none;
	opacity: .8;
}

.nrm-hero-content {
	position: relative;
	z-index: 2;
	max-width: 800px;
}

.nrm-hero .nrm-label {
	justify-content: center;
	margin-bottom: 20px;
	animation: nrmFadeInUp .9s cubic-bezier(.22,1,.36,1) .1s both;
}

.nrm-hero h1 {
	font-size: clamp(2.6rem, 6vw, 4.2rem);
	color: var(--nrm-navy);
	margin: 0;
	letter-spacing: -.01em;
	animation: nrmFadeInUp .9s cubic-bezier(.22,1,.36,1) .2s both;
}

.nrm-hero-subtitle {
	font-family: 'DM Serif Display', serif;
	font-size: clamp(1.15rem, 2.2vw, 1.5rem);
	font-weight: 400;
	font-style: italic;
	color: var(--nrm-text-secondary);
	margin: 14px 0 0;
	line-height: 1.4;
	animation: nrmFadeInUp .9s cubic-bezier(.22,1,.36,1) .28s both;
}

.nrm-hero-line {
	width: 80px;
	height: 3px;
	background: var(--nrm-teal);
	margin: 20px auto;
	border-radius: 2px;
	animation: nrmFadeIn .6s ease .45s both;
}

.nrm-hero-intro {
	font-family: 'Karla', sans-serif;
	font-size: clamp(1rem, 1.6vw, 1.18rem);
	font-weight: 400;
	color: var(--nrm-text-secondary);
	margin: 0;
	max-width: 620px;
	margin-left: auto;
	margin-right: auto;
	line-height: 1.7;
	animation: nrmFadeInUp .9s cubic-bezier(.22,1,.36,1) .35s both;
}

/* Scroll indicator */
.nrm-hero-scroll {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	margin-top: 36px;
	animation: nrmFadeIn 1s ease 1.2s both;
}
.nrm-hero-scroll span {
	font-size: .68rem;
	text-transform: uppercase;
	letter-spacing: .15em;
	color: var(--nrm-text-secondary);
	opacity: .5;
}
.nrm-hero-scroll-line {
	width: 1px;
	height: 36px;
	background: linear-gradient(to bottom, var(--nrm-teal), transparent);
	animation: nrmFloat 2s ease-in-out infinite;
}


/* ══════════════════════════════════════════════════════
   2. IMPACT STATS
   ══════════════════════════════════════════════════════ */
.nrm-impact {
	background: var(--nrm-cream);
	padding: 24px 24px 48px;
	position: relative;
	overflow: hidden;
}

.nrm-impact::before {
	content: '';
	position: absolute;
	inset: 0;
	background: radial-gradient(ellipse at 50% 80%, rgba(61,170,189,.06) 0%, transparent 50%);
	pointer-events: none;
}

.nrm-impact-inner {
	max-width: 1140px;
	margin: 0 auto;
}

.nrm-stats-row {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 48px;
}

/* ── Main stat (total + in vigore) ── */
.nrm-stat-main {
	text-align: center;
}

.nrm-stat-main__value {
	font-family: 'DM Serif Display', serif;
	font-size: clamp(3rem, 6vw, 4.5rem);
	color: var(--nrm-teal);
	margin: 0;
	line-height: 1;
}

.nrm-stat-main__label {
	font-family: 'Karla', sans-serif;
	font-size: .82rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .12em;
	color: var(--nrm-text-secondary);
	margin: 4px 0 0;
}

.nrm-stat-main__sub {
	font-family: 'Karla', sans-serif;
	font-size: .82rem;
	font-weight: 600;
	color: var(--nrm-teal);
	margin: 8px 0 0;
	opacity: .8;
}

/* ── Scope breakdown cards ── */
.nrm-stat-cards {
	display: flex;
	gap: 12px;
}

.nrm-stat-card {
	background: #fff;
	border: 1px solid rgba(61,170,189,.12);
	border-radius: var(--nrm-radius-sm);
	padding: 16px 22px;
	text-align: center;
	min-width: 100px;
	transition: all .35s cubic-bezier(.22,1,.36,1);
}

.nrm-stat-card:hover {
	border-color: var(--nrm-teal);
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(61,170,189,.1);
}

.nrm-stat-card__value {
	font-family: 'DM Serif Display', serif;
	font-size: 1.6rem;
	color: var(--nrm-navy);
	margin: 0 0 2px;
	line-height: 1;
}

.nrm-stat-card__label {
	font-family: 'Karla', sans-serif;
	font-size: .68rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .08em;
	color: var(--nrm-text-secondary);
	margin: 0;
}


/* ══════════════════════════════════════════════════════
   3. CARD GRID
   ══════════════════════════════════════════════════════ */
.nrm-grid-section {
	background: var(--nrm-navy);
	padding: 90px 24px 100px;
	position: relative;
	overflow: hidden;
}

.nrm-grid-section::before {
	content: '';
	position: absolute;
	inset: 0;
	background:
		radial-gradient(ellipse at 20% 10%, rgba(61,170,189,.1) 0%, transparent 50%),
		radial-gradient(ellipse at 80% 90%, rgba(61,170,189,.06) 0%, transparent 40%);
	pointer-events: none;
}

.nrm-grid-inner {
	max-width: 1140px;
	margin: 0 auto;
}

.nrm-grid-header {
	text-align: center;
	margin-bottom: 52px;
}

.nrm-grid-header .nrm-label {
	justify-content: center;
	margin-bottom: 14px;
}

.nrm-grid-header h2 {
	font-size: clamp(1.8rem, 3.5vw, 2.6rem);
	color: #fff;
	margin: 0;
}

.nrm-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 36px;
}


/* ══════════════════════════════════════════════════════
   4. CARDS — icon-forward layout with materia accent
   ══════════════════════════════════════════════════════ */
.nrm-card {
	--materia-color: var(--nrm-teal);
	display: flex;
	flex-direction: column;
	background: #fff;
	border-radius: var(--nrm-radius);
	overflow: hidden;
	border: 1px solid rgba(26,35,50,.06);
	box-shadow: 0 2px 16px rgba(26,35,50,.05);
	text-decoration: none !important;
	color: var(--nrm-text) !important;
	position: relative;
	transition: all .45s cubic-bezier(.22,1,.36,1);
}

/* Left accent strip — materia-coloured */
.nrm-card::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	width: 4px;
	background: var(--materia-color);
	z-index: 1;
	border-radius: var(--nrm-radius) 0 0 var(--nrm-radius);
}

/* Decorative watermark icon */
.nrm-card::after {
	content: '';
	position: absolute;
	bottom: -12px;
	right: -12px;
	width: 100px;
	height: 100px;
	opacity: .035;
	pointer-events: none;
	transition: opacity .45s ease, transform .45s ease;
}

.nrm-card:hover {
	transform: translateY(-6px);
	box-shadow:
		0 20px 48px rgba(26,35,50,.1),
		0 0 0 1px color-mix(in srgb, var(--materia-color) 15%, transparent);
	color: var(--nrm-text) !important;
}

.nrm-card:hover::after {
	opacity: .06;
	transform: translate(-4px, -4px) scale(1.05);
}

/* ── Card header: icon + meta badges ── */
.nrm-card__header {
	display: flex;
	align-items: flex-start;
	gap: 14px;
	padding: 22px 24px 0;
}

.nrm-card__icon {
	flex-shrink: 0;
	width: 42px;
	height: 42px;
	border-radius: 11px;
	background: color-mix(in srgb, var(--materia-color) 10%, #fff);
	color: var(--materia-color);
	display: flex;
	align-items: center;
	justify-content: center;
	transition: transform .35s cubic-bezier(.22,1,.36,1), box-shadow .35s ease;
}

.nrm-card__icon svg {
	width: 20px;
	height: 20px;
}

.nrm-card:hover .nrm-card__icon {
	transform: scale(1.08);
	box-shadow: 0 4px 16px color-mix(in srgb, var(--materia-color) 20%, transparent);
}

.nrm-card__meta {
	display: flex;
	gap: 5px;
	flex-wrap: wrap;
	padding-top: 4px;
}

/* Body */
.nrm-card__body {
	padding: 14px 24px 0;
	flex: 1;
	display: flex;
	flex-direction: column;
}

/* Badges row (shared between header and timeline) */
.nrm-card__badges {
	display: flex;
	gap: 6px;
	flex-wrap: wrap;
	margin-bottom: 10px;
}

.nrm-card__badge {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	font-family: 'Karla', sans-serif;
	font-size: .62rem;
	font-weight: 700;
	letter-spacing: .05em;
	text-transform: uppercase;
	padding: 3px 10px;
	border-radius: 12px;
	background: rgba(26,35,50,.06);
	color: var(--nrm-text-secondary);
}

.nrm-card__badge--tipologia {
	background: rgba(61,170,189,.12);
	color: var(--nrm-teal-deep);
}

.nrm-card__badge--ambito {
	background: rgba(26,35,50,.08);
	color: var(--nrm-navy-light);
}

.nrm-card__badge--vigore {
	background: rgba(61,170,189,.12);
	color: var(--nrm-teal-deep);
}

.nrm-card__badge--abrogata {
	background: rgba(26,35,50,.06);
	color: var(--nrm-text-secondary);
}

.nrm-card__badge--proposta {
	background: rgba(139,92,246,.12);
	color: #6d28d9;
}

.nrm-card__badge--modificata {
	background: rgba(232,168,23,.12);
	color: #b8860b;
}

/* Badge status dot */
.nrm-card__badge-dot {
	width: 5px;
	height: 5px;
	border-radius: 50%;
	flex-shrink: 0;
}

.nrm-card__badge--vigore .nrm-card__badge-dot {
	background: var(--nrm-teal);
}

.nrm-card__badge--proposta .nrm-card__badge-dot {
	background: #8b5cf6;
}

.nrm-card__badge--abrogata .nrm-card__badge-dot {
	background: var(--nrm-text-secondary);
}

.nrm-card__badge--modificata .nrm-card__badge-dot {
	background: #E8A817;
}

/* Reference number */
.nrm-card__ref {
	font-family: 'SFMono-Regular', Consolas, 'Liberation Mono', Menlo, monospace;
	font-size: .72rem;
	color: var(--nrm-teal);
	margin: 0 0 8px;
	letter-spacing: .02em;
}

/* Card title */
.nrm-card__body h2 {
	font-size: clamp(1.05rem, 2vw, 1.25rem);
	color: var(--nrm-navy);
	margin: 0 0 8px;
	line-height: 1.3;
	transition: color .3s ease;
}

.nrm-card:hover .nrm-card__body h2 {
	color: var(--materia-color);
}

/* Summary text */
.nrm-card__summary {
	font-size: .88rem;
	color: var(--nrm-text-secondary);
	line-height: 1.65;
	margin: 0;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
	flex: 1;
}

/* ── Card footer ── */
.nrm-card__footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding: 14px 24px 18px;
	border-top: 1px solid rgba(26,35,50,.06);
	margin-top: auto;
}

.nrm-card__footer-left {
	display: flex;
	align-items: center;
	gap: 8px;
	flex-wrap: wrap;
	min-width: 0;
}

/* Materia pill in footer */
.nrm-card__materia {
	display: inline-block;
	font-family: 'Karla', sans-serif;
	font-size: .62rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .06em;
	color: var(--materia-color);
	background: color-mix(in srgb, var(--materia-color) 10%, #fff);
	padding: 3px 9px;
	border-radius: 20px;
	white-space: nowrap;
}

/* Date */
.nrm-card__date {
	font-family: 'Karla', sans-serif;
	font-size: .72rem;
	color: var(--nrm-text-secondary);
}

/* Arrow CTA */
.nrm-card__cta {
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	border-radius: 50%;
	background: color-mix(in srgb, var(--materia-color) 8%, #fff);
	color: var(--materia-color);
	font-size: 1rem;
	transition: all .35s cubic-bezier(.22,1,.36,1);
}

.nrm-card:hover .nrm-card__cta {
	background: var(--materia-color);
	color: #fff;
	transform: translateX(3px);
}

/* Landmark badge */
.nrm-card__badge--landmark {
	background: linear-gradient(135deg, #E8A817, #d4960f);
	color: #fff;
	font-weight: 800;
	letter-spacing: .08em;
	padding: 3px 12px;
	box-shadow: 0 2px 8px rgba(232,168,23,.25);
}

/* Landmark card */
.nrm-card--landmark {
	border: none;
	background:
		linear-gradient(160deg, #fffdf7 0%, #fef9ed 40%, #fdf3dc 100%);
	box-shadow:
		0 2px 16px rgba(232,168,23,.12),
		inset 0 0 0 1.5px rgba(232,168,23,.18);
}

.nrm-card--landmark::before {
	width: 5px;
	background: linear-gradient(180deg, #E8A817 0%, #c4880e 100%);
}

.nrm-card--landmark .nrm-card__icon {
	background: linear-gradient(135deg, #E8A817, #d4960f);
	color: #fff;
	box-shadow: 0 3px 12px rgba(232,168,23,.3);
}

.nrm-card--landmark .nrm-card__footer {
	border-top-color: rgba(232,168,23,.12);
}

.nrm-card--landmark .nrm-card__cta {
	background: rgba(232,168,23,.12);
	color: #b8860b;
}

.nrm-card--landmark:hover {
	transform: translateY(-8px);
	box-shadow:
		0 24px 56px rgba(232,168,23,.18),
		0 8px 24px rgba(232,168,23,.1),
		inset 0 0 0 1.5px rgba(232,168,23,.25);
}

.nrm-card--landmark:hover .nrm-card__icon {
	transform: scale(1.1);
	box-shadow: 0 6px 20px rgba(232,168,23,.4);
}

.nrm-card--landmark:hover .nrm-card__cta {
	background: #E8A817;
	color: #fff;
}

/* Hidden by filter */
.nrm-card--hidden {
	display: none !important;
}

/* Paginated: hide cards beyond limit */
.nrm-card--paged {
	display: none !important;
}


/* ══════════════════════════════════════════════════════
   5. FILTERS
   ══════════════════════════════════════════════════════ */
.nrm-filters {
	display: flex;
	gap: 16px;
	flex-wrap: wrap;
	margin-bottom: 32px;
}

.nrm-filter {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.nrm-filter label {
	font-family: 'Karla', sans-serif;
	font-size: .68rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .1em;
	color: rgba(255,255,255,.5);
}

.nrm-filter select {
	font-family: 'Karla', sans-serif;
	font-size: .85rem;
	padding: 8px 32px 8px 14px;
	border: 1px solid rgba(255,255,255,.12);
	border-radius: 8px;
	background: var(--nrm-navy-light);
	color: rgba(255,255,255,.8);
	cursor: pointer;
	appearance: none;
	-webkit-appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='rgba(255,255,255,0.5)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 10px center;
	transition: border-color .25s ease;
}

.nrm-filter select:focus,
.nrm-filter input:focus {
	outline: none;
	border-color: var(--nrm-teal);
}


/* Landmark checkbox filter */
.nrm-checkbox {
	display: flex;
	align-items: center;
	gap: 8px;
	font-family: 'Karla', sans-serif;
	font-size: .82rem;
	font-weight: 600;
	color: rgba(255,255,255,.6);
	cursor: pointer;
	padding: 8px 14px;
	border: 1px solid rgba(255,255,255,.12);
	border-radius: 8px;
	background: var(--nrm-navy-light);
	transition: border-color .25s ease, color .25s ease;
	white-space: nowrap;
}

.nrm-checkbox:hover {
	border-color: var(--nrm-teal);
	color: var(--nrm-teal);
}

.nrm-checkbox input[type="checkbox"] {
	accent-color: #E8A817;
	width: 16px;
	height: 16px;
	cursor: pointer;
}

.nrm-checkbox input[type="checkbox"]:checked + span {
	color: #b8860b;
}

/* Filter toggle (mobile only) */
.nrm-filters-toggle {
	display: none;
	align-items: center;
	gap: 8px;
	font-family: 'Karla', sans-serif;
	font-size: .82rem;
	font-weight: 600;
	color: rgba(255,255,255,.6);
	background: var(--nrm-navy-light);
	border: 1px solid rgba(255,255,255,.12);
	border-radius: 8px;
	padding: 9px 18px;
	cursor: pointer;
	margin-bottom: 16px;
	transition: border-color .25s ease, color .25s ease;
}
.nrm-filters-toggle:hover,
.nrm-filters-toggle[aria-expanded="true"] {
	border-color: var(--nrm-teal);
	color: var(--nrm-teal);
}
.nrm-filters-toggle svg { flex-shrink: 0; }


/* ══════════════════════════════════════════════════════
   5b. TOOLBAR (view toggle + search)
   ══════════════════════════════════════════════════════ */
.nrm-toolbar {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 20px;
}

.nrm-toolbar__search {
	flex: 1;
	max-width: 300px;
	position: relative;
}

.nrm-toolbar__search-icon {
	position: absolute;
	left: 12px;
	top: 50%;
	transform: translateY(-50%);
	color: rgba(255,255,255,.4);
	pointer-events: none;
}

.nrm-toolbar__search input[type="search"] {
	font-family: 'Karla', sans-serif;
	font-size: .85rem;
	padding: 8px 14px 8px 36px;
	border: 1px solid rgba(255,255,255,.12);
	border-radius: 8px;
	background: var(--nrm-navy-light);
	color: rgba(255,255,255,.8);
	transition: border-color .25s ease;
	width: 100%;
	box-sizing: border-box;
}

.nrm-toolbar__search input[type="search"]:focus {
	outline: none;
	border-color: var(--nrm-teal);
}

.nrm-toolbar__search input[type="search"]::-webkit-search-cancel-button { cursor: pointer; }

.nrm-view-toggle {
	display: flex;
	gap: 4px;
	background: rgba(255,255,255,.06);
	border-radius: 10px;
	padding: 4px;
	width: fit-content;
	flex-shrink: 0;
}

.nrm-view-btn {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-family: 'Karla', sans-serif;
	font-size: .78rem;
	font-weight: 600;
	color: rgba(255,255,255,.5);
	background: transparent;
	border: none;
	border-radius: 8px;
	padding: 8px 16px;
	cursor: pointer;
	transition: all .25s ease;
}

.nrm-view-btn:hover {
	color: var(--nrm-teal);
}

.nrm-view-btn--active {
	background: rgba(255,255,255,.1);
	color: var(--nrm-teal);
	box-shadow: 0 2px 8px rgba(0,0,0,.15);
}

.nrm-view-btn svg {
	flex-shrink: 0;
}


/* ══════════════════════════════════════════════════════
   5c. UPDATED INDICATOR
   ══════════════════════════════════════════════════════ */
.nrm-card__updated {
	font-family: 'Karla', sans-serif;
	font-size: .62rem;
	font-weight: 600;
	color: #b8860b;
	background: rgba(232,168,23,.1);
	padding: 2px 8px;
	border-radius: 10px;
	letter-spacing: .02em;
	white-space: nowrap;
}


/* ══════════════════════════════════════════════════════
   5d. TIMELINE VIEW
   ══════════════════════════════════════════════════════ */
.nrm-timeline {
	position: relative;
	padding-left: 40px;
	max-width: 800px;
	margin: 0 auto;
}

/* Vertical line */
.nrm-timeline::before {
	content: '';
	position: absolute;
	left: 12px;
	top: 0;
	bottom: 0;
	width: 2px;
	background: linear-gradient(to bottom, var(--nrm-teal), rgba(61,170,189,.15));
	border-radius: 1px;
}

/* Year header */
.nrm-tl-year {
	position: relative;
	margin: 36px 0 20px 0;
	padding-left: 0;
}

.nrm-tl-year span {
	display: inline-block;
	font-family: 'DM Serif Display', serif;
	font-size: 1.5rem;
	color: #fff;
	background: var(--nrm-teal);
	padding: 4px 18px;
	border-radius: 20px;
	position: relative;
	z-index: 1;
}

/* Timeline item */
.nrm-tl-item {
	display: flex;
	gap: 16px;
	align-items: flex-start;
	position: relative;
	padding: 16px 20px;
	margin-bottom: 12px;
	background: #fff;
	border-radius: var(--nrm-radius-sm);
	border: 1px solid rgba(26,35,50,.06);
	text-decoration: none !important;
	color: var(--nrm-text) !important;
	transition: all .3s cubic-bezier(.22,1,.36,1);
}

.nrm-tl-item:hover {
	box-shadow: 0 8px 24px rgba(26,35,50,.08);
	border-color: rgba(61,170,189,.2);
}

.nrm-tl-item:hover .nrm-tl-content {
	transform: translateX(6px);
}

/* Dot on timeline */
.nrm-tl-dot {
	position: absolute;
	left: -34px;
	top: 22px;
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background: var(--nrm-teal);
	border: 2px solid var(--nrm-cream);
	flex-shrink: 0;
	z-index: 1;
}

.nrm-tl-dot--proposta {
	background: #8b5cf6;
}

.nrm-tl-dot--abrogata {
	background: #999;
}

.nrm-tl-dot--modificata {
	background: #E8A817;
}

.nrm-tl-content {
	flex: 1;
	min-width: 0;
	transition: transform .3s cubic-bezier(.22,1,.36,1);
}

.nrm-tl-date {
	font-family: 'Karla', sans-serif;
	font-size: .72rem;
	font-weight: 600;
	color: var(--nrm-text-secondary);
	text-transform: uppercase;
	letter-spacing: .06em;
}

.nrm-tl-content h3 {
	font-size: 1.05rem;
	color: var(--nrm-navy);
	margin: 4px 0 6px;
	line-height: 1.3;
}

.nrm-tl-ref {
	font-family: 'SFMono-Regular', Consolas, 'Liberation Mono', Menlo, monospace;
	font-size: .72rem;
	color: var(--nrm-teal);
	display: block;
	margin-bottom: 8px;
}

.nrm-tl-badges {
	display: flex;
	gap: 6px;
	flex-wrap: wrap;
}


/* ── Landmark badge ── */
.nrm-tl-landmark-badge {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	font-family: 'Karla', sans-serif;
	font-size: .62rem;
	font-weight: 800;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: #fff;
	background: linear-gradient(135deg, #E8A817, #d4960f);
	padding: 3px 12px;
	border-radius: 12px;
	margin-bottom: 4px;
	box-shadow: 0 2px 8px rgba(232,168,23,.25);
}

.nrm-tl-landmark-badge::before {
	content: '\2605';
	font-size: .7rem;
}

/* Landmark timeline item */
.nrm-tl-item--landmark {
	border: none;
	background: linear-gradient(160deg, #fffdf7 0%, #fef9ed 40%, #fdf3dc 100%);
	box-shadow:
		0 2px 12px rgba(232,168,23,.1),
		inset 0 0 0 1.5px rgba(232,168,23,.18);
}

.nrm-tl-item--landmark:hover {
	box-shadow:
		0 8px 28px rgba(232,168,23,.16),
		inset 0 0 0 1.5px rgba(232,168,23,.25);
}

.nrm-tl-item--landmark .nrm-tl-content h3 {
	font-size: 1.15rem;
}

/* Landmark dot — parent-child selector avoids !important */
.nrm-tl-item--landmark .nrm-tl-dot {
	background: #E8A817;
	width: 14px;
	height: 14px;
	left: -36px;
	top: 20px;
	box-shadow: 0 0 0 3px rgba(232,168,23,.2);
}

/* ── Timeline materia icon ── */
.nrm-tl-icon {
	flex-shrink: 0;
	width: 30px;
	height: 30px;
	border-radius: 8px;
	background: color-mix(in srgb, var(--materia-color, var(--nrm-teal)) 10%, #fff);
	color: var(--materia-color, var(--nrm-teal));
	display: flex;
	align-items: center;
	justify-content: center;
}

.nrm-tl-icon svg {
	width: 16px;
	height: 16px;
}


/* ══════════════════════════════════════════════════════
   6. GRID ACTIONS
   ══════════════════════════════════════════════════════ */
.nrm-grid-actions {
	display: flex;
	justify-content: center;
	gap: 16px;
	margin-top: 40px;
	flex-wrap: wrap;
}

.nrm-grid-empty {
	grid-column: 1 / -1;
	text-align: center;
	padding: 60px 20px;
	color: var(--nrm-text-secondary);
	font-size: .95rem;
}


/* ══════════════════════════════════════════════════════
   7. CTA
   ══════════════════════════════════════════════════════ */
.nrm-cta {
	background: var(--nrm-cream);
	padding: 90px 24px 100px;
	position: relative;
	overflow: hidden;
}

.nrm-cta::before {
	content: '';
	position: absolute;
	top: -120px;
	left: -80px;
	width: 400px;
	height: 400px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(61,170,189,.06) 0%, transparent 70%);
	pointer-events: none;
}

.nrm-cta::after {
	content: '';
	position: absolute;
	bottom: -100px;
	right: -60px;
	width: 300px;
	height: 300px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(61,170,189,.04) 0%, transparent 70%);
	pointer-events: none;
}

.nrm-cta-inner {
	max-width: 700px;
	margin: 0 auto;
	text-align: center;
	position: relative;
	z-index: 1;
}

.nrm-cta .nrm-label {
	justify-content: center;
	margin-bottom: 16px;
}

.nrm-cta h2 {
	font-size: clamp(1.6rem, 3vw, 2.2rem);
	color: var(--nrm-navy);
	margin: 0 0 16px;
}

.nrm-cta-text {
	font-size: .95rem;
	color: var(--nrm-text-secondary);
	margin: 0 0 32px;
	line-height: 1.7;
}


/* ── Cross-link to ALI full database ──────────────── */
.nrm-crosslink {
	background: #fff;
	padding: 64px 24px;
}
.nrm-crosslink-inner {
	max-width: 1000px;
	margin: 0 auto;
	display: flex;
	align-items: center;
	gap: 28px;
	background: var(--nrm-cream);
	border: 1px solid rgba(0,0,0,.06);
	border-left: 4px solid var(--nrm-teal);
	border-radius: var(--nrm-radius);
	padding: 32px 36px;
}
.nrm-crosslink-icon {
	flex-shrink: 0;
	width: 56px;
	height: 56px;
	display: grid;
	place-items: center;
	border-radius: 14px;
	background: var(--nrm-teal-glow);
	color: var(--nrm-teal);
}
.nrm-crosslink-icon svg { width: 28px; height: 28px; }
.nrm-crosslink-body { flex: 1 1 auto; min-width: 0; }
.nrm-crosslink-body .nrm-label { margin-bottom: 10px; }
.nrm-crosslink-body h2 {
	font-size: clamp(1.3rem, 2.2vw, 1.6rem);
	color: var(--nrm-navy);
	margin: 0 0 8px;
}
.nrm-crosslink-body p {
	font-size: .92rem;
	color: var(--nrm-text-secondary);
	line-height: 1.65;
	margin: 0;
}
.nrm-crosslink .nrm-btn { flex-shrink: 0; }

@media (max-width: 760px) {
	.nrm-crosslink { padding: 44px 20px; }
	.nrm-crosslink-inner {
		flex-direction: column;
		align-items: flex-start;
		gap: 18px;
		padding: 26px 24px;
	}
}

/* ══════════════════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════════════════ */
@media (max-width: 900px) {
	.nrm-hero {
		padding: 90px 24px 36px;
	}
	.nrm-hero::after { width: 300px; height: 300px; }
	.nrm-hero-scroll { display: none; }
	.nrm-impact { padding: 32px 20px; }
	.nrm-stats-row { flex-direction: column; gap: 24px; }
	.nrm-stat-cards { gap: 10px; }
	.nrm-stat-card { padding: 12px 16px; min-width: 0; flex: 1; }
	.nrm-grid-section,
	.nrm-cta { padding: 60px 20px 70px; }
	.nrm-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 24px;
	}
	.nrm-filters-toggle { display: inline-flex; }
	.nrm-filters {
		display: none;
		flex-direction: column;
		gap: 12px;
	}
	.nrm-filters.nrm-filters--open { display: flex; }
	.nrm-toolbar__search { max-width: none; }
}

@media (max-width: 520px) {
	.nrm-hero {
		min-height: auto;
		padding: 80px 20px 32px;
	}
	.nrm-hero h1 { font-size: clamp(2rem, 8vw, 3rem); }
	.nrm-grid {
		grid-template-columns: 1fr;
		gap: 20px;
	}
	.nrm-card__header { padding: 18px 18px 0; gap: 10px; }
	.nrm-card__icon { width: 36px; height: 36px; border-radius: 9px; }
	.nrm-card__icon svg { width: 17px; height: 17px; }
	.nrm-card__body { padding: 10px 18px 0; }
	.nrm-card__footer { padding: 12px 18px 14px; }
	.nrm-stat-card__value { font-size: 1.3rem; }
	.nrm-stat-card__label { font-size: .62rem; }
	.nrm-timeline { padding-left: 32px; }
	.nrm-tl-dot { left: -26px; }
	.nrm-tl-item--landmark .nrm-tl-dot { left: -28px; }
	.nrm-tl-item { padding: 14px 16px; }
}

/* Mobile reveal fix: prevent blank space below hero on first load */
@media (max-width: 900px) {
	.nrm-impact .reveal,
	.nrm-grid-section .reveal:first-child {
		opacity: 1;
		transform: none;
	}
}
