/**
 * Nauru Judiciary CMS — unified frontend design system.
 */

:root {
	--nj-navy: var(--njcms-color-primary, #012169);
	--nj-navy-dark: var(--njcms-color-primary-dark, #00164a);
	--nj-gold: var(--njcms-color-gold, #c8a45d);
	--nj-text: var(--njcms-color-text, #1c2e4a);
	--nj-muted: var(--njcms-color-muted, #60708a);
	--nj-border: var(--njcms-color-border, #d8e1ef);
	--nj-bg: var(--njcms-color-surface-alt, #f4f7fc);
	--nj-card-bg: var(--njcms-color-surface, #fff);
	--nj-focus: #2563eb;
	--nj-radius: var(--njcms-radius-lg, 0.75rem);
	--nj-radius-sm: var(--njcms-radius-md, 0.5rem);
	--nj-shadow: 0 4px 14px rgba(1, 33, 105, 0.06);
	--nj-gap: clamp(1rem, 2vw, 1.5rem);
	--nj-prose-width: 42rem;
}

.njcms-page-chrome--intro {
	margin-top: clamp(1rem, 2.5vw, 1.75rem);
	margin-bottom: clamp(1rem, 2vw, 1.5rem);
	padding: clamp(1.15rem, 2.5vw, 1.75rem) clamp(1.1rem, 2.5vw, 1.5rem);
	background: var(--nj-card-bg);
	border: 1px solid var(--nj-border);
	border-top: 3px solid var(--nj-gold);
	border-radius: var(--nj-radius);
	box-shadow: var(--nj-shadow);
}

.njcms-page-chrome__title {
	font-size: clamp(1.65rem, 3vw, 2.25rem);
	line-height: 1.2;
}

.njcms-page-chrome__eyebrow {
	color: var(--nj-gold);
	font-size: 0.75rem;
	letter-spacing: 0.12em;
}

.njcms-page-chrome__description {
	color: var(--nj-muted);
	font-size: 1rem;
	line-height: 1.65;
	max-width: var(--nj-prose-width);
}

.nj-page,
.nj-directory-page,
.nj-people-page {
	max-width: min(1200px, 100%);
	margin-inline: auto;
	display: flex;
	flex-direction: column;
	gap: var(--nj-gap);
	color: var(--nj-text);
}

.nj-page-hero,
.nj-people-hero {
	margin-bottom: clamp(0.75rem, 2vw, 1.25rem);
	padding-bottom: 1.15rem;
	border-bottom: 1px solid var(--nj-border);
}

.nj-page-hero__eyebrow,
.nj-people-hero__eyebrow {
	margin: 0 0 0.35rem;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--nj-gold);
}

.nj-page-hero__title,
.nj-people-hero__title {
	margin: 0 0 0.65rem;
	font-family: var(--njcms-font-heading, "DM Sans", system-ui, sans-serif);
	font-size: clamp(1.65rem, 3vw, 2.15rem);
	font-weight: 700;
	line-height: 1.2;
	color: var(--nj-navy);
}

.nj-page-hero__intro,
.nj-people-hero__intro {
	max-width: var(--nj-prose-width);
	font-size: 1rem;
	line-height: 1.65;
	color: var(--nj-muted);
}

.nj-section + .nj-section,
.nj-people-section + .nj-people-section,
.nj-section-block + .nj-section-block {
	margin-top: clamp(1rem, 2vw, 1.5rem);
	padding-top: clamp(1rem, 2vw, 1.5rem);
	border-top: 1px solid var(--nj-border);
}

.nj-section__title,
.nj-people-section-header__title,
.nj-section-block__title {
	margin: 0 0 1rem;
	padding-bottom: 0.45rem;
	font-family: var(--njcms-font-heading, "DM Sans", system-ui, sans-serif);
	font-size: clamp(1.05rem, 1.8vw, 1.25rem);
	font-weight: 700;
	line-height: 1.35;
	color: var(--nj-navy);
	border-bottom: 1px solid var(--nj-border);
}

.nj-section__title::after,
.nj-people-section-header__title::after,
.nj-section-block__title::after {
	content: "";
	display: block;
	width: 2rem;
	height: 2px;
	margin-top: 0.4rem;
	background: var(--nj-gold);
	border-radius: 2px;
}

.nj-grid {
	display: grid;
	gap: var(--nj-gap);
}

@media (min-width: 640px) {
	.nj-grid--2 {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

.nj-card,
.nj-result-card {
	display: flex;
	flex-direction: column;
	gap: 0.65rem;
	padding: 1rem 1.1rem;
	border: 1px solid var(--nj-border);
	border-left: 3px solid var(--nj-gold);
	border-radius: var(--nj-radius);
	background: var(--nj-card-bg);
	box-shadow: var(--nj-shadow);
}

.nj-card__title,
.nj-result-card__title {
	margin: 0;
	font-size: 1.05rem;
	font-weight: 700;
	line-height: 1.35;
	color: var(--nj-navy);
}

.nj-card__title a,
.nj-result-card__title a {
	color: inherit;
	text-decoration: none;
}

.nj-card__title a:hover,
.nj-card__title a:focus-visible,
.nj-result-card__title a:hover,
.nj-result-card__title a:focus-visible {
	color: var(--nj-navy-dark);
	text-decoration: underline;
}

.nj-button,
.nj-action-buttons__btn {
	display: inline-flex;
	align-items: center;
	padding: 0.45rem 0.85rem;
	border: 1px solid var(--nj-border);
	border-radius: var(--nj-radius-sm);
	font-size: 0.8125rem;
	font-weight: 600;
	text-decoration: none;
	color: var(--nj-navy);
	background: var(--nj-card-bg);
}

.nj-button--primary,
.nj-action-buttons__btn--primary {
	background: var(--nj-navy);
	border-color: var(--nj-navy);
	color: #fff;
}

.nj-empty-state {
	margin: 1.5rem auto;
	padding: 1.25rem 1.15rem;
	max-width: 36rem;
	text-align: center;
	border: 1px dashed var(--nj-border);
	border-radius: var(--nj-radius);
	background: var(--nj-bg);
}

.nj-empty-state__title {
	margin: 0 0 0.35rem;
	font-size: 1rem;
	font-weight: 700;
	color: var(--nj-navy);
}

.nj-empty-state__text {
	margin: 0;
	font-size: 0.9375rem;
	line-height: 1.6;
	color: var(--nj-muted);
}

.nj-page a:focus-visible,
.nj-directory-page a:focus-visible,
.nj-filter-bar__input:focus-visible,
.nj-filter-bar__chip:focus-visible,
.nj-button:focus-visible {
	outline: 2px solid var(--nj-focus);
	outline-offset: 2px;
}

@media (prefers-reduced-motion: reduce) {
	.nj-button,
	.nj-action-buttons__btn {
		transition: none;
	}
}
