/**
 * Public styles for CongoHeritage Membership frontend authentication.
 */

.chm-public-wrap {
	box-sizing: border-box;
	max-width: 760px;
	margin: 32px auto;
}

.chm-public-wrap *,
.chm-public-wrap *::before,
.chm-public-wrap *::after {
	box-sizing: border-box;
}

.chm-auth-card,
.chm-public-notice,
.chm-notice {
	border-radius: 18px;
	box-shadow: 0 14px 36px rgba(15, 23, 42, 0.08);
}

.chm-auth-card {
	padding: 32px;
	border: 1px solid #e2e8f0;
	background: #ffffff;
}

.chm-auth-header {
	margin-bottom: 24px;
	padding-bottom: 20px;
	border-bottom: 1px solid #edf2f7;
}

.chm-auth-eyebrow {
	margin: 0 0 8px;
	color: #b3862c;
	font-size: 12px;
	font-weight: 800;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}

.chm-auth-header h2 {
	margin: 0 0 10px;
	color: #102a43;
	font-size: 30px;
	line-height: 1.15;
}

.chm-auth-header p {
	margin: 0;
	color: #52606d;
}

.chm-form-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 18px;
}

.chm-form-field {
	margin: 0 0 18px;
}

.chm-form-field label,
.chm-checkbox-field label {
	display: block;
	margin-bottom: 8px;
	color: #243b53;
	font-weight: 700;
}

.chm-form-field label span {
	color: #b42318;
}

.chm-form-field input,
.chm-form-field select {
	display: block;
	width: 100%;
	min-height: 46px;
	padding: 10px 13px;
	border: 1px solid #cbd5e1;
	border-radius: 12px;
	background: #ffffff;
	color: #102a43;
	font-size: 16px;
}

.chm-form-field input:focus,
.chm-form-field select:focus {
	outline: 2px solid rgba(179, 134, 44, 0.28);
	border-color: #b3862c;
}

.chm-help-text {
	display: block;
	margin-top: 7px;
	color: #6b7280;
	font-size: 13px;
	line-height: 1.45;
}

.chm-checkbox-field {
	margin: 0 0 20px;
}

.chm-checkbox-field label {
	display: flex;
	align-items: center;
	gap: 10px;
	font-weight: 600;
}

.chm-checkbox-field input {
	width: 18px;
	height: 18px;
}

.chm-button,
.chm-logout-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 46px;
	padding: 12px 22px;
	border-radius: 999px;
	font-weight: 800;
	line-height: 1.2;
	text-decoration: none;
	cursor: pointer;
}

.chm-button-primary {
	border: 1px solid #0b3d2f;
	background: #0b3d2f;
	color: #ffffff;
}

.chm-button-primary:hover,
.chm-button-primary:focus {
	background: #06281f;
	color: #ffffff;
}

.chm-logout-link {
	min-height: 36px;
	padding: 8px 15px;
	border: 1px solid #b3862c;
	background: #fff8e5;
	color: #102a43;
}

.chm-auth-footer {
	margin: 18px 0 0;
	color: #52606d;
}

.chm-auth-footer a {
	font-weight: 800;
}

.chm-public-notice,
.chm-notice {
	margin-bottom: 18px;
	padding: 16px 18px;
	border: 1px solid #d8b45d;
	background: #fff8e5;
	color: #243b53;
}

.chm-public-notice-success,
.chm-notice-success {
	border-color: #86c79a;
	background: #edf7ed;
	color: #0b6b45;
}

.chm-public-notice-error,
.chm-notice-error {
	border-color: #f2a6a6;
	background: #fff1f1;
	color: #8a1f1f;
}

.chm-public-notice-info,
.chm-notice-info {
	border-color: #b8ccf0;
	background: #f0f6ff;
	color: #1f3b69;
}

.chm-honeypot {
	position: absolute;
	left: -9999px;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

@media screen and (max-width: 680px) {
	.chm-public-wrap {
		margin: 20px auto;
	}

	.chm-auth-card {
		padding: 22px;
	}

	.chm-form-grid {
		grid-template-columns: 1fr;
		gap: 0;
	}

	.chm-auth-header h2 {
		font-size: 24px;
	}
}

/* v0.4 Member dashboard and profile */
.chm-dashboard-wrap,
.chm-profile-wrap {
	max-width: 1040px;
}

.chm-member-hero {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
	margin-bottom: 24px;
	padding: 34px;
	border-radius: 24px;
	background: linear-gradient(135deg, #063f32 0%, #102a43 100%);
	color: #ffffff;
	box-shadow: 0 18px 45px rgba(16, 42, 67, 0.18);
}

.chm-member-hero h2 {
	margin: 0 0 10px;
	color: #ffffff;
	font-size: 34px;
	line-height: 1.15;
}

.chm-member-hero p {
	max-width: 680px;
	margin: 0;
	color: rgba(255, 255, 255, 0.85);
}

.chm-dashboard-role-badge {
	min-width: 190px;
	padding: 18px 20px;
	border: 1px solid rgba(255, 255, 255, 0.22);
	border-radius: 18px;
	background: rgba(255, 255, 255, 0.11);
	text-align: center;
}

.chm-dashboard-role-badge span {
	display: block;
	margin-bottom: 6px;
	font-size: 12px;
	font-weight: 800;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.75);
}

.chm-dashboard-role-badge strong {
	display: block;
	color: #f5c542;
	font-size: 18px;
}

.chm-dashboard-grid {
	display: grid;
	grid-template-columns: minmax(0, 1.4fr) minmax(280px, 0.6fr);
	gap: 22px;
}

.chm-member-card {
	padding: 26px;
	border: 1px solid #e6ebf1;
	border-radius: 22px;
	background: #ffffff;
	box-shadow: 0 14px 34px rgba(16, 42, 67, 0.08);
}

.chm-member-card h3 {
	margin: 0 0 18px;
	color: #102a43;
	font-size: 21px;
}

.chm-definition-list {
	margin: 0;
}

.chm-definition-list div {
	display: grid;
	grid-template-columns: 170px minmax(0, 1fr);
	gap: 16px;
	padding: 13px 0;
	border-bottom: 1px solid #edf1f5;
}

.chm-definition-list div:last-child {
	border-bottom: 0;
}

.chm-definition-list dt {
	color: #52606d;
	font-weight: 800;
}

.chm-definition-list dd {
	margin: 0;
	color: #102a43;
}

.chm-pill {
	display: inline-flex;
	align-items: center;
	padding: 5px 10px;
	border-radius: 999px;
	background: #edf7ed;
	color: #0b6b45;
	font-size: 13px;
	font-weight: 800;
}

.chm-action-list {
	display: grid;
	gap: 12px;
}

.chm-action-link,
.chm-action-list .chm-logout-link {
	display: block;
	padding: 13px 15px;
	border: 1px solid #d8b45d;
	border-radius: 14px;
	background: #fffaf0;
	color: #102a43;
	font-weight: 800;
	text-decoration: none;
}

.chm-action-link:hover,
.chm-action-list .chm-logout-link:hover {
	background: #f5c542;
	color: #102a43;
}

.chm-action-link-muted {
	border-color: #d8dee6;
	background: #f7f9fb;
	color: #627386;
	font-weight: 700;
}

.chm-profile-form textarea {
	width: 100%;
	min-height: 120px;
	resize: vertical;
}

.chm-button-row {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	align-items: center;
	margin-top: 8px;
}

.chm-button-secondary {
	border-color: #d8dee6;
	background: #ffffff;
	color: #102a43;
}

.chm-button-secondary:hover,
.chm-button-secondary:focus {
	background: #f7f9fb;
	color: #102a43;
}

@media screen and (max-width: 782px) {
	.chm-member-hero,
	.chm-dashboard-grid {
		grid-template-columns: 1fr;
	}

	.chm-member-hero {
		align-items: flex-start;
		flex-direction: column;
		padding: 24px;
	}

	.chm-member-hero h2 {
		font-size: 26px;
	}

	.chm-dashboard-role-badge {
		width: 100%;
		text-align: left;
	}

	.chm-definition-list div {
		grid-template-columns: 1fr;
		gap: 5px;
	}
}

/* v0.5 Content restriction */
.chm-restricted-card {
	box-sizing: border-box;
	max-width: 820px;
	margin: 28px auto;
	padding: 30px;
	border: 1px solid #d8b45d;
	border-radius: 22px;
	background: linear-gradient(180deg, #fffaf0 0%, #ffffff 100%);
	box-shadow: 0 16px 42px rgba(15, 23, 42, 0.1);
}

.chm-restricted-card h2 {
	margin: 0 0 10px;
	color: #102a43;
	font-size: 28px;
	line-height: 1.2;
}

.chm-restricted-card p {
	color: #52606d;
	font-size: 16px;
	line-height: 1.6;
}

.chm-restricted-level {
	padding: 12px 14px;
	border-radius: 14px;
	background: #f8fafc;
}

.chm-restricted-note {
	display: inline-block;
	max-width: 640px;
	padding: 12px 14px;
	border-radius: 14px;
	background: #f0f6ff;
	color: #1f3b69;
	font-weight: 700;
}

.chm-restricted-excerpt {
	display: inline-block;
	padding: 10px 13px;
	border: 1px solid #d8b45d;
	border-radius: 999px;
	background: #fff8e5;
	color: #243b53;
	font-size: 14px;
	font-weight: 800;
}

/* v0.8 Member resource library */
.chm-resource-library {
	max-width: 1180px;
	margin: 0 auto;
}

.chm-resource-hero {
	margin-bottom: 24px;
	padding: 34px;
	border-radius: 24px;
	background: linear-gradient(135deg, #102a43 0%, #1b4332 100%);
	box-shadow: 0 18px 42px rgba(15, 23, 42, 0.18);
	color: #ffffff;
}

.chm-resource-hero h2 {
	margin: 0 0 10px;
	color: #ffffff;
	font-size: clamp(30px, 4vw, 46px);
	line-height: 1.08;
}

.chm-resource-hero p {
	max-width: 780px;
	margin: 0;
	color: rgba(255, 255, 255, 0.86);
	font-size: 17px;
	line-height: 1.7;
}

.chm-resource-hero .chm-auth-eyebrow {
	color: #f5c542;
}

.chm-resource-filters {
	display: grid;
	grid-template-columns: minmax(220px, 1fr) minmax(180px, 260px) minmax(180px, 260px) auto;
	gap: 14px;
	align-items: end;
	margin-bottom: 24px;
	padding: 18px;
	border: 1px solid #e5e7eb;
	border-radius: 18px;
	background: #ffffff;
	box-shadow: 0 10px 28px rgba(15, 23, 42, 0.06);
}

.chm-resource-filters .chm-form-field,
.chm-resource-filter-actions {
	margin: 0;
}

.chm-resource-filter-actions {
	display: flex;
	gap: 10px;
	align-items: center;
}

.chm-resource-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 22px;
}

.chm-resource-card {
	display: flex;
	flex-direction: column;
	overflow: hidden;
	min-height: 100%;
	border: 1px solid #e5e7eb;
	border-radius: 22px;
	background: #ffffff;
	box-shadow: 0 16px 36px rgba(15, 23, 42, 0.08);
}

.chm-resource-image {
	display: block;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background: #eef2f7;
}

.chm-resource-image img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.chm-resource-card-body {
	display: flex;
	flex: 1;
	flex-direction: column;
	gap: 12px;
	padding: 20px;
}

.chm-resource-badges,
.chm-resource-terms {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.chm-resource-badges span {
	display: inline-flex;
	align-items: center;
	padding: 6px 9px;
	border-radius: 999px;
	background: #f0f6ff;
	color: #1f3b69;
	font-size: 12px;
	font-weight: 800;
	line-height: 1;
}

.chm-resource-badges span:first-child {
	background: #fff4cc;
	color: #7a5300;
}

.chm-resource-card h3 {
	margin: 0;
	font-size: 21px;
	line-height: 1.25;
}

.chm-resource-card h3 a {
	color: #102a43;
	text-decoration: none;
}

.chm-resource-card h3 a:hover,
.chm-resource-card h3 a:focus {
	color: #0f5132;
	text-decoration: underline;
}

.chm-resource-card p {
	margin: 0;
	color: #52606d;
	font-size: 15px;
	line-height: 1.65;
}

.chm-resource-terms span {
	padding: 5px 8px;
	border: 1px solid #d8dee6;
	border-radius: 999px;
	background: #f8fafc;
	color: #52606d;
	font-size: 12px;
	font-weight: 700;
}

.chm-resource-card .chm-button {
	align-self: flex-start;
	margin-top: auto;
}

@media screen and (max-width: 980px) {
	.chm-resource-grid,
	.chm-resource-filters {
		grid-template-columns: 1fr;
	}

	.chm-resource-filter-actions {
		flex-wrap: wrap;
	}
}

/* v1.0 Premium public interface polish */
.chm-public-wrap {
	font-family: inherit;
}

.chm-auth-card,
.chm-member-card,
.chm-restricted-card,
.chm-resource-card,
.chm-resource-filters {
	transition: box-shadow 180ms ease, transform 180ms ease, border-color 180ms ease;
}

.chm-auth-card {
	position: relative;
	overflow: hidden;
	border-color: #dfe7ef;
	box-shadow: 0 20px 50px rgba(15, 23, 42, 0.10);
}

.chm-auth-card::before {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 5px;
	background: linear-gradient(90deg, #0b3d2f, #d8b45d, #102a43);
	content: "";
}

.chm-auth-header h2,
.chm-member-hero h2,
.chm-resource-hero h2,
.chm-restricted-card h2 {
	letter-spacing: -0.025em;
}

.chm-form-field input,
.chm-form-field select,
.chm-profile-form textarea {
	box-shadow: inset 0 1px 2px rgba(15, 23, 42, 0.035);
	transition: border-color 140ms ease, box-shadow 140ms ease, background-color 140ms ease;
}

.chm-form-field input:hover,
.chm-form-field select:hover,
.chm-profile-form textarea:hover {
	border-color: #94a3b8;
}

.chm-form-field input:focus,
.chm-form-field select:focus,
.chm-profile-form textarea:focus {
	background: #fffef9;
	box-shadow: 0 0 0 4px rgba(216, 180, 93, 0.18);
}

.chm-button,
.chm-action-link,
.chm-logout-link {
	transition: transform 150ms ease, box-shadow 150ms ease, background-color 150ms ease, border-color 150ms ease;
}

.chm-button:hover,
.chm-action-link:hover,
.chm-logout-link:hover {
	box-shadow: 0 10px 22px rgba(15, 23, 42, 0.10);
	transform: translateY(-1px);
}

.chm-member-hero,
.chm-resource-hero {
	position: relative;
	overflow: hidden;
	border: 1px solid rgba(255, 255, 255, 0.08);
}

.chm-member-hero::after,
.chm-resource-hero::after {
	position: absolute;
	right: -90px;
	bottom: -120px;
	width: 260px;
	height: 260px;
	border: 1px solid rgba(255, 255, 255, 0.16);
	border-radius: 999px;
	content: "";
}

.chm-dashboard-role-badge {
	position: relative;
	z-index: 1;
	backdrop-filter: blur(8px);
}

.chm-member-card:hover,
.chm-resource-card:hover {
	border-color: #d8b45d;
	box-shadow: 0 20px 46px rgba(15, 23, 42, 0.12);
	transform: translateY(-2px);
}

.chm-definition-list div {
	align-items: center;
}

.chm-pill {
	box-shadow: inset 0 0 0 1px rgba(11, 107, 69, 0.10);
}

.chm-restricted-card {
	position: relative;
	overflow: hidden;
}

.chm-restricted-card::before {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 5px;
	background: linear-gradient(90deg, #d8b45d, #0b3d2f);
	content: "";
}

.chm-resource-filters {
	position: sticky;
	top: 16px;
	z-index: 5;
}

.chm-resource-card h3 a {
	text-underline-offset: 3px;
}

.chm-resource-card .chm-button {
	width: auto;
}

.chm-resource-badges span,
.chm-resource-terms span {
	letter-spacing: 0.01em;
}

@media screen and (max-width: 782px) {
	.chm-resource-filters {
		position: static;
	}

	.chm-auth-card,
	.chm-member-card,
	.chm-restricted-card {
		border-radius: 18px;
	}

	.chm-button,
	.chm-resource-card .chm-button {
		width: 100%;
	}
}

/* v1.1 protected downloads */
.chm-protected-download-box {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 18px;
	margin: 28px 0;
	padding: 22px;
	border: 1px solid rgba(15, 23, 42, 0.12);
	border-radius: 18px;
	background: linear-gradient(135deg, #f8fafc 0%, #fff7ed 100%);
	box-shadow: 0 16px 36px rgba(15, 23, 42, 0.08);
}

.chm-protected-download-box h3 {
	margin: 4px 0 6px;
	font-size: 1.2rem;
}

.chm-protected-download-box p {
	margin: 0;
}

@media (max-width: 700px) {
	.chm-protected-download-box {
		align-items: flex-start;
		flex-direction: column;
	}
}

/* v1.2 auto-created page note */
.chm-auto-page-note {
	border: 1px solid rgba(12, 75, 58, 0.18);
	border-radius: 18px;
	padding: 22px;
	background: #f8faf9;
	font-weight: 600;
}

/* v1.3 Advanced member profiles */
.chm-member-hero-advanced {
	display: flex;
	align-items: center;
	gap: 22px;
}

.chm-profile-avatar-wrap {
	flex: 0 0 auto;
}

.chm-profile-avatar {
	width: 104px;
	height: 104px;
	border-radius: 999px;
	object-fit: cover;
	border: 4px solid rgba(255,255,255,.8);
	box-shadow: 0 16px 35px rgba(10, 35, 55, .18);
	background: #fff;
}

.chm-profile-avatar-edit {
	margin-bottom: 14px;
}

.chm-profile-completion-card,
.chm-download-preview-card {
	position: relative;
	overflow: hidden;
}

.chm-completion-ring {
	width: 96px;
	height: 96px;
	border-radius: 999px;
	display: grid;
	place-items: center;
	background: linear-gradient(135deg, rgba(22, 111, 74, .12), rgba(198, 148, 46, .18));
	border: 1px solid rgba(22, 111, 74, .18);
	margin: 12px 0;
}

.chm-completion-ring strong {
	font-size: 1.55rem;
	color: #12382b;
}

.chm-download-mini-list,
.chm-compact-list {
	margin: 12px 0 0;
	padding-left: 18px;
}

.chm-download-mini-list li {
	margin-bottom: 10px;
}

.chm-download-mini-list strong,
.chm-download-mini-list span {
	display: block;
}

.chm-download-mini-list span {
	font-size: .88rem;
	color: #667085;
	margin-top: 2px;
}

.chm-profile-wrap-advanced .chm-auth-card {
	max-width: 980px;
}

.chm-profile-form-header {
	display: flex;
	align-items: center;
	gap: 20px;
}

.chm-profile-section {
	border-top: 1px solid rgba(15, 23, 42, .08);
	padding-top: 22px;
	margin-top: 22px;
}

.chm-profile-section h3 {
	margin: 0 0 14px;
	font-size: 1.08rem;
	color: #12382b;
}

.chm-profile-progress {
	height: 12px;
	border-radius: 999px;
	background: #edf2f0;
	overflow: hidden;
	border: 1px solid rgba(22, 111, 74, .1);
}

.chm-profile-progress span {
	display: block;
	height: 100%;
	border-radius: inherit;
	background: linear-gradient(90deg, #166f4a, #c6942e);
}

.chm-privacy-note {
	display: block;
	margin-bottom: 14px;
}

.chm-privacy-select-label {
	display: block;
	font-size: .84rem;
	font-weight: 700;
	margin-top: 8px;
	color: #4b5563;
}

.chm-privacy-select {
	margin-top: 4px;
}

.chm-download-history-list {
	display: grid;
	gap: 12px;
}

.chm-download-history-item {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding: 16px;
	border: 1px solid rgba(15, 23, 42, .08);
	border-radius: 16px;
	background: #fff;
}

.chm-download-history-item strong,
.chm-download-history-item span {
	display: block;
}

.chm-download-history-item span {
	margin-top: 4px;
	color: #667085;
	font-size: .9rem;
}

@media (max-width: 720px) {
	.chm-member-hero-advanced,
	.chm-profile-form-header,
	.chm-download-history-item {
		align-items: flex-start;
		flex-direction: column;
	}

	.chm-profile-avatar {
		width: 86px;
		height: 86px;
	}
}

/* v1.4 Public member directory and profiles */
.chm-directory-wrap,
.chm-public-profile-wrap {
	max-width: 1180px;
	margin: 0 auto;
}

.chm-directory-hero,
.chm-public-profile-hero {
	background: linear-gradient(135deg, #062b26, #0e4b3f);
	color: #fff;
	border-radius: 28px;
	padding: clamp(28px, 5vw, 54px);
	margin-bottom: 28px;
	box-shadow: 0 24px 70px rgba(6, 43, 38, 0.22);
}

.chm-directory-hero h2,
.chm-public-profile-hero h2 {
	color: #fff;
	font-size: clamp(2rem, 4vw, 3.5rem);
	line-height: 1.02;
	margin: 0 0 12px;
}

.chm-directory-hero p,
.chm-public-profile-hero p {
	max-width: 780px;
	font-size: 1.05rem;
}

.chm-directory-filters {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr)) auto auto;
	gap: 14px;
	align-items: end;
	background: #fff;
	border: 1px solid rgba(6, 43, 38, 0.12);
	border-radius: 22px;
	padding: 18px;
	margin-bottom: 18px;
	box-shadow: 0 16px 45px rgba(12, 35, 31, 0.08);
}

.chm-directory-filters .chm-form-field { margin: 0; }
.chm-directory-filters .chm-button { white-space: nowrap; }

.chm-directory-summary {
	display: flex;
	align-items: baseline;
	gap: 8px;
	margin: 18px 0;
	color: #21443d;
}

.chm-directory-summary strong {
	font-size: 1.7rem;
	color: #0b3b33;
}

.chm-directory-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 22px;
}

.chm-directory-card {
	background: #fff;
	border: 1px solid rgba(6, 43, 38, 0.12);
	border-radius: 24px;
	padding: 22px;
	box-shadow: 0 18px 55px rgba(12, 35, 31, 0.08);
	display: flex;
	gap: 16px;
	align-items: flex-start;
}

.chm-directory-avatar,
.chm-public-profile-avatar {
	width: 88px;
	height: 88px;
	object-fit: cover;
	border-radius: 999px;
	border: 4px solid rgba(194, 150, 62, 0.35);
	background: #f8f4e9;
	flex: 0 0 auto;
}

.chm-directory-card h3 {
	margin: 0 0 4px;
	font-size: 1.2rem;
	color: #082f2a;
}

.chm-directory-role {
	margin: 0 0 8px;
	font-weight: 700;
	color: #a57418;
}

.chm-directory-meta,
.chm-directory-excerpt,
.chm-muted-text {
	color: #52635f;
}

.chm-directory-pagination {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	justify-content: center;
	margin-top: 30px;
}

.chm-directory-pagination a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 38px;
	height: 38px;
	border-radius: 999px;
	border: 1px solid rgba(6, 43, 38, 0.18);
	background: #fff;
	text-decoration: none;
	font-weight: 700;
	color: #0b3b33;
}

.chm-directory-pagination a.is-active {
	background: #0b3b33;
	color: #fff;
}

.chm-public-profile-hero {
	display: flex;
	align-items: center;
	gap: 28px;
}

.chm-public-profile-avatar {
	width: 138px;
	height: 138px;
	border-width: 5px;
}

.chm-public-profile-subtitle {
	font-size: 1.12rem;
	opacity: 0.92;
}

.chm-public-profile-grid {
	display: grid;
	grid-template-columns: minmax(0, 1.35fr) minmax(280px, 0.65fr);
	gap: 22px;
}

.chm-public-profile-main {
	grid-row: span 2;
}

.chm-public-links {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 12px;
}

.chm-public-links a,
.chm-directory-back a {
	display: inline-flex;
	align-items: center;
	border-radius: 999px;
	padding: 8px 13px;
	background: rgba(194, 150, 62, 0.12);
	color: #6d4a0d;
	font-weight: 700;
	text-decoration: none;
}

.chm-directory-back { margin-bottom: 16px; }

.chm-public-profile-consent {
	border: 1px solid rgba(194, 150, 62, 0.25);
	background: linear-gradient(180deg, rgba(194, 150, 62, 0.08), rgba(255,255,255,0.95));
}

@media (max-width: 960px) {
	.chm-directory-filters,
	.chm-directory-grid,
	.chm-public-profile-grid {
		grid-template-columns: 1fr;
	}
	.chm-directory-card,
	.chm-public-profile-hero {
		flex-direction: column;
	}
}

/* v1.5 Contributor workspace */
.chm-contributor-wrap .chm-contributor-hero,
.chm-submission-form-wrap .chm-auth-card {
	border-top: 5px solid #b88928;
}

.chm-submission-stats-grid {
	grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
}

.chm-stat-card-mini span {
	display: block;
	font-size: 0.85rem;
	color: #5b6472;
	margin-bottom: 0.35rem;
}

.chm-stat-card-mini strong {
	display: block;
	font-size: 2rem;
	line-height: 1;
	color: #10261f;
}

.chm-submission-list {
	display: grid;
	gap: 0.85rem;
}

.chm-submission-item {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	padding: 1rem;
	border: 1px solid rgba(16, 38, 31, 0.12);
	border-radius: 16px;
	background: #fff;
}

.chm-submission-item strong {
	display: block;
	font-size: 1rem;
	color: #10261f;
}

.chm-submission-item span {
	display: block;
	font-size: 0.88rem;
	color: #667085;
	margin-top: 0.2rem;
}

.chm-submission-form textarea {
	width: 100%;
	min-height: 120px;
}

.chm-submission-form #chm_submission_content {
	min-height: 340px;
	font-family: inherit;
	line-height: 1.65;
}

.chm-upload-box {
	padding: 1rem;
	border: 1px dashed rgba(184, 137, 40, 0.55);
	border-radius: 16px;
	background: rgba(184, 137, 40, 0.06);
	margin: 1rem 0;
}

.chm-upload-box label {
	display: block;
	font-weight: 700;
	margin-bottom: 0.45rem;
}

.chm-file-list {
	margin-top: 0.75rem;
}

@media (max-width: 700px) {
	.chm-submission-item {
		align-items: flex-start;
		flex-direction: column;
	}
}

/* v1.6 Editorial Workflow Pro */
.chm-editorial-checklist,
.chm-submission-timeline-box {
	margin: 1rem 0;
	padding: 1rem;
	border: 1px solid rgba(22, 111, 74, 0.18);
	border-radius: 16px;
	background: rgba(22, 111, 74, 0.045);
}

.chm-editorial-checklist h3,
.chm-submission-timeline-box h3 {
	margin-top: 0;
	color: #10261f;
}

.chm-checkbox-line {
	display: flex;
	gap: 0.7rem;
	align-items: flex-start;
	margin: 0.75rem 0;
	font-weight: 600;
}

.chm-checkbox-line input {
	margin-top: 0.25rem;
}

.chm-editorial-timeline {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 0.7rem;
}

.chm-editorial-timeline li {
	padding: 0.85rem;
	border-radius: 12px;
	background: #fff;
	border: 1px solid rgba(16, 38, 31, 0.1);
}

.chm-editorial-timeline strong,
.chm-editorial-timeline span,
.chm-editorial-timeline em {
	display: block;
}

.chm-editorial-timeline strong {
	font-size: 0.83rem;
	color: #166f4a;
}

.chm-editorial-timeline em {
	margin-top: 0.25rem;
	color: #667085;
	font-size: 0.82rem;
}

/* v1.7 CAPTCHA / anti-spam */
.chm-captcha-box {
	margin: 1.25rem 0;
	padding: 1rem;
	border: 1px solid rgba(15, 23, 42, 0.12);
	border-radius: 14px;
	background: rgba(248, 250, 252, 0.85);
	display: flex;
	justify-content: center;
}
.chm-captcha-box .cf-turnstile {
	max-width: 100%;
}
