/* ============================================================
   PflegeBrücke — content templates
   For index/page/single/archive/search/404.
   Built on the same tokens as everything else.
   ============================================================ */

/* Page heads --------------------------------------------------- */
.page-head {
	margin-bottom: var(--space-10);
}

.page-head__title {
	font-family: var(--font-display);
	font-weight: 500;
	font-size: clamp(2rem, 1.4rem + 2.4vw, 3.25rem);
	line-height: 1.05;
	letter-spacing: -0.02em;
	color: var(--ink-primary);
	margin: 0;
}

.page-head__lede {
	font-size: var(--text-lg);
	line-height: 1.55;
	color: var(--ink-secondary);
	max-width: 60ch;
	margin: 0;
}

.page-head__breadcrumb {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	color: var(--ink-tertiary);
	font-size: var(--text-sm);
	text-decoration: none;
	transition: color 180ms cubic-bezier(0.23, 1, 0.32, 1);
}
.page-head__breadcrumb:hover {
	color: var(--brand-700);
}

.search-query {
	font-style: italic;
	color: var(--brand-700);
}

/* Container variant for prose --------------------------------- */
.container--prose {
	max-width: 720px;
}

/* Post / page meta -------------------------------------------- */
.post-meta {
	display: flex;
	align-items: center;
	gap: var(--space-2);
	color: var(--ink-tertiary);
	font-size: var(--text-sm);
}

/* Post cards in list views ------------------------------------ */
.post-list {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-6);
}

@media (min-width: 720px) {
	.post-list {
		grid-template-columns: repeat(2, 1fr);
	}
}

.post-card {
	display: flex;
	flex-direction: column;
	overflow: hidden;
	padding: 0;
}

.post-card__media {
	display: block;
	background: var(--brand-50);
	overflow: hidden;
	aspect-ratio: 16 / 9;
}
.post-card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 360ms cubic-bezier(0.23, 1, 0.32, 1);
}
@media (hover: hover) and (pointer: fine) {
	.post-card:hover .post-card__media img {
		transform: scale(1.03);
	}
}

.post-card__body {
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
	padding: var(--space-6);
}

.post-card__meta {
	display: flex;
	align-items: center;
	gap: var(--space-2);
	color: var(--ink-tertiary);
	font-size: var(--text-xs);
	text-transform: uppercase;
	letter-spacing: 0.06em;
}

.post-card__title {
	font-family: var(--font-display);
	font-size: var(--text-2xl);
	line-height: 1.2;
	letter-spacing: -0.01em;
	margin: 0;
	color: var(--ink-primary);
}
.post-card__title a {
	color: inherit;
	text-decoration: none;
	transition: color 180ms cubic-bezier(0.23, 1, 0.32, 1);
}
.post-card__title a:hover {
	color: var(--brand-700);
}

.post-card__excerpt {
	color: var(--ink-secondary);
	font-size: var(--text-base);
	line-height: 1.6;
}
.post-card__excerpt p {
	margin: 0;
}

.post-card__more {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	margin-top: auto;
	color: var(--brand-700);
	font-weight: 500;
	font-size: var(--text-sm);
	text-decoration: none;
	transition: gap 200ms cubic-bezier(0.23, 1, 0.32, 1);
}
@media (hover: hover) and (pointer: fine) {
	.post-card__more:hover {
		gap: calc(var(--space-2) + 4px);
	}
}

/* Single article ---------------------------------------------- */
.page-article__media {
	margin: 0 0 var(--space-8);
	border-radius: var(--radius-lg);
	overflow: hidden;
	background: var(--brand-50);
}
.page-article__media img {
	width: 100%;
	height: auto;
	display: block;
}

/* Prose styling ----------------------------------------------- */
.prose {
	color: var(--ink-secondary);
	font-size: var(--text-lg);
	line-height: 1.7;
}
.prose > * + * {
	margin-top: 1em;
}
.prose h2 {
	font-family: var(--font-display);
	font-size: var(--text-3xl);
	line-height: 1.2;
	letter-spacing: -0.01em;
	color: var(--ink-primary);
	margin-top: 2em;
	margin-bottom: 0.5em;
}
.prose h3 {
	font-family: var(--font-display);
	font-size: var(--text-2xl);
	line-height: 1.25;
	color: var(--ink-primary);
	margin-top: 1.6em;
	margin-bottom: 0.4em;
}
.prose h4 {
	font-size: var(--text-lg);
	font-weight: 600;
	color: var(--ink-primary);
	margin-top: 1.4em;
}
.prose a {
	color: var(--brand-700);
	text-decoration: underline;
	text-underline-offset: 3px;
	text-decoration-thickness: 1px;
	transition: color 180ms cubic-bezier(0.23, 1, 0.32, 1);
}
.prose a:hover {
	color: var(--brand-800);
}
.prose strong {
	color: var(--ink-primary);
	font-weight: 600;
}
.prose ul,
.prose ol {
	padding-left: 1.4em;
}
.prose li {
	margin: 0.4em 0;
}
.prose blockquote {
	border-left: 3px solid var(--brand-500);
	padding: 0.4em 0 0.4em 1.2em;
	color: var(--ink-secondary);
	font-style: italic;
	margin: 1.6em 0;
}
.prose code {
	font-family: var(--font-mono);
	font-size: 0.9em;
	background: var(--surface-sunken);
	padding: 0.15em 0.4em;
	border-radius: var(--radius-xs);
	color: var(--ink-primary);
}
.prose pre {
	background: var(--ink-primary);
	color: var(--surface-raised);
	padding: var(--space-5);
	border-radius: var(--radius-md);
	overflow-x: auto;
	font-size: var(--text-sm);
	line-height: 1.55;
}
.prose pre code {
	background: transparent;
	padding: 0;
	color: inherit;
}
.prose img,
.prose figure {
	border-radius: var(--radius-md);
	margin: 1.6em 0;
	max-width: 100%;
	height: auto;
}
.prose hr {
	border: 0;
	border-top: 1px solid var(--border-default);
	margin: 2.4em 0;
}

/* Tags --------------------------------------------------------- */
.post-tags {
	margin-top: var(--space-8);
	padding-top: var(--space-6);
	border-top: 1px solid var(--border-default);
}

/* Post navigation --------------------------------------------- */
.post-nav {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-3);
	margin-top: var(--space-10);
	padding-top: var(--space-8);
	border-top: 1px solid var(--border-default);
}

@media (min-width: 720px) {
	.post-nav {
		grid-template-columns: 1fr 1fr;
	}
}

.post-nav__link {
	display: flex;
	flex-direction: column;
	gap: var(--space-2);
	padding: var(--space-5);
	border-radius: var(--radius-md);
	background: var(--surface-sunken);
	text-decoration: none;
	color: var(--ink-primary);
	transition: background 200ms cubic-bezier(0.23, 1, 0.32, 1),
		transform 200ms cubic-bezier(0.23, 1, 0.32, 1);
}
@media (hover: hover) and (pointer: fine) {
	.post-nav__link:hover {
		background: var(--brand-50);
		transform: translateY(-2px);
	}
}
.post-nav__link--next {
	text-align: right;
}
.post-nav__label {
	font-size: var(--text-xs);
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--ink-tertiary);
}
.post-nav__title {
	font-weight: 500;
	font-size: var(--text-base);
	line-height: 1.4;
}

/* Pagination --------------------------------------------------- */
.pagination {
	margin-top: var(--space-10);
	display: flex;
	justify-content: center;
}
.pagination .nav-links {
	display: flex;
	gap: var(--space-2);
	flex-wrap: wrap;
}
.pagination a,
.pagination span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding: 0 var(--space-3);
	border-radius: var(--radius-sm);
	font-size: var(--text-sm);
	font-weight: 500;
	color: var(--ink-secondary);
	text-decoration: none;
	transition: background 180ms cubic-bezier(0.23, 1, 0.32, 1),
		color 180ms cubic-bezier(0.23, 1, 0.32, 1);
}
.pagination a:hover {
	background: var(--surface-sunken);
	color: var(--ink-primary);
}
.pagination .current {
	background: var(--brand-500);
	color: white;
}

/* Search form -------------------------------------------------- */
.search-form {
	display: flex;
	gap: var(--space-2);
	max-width: 480px;
	margin-top: var(--space-4);
}
.search-form input[type="search"] {
	flex: 1;
	padding: 0 var(--space-4);
	height: 44px;
	border: 1px solid var(--border-default);
	border-radius: var(--radius-sm);
	background: var(--surface-raised);
	font-size: var(--text-base);
	color: var(--ink-primary);
	transition: border-color 180ms cubic-bezier(0.23, 1, 0.32, 1),
		box-shadow 180ms cubic-bezier(0.23, 1, 0.32, 1);
}
.search-form input[type="search"]:focus {
	outline: none;
	border-color: var(--brand-500);
	box-shadow: var(--shadow-focus);
}

/* Empty state extras ----------------------------------------- */
.empty--lg {
	padding: var(--space-12) var(--space-6);
	text-align: center;
}
.empty--lg h2 {
	font-family: var(--font-display);
	font-size: var(--text-3xl);
	color: var(--ink-primary);
	margin: 0 0 var(--space-3);
}
.empty--lg p {
	color: var(--ink-secondary);
	max-width: 48ch;
	margin: 0 auto var(--space-6);
	line-height: 1.6;
}
.empty--centered {
	display: flex;
	flex-direction: column;
	align-items: center;
}

.empty__code {
	font-family: var(--font-display);
	font-size: clamp(4rem, 3rem + 5vw, 7rem);
	font-weight: 500;
	line-height: 1;
	letter-spacing: -0.04em;
	color: var(--brand-500);
	opacity: 0.85;
	margin-bottom: var(--space-4);
}

/* Section variant for narrow content -------------------------- */
.section--narrow {
	padding-top: clamp(var(--space-10), 6vw, var(--space-16));
	padding-bottom: clamp(var(--space-10), 6vw, var(--space-16));
}

/* Comments ---------------------------------------------------- */
.comments-area {
	margin-top: var(--space-12);
	padding-top: var(--space-8);
	border-top: 1px solid var(--border-default);
}

.page-links {
	display: flex;
	gap: var(--space-2);
	align-items: center;
	margin-top: var(--space-6);
	font-size: var(--text-sm);
	color: var(--ink-tertiary);
}

/* Neutral badge variant for tags ------------------------------ */
.badge--neutral {
	background: var(--surface-sunken);
	color: var(--ink-secondary);
	border-color: transparent;
	text-decoration: none;
	transition: background 180ms cubic-bezier(0.23, 1, 0.32, 1),
		color 180ms cubic-bezier(0.23, 1, 0.32, 1);
}
.badge--neutral:hover {
	background: var(--brand-50);
	color: var(--brand-700);
}

/* ============================================================
   Marketing pages: hero variants
   ============================================================ */
.hero--simple {
	padding: clamp(64px, 10vw, 120px) 0 clamp(40px, 6vw, 64px);
	text-align: center;
	background: linear-gradient(180deg, var(--brand-50) 0%, transparent 100%);
}
.hero--simple .hero__title {
	margin-left: auto;
	margin-right: auto;
	max-width: 18ch;
}
.hero--simple .hero__lede {
	margin: 16px auto 0;
	max-width: 56ch;
	color: var(--ink-secondary);
}

.hero--persona {
	padding: clamp(64px, 10vw, 100px) 0;
}
.hero--persona .hero__inner {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-8);
	align-items: center;
}
@media (min-width: 900px) {
	.hero--persona .hero__inner { grid-template-columns: 1.2fr 1fr; }
}

.hero__copy { max-width: 520px; }
.hero__eyebrow {
	display: inline-block;
	color: var(--brand-700);
	font-weight: 500;
	font-size: 13px;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	margin: 0 0 var(--space-3);
}
.hero__title {
	font-family: var(--font-display, 'Fraunces', serif);
	font-size: clamp(36px, 5vw, 56px);
	font-weight: 500;
	line-height: 1.1;
	color: var(--ink-primary);
	margin: 0 0 var(--space-4);
	letter-spacing: -0.02em;
}
.hero__lede {
	font-size: 18px;
	line-height: 1.6;
	color: var(--ink-secondary);
	margin: 0 0 var(--space-6);
}
.hero__cta {
	display: flex;
	gap: 12px;
	flex-wrap: wrap;
}

/* Persona card mockup in the hero */
.hero__visual {
	display: flex;
	justify-content: center;
}
.hero__card {
	background: var(--surface-raised);
	border: 1px solid var(--surface-sunken);
	border-radius: var(--radius-lg, 16px);
	padding: var(--space-5);
	max-width: 360px;
	box-shadow: 0 12px 40px rgba(20, 31, 36, 0.08);
}
.hero__card-head {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: var(--space-4);
}
.hero__card-head .dash-avatar {
	width: 44px; height: 44px; flex-shrink: 0;
}
.hero__card-head strong { display: block; color: var(--ink-primary); }
.hero__card-head small { color: var(--ink-tertiary); font-size: 12px; }
.hero__card-body {
	display: flex;
	flex-direction: column;
	gap: 12px;
}
.hero__card-body p {
	color: var(--ink-secondary);
	font-size: 14px;
	line-height: 1.5;
	margin: 0;
}

/* ============================================================
   Sections / generic
   ============================================================ */
.section {
	padding: clamp(48px, 7vw, 80px) 0;
}
.section--alt {
	background: var(--surface-sunken);
}
.section--features {
	background: var(--surface-raised);
}
.section__head {
	text-align: center;
	max-width: 720px;
	margin: 0 auto var(--space-8);
}
.section__head h2 {
	font-family: var(--font-display, 'Fraunces', serif);
	font-size: clamp(28px, 4vw, 40px);
	font-weight: 500;
	line-height: 1.15;
	color: var(--ink-primary);
	margin: 0 0 var(--space-3);
}
.section__head p {
	color: var(--ink-secondary);
	font-size: 17px;
	line-height: 1.6;
	margin: 0;
}
.section__cta-row {
	text-align: center;
	margin-top: var(--space-8);
}

/* ============================================================
   Feature grid
   ============================================================ */
.feature-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: var(--space-6);
}
.feature {
	background: var(--surface-raised);
	border: 1px solid var(--surface-sunken);
	border-radius: var(--radius-lg, 16px);
	padding: var(--space-6);
	transition: transform 220ms cubic-bezier(0.23, 1, 0.32, 1),
		border-color 220ms cubic-bezier(0.23, 1, 0.32, 1);
}
.feature:hover {
	transform: translateY(-2px);
	border-color: var(--brand-300);
}
.feature__icon {
	font-size: 32px;
	line-height: 1;
	margin-bottom: var(--space-4);
}
.feature h3 {
	font-size: 18px;
	font-weight: 500;
	color: var(--ink-primary);
	margin: 0 0 var(--space-2);
}
.feature p {
	color: var(--ink-secondary);
	line-height: 1.55;
	margin: 0;
}

/* ============================================================
   Steps (numbered)
   ============================================================ */
.steps {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-5);
}
@media (min-width: 720px) {
	.steps { grid-template-columns: repeat(3, 1fr); }
}
.steps--vertical { grid-template-columns: 1fr !important; gap: var(--space-4); }

.step {
	background: var(--surface-raised);
	border: 1px solid var(--surface-sunken);
	border-radius: var(--radius-lg, 12px);
	padding: var(--space-5);
}
.step__num {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: var(--brand-500);
	color: white;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 600;
	font-size: 16px;
	margin-bottom: var(--space-3);
}
.step h3 {
	font-size: 17px;
	font-weight: 500;
	color: var(--ink-primary);
	margin: 0 0 8px;
}
.step p {
	color: var(--ink-secondary);
	font-size: 14px;
	line-height: 1.55;
	margin: 0;
}

/* ============================================================
   How-it-works two-column
   ============================================================ */
.how-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-8);
}
@media (min-width: 900px) {
	.how-grid { grid-template-columns: 1fr 1fr; gap: var(--space-10); }
}
.how-col h2 {
	font-family: var(--font-display, 'Fraunces', serif);
	font-size: 24px;
	font-weight: 500;
	color: var(--ink-primary);
	margin: 0 0 var(--space-5);
	padding-bottom: var(--space-3);
	border-bottom: 1px solid var(--surface-sunken);
}

/* ============================================================
   Pricing
   ============================================================ */
.pricing-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-5);
	margin-bottom: var(--space-6);
}
@media (min-width: 800px) {
	.pricing-grid { grid-template-columns: repeat(3, 1fr); }
}
.pricing-card {
	background: var(--surface-raised);
	border: 1px solid var(--surface-sunken);
	border-radius: var(--radius-lg, 16px);
	padding: var(--space-6);
	display: flex;
	flex-direction: column;
	gap: var(--space-4);
	position: relative;
}
.pricing-card--featured {
	border-color: var(--brand-500);
	border-width: 2px;
	transform: translateY(-4px);
	box-shadow: 0 16px 40px rgba(20, 31, 36, 0.08);
}
.pricing-card__badge {
	position: absolute;
	top: -12px;
	left: 50%;
	transform: translateX(-50%);
	background: var(--brand-500);
	color: white;
	padding: 4px 14px;
	border-radius: 999px;
	font-size: 12px;
	font-weight: 500;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}
.pricing-card__head h3 {
	font-size: 20px;
	font-weight: 500;
	margin: 0 0 4px;
	color: var(--ink-primary);
}
.pricing-card__lede {
	font-size: 13px;
	color: var(--ink-tertiary);
	margin: 0;
}
.pricing-card__price {
	display: flex;
	align-items: baseline;
	gap: 6px;
	padding: var(--space-3) 0;
	border-top: 1px solid var(--surface-sunken);
	border-bottom: 1px solid var(--surface-sunken);
}
.pricing-card__amount {
	font-family: var(--font-display, 'Fraunces', serif);
	font-size: 28px;
	font-weight: 500;
	color: var(--ink-primary);
}
.pricing-card__period {
	color: var(--ink-tertiary);
	font-size: 13px;
}
.pricing-card__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 8px;
	color: var(--ink-secondary);
	font-size: 14px;
	line-height: 1.5;
	flex: 1;
}
.pricing__footnote {
	color: var(--ink-tertiary);
	font-size: 13px;
	text-align: center;
	max-width: 60ch;
	margin: 0 auto;
}

/* ============================================================
   CTA band
   ============================================================ */
.cta-band {
	background: var(--surface-raised);
	border: 1px solid var(--surface-sunken);
	border-radius: var(--radius-lg, 16px);
	padding: var(--space-8);
	text-align: center;
	max-width: 720px;
	margin: 0 auto;
}
.cta-band h2 {
	font-family: var(--font-display, 'Fraunces', serif);
	font-size: 28px;
	font-weight: 500;
	color: var(--ink-primary);
	margin: 0 0 var(--space-3);
}
.cta-band p {
	color: var(--ink-secondary);
	margin: 0 0 var(--space-5);
}

/* ============================================================
   About page
   ============================================================ */
.about-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-8);
}
@media (min-width: 900px) {
	.about-grid { grid-template-columns: 1.5fr 1fr; gap: var(--space-10); }
}
.about-text h2 {
	font-family: var(--font-display, 'Fraunces', serif);
	font-size: 26px;
	font-weight: 500;
	color: var(--ink-primary);
	margin: var(--space-6) 0 var(--space-3);
}
.about-text h2:first-child { margin-top: 0; }
.about-text p {
	color: var(--ink-secondary);
	font-size: 16px;
	line-height: 1.7;
	margin: 0 0 var(--space-3);
}
.about-values {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
}
.about-values li {
	color: var(--ink-secondary);
	line-height: 1.6;
}
.about-values strong {
	color: var(--ink-primary);
	display: inline-block;
	min-width: 130px;
}

.about-stats {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-3);
	align-content: start;
}
.about-stat {
	background: var(--brand-50);
	border-radius: var(--radius-md);
	padding: var(--space-5);
	text-align: center;
}
.about-stat__num {
	font-family: var(--font-display, 'Fraunces', serif);
	font-size: 36px;
	font-weight: 500;
	color: var(--brand-700);
	line-height: 1.1;
}
.about-stat__label {
	color: var(--ink-secondary);
	font-size: 13px;
	margin-top: 4px;
}

/* ============================================================
   Contact page
   ============================================================ */
.contact-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-8);
}
@media (min-width: 900px) {
	.contact-grid { grid-template-columns: 2fr 1fr; gap: var(--space-10); }
}
.contact-form-wrap {
	background: var(--surface-raised);
	border: 1px solid var(--surface-sunken);
	border-radius: var(--radius-lg, 16px);
	padding: var(--space-6);
}
.contact-info { display: flex; flex-direction: column; gap: var(--space-5); }
.contact-info h2 {
	font-family: var(--font-display, 'Fraunces', serif);
	font-size: 20px;
	font-weight: 500;
	margin: 0;
	color: var(--ink-primary);
}
.contact-block {
	display: flex;
	gap: 14px;
	align-items: flex-start;
}
.contact-block__icon {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: var(--brand-50);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	font-size: 16px;
}
.contact-block strong {
	display: block;
	color: var(--ink-primary);
	font-weight: 500;
	margin-bottom: 2px;
}
.contact-block a {
	color: var(--brand-600);
	text-decoration: none;
}
.contact-block a:hover { text-decoration: underline; }
.contact-block small { display: block; color: var(--ink-tertiary); font-size: 12px; margin-top: 2px; }
.contact-block address {
	font-style: normal;
	color: var(--ink-secondary);
	line-height: 1.5;
}

/* ============================================================
   Directory pages
   ============================================================ */
.dir-filter {
	display: flex;
	gap: var(--space-4);
	flex-wrap: wrap;
	align-items: end;
	background: var(--surface-raised);
	border: 1px solid var(--surface-sunken);
	border-radius: var(--radius-lg, 12px);
	padding: var(--space-4);
	margin-bottom: var(--space-4);
}
.dir-filter__field {
	display: flex;
	flex-direction: column;
	gap: 4px;
	min-width: 180px;
	flex: 1;
}
.dir-filter__field span {
	font-size: 12px;
	color: var(--ink-tertiary);
	text-transform: uppercase;
	letter-spacing: 0.04em;
}
.dir-filter__field select {
	padding: 8px 12px;
	border: 1px solid var(--surface-sunken);
	border-radius: var(--radius-md);
	background: var(--surface-raised);
	font-family: inherit;
	font-size: 14px;
	color: var(--ink-primary);
}
.dir-filter__reset {
	color: var(--brand-600);
	font-size: 13px;
	text-decoration: none;
	padding-bottom: 10px;
	white-space: nowrap;
}

.dir-count {
	color: var(--ink-tertiary);
	font-size: 14px;
	margin: 0 0 var(--space-4);
}

.dir-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
	gap: var(--space-4);
}
.dir-card {
	background: var(--surface-raised);
	border: 1px solid var(--surface-sunken);
	border-radius: var(--radius-lg, 12px);
	padding: var(--space-5);
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
	transition: border-color 180ms cubic-bezier(0.23, 1, 0.32, 1),
		box-shadow 180ms cubic-bezier(0.23, 1, 0.32, 1);
}
.dir-card:hover {
	border-color: var(--brand-200);
	box-shadow: 0 4px 12px rgba(20, 31, 36, 0.04);
}
.dir-card__head { display: flex; gap: 12px; align-items: center; }
.dir-card__head .dash-avatar { width: 44px; height: 44px; }
.dir-card__name { margin: 0; font-size: 16px; font-weight: 500; color: var(--ink-primary); }
.dir-card__sub { font-size: 13px; color: var(--ink-tertiary); display: flex; gap: 4px; flex-wrap: wrap; }
.dir-card__bio { color: var(--ink-secondary); line-height: 1.55; font-size: 14px; margin: 0; flex: 1; }
.dir-card__chips { display: flex; gap: 6px; flex-wrap: wrap; }
.dir-chip {
	background: var(--brand-50);
	color: var(--brand-700);
	padding: 3px 10px;
	border-radius: 999px;
	font-size: 12px;
	font-weight: 500;
}
.dir-card__foot {
	display: flex;
	gap: 8px;
	padding-top: var(--space-3);
	border-top: 1px solid var(--surface-sunken);
}
.dir-card__foot .btn { flex: 1; }

/* ============================================================
   Job list (linear)
   ============================================================ */
.job-list { display: flex; flex-direction: column; gap: 12px; }
.job-item {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: var(--space-4);
	align-items: center;
	background: var(--surface-raised);
	border: 1px solid var(--surface-sunken);
	border-radius: var(--radius-lg, 12px);
	padding: var(--space-5);
	transition: border-color 180ms cubic-bezier(0.23, 1, 0.32, 1);
}
.job-item:hover { border-color: var(--brand-200); }
.job-item__title { margin: 0 0 6px; font-size: 17px; font-weight: 500; }
.job-item__title a { color: var(--ink-primary); text-decoration: none; }
.job-item__title a:hover { color: var(--brand-600); }
.job-item__meta {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	font-size: 13px;
	color: var(--ink-tertiary);
	margin-bottom: 8px;
}
.job-item__excerpt {
	color: var(--ink-secondary);
	font-size: 14px;
	line-height: 1.5;
	margin: 0;
}
.job-item__actions { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }
@media (max-width: 640px) {
	.job-item { grid-template-columns: 1fr; }
}

/* ============================================================
   Profile (Pflegekraft / Stelle detail)
   ============================================================ */
.profile { background: var(--surface-canvas); }

.profile__header {
	background: linear-gradient(180deg, var(--brand-50) 0%, transparent 100%);
	padding: clamp(48px, 7vw, 80px) 0 clamp(32px, 5vw, 48px);
}
.profile__header-inner {
	display: flex;
	align-items: center;
	gap: var(--space-5);
	flex-wrap: wrap;
}
.profile__avatar {
	width: 72px;
	height: 72px;
	border-radius: 50%;
	background: var(--brand-500);
	color: white;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 600;
	font-size: 24px;
	flex-shrink: 0;
}
.profile__avatar--lg { width: 88px; height: 88px; font-size: 28px; }
.profile__head-text { flex: 1; min-width: 0; }
.profile__name {
	font-family: var(--font-display, 'Fraunces', serif);
	font-size: clamp(28px, 4vw, 40px);
	font-weight: 500;
	color: var(--ink-primary);
	margin: 0 0 6px;
	line-height: 1.15;
}
.profile__head-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
	color: var(--ink-secondary);
	font-size: 14px;
}

.profile__body { padding: var(--space-8) 0; }
.profile__cols {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-6);
}
@media (min-width: 900px) {
	.profile__cols { grid-template-columns: 1.6fr 1fr; gap: var(--space-8); }
}

.profile__section { margin-bottom: var(--space-6); }
.profile__section h2 {
	font-family: var(--font-display, 'Fraunces', serif);
	font-size: 20px;
	font-weight: 500;
	color: var(--ink-primary);
	margin: 0 0 var(--space-3);
}
.profile__section p {
	color: var(--ink-secondary);
	line-height: 1.7;
	margin: 0;
}
.profile__chips { display: flex; gap: 8px; flex-wrap: wrap; }

.profile__aside { align-self: start; position: sticky; top: 96px; }
@media (max-width: 899px) { .profile__aside { position: static; } }

.profile__panel {
	background: var(--surface-raised);
	border: 1px solid var(--surface-sunken);
	border-radius: var(--radius-lg, 16px);
	padding: var(--space-6);
}
.profile__panel--success {
	background: #ECFDF5;
	border-color: #A7F3D0;
}
.profile__panel h3 {
	font-size: 17px;
	font-weight: 500;
	color: var(--ink-primary);
	margin: 0 0 var(--space-3);
}
.profile__panel-lede {
	color: var(--ink-secondary);
	font-size: 14px;
	line-height: 1.55;
	margin: 0 0 var(--space-4);
}

.prose p { margin: 0 0 var(--space-3); line-height: 1.7; color: var(--ink-secondary); }
.prose h2, .prose h3 {
	font-family: var(--font-display, 'Fraunces', serif);
	color: var(--ink-primary);
	margin: var(--space-5) 0 var(--space-2);
}
.prose ul, .prose ol { padding-left: 20px; line-height: 1.7; color: var(--ink-secondary); }
