/*!
Theme Name: traveljunkies modern
Theme URI: https://www.traveljunkies.tours/
Author: Juri Neiz
Author URI: https://neizcon.de
Description: Theme for the traveljunkies Site
Version: 2.0.0
*/

/* ========================================================================
   Benutzerdefinierte Bullet Points für Reiseart-Beschreibungen
   ======================================================================== */

/* Optional: Nur für Feinschliff des Abstands */
.entry-content ul[style*="list-style-image"] {
	padding-left: 2em;
	/* Vergrößert den Einzug der ganzen Liste */
	margin-left: 1em;
}

/**
 * Accordion
 */
.accordion-button {
	color: #194b59;
	font-size: .875rem;
	font-weight: 500;
}

.accordion-button:hover {
	color: #0c252c;
	background-color: #f9f9f9;
}

.accordion-button:focus {
	border: none;
	box-shadow: none;
}

.accordion-button::after {
	font-family: 'Font Awesome 5 Pro';
	font-weight: 300;
	font-size: 1.375rem;
	color: #999;
	content: "\f107";
	background-image: none;
	width: auto;
	height: auto;
}

.accordion-button:not(.collapsed) {
	color: #0c252c;
	background-color: #f9f9f9;
	box-shadow: inset 0 -1px 0 rgb(0 0 0 / 7%);
}

.accordion-button:not(.collapsed)::after {
	background-image: none;
}

.accordion-body p:last-child {
	margin-bottom: 0;
}

.accordion-link {
	line-height: 1.9;
	text-decoration: none;
}

.accordion-link::after {
	content: "";
}

/**
 * Accordion (Flush)
 */
.accordion-flush .accordion-button {
	padding-right: 0px;
	padding-left: 0px;
}

.accordion-flush .accordion-button:hover {
	background-color: #fff;
}

.accordion-flush .accordion-button:not(.collapsed) {
	color: #194b59;
	background-color: #fff;
	box-shadow: none;
}

.accordion-flush .accordion-button:not(.collapsed)::after {
	color: #999;
}

.accordion-flush .accordion-body {
	padding-top: 0px;
	padding-right: 0px;
	padding-left: 0px;
}

/**
 * Avatar
 */
.avatar {
	border: 5px solid #fff;
	border-radius: 50%;
}

/**
 * Border
 */
.h-border {
	background-color: #3fbddf;
	height: 3px;
	width: 70px;
}

/**
 * Buttons (Icon)
 */
.btn-icon {
	display: flex;
	justify-content: center;
	align-items: center;
}

.btn-sm.btn-icon {
	min-width: 31px;
	height: 31px;
	width: 31px;
}

/**
 * Cards
 */
.card-img-cover {
	height: 360px;
	object-fit: cover;
}

.card-img-overlay {
	background-image: -webkit-linear-gradient(top, rgba(0, 0, 0, 0), rgba(0, 0, 0, .6));
	background-image: -o-linear-gradient(top, rgba(0, 0, 0, 0), rgba(0, 0, 0, .6));
	background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0), rgba(0, 0, 0, .6));
	height: 50%;
	margin-top: auto;
}

.card.bg-primary .form-control,
.card.bg-primary .form-select,
.card.bg-primary .input-group-text {
	border-color: #fff;
}

.card.bg-primary input:focus {
	box-shadow: none;
}

.card.disabled {
	opacity: .4;
}

/**
 * Cards (Filter)
 */
.card-filter .datepicker {
	position: relative;
}

.card-filter .datepicker:before {
	font-family: 'Font Awesome 5 Pro';
	font-weight: 300;
	color: #999;
	content: "\f133";
	position: absolute;
	top: 50%;
	left: .875rem;
	transform: translateY(-50%);
}

.card-filter .datepicker .form-control {
	padding-left: 2.5rem;
}

/**
 * Cards (Icon)
 */
.card-icon {
	min-height: 80px;
	width: 100px;
	display: flex;
	justify-content: center;
	align-items: center;
}

/**
 * Cards (Tour)
 */
.card-tour {
	border: none;
	border-radius: .5rem;
	box-shadow: 0 .125rem .25rem rgba(0, 0, 0, .075);
	height: 100%;
}

.card-tour .card-img {
	border-top-right-radius: .5rem;
	border-top-left-radius: .5rem;
	border-bottom-right-radius: 0;
	border-bottom-left-radius: 0;
}

.card-tour .tour-img {
	border-bottom: 3px solid #f4bb3a;
	position: relative;
	overflow: hidden;
}

.card-tour .tour-discount {
	color: #fff;
	background-color: #df613f;
	font-size: .875rem;
	font-weight: 500;
	text-align: center;
	line-height: 30px;
	width: 100px;
	position: absolute;
	top: 6px;
	right: -30px;
	transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	z-index: 1;
}

.card-tour .tour-region {
	color: #fff;
	background-color: #f4bb3a;
	font-size: .75rem;
	font-weight: 500;
	text-transform: uppercase;
	height: 27px;
	max-width: 100%;
	padding-top: 3px;
	padding-right: .25rem;
	padding-left: 1rem;
	display: flex;
	align-items: center;
	position: absolute;
	bottom: 0;
}

.card-tour .tour-region:after {
	border-bottom: 27px solid #f4bb3a;
	border-right: 27px solid transparent;
	content: "";
	position: absolute;
	right: -27px;
	bottom: 0;
}

.card-tour .tour-course {
	background-color: #eee;
	position: relative;
}

.card-tour .tour-course span {
	background-color: #eee;
	font-size: .75rem;
	font-weight: 500;
	padding: .5rem 1rem;
	z-index: 1;
}

.card-tour .tour-course:after {
	border-top: 2px dotted #ddd;
	content: "";
	position: absolute;
	top: 50%;
	right: 0;
	left: 0;
}

.card-tour .tour-type {
	color: #2c849c;
	font-size: .75rem;
	font-weight: 500;
	text-transform: uppercase;
}

.card-tour .tour-title {
	min-height: 57px;
}

.card-tour .card-footer {
	border-bottom-right-radius: .5rem;
	border-bottom-left-radius: .5rem;
}

.card-tour .tour-meta {
	color: #2c849c;
	font-size: .75rem;
}

.card-tour .tour-price {
	color: #f4bb3a;
	border-left: 1px solid rgba(0, 0, 0, .125);
	font-size: 1.5rem;
	text-align: right;
}

.card-tour .tour-price span {
	color: #194B5A;
	font-size: .75rem;
}

/**
 * Carousel
 */
.carousel-control-next,
.carousel-control-prev {
	color: #f3b322;
	font-size: 1.125rem;
	opacity: 1;
	width: auto;
}

.carousel-control-next:focus,
.carousel-control-next:hover,
.carousel-control-prev:focus,
.carousel-control-prev:hover {
	color: #f3b322;
	opacity: 1;
}

.carousel-control-next {
	right: -25px;
}

.carousel-control-prev {
	left: -25px;
}

.carousel-control-next i,
.carousel-control-prev i {
	background: #fff;
	width: 50px;
	height: 50px;
	border-radius: 50%;
	display: flex;
	justify-content: center;
	align-items: center;
}

.carousel-indicators {
	bottom: -4.5rem;
}

.carousel-indicators [data-bs-target] {
	background-color: #f3b322;
	border-radius: 50%;
	margin-right: 5px;
	margin-left: 5px;
	width: 11px;
	height: 11px;
}

/**
 * Colors (Background)
 */
.bg-discount {
	background-color: #df613f;
}

/**
 * Content
 */
.site-content {
	overflow-x: hidden;
}

.entry-title a,
.page-title a {
	text-decoration: none;
}

.entry-content,
.page-content {
	line-height: 1.7;
}

.entry-content h2,
.page-content h2 {
	font-size: 1.5rem;
	margin-top: 1rem;
}

.entry-content h3,
.page-content h3 {
	font-family: Journal, Roboto, "Helvetica Neue", Arial, sans-serif;
	font-size: 2.5rem;
	color: #f3b322;
}

/**
 * Content (Tour)
 */
.tour-content .tour-img {
	position: relative;
}

.tour-content .tour-img img {
	border-radius: .5rem;
	box-shadow: 0 .125rem .25rem rgba(0, 0, 0, .075);
}

.tour-content .tour-img .img-map {
	border: 3px solid #fff;
	box-shadow: none;
	width: 120px;
	position: absolute;
	top: 1rem;
	left: 1rem;
}

.tour-content .entry-content.ellipsis {
	max-height: 380px;
}

.tour-content .accordion .entry-content.ellipsis {
	max-height: 1200px;
}

.tour-content .tour-price {
	color: #f4bb3a;
	font-size: 3rem;
	line-height: 1;
}

.tour-content .tour-gallery img {
	height: 240px;
	object-fit: cover;
}

.tour-content .tour-gallery .card-img-overlay {
	background-image: -webkit-linear-gradient(bottom, rgba(0, 0, 0, 0), rgba(0, 0, 0, .6));
	background-image: -o-linear-gradient(bottom, rgba(0, 0, 0, 0), rgba(0, 0, 0, .6));
	background-image: linear-gradient(to top, rgba(0, 0, 0, 0), rgba(0, 0, 0, .6));
	border-bottom-left-radius: 0;
	border-bottom-right-radius: 0;
	height: 50px;
	margin-top: 0;
}

.tour-content .tour-gallery .invisible {
	height: 0;
	width: 0;
}

/**
 * Footer
 */
.site-footer {
	border-top: 1px solid #dee2e6;
}

.site-footer h5 {
	font-size: .875rem;
	text-transform: uppercase;
	margin-bottom: .5rem;
}

/**
 * Formidable Forms (Site Style)
 */
.frm_style_site-style.with_frm_style label {
	margin-bottom: .25rem !important;
}

.frm_style_site-style.with_frm_style input,
.frm_style_site-style.with_frm_style textarea {
	background-image: linear-gradient(transparent, transparent);
	/* Remove iOS input shadow */
	transition: border-color .15s ease-in-out, box-shadow .15s ease-in-out;
}

.frm_style_site-style.with_frm_style .form-field input:not([type=checkbox]):not([type=radio]):focus,
.frm_style_site-style.with_frm_style textarea:focus {
	border-color: #8bd7eb !important;
	box-shadow: 0 0 0 0.25rem rgb(63 189 223 / 25%) !important;
}

.frm_style_site-style.with_frm_style .form-select {
	background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23999999' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M2 5l6 6 6-6'/%3e%3c/svg%3e") !important;
}

.frm_style_site-style.with_frm_style .vertical_radio .frm_radio {
	margin: .5rem 0 !important;
}

.frm_style_site-style.with_frm_style .frm_required {
	margin-left: .25rem !important;
}

.frm_style_site-style.with_frm_style .frm_error_style,
.frm_style_site-style.with_frm_style .frm_message,
.frm_style_site-style.frm_success_style {
	margin: 1rem 0 !important;
	padding: 1rem !important;
}

.frm_style_site-style.with_frm_style .frm_error_style p,
.frm_style_site-style.with_frm_style .frm_message p,
.frm_style_site-style.frm_success_style p {
	margin-bottom: 0 !important;
}

.frm_style_site-style.with_frm_style .form-field input::placeholder,
.frm_style_site-style.with_frm_style .form-field textarea::placeholder {
	/* Chrome, Firefox, Opera, Safari 10.1+ */
	color: #999 !important;
	opacity: 1;
	/* Firefox */
}

.frm_style_site-style.with_frm_style .form-field input:-ms-input-placeholder,
.frm_style_site-style.with_frm_style .form-field textarea:-ms-input-placeholder {
	/* Internet Explorer 10-11 */
	color: #999 !important;
}

.frm_style_site-style.with_frm_style .form-field input::-ms-input-placeholder,
.frm_style_site-style.with_frm_style .form-field textarea:-ms-input-placeholder {
	/* Microsoft Edge */
	color: #999 !important;
}

/**
 * Forms (Search)
 */
form.search {
	position: relative;
}

form.search:before {
	font-family: 'Font Awesome 5 Pro';
	font-weight: 300;
	color: #999;
	content: "\f002";
	position: absolute;
	top: 50%;
	left: .875rem;
	transform: translateY(-50%);
}

form.search .form-control {
	padding-left: 2.5rem;
}

/**
 * Hero
 */
.hero {
	margin-top: -1px;
	max-height: 500px;
	position: relative;
	overflow: hidden;
}

/**
 * Hero (Image)
 */
.hero img {
	height: auto;
	width: 100%;
	position: relative;
}

.hero img.clip-top {
	top: 0;
}

.hero img.clip-top-10 {
	top: 10%;
	margin-bottom: -10%;
	-webkit-transform: translateY(-10%);
	transform: translateY(-10%);
}

.hero img.clip-center {
	top: 50%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}

.hero img.clip-bottom {
	top: 100%;
	-webkit-transform: translateY(-100%);
	transform: translateY(-100%);
}

/**
 * Hero (Slogan)
 */
.hero-slogan {
	color: #fff;
	text-align: center;
	text-shadow: 0 1px 1px rgb(0 0 0 / 30%);
	padding-right: .75rem;
	padding-left: .75rem;
	width: 100%;
	position: absolute;
	top: 50%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	z-index: 1;
}

/**
 * Hero (Search)
 */
.hero-search {
	margin-top: -45px;
}

.hero-search .form-control {
	padding-left: 2.5rem;
}

.hero-search .form-floating>label {
	padding-left: 2.75rem;
}

.hero-search .form-floating:before {
	font-family: 'Font Awesome 5 Pro';
	font-weight: 300;
	color: #999;
	content: "\f002";
	position: absolute;
	top: 50%;
	left: .875rem;
	transform: translateY(-50%);
}

.hero-search .form-floating.datepicker:before {
	content: "\f133";
}

/**
 * Icons (Social)
 */
.social-icon {
	display: flex !important;
	justify-content: center !important;
	align-items: center !important;
	background-color: #f5f5f5;
	border-radius: 50%;
	font-size: 1.125rem;
	min-width: 42px;
	height: 42px;
	width: 42px;
}

/**
 * Lists
 */
ul.checklist,
.checklist ul {
	list-style: none;
	margin-bottom: 0;
	padding: 0;
}

.checklist li {
	line-height: 1.65 !important;
	padding: .5rem 0 .5rem 2.5rem;
}

.checklist li:before {
	font-family: 'Font Awesome 5 Pro';
	font-weight: 900;
	content: "\f00c";
	color: #f4bb3a;
	display: inline-block;
	margin-left: -2rem;
	width: 2rem;
}

.checklist.not li:before {
	content: "\f00d";
}

/**
 * MashShare
 */
.mashsb-container {
	padding-top: 0;
	padding-bottom: 0;
}

.mashsb-box {
	display: flex;
	align-items: center !important;
}

.mashsb-count.mash-small {
	font-family: inherit;
	font-size: 1.25rem;
	font-weight: 500;
	margin-right: 1rem;
	margin-top: 5px;
}

.mashsb-sharetext {
	font-family: inherit;
	font-size: .625rem;
	color: #b7bfc6;
}

.mashsb-box .mashsb-buttons a.mash-small,
.onoffswitch.mash-small,
.onoffswitch2.mash-small {
	display: flex;
	justify-content: center !important;
	align-items: center !important;
	height: 35px;
	width: 35px;
	padding: 0;
	margin: 0 .5rem 0 0;
}

[class^=mashicon-] .icon:before {
	font-family: 'Font Awesome 5 Brands';
	font-size: .875rem;
}

.mashicon-whatsapp {
	background: #4ac959;
}

.mashicon-whatsapp .icon:before {
	font-size: 1.25rem;
	content: "\f232";
}

.mashicon-facebook {
	background: #4267b2;
}

.mashicon-facebook .icon:before {
	content: "\f39e";
}

.mashicon-twitter {
	background: #1da1f2;
}

.mashicon-twitter .icon:before {
	content: "\f099";
}

.mashicon-pinterest {
	background: #bd081c;
}

.mashicon-pinterest .icon:before {
	font-size: 1rem;
	content: "\f0d2";
}

.mashicon-linkedin {
	background: #2867b2;
}

.mashicon-linkedin .icon:before {
	content: "\f0e1";
}

.mashicon-xing {
	background: #026466;
}

.mashicon-xing .icon:before {
	content: "\f168";
}

.mashicon-mail .icon:before {
	font-family: 'Font Awesome 5 Pro';
	font-size: 1rem;
	font-weight: 900;
	content: "\f0e0";
}

.onoffswitch,
.onoffswitch2 {
	background-color: #fff;
	border: 1px solid #eee;
	color: #b7bfc6;
}

.onoffswitch:before,
.onoffswitch2:before {
	font-family: 'Font Awesome 5 Pro';
	font-size: 1rem;
	font-weight: 300;
}

.onoffswitch:before {
	content: "\f067";
}

.onoffswitch2:before {
	content: "\f068";
}

/**
 * Navbar
 */
.navbar {
	background-color: #fff;
	border-bottom: 1px solid #eee;
	min-height: 74px;
	padding-top: .875rem;
	padding-bottom: .875rem;
	-webkit-animation-duration: .5s;
	animation-duration: .5s;
}

.navbar.fixed-top {
	box-shadow: 0 .125rem .25rem rgba(0, 0, 0, .075);
}

.navbar h5 {
	font-size: .875rem;
	text-transform: uppercase;
	margin-bottom: .5rem;
}

/**
 * Nav Pills
 */
.nav-pills .nav-link {
	background-color: #fff;
	border: 1px solid rgba(0, 0, 0, .125);
	border-radius: .25rem;
	font-weight: 500;
	padding: .75rem .5rem;
}

.navbar .nav-pills .nav-link {
	padding: .75rem .5rem !important;
}

.nav-pills .nav-link:hover,
.nav-pills .nav-link:focus {
	background-color: #f5f5f5;
}

.nav-pills .nav-link.active,
.nav-pills .show>.nav-link {
	color: #fff !important;
	background-color: #3fbddf;
	border-color: #3fbddf;
}

/**
 * Offcanvas
 */
.offcanvas-header {
	border-bottom: 1px solid #dee2e6;
}

/**
 * Sharebar
 */
.sharebar {
	display: none;
	background-color: #fff;
	border-top: 1px solid #eee;
	padding: .75rem 0;
	width: 100%;
	position: fixed;
	top: 75px;
	left: 0;
}

.navbar.fixed-top:not(.collapsed) .sharebar {
	display: block;
}

.navbar.with-sharebar.fixed-top:not(.collapsed) {
	padding-bottom: calc(75px + .875rem);
}

/**
 * Slider
 */
.slider {
	margin-left: .685rem;
	margin-right: .685rem;
	width: calc(100% - 1.25rem) !important;
}

.slider-track {
	background-color: #fff;
	border: 1px solid #8bd7eb;
	background-image: none;
	filter: none;
	box-shadow: none;
}

.slider.slider-horizontal .slider-track {
	height: 8px;
	margin-top: -5px;
}

.slider-selection {
	background-color: #b2e4f2;
	background-image: none;
	filter: none;
	box-shadow: none;
}

.slider-handle {
	background-color: #3fbddf;
	border: 1px solid #fff;
	background-image: none;
	filter: none;
	box-shadow: none;
	height: 18px;
	width: 18px;
}

/*
 * Tables
 */
.table {
	color: #194b59;
	margin-bottom: 0;
}

.table>thead>tr>th {
	background-color: #f5f5f5;
	border-bottom: none;
	font-size: .875rem;
	font-weight: 500;
}

.table>thead>tr>th:first-child {
	border-top-left-radius: .25rem;
	border-bottom-left-radius: .25rem;
}

.table>thead>tr>th:last-child {
	border-top-right-radius: .25rem;
	border-bottom-right-radius: .25rem;
}

.table>tbody>tr>td,
.table>tbody>tr>th {
	font-weight: 500;
	padding: 1.5rem .5rem;
	vertical-align: middle;
}

.table>tbody>tr:last-child>td {
	border-bottom: none;
}

/*
 * Videos
 */
.ratio[data-vid] {
	cursor: pointer;
}

/**
 * Media Queries
 */
@media (min-width: 576px) {

	/* sm */
	/**
	 * Content (Tour)
	 */
	.tour-content .tour-gallery img {
		height: 137px;
	}

	/**
	 * Formidable Forms (Site Style)
	 */
	.frm_style_site-style.with_frm_style label {
		margin-top: .5rem !important;
	}
}

@media (min-width: 768px) {

	/* md */
	/**
	 * Content (Tour)
	 */
	.tour-content .tour-gallery img {
		height: 187.5px;
	}
}

@media (min-width: 992px) {

	/* lg */
	/**
	* Columns
	*/
	.columns-2 {
		column-count: 2;
		column-gap: 1rem;
	}

	.columns-3 {
		column-count: 3;
		column-gap: 1rem;
	}

	/**
	 * Content (Tour)
	 */
	.tour-content .tour-gallery img {
		height: 121.5px;
	}

	/**
	 * Navbar
	 */
	.navbar {
		padding-top: 0;
		padding-bottom: 0;
	}

	.navbar .nav-link-hover {
		padding-top: 1.625rem;
		padding-bottom: 1.625rem;
	}

	.navbar-expand-lg .navbar-nav .nav-link {
		padding-right: 1.25rem;
		padding-left: 1.25rem;
	}

	.navbar .dropdown-megamenu {
		border-top: 1px solid #eee;
		border-radius: 0;
		box-shadow: 0 .125rem .25rem rgba(0, 0, 0, .075);
		margin-top: 0;
		padding: 3rem 0;
		left: 0;
		right: 0;
		width: 100%;
	}

	/**
	 * Sharebar
	 */
	.sharebar {
		top: 74px;
	}

	.navbar.with-sharebar.fixed-top:not(.collapsed) {
		padding-bottom: 74px;
	}
}

@media (min-width: 1200px) {

	/* xl */
	/**
	 * Content (Tour)
	 */
	.tour-content .tour-gallery img {
		height: 120px;
	}
}

@media (min-width: 1400px) {

	/* xxl */
	/**
	 * Content (Tour)
	 */
	.tour-content .tour-gallery img {
		height: 125.5px;
	}

	/**
	 * Navbar
	 */
	.navbar form.search {
		min-width: 260px;
	}
}

/**
 * ========================================================================
 * Moderne Alternative für "dotdotdot.js"
 * Schneidet mehrzeiligen Text mit "..." ab.
 * ========================================================================
 */
.ellipsis {
	display: -webkit-box;
	-webkit-box-orient: vertical;
	overflow: hidden;
	text-overflow: ellipsis;
}

/* 
 * Definiert, nach wie vielen Zeilen abgeschnitten werden soll.
 * Du kannst hier verschiedene Klassen für unterschiedliche Höhen anlegen.
 * .tour-content .entry-content.ellipsis in single-reisen.php hat max-height: 380px; 
 * Basierend auf line-height: 1.7 und font-size: 1rem (16px), sind das ca. 14 Zeilen.
 */
.ellipsis-14-lines {
	line-clamp: 14;
	-webkit-line-clamp: 14;
	max-height: 380px;
	/* Muss zur Zeilenanzahl und Schriftgröße passen */
}

/* Für das Akkordeon in single-reisen.php (war höher) */
.accordion .ellipsis-44-lines {
	line-clamp: 44;
	-webkit-line-clamp: 44;
	max-height: 1200px;
}

/* ========================================================================
   "Weiterlesen" Link für ausklappbare Inhalte
   ======================================================================== */

.read-more-container {
	display: inline;
	/* Behält den Container im Textfluss */
}

.read-more-link {
	display: inline-block;
	cursor: pointer;
	color: var(--bs-link-color);
	text-decoration: underline;
	margin-top: 5px;
	color: #38aac8;
	text-decoration: none;
	white-space: nowrap;
}

.read-more-link:hover {
	color: var(--bs-link-hover-color);
}

/* Versteckt den "Weiterlesen"-Link, wenn der Inhalt ausgeklappt ist */
.read-more-link[aria-expanded="true"] {
	display: none;
}

/* ========================================================================
   Stile für das neue Termine-Modal (Version 2.1)
   ======================================================================== */
.departures-filters {
	display: flex;
	flex-direction: column;
	/* Standard: Untereinander */
	gap: 1rem;
	/* Abstand zwischen Jahr- und Monat-Gruppe */
}

.filter-group {
	display: flex;
	flex-wrap: wrap;
	/* Erlaubt Umbruch bei Platzmangel */
	gap: 0.5rem;
	/* Abstand zwischen den Buttons/Dropdowns */
}

.filter-group .btn {
	border-radius: .25rem !important;
}

.filter-group.year-group .btn {
	/* Style für Jahres-Buttons (Primary) */
	background-color: #fff;
	border-color: #3fbddf;
	color: #3fbddf;
}

.filter-group.year-group .btn.active {
	background-color: #3fbddf;
	border-color: #3fbddf;
	color: #fff;
}

.filter-group.month-group .btn {
	/* Style für Monats-Buttons (Secondary) */
	background-color: #fff;
	border-color: #dee2e6;
	color: #6c757d;
}

.filter-group.month-group .btn.active {
	background-color: #3fbddf;
	border-color: #3fbddf;
	color: #fff;
}

.departure-item {
	border-bottom: 1px solid #eee;
}

.departure-item:last-child {
	border-bottom: none;
}

/* Desktop Layout: Filter nebeneinander */
@media (min-width: 768px) {
	.departures-filters {
		flex-direction: row;
		/* Nebeneinander auf Desktops */
		align-items: center;
	}

	.filter-group.year-group {
		border-right: 1px solid #dee2e6;
		padding-right: 1rem;
	}
}

/* ========================================================================
   Formidable Forms: Eigene Stile für Fehlermeldungen
   ======================================================================== */
.frm_forms .frm_error {
	color: #dc3545 !important;
	font-weight: bold !important;
}

/* ========================================================================
   Verbesserungen für die Filter-Label
   ======================================================================== */

.filter-label {
	/* Stellt sicher, dass der Button seine Form behält */
	transition: border-color 0.2s ease-in-out;
}

.filter-label .filter-remove-icon {
	/* Macht das Icon klickbarer, ohne das Layout zu verschieben */
	padding: 5px;
	margin: -5px;
	border-radius: 50%;
	transition: transform 0.2s ease-in-out, background-color 0.2s ease-in-out;
}

/* Hover-Effekt für das "X"-Icon */
.filter-label:hover .filter-remove-icon {
	background-color: rgba(0, 0, 0, 0.1);
}

/* Hover-Effekt für den gesamten Button, wenn man über das "X" geht */
.filter-label .filter-remove-icon:hover {
	color: #dc3545;
	transform: scale(1.4);
}

.filter-label:has(.filter-remove-icon:hover) {
	border-color: #dc3545;
	/* Roter Rahmen für den ganzen Button */
	box-shadow: 0 0 0 0.25rem rgba(220, 53, 69, 0.25);
	/* Leichter roter Schein */
}

.filter-disabled label {
	text-decoration: line-through;
	color: #999;
	/* Etwas grauer, um es weniger prominent zu machen */
	cursor: not-allowed;
}

.filter-disabled {
	opacity: 0.6;
	/* Graut das Element leicht aus */
}

.filter-disabled .accordion-button {
	text-decoration: line-through;
	/* Fügt den Durchstrich hinzu */
	cursor: not-allowed;
	/* Zeigt ein "Nicht erlaubt"-Cursor-Symbol */
}