.abc-profile-public,
.abc-profile-edit {
	max-width: 1180px;
	margin: 0 auto;
	padding: 40px 24px;
	color: #0f172a;
}

.abc-profile-hero {
	display: grid;
	grid-template-columns: 120px 1fr;
	gap: 26px;
	align-items: center;
	margin-bottom: 24px;
	padding: 34px;
	background: linear-gradient(135deg, #0f172a 0%, #1f2937 100%);
	border-radius: 28px;
	color: #ffffff;
	box-shadow: 0 24px 70px rgba(15, 23, 42, 0.22);
}

.abc-profile-avatar,
.abc-profile-card__avatar {
	width: 104px;
	height: 104px;
	border-radius: 28px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #3a5f7d;
	color: #ffffff;
	font-size: 38px;
	font-weight: 900;
}

.abc-profile-hero h1 {
	margin: 8px 0 10px;
	color: #ffffff;
	font-size: 42px;
	line-height: 1.05;
	font-weight: 900;
}

.abc-profile-hero p {
	max-width: 760px;
	margin: 0;
	color: #cbd5e1;
	font-size: 17px;
	line-height: 1.6;
}

.abc-profile-role,
.abc-profile-card__role {
	display: inline-flex;
	width: fit-content;
	padding: 7px 12px;
	border-radius: 999px;
	background: rgba(242, 183, 5, 0.16);
	border: 1px solid rgba(242, 183, 5, 0.42);
	color: #fde68a;
	font-size: 12px;
	font-weight: 900;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.abc-profile-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 18px;
}

.abc-profile-meta span {
	padding: 8px 12px;
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.14);
	border-radius: 999px;
	color: #e5e7eb;
	font-size: 13px;
	font-weight: 700;
}

.abc-profile-section {
	margin-bottom: 20px;
	padding: 28px;
	background: #ffffff;
	border: 1px solid #e5e7eb;
	border-radius: 24px;
	box-shadow: 0 18px 50px rgba(15, 23, 42, 0.08);
}

.abc-profile-section h2 {
	margin: 0 0 18px;
	color: #0f172a;
	font-size: 28px;
	line-height: 1.15;
	font-weight: 900;
}

.abc-profile-section p,
.abc-profile-section li {
	color: #475569;
	font-size: 16px;
	line-height: 1.7;
}

.abc-profile-badges,
.abc-profile-card__badges,
.abc-profile-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}

.abc-profile-tags span,
.is-verified,
.is-pending {
	display: inline-flex;
	align-items: center;
	width: fit-content;
	padding: 8px 12px;
	border-radius: 999px;
	font-size: 13px;
	font-weight: 800;
}

.abc-profile-tags span {
	background: #f1f5f9;
	color: #334155;
}

.is-verified {
	background: rgba(35, 195, 120, 0.14);
	border: 1px solid rgba(35, 195, 120, 0.35);
	color: #047857;
}

.is-pending {
	background: rgba(242, 183, 5, 0.16);
	border: 1px solid rgba(242, 183, 5, 0.42);
	color: #92400e;
}

.abc-profile-portfolio {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 16px;
}

.abc-profile-portfolio__item {
	padding: 18px;
	background: #f8fafc;
	border: 1px solid #e2e8f0;
	border-radius: 18px;
}

.abc-profile-portfolio__item strong,
.abc-profile-portfolio__content h3 {
	display: block;
	margin-bottom: 8px;
	color: #0f172a;
	font-size: 18px;
	font-weight: 900;
}

.abc-profile-portfolio__item a,
.abc-profile-portfolio__content a {
	display: inline-flex;
	margin-top: 10px;
	color: #3a5f7d;
	font-weight: 900;
	text-decoration: none;
}

.abc-profile-role-details__grid,
.abc-profile-role-details {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 16px;
}

.abc-profile-role-details__item,
.abc-profile-role-block,
.abc-profile-contact__item {
	padding: 18px;
	background: #f8fafc;
	border: 1px solid #e2e8f0;
	border-radius: 18px;
}

.abc-profile-role-details__item strong,
.abc-profile-contact__item strong,
.abc-profile-role-block h3 {
	display: block;
	margin-bottom: 8px;
	color: #0f172a;
	font-size: 15px;
	font-weight: 900;
}

.abc-profile-contact__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 16px;
}

.abc-profile-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 22px;
}

.abc-profile-actions a,
.abc-profile-actions button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 44px;
	padding: 12px 18px;
	background: #3a5f7d;
	border: 0;
	border-radius: 14px;
	color: #ffffff;
	font-size: 14px;
	font-weight: 900;
	text-decoration: none;
	cursor: pointer;
}

.abc-profile-actions a:hover,
.abc-profile-actions button:hover {
	background: #284761;
	color: #ffffff;
}

.abc-profile-contact-note,
.abc-profiles-note {
	margin-top: 14px;
	color: #64748b;
	font-size: 14px;
}

.abc-profile-card {
	display: grid;
	grid-template-columns: 82px 1fr;
	gap: 18px;
	padding: 22px;
	background: #ffffff;
	border: 1px solid #e5e7eb;
	border-radius: 22px;
	box-shadow: 0 16px 40px rgba(15, 23, 42, 0.08);
}

.abc-profile-card__avatar {
	width: 82px;
	height: 82px;
	border-radius: 22px;
	font-size: 30px;
}

.abc-profile-card h3 {
	margin: 10px 0 8px;
	color: #0f172a;
	font-size: 22px;
	font-weight: 900;
}

.abc-profile-card p {
	margin: 0 0 8px;
	color: #475569;
}

.abc-profile-card small {
	color: #64748b;
	font-weight: 700;
}

.abc-profile-form {
	display: flex;
	flex-direction: column;
	gap: 20px;
}

.abc-profile-form label {
	display: flex;
	flex-direction: column;
	gap: 8px;
	color: #0f172a;
	font-weight: 800;
}

.abc-profile-form input,
.abc-profile-form textarea,
.abc-profile-form select {
	width: 100%;
	padding: 13px 14px;
	background: #ffffff;
	border: 1px solid #cbd5e1;
	border-radius: 14px;
	color: #0f172a;
	font-size: 15px;
}

.abc-profile-notice {
	margin-bottom: 20px;
	padding: 16px;
	border-radius: 16px;
	font-weight: 800;
}

.abc-profile-notice--success {
	background: #dcfce7;
	color: #166534;
}

.abc-profile-notice--error {
	background: #fee2e2;
	color: #991b1b;
}

@media (max-width: 768px) {
	.abc-profile-public,
	.abc-profile-edit {
		padding: 24px 16px;
	}

	.abc-profile-hero,
	.abc-profile-card {
		grid-template-columns: 1fr;
		text-align: center;
	}

	.abc-profile-avatar,
	.abc-profile-card__avatar {
		margin: 0 auto;
	}

	.abc-profile-hero h1 {
		font-size: 34px;
	}

	.abc-profile-meta,
	.abc-profile-badges,
	.abc-profile-tags,
	.abc-profile-actions {
		justify-content: center;
	}
}