/* =========================================================
   Agency card
   ========================================================= */

.tra-agency-card {
	margin: 0 0 var(--tr-space-5);
	padding: var(--tr-space-4);
	display: flex;
	gap: 1.25rem;
	align-items: flex-start;
	border: 1px solid var(--tr-border);
	box-shadow: var(--tr-shadow-sm);
}

.tra-agency-card__image {
	display: flex;
	align-items: center;
	justify-content: center;
	flex: 0 0 120px;
	width: 120px;
	height: 120px;
	box-sizing: border-box;
	overflow: hidden;
	padding: 0.75rem;
	border: 1px solid var(--tr-border);
	border-radius: 12px;
	background: #FFFFFF;
}

.tra-agency-card__image:empty {
	display: none;
}

.tra-agency-card__logo {
	display: block;
	width: 100% !important;
	max-width: 100% !important;
	height: 100% !important;
	max-height: 100% !important;
	object-fit: contain;
	border: 0;
	border-radius: 0;
	background: transparent;
}

.tra-agency-card__content {
	flex: 1 1 auto;
	min-width: 0;
}

.tra-agency-card__name {
	margin: 0 0 var(--tr-space-1);
	font-size: 1.125rem;
	line-height: 1.4;
}

.tra-agency-card__website {
	display: inline-block;
	margin-right: var(--tr-space-1);
	font-size: 0.95rem;
	text-decoration: none;
}

.tra-agency-card__locations,
.tra-agency-card__specialisms,
.tra-agency-card__summary,
.tra-agency-card__contact,
.tra-agency-card__actions {
	margin: var(--tr-space-1) 0 0;
}

.tra-agency-card__summary {
	color: var(--tr-muted);
}

.tra-agency-card__button {
	display: inline-block;
	margin-top: 0.25rem;
}

/* =========================================================
   Agency profile page
   ========================================================= */

/* Featured image is a logo, not a hero banner.
   The figure keeps its full content-width so is-layout-constrained aligns it
   with the H1. The img inside is sized as a logo tile.
   aspect-ratio, object-fit and height are inline on the block so !important is required. */
body.single-agency_profile .wp-block-post-featured-image {
	aspect-ratio: auto !important;
	margin-bottom: 1.5rem;
	padding: 0;
	border: 0;
	border-radius: 0;
	background: transparent;
	box-shadow: none;
	overflow: visible;
}

body.single-agency_profile .wp-block-post-featured-image img {
	display: block;
	width: 140px !important;
	height: auto !important;
	max-width: 140px;
	object-fit: contain !important;
	padding: 0.75rem;
	border: 1px solid var(--tr-border);
	border-radius: 12px;
	background: #FFFFFF;
	box-shadow: 0 1px 3px rgba(0, 43, 48, 0.06);
	box-sizing: border-box;
}

.tra-agency-profile-page {
	max-width: var(--tr-max-content);
	margin: 0 auto;
	padding: var(--tr-space-5) var(--tr-space-3);
}

.tra-agency-profile {
	background: transparent;
}

.tra-agency-profile__header {
	display: flex;
	flex-wrap: wrap;
	gap: var(--tr-space-5);
	margin-bottom: var(--tr-space-5);
	padding-bottom: var(--tr-space-4);
	border-bottom: 1px solid var(--tr-border);
}

.tra-agency-profile__logo img {
	display: block;
	max-width: 180px;
	height: auto;
	border-radius: 12px;
	border: 1px solid var(--tr-border);
	background: #FFFFFF;
}

.tra-agency-profile__intro {
	flex: 1 1 320px;
	min-width: 0;
}

.tra-agency-profile__intro h1 {
	margin: 0 0 var(--tr-space-3);
}

.tra-agency-profile__locations,
.tra-agency-profile__specialisms,
.tra-agency-profile__contact p {
	margin: 0 0 var(--tr-space-2);
}

.tra-agency-profile__content {
	margin-bottom: var(--tr-space-5);
}

.tra-agency-profile__jobs {
	margin-top: var(--tr-space-5);
	padding-top: var(--tr-space-4);
	border-top: 1px solid var(--tr-border);
}

.tra-agency-profile__job-list {
	margin: var(--tr-space-3) 0 0;
	padding-left: 1.25rem;
}

.tra-agency-profile__job-item {
	margin-bottom: var(--tr-space-1);
}

/* Agency Profile Shortcode Output */
.tra-agency-profile-details {
	display: grid;
	grid-template-columns: max-content 1fr;
	row-gap: 0.55rem;
	column-gap: 1.25rem;
	margin: 1rem 0 1.5rem;
	align-items: baseline;
	font-family: var(--tr-font-sans) !important;
}

/* Let <p> children flow directly into the parent grid */
.tra-agency-profile-details p {
	display: contents;
}

/* Defensive: hide any <br> wpautop may inject between label and value */
.tra-agency-profile-details br {
	display: none;
}

.tra-agency-profile-details strong {
	font-size: var(--tr-text-xs);
	font-weight: 700;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: var(--tr-muted);
	white-space: nowrap;
}

.tra-agency-profile-details span {
	font-size: 0.95rem;
	color: var(--tr-text);
	font-weight: 500;
}

.tra-agency-profile-details a {
	font-size: 0.95rem;
	color: var(--tr-primary);
	text-decoration: none;
	font-weight: 500;
	word-break: break-all;
}

.tra-agency-profile-details a:hover,
.tra-agency-profile-details a:focus {
	color: var(--tr-primary-hover);
	text-decoration: underline;
}

.tra-agency-jobs {
	margin-top: 2.5rem;
	padding-top: 2rem;
	border-top: 1px solid var(--tr-border-soft);
	font-family: var(--tr-font-sans) !important;
}

.tra-agency-jobs h3 {
	margin: 0 0 1.5rem;
	font-size: var(--tr-text-xs);
	font-weight: 800;
	letter-spacing: 0.07em;
	text-transform: uppercase;
	color: var(--tr-primary);
}

/* =========================================================
   Agency profile form
   ========================================================= */

.page .entry-content > .tr-agency-form,
.page .entry-content .tr-agency-form,
.page .entry-content > .tra-agency-profile-form,
.page .entry-content .tra-agency-profile-form {
	max-width: var(--tr-max-form);
	width: 100%;
	margin: 0 auto 2rem;
}

.tr-agency-form,
.tra-agency-profile-form {
	padding: 2rem;
	background: linear-gradient(180deg, #FFFFFF 0%, #F8FCFC 100%);
	border: 1px solid var(--tr-border-soft);
	border-radius: 16px;
	box-shadow: var(--tr-shadow-lg);
	box-sizing: border-box;
	font-family: var(--tr-font-sans);
	letter-spacing: normal;
}

.tr-agency-form > p,
.tra-agency-profile-form > p {
	margin: 0 0 24px;
}

.tr-agency-form__section {
	display: grid;
	gap: 0;
	margin: 0 0 1.35rem;
}

.tr-agency-form__section:last-of-type {
	margin-bottom: 0;
}

.tr-agency-form__field {
	display: grid;
	grid-template-columns: 280px minmax(0, 1fr);
	column-gap: 2rem;
	row-gap: 0.55rem;
	align-items: start;
	border: 0 !important;
	padding: 0 0 1.5rem !important;
	margin: 0 0 1.5rem !important;
	border-bottom: 1px solid rgba(0, 43, 48, 0.08) !important;
}

.tr-agency-form__section .tr-agency-form__field:last-child {
	padding-bottom: 0 !important;
	margin-bottom: 0 !important;
	border-bottom: 0 !important;
}

.tr-agency-form__field > label,
.tra-agency-profile-form .tra-agency-field > label {
	grid-column: 1;
	display: block;
	width: 100% !important;
	max-width: 100% !important;
	margin: 0 !important;
	font-weight: 700;
	color: var(--tr-text);
	line-height: 1.35;
}

.tr-agency-form__field > label strong,
.tra-agency-profile-form .tra-agency-field > label strong {
	margin: 0;
	line-height: 1.2;
}

.tr-agency-form__field > :not(label) {
	grid-column: 2;
	min-width: 0;
	width: 100%;
}

.tr-agency-form :is(input[type="text"], input[type="email"], input[type="url"], input[type="tel"], input[type="file"], select, textarea),
.tra-agency-profile-form :is(input[type="text"], input[type="email"], input[type="url"], input[type="tel"], input[type="file"], select, textarea) {
	display: block;
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	min-height: 48px;
	padding: 0.68rem 0.85rem !important;
	border: 1px solid rgba(0, 109, 119, 0.2) !important;
	border-radius: 11px !important;
	background: #FFFFFF !important;
	color: var(--tr-text) !important;
	font-family: var(--tr-font-sans);
	font-size: 0.95rem !important;
	line-height: 1.45 !important;
	box-shadow: inset 0 1px 0 rgba(0, 43, 48, 0.02);
}

.tr-agency-form :is(input[type="file"]),
.tra-agency-profile-form :is(input[type="file"]) {
	min-height: 44px;
	padding: 0.58rem 0.75rem !important;
	background: rgba(255, 255, 255, 0.78) !important;
}

.tr-agency-form :is(input, select, textarea):focus,
.tra-agency-profile-form :is(input, select, textarea):focus {
	border-color: var(--tr-primary) !important;
	box-shadow: var(--tr-focus) !important;
	outline: none;
}

.tr-agency-form textarea,
.tra-agency-profile-form textarea {
	min-height: 180px;
	resize: vertical;
}

.tr-agency-form small,
.tra-agency-profile-form small {
	display: block;
	margin-top: 8px;
	color: var(--tr-muted);
	font-size: 14px;
	line-height: 1.4;
}

.tr-agency-form img,
.tra-agency-profile-form img {
	border-radius: 10px;
	border: 1px solid var(--tr-border);
	background: #FFFFFF;
	padding: 8px;
	max-width: 100%;
	height: auto;
}

.tra-form-help {
	margin: 0 0 18px;
	color: var(--tr-muted);
	font-size: 14px;
	line-height: 1.5;
}

.tra-agency-profile-overview {
	display: grid;
	grid-template-columns: minmax(0, 1.35fr) minmax(280px, 0.9fr);
	gap: 1rem;
	max-width: var(--tr-max-content);
	margin: 0 auto 1.25rem;
}

.tra-agency-profile-overview__copy,
.tra-agency-profile-overview__panel {
	padding: 1.25rem;
	border-radius: 18px;
	border: 1px solid rgba(0, 109, 119, 0.12);
	background: rgba(255, 255, 255, 0.92);
	box-shadow: var(--tr-shadow-sm);
}

.tra-agency-profile-overview__copy {
	background:
		radial-gradient(circle at top right, rgba(131, 197, 190, 0.18), transparent 28%),
		linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(237, 246, 249, 0.92) 100%);
}

.tra-agency-profile-overview__eyebrow,
.tra-agency-profile-form__eyebrow,
.tra-agency-profile-overview__panel-label {
	margin: 0 0 0.55rem;
	font-size: var(--tr-text-xs);
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--tr-primary);
}

.tra-agency-profile-overview__title {
	margin: 0 0 0.75rem;
	line-height: 1.12;
}

.tra-agency-profile-overview__intro,
.tra-agency-profile-form__section-heading p {
	margin: 0;
	color: var(--tr-muted);
	line-height: 1.6;
}

.tra-agency-profile-overview__meter {
	display: grid;
	gap: 0.55rem;
	margin-top: 1rem;
}

.tra-agency-profile-overview__meter-meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 0.6rem;
	font-size: 0.95rem;
}

.tra-agency-profile-overview__meter-meta strong {
	color: var(--tr-text);
}

.tra-agency-profile-overview__meter-meta span {
	color: var(--tr-muted);
}

.tra-agency-profile-overview__meter-bar {
	height: 0.7rem;
	border-radius: 999px;
	background: rgba(0, 109, 119, 0.1);
	overflow: hidden;
}

.tra-agency-profile-overview__meter-bar span {
	display: block;
	height: 100%;
	border-radius: inherit;
	background: linear-gradient(90deg, rgba(0, 109, 119, 0.96) 0%, rgba(131, 197, 190, 0.92) 100%);
}

.tra-agency-profile-overview__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	margin-top: 1.1rem;
}

.tra-agency-profile-checklist {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 0.7rem;
}

.tra-agency-profile-benefits {
	list-style: none;
	margin: 0 0 1rem;
	padding: 0;
	display: grid;
	gap: 0.6rem;
}

.tra-agency-profile-benefits li {
	position: relative;
	padding-left: 1.15rem;
	color: var(--tr-text);
	line-height: var(--tr-leading);
}

.tra-agency-profile-benefits li::before {
	content: "";
	position: absolute;
	top: 0.62rem;
	left: 0;
	width: 0.42rem;
	height: 0.42rem;
	border-radius: 999px;
	background: var(--tr-primary);
}

.tra-agency-profile-checklist li {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem;
	padding: 0.75rem 0.9rem;
	border-radius: 14px;
	border: 1px solid rgba(0, 109, 119, 0.1);
	background: rgba(237, 246, 249, 0.56);
	color: var(--tr-text);
}

.tra-agency-profile-checklist li strong {
	font-size: 0.82rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.tra-agency-profile-checklist li.is-complete strong {
	color: var(--tr-primary);
}

.tra-agency-profile-checklist li.is-missing strong {
	color: #8A5A00;
}

.tra-agency-profile-overview__panel .tr-journey-tags {
	margin-top: 0.8rem;
}

.tra-agency-profile-form__section-heading {
	margin: 0 0 0.4rem;
	padding: 0 0 0.9rem;
	border-bottom: 1px solid rgba(0, 43, 48, 0.08);
}

.tra-agency-profile-form__section-heading h3 {
	margin: 0 0 0.45rem;
	color: var(--tr-text);
}

.tra-agency-profile-form--dashboard-tab .tra-agency-profile-form__section-heading {
	padding-bottom: 0.65rem;
	margin-bottom: 0.9rem;
	border-bottom: 1px solid rgba(0, 43, 48, 0.07);
}

.tra-agency-profile-form--dashboard-tab .tra-agency-profile-form__section-heading .tra-agency-profile-form__eyebrow {
	margin-bottom: 0.3rem;
}

.tra-agency-profile-form--dashboard-tab .tra-agency-profile-form__section-heading h3 {
	display: none;
}

/* Stack fields vertically to match the Post a job and My account tab forms */
.tra-agency-profile-form--dashboard-tab .tr-agency-form__field {
	grid-template-columns: minmax(0, 1fr);
	column-gap: 0;
	padding-bottom: 1.25rem;
	margin-bottom: 1.25rem;
}

.tra-agency-profile-form--dashboard-tab .tr-agency-form__field > label {
	grid-column: 1;
	font-size: 0.95rem;
	font-weight: 700;
}

.tra-agency-profile-form--dashboard-tab .tr-agency-form__field > :not(label) {
	grid-column: 1;
}

.tr-agency-form__field-content,
.tra-agency-field__content {
	display: block;
}

.tr-agency-form__checkbox-row,
.tra-agency-profile-form__checkbox-row {
	display: inline-flex !important;
	align-items: center !important;
	gap: 0.6rem !important;
	font-weight: 600 !important;
}

.tr-agency-form__checkbox-row input[type="checkbox"],
.tra-agency-profile-form__checkbox-row input[type="checkbox"] {
	width: 18px;
	height: 18px;
	margin: 0;
}

.tr-agency-form__actions,
.tra-agency-profile-form__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.85rem;
	align-items: center;
	margin-top: 0.5rem;
}

.tr-agency-form__actions button[type="submit"],
.tra-agency-profile-form__actions button[type="submit"] {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 48px;
	padding: 0.7rem 1.1rem !important;
	border: 1px solid var(--tr-primary) !important;
	border-radius: 12px !important;
	background: var(--tr-primary) !important;
	color: #FFFFFF !important;
	font-weight: 800 !important;
	line-height: 1.2 !important;
	letter-spacing: 0 !important;
	box-shadow: 0 8px 16px rgba(12, 122, 128, 0.18) !important;
	cursor: pointer;
}

.tr-agency-form__actions button[type="submit"]:hover,
.tr-agency-form__actions button[type="submit"]:focus,
.tra-agency-profile-form__actions button[type="submit"]:hover,
.tra-agency-profile-form__actions button[type="submit"]:focus {
	background: var(--tr-primary-hover) !important;
	border-color: var(--tr-primary-hover) !important;
	color: #FFFFFF !important;
}

.tra-agency-profile-form__secondary {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 46px;
	padding: 0.8rem 1rem;
	border-radius: 14px;
	border: 1px solid rgba(0, 109, 119, 0.14);
	background: rgba(255, 255, 255, 0.92);
	color: var(--tr-primary);
	font-weight: 700;
	text-decoration: none;
}

.tra-agency-profile-form__secondary:hover,
.tra-agency-profile-form__secondary:focus {
	border-color: var(--tr-primary);
	background: rgba(0, 109, 119, 0.05);
	color: var(--tr-primary-hover);
}

.tra-required-label,
.tra-optional-label {
	display: block;
	font-weight: 400;
	color: var(--tr-muted);
	font-size: 0.85rem;
	margin-top: 0.2rem;
	background: transparent;
	border: none;
	padding: 0;
	text-transform: lowercase;
	letter-spacing: normal;
	line-height: 1.4;
	white-space: normal;
}

.tra-required-label::before,
.tra-optional-label::before {
	content: "(";
}

.tra-required-label::after,
.tra-optional-label::after {
	content: ")";
}

@media (max-width: 760px) {
	.tr-agency-form,
	.tra-agency-profile-form {
		padding: 1.15rem;
		border-radius: 14px;
	}

	.tr-agency-form__field {
		grid-template-columns: minmax(0, 1fr);
		gap: 0.6rem;
	}

	.tr-agency-form__field > label,
	.tr-agency-form__field > :not(label) {
		grid-column: 1;
	}

	.tr-agency-form__actions,
	.tra-agency-profile-form__actions {
		display: grid;
	}

	.tr-agency-form__actions > *,
	.tra-agency-profile-form__actions > * {
		width: 100%;
		justify-content: center;
		box-sizing: border-box;
	}
}

/* =========================================================
   Contact form
   ========================================================= */

.page .entry-content > .tr-contact-form-wrap,
.page .entry-content .tr-contact-form-wrap,
.page .entry-content > .tr-contact-form,
.page .entry-content .tr-contact-form {
	max-width: var(--tr-max-form);
	width: 100%;
	margin: 0 auto 2rem;
}

.tr-contact-form {
	display: grid;
	gap: 1rem;
	padding: clamp(1.15rem, 2.5vw, 2rem);
	border: 1px solid rgba(0, 109, 119, 0.14);
	border-radius: 18px;
	background: linear-gradient(180deg, #FFFFFF 0%, #F8FCFC 100%);
	box-shadow: var(--tr-shadow-lg);
	box-sizing: border-box;
	font-family: var(--tr-font-sans);
	letter-spacing: normal;
}

.tr-contact-form__field {
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	gap: 0.45rem;
	margin: 0 !important;
	padding: 0 0 1rem !important;
	border-bottom: 1px solid rgba(0, 43, 48, 0.08);
}

.tr-contact-form__field:last-of-type {
	padding-bottom: 0 !important;
	border-bottom: 0;
}

.tr-contact-form__field label {
	display: block;
	margin: 0 !important;
	color: var(--tr-text);
	font-weight: 750;
	line-height: 1.35;
}

.tr-contact-form__field label strong {
	display: inline;
	line-height: 1.2;
}

.tr-contact-form :is(input[type="text"], input[type="email"], select, textarea) {
	display: block;
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	min-height: 52px;
	padding: 12px 16px !important;
	border: 1px solid rgba(0, 109, 119, 0.2) !important;
	border-radius: 12px !important;
	background: #FFFFFF !important;
	color: var(--tr-text) !important;
	font-size: 15px !important;
	line-height: 1.45 !important;
	box-shadow: inset 0 1px 0 rgba(0, 43, 48, 0.02);
}

.tr-contact-form textarea {
	min-height: 160px;
	resize: vertical;
}

.tr-contact-form :is(input, select, textarea):focus {
	border-color: var(--tr-primary) !important;
	box-shadow: var(--tr-focus) !important;
	outline: none;
}

.tr-contact-form__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	align-items: center;
	margin-top: 0.25rem;
}

.tr-contact-form__submit {
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	min-height: 48px;
	min-width: 180px;
	border-radius: 12px !important;
	font-weight: 800 !important;
}

.tr-contact-form__notice {
	max-width: var(--tr-max-form);
	margin: 0 auto 1rem;
}

.tr-contact-form__honeypot {
	position: absolute !important;
	left: -9999px !important;
	opacity: 0 !important;
	pointer-events: none !important;
}

@media (max-width: 760px) {
	.tr-contact-form {
		padding: 1rem;
		border-radius: 14px;
	}

	.tr-contact-form__actions {
		display: grid;
	}

	.tr-contact-form__actions > * {
		width: 100%;
		box-sizing: border-box;
		justify-content: center;
	}
}

/* =========================================================
   Agency mobile public-card polish
   ========================================================= */

@media (max-width: 640px) {
	.tra-agency-card {
		flex-direction: column;
		padding: 1.25rem;
	}

	.tra-agency-card__image {
		flex-basis: auto;
		width: 96px;
		height: 96px;
		padding: 0.6rem;
	}

	.tra-agency-card__logo {
		width: 100% !important;
	}

	.tra-agency-profile__header {
		gap: 1.25rem;
	}

	.tra-agency-profile__logo img {
		max-width: 120px;
	}
}
