.ttl-terminliste {
	margin: 2rem 0;
}

.ttl-monatsgruppe {
	margin-bottom: 2.5rem;
}

.ttl-monatsgruppe-titel {
	margin: 0 0 1rem 0;
	padding-bottom: 0.4rem;
	border-bottom: 2px solid #e5e5e5;
	font-size: 1.35rem;
	font-weight: 700;
	line-height: 1.2;
}

.ttl-termin {
	padding: 1rem 1.1rem;
	margin-bottom: 1rem;
	border: 1px solid #dddddd;
	border-radius: 10px;
	background: #ffffff;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

.ttl-termin-titel {
	margin-bottom: 0.35rem;
	font-size: 0.82rem;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: #777777;
}


.ttl-termin-ort {
	margin-bottom: 0.2rem;
	font-size: 1rem;
	font-weight: 600;
	color: #222222;
}

.ttl-termin-adresse {
	margin-bottom: 0.75rem;
	font-size: 0.9rem;
	font-weight: 400;
	line-height: 1.45;
	color: #777777;
}

.ttl-termin-links {
	margin-top: 0.75rem;
	padding-top: 0.75rem;
	border-top: 1px solid #eeeeee;
}

.ttl-termin-link + .ttl-termin-link {
	margin-top: 0.4rem;
}

.ttl-termin-link a {
	display: inline-block;
	font-weight: 600;
	font-size: 0.82rem;
	text-decoration: none;

	padding: 0.18rem 0.55rem;
	border: 1px solid #dddddd;
	border-radius: 6px;

	background: #fafafa;
	color: inherit;

	transition: background 0.15s ease, border-color 0.15s ease;
}

.ttl-termin-link a:hover,
.ttl-termin-link a:focus {
	background: #f0f0f0;
	border-color: #cccccc;
	text-decoration: none;
}

.ttl-termin-datum-uhrzeit {
	margin-bottom: 0.5rem;
	line-height: 1.2;
}

.ttl-termin-datum {
	font-size: 1.2rem;
	font-weight: 700;
	color: #111111;
}

.ttl-termin-uhrzeit {
	margin-top: 0.05rem;
	font-size: 0.82rem !important;
	font-weight: 400 !important;
	color: #777777 !important;
	letter-spacing: 0.01em;
}