/* Floating Login Button */
.floating-login-btn {
	position: fixed;
	top: 20px;
	right: 20px;
	z-index: 1021; /* Höher als Barrierefrei-Button (1020) */
	display: block;
}

.btn-floating {
	border-radius: 50px !important;
	padding: 12px 20px !important;
	font-weight: 600;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
	transition: all 0.3s ease;
	border: none !important;
	min-width: 60px;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 8px;
	float: none !important; /* Bootstrap float überschreiben */
}

.btn-floating:hover {
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(0, 0, 0, 0.25);
}

.btn-floating i {
	font-size: 18px;
}

.btn-floating .btn-text {
	font-size: 14px;
	white-space: nowrap;
}

/* Responsive Anpassungen für Floating Button */
@media (max-width: 767.98px) {
	.floating-login-btn {
		display: none !important;
	}
	
	.btn-floating {
		padding: 10px 15px !important;
		min-width: 50px;
	}
	
	.btn-floating i {
		font-size: 16px;
	}
}

/* Mobile Navigation nur auf kleinen Bildschirmen */
@media (min-width: 768px) {
	#mobile_login_section,
	#mobile_logout_section {
		display: none !important;
	}
}

/* Floating Button nur auf größeren Bildschirmen */
@media (max-width: 767.98px) {
	.floating-login-btn {
		display: none !important;
	}
}

/* Zusätzliche Sicherheit gegen Bootstrap-Konflikte */
.floating-login-btn {
	transform: none !important;
	flex: none !important;
	order: none !important;
}

/* Container-Konflikte verhindern */
.container .floating-login-btn,
.container-fluid .floating-login-btn,
.row .floating-login-btn,
[class*="col-"] .floating-login-btn {
	position: fixed !important;
	top: 20px !important;
	right: 20px !important;
	left: auto !important;
}

/* LÖSUNG: Bootstrap Modal Scrollbar-Verrutschen komplett verhindern */
html {
	overflow-y: scroll !important; /* Scrollbar immer sichtbar */
	scrollbar-gutter: stable; /* Moderne Browser: Platz für Scrollbar reservieren */
}

/* Bootstrap Modal-Padding komplett deaktivieren */
body.modal-open {
	padding-right: 0 !important;
	overflow: hidden !important;
}

/* Floating Button braucht keine Kompensation mehr */
.floating-login-btn {
	transition: none !important; /* Keine Animation mehr nötig */
}

.display_none {
	display: none;
}

.cursor_pointer {
	cursor: pointer;
}

.regAsterisk {
	display: none;
}

.modal {
	z-index: 999999;
}

#login_mobile_btn,
#logout_mobile_btn {
	display: none;
}

#suche_hinweis {
	width: 70%;
	position: relative;
	margin: 0 auto;
	margin-top: 45px;
	text-align: center;
}

#ajax_loader {
	width: 220px;
	position: relative;
	margin: 0 auto;
	margin-top: 45px;
	display: none;
}

.clear {
	clear: both;
}

#container {
	max-width: 1170px;
	position: relative;
	margin: 0 auto;
}

#hide_no_session {
	/* Login-Status wird via JavaScript gesteuert - kein CSS display: none mehr */
	height: auto !important;
	min-height: 135px !important;
	overflow: visible !important;
}

/* Nur verstecken wenn explizit ANONYMUS */
body[data-login-mode="ANONYMUS"] #hide_no_session {
	display: none;
}

.hide_no_session_menu {
	
}

.carousel {
	margin: 0 auto;
	max-height: 274px;
	max-width: 920px;
}

#dropdown_ma_auswahl a {
	text-decoration: none;
}

/* Anpassung der Dropdown Listen Breite */
.dropdown-menu {
	width: 90%;	
}

/* Anpassung der Dropdown Kategorie Schriftgröße */
.dropdown-header {
    color: #777;
    font-weight: bold;
	font-size: 18px;
}
.field-icon {
	padding-top:10px;
}

/* Dropdown Auswahl Scrollbar machen */
.scrollable-menu {
    height: auto;
    max-height: 200px;
    overflow-x: hidden;
}

.scrollable-menu::-webkit-scrollbar {
    -webkit-appearance: none;
    width: 10px;        
}    
.scrollable-menu::-webkit-scrollbar-thumb {
    border-radius: 3px;
    background-color: lightgray;
    -webkit-box-shadow: 0 0 1px rgba(255,255,255,.75);        
}

#dropdown_taet_auswahl {
	display: block;
	width: 320px;
	position: relative;
	margin: 0 auto;
}

#dropdown_taet, #dropdown_ma_auswahl {
	max-height: 400px !important;
}

.disabled {
	background-color: #d8d8d8;
}

#sidebar_left {
  /* border: 1px solid #ccc; entfernt für volle Transparenz */
  min-height: 450px;
  padding-left: 0;
  padding-right: 0;
  /* background-color: #ffffff; entfernt für Transparenz */
  height: fit-content;
  overflow: visible;
  position: sticky;
  top: 0;
  display: block !important;
}

#sidebar_sektion_salon_adresse,
#sidebar_sektion_salon_zeiten,
#sidebar_sektion_salon_karte,
#qrcode {
	background-color: #fff !important;
}

#profil_einblenden_nav_btn,
#termine_einblenden_nav_btn,
#filter_einblenden_nav_btn {
	display: none;
}


#container_buchung {
	min-height: 680px;
	padding-left: 5px !important;
	padding-right: 5px !important;
}

.sidebar_sektion {
	padding-top: 0px;
	padding-bottom: 0px;
}

.sektion_buchung {
	margin-bottom: 35px;
}

.sektion_ueberschrift_buchung {
	width: 100%;
	color: #fff;
	background-color: #666666;
	min-height: 45px;
	padding-top: 10px;
	padding-bottom: 10px;
	text-align: center;
	border: 1px solid #E8E8E8;
	font-size: 16px; /* Gleiche Schriftgröße wie Sidebar-Header */
	display: flex;
	align-items: center;
	justify-content: flex-start;
	border-radius: 0.5rem !important;
}

.sektion_ueberschrift_buchung i {
	font-size: 1.5em;
	margin-left: 8px;
	margin-right: 0;
	display: flex;
	align-items: center;
}

.sektion_ueberschrift_buchung i.float-start {
	margin-right: 10px;
}

.sektion_ueberschrift_buchung i.float-end {
	margin-left: 10px;
	margin-right: 10px; /* Symmetrischer Abstand wie links */
}

.sektion_ueberschrift_buchung .title {
	flex-grow: 1;
	text-align: center;
	margin: 0 15px;
}

#sidebar_sektion_salon_adresse, #sidebar_sektion_salon_zeiten {
	background-color: #ffffff;	
}

#terminhistorie_container {
	max-height: 230px;
	overflow: scroll;
	overflow-x: hidden;
}

#terminhistorie_container_modal {
	max-height: 400px;
	overflow: scroll;
	overflow-x: hidden;
  font-size: 1.1rem;
}

#kalender {
	width: 100%;		/* ANPASSUNG 22.01.2021 JB */
	position:relative;
	margin: 0 auto;
	margin-top: 45px;
	display: none; /* erst nach Suche einblenden */
	font-size: 1.0em !important;
	width: 100% !important;
	table-layout: fixed !important;
	text-align: center !important;
}

#kalender thead th, #kalender {
	text-align:center;
	background-color: #ccc;
	font-size: 0.9em !important;
	padding: 4px 2px !important;
	word-wrap: break-word !important;
	white-space: normal !important;
	min-width: 0 !important;
}

#kalender tbody tr {
	display: none;
}

#kalender td {
	cursor: pointer;
	padding: 3px 1px !important;
	font-size: 0.9em !important;
	word-wrap: break-word !important;
	white-space: normal !important;
	min-width: 0 !important;
	text-align: center !important;
}

#kalender td:hover {
	/* font-weight: bold; */
	background-color: #ccc;
}

#sidebar_sektion_historie {
	border-bottom: 1px solid #ccc;
}

#sidebar_sektion_profil {
	border-bottom: 1px solid #ccc;
	padding-left: 5px;
}
#sidebar_sektion_salon_adresse a {
	text-decoration: none;
}

#sidebar_sektion_salon_adresse {
	border-bottom: 1px solid #ccc;
	padding-left: 5px;
	padding-top: 10px;
	padding-bottom: 10px;
}

#sidebar_sektion_salon_zeiten {
	padding-top: 10px;
	padding-bottom: 10px;
	padding-right: 10px;
}

#sidebar_sektion_salon_karte {
	
}

.sidebar_header {
	color: #fff;
	background-color: #666666;
	width: 100%;
	/* margin-bottom: 1px; */
	height: 45px;
	text-align:center;
	line-height: 45px;
	vertical-align: middle;
}

/* Spezielle Anpassung für die Hauptüberschrift - entfernt, da jetzt 1:1 wie user_name_box */

/* Spezielle Anpassung nur für die Hauptüberschrift */
#main_title_header {
	font-weight: bold;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 0.5rem 0.5rem 0 0 !important;
}

#main_title_header span {
	font-weight: bold;
}

.icon-lg-right {
	line-height: 45px;
	font-size: 22px;
	float:right;
	margin-right: 5px;
}

.icon-lg-left {
	line-height: 45px;
	font-size: 22px;
	float:left;
	margin-left: 5px;
}

.icon-right {
	float:right;
	margin-right: 5px;
}

.icon-small {
	font-size: 1.0em;
}

.termin_zukunft, .termin_vergangenheit {
    box-shadow: 0 2px 6px rgba(0,0,0,0.06);
    margin-bottom: 2px;
    padding: 8px 6px 8px 6px;
    display: block;
    border-radius: 0;
    border-bottom: 1px solid rgba(0,0,0,0.08);
}
.termin_mitarbeiter, .termin_taetigkeit {
    padding-left: 0;
    font-size: 12px;
    margin-bottom: 2px;
}
.termin_mitarbeiter {
    margin-top: 4px;
    font-weight: 600;
}
.termin_taetigkeit {
    font-style: italic;
}

#historie_mehr_vergangenheit, #historie_mehr_vergangenheit_modal, #ozeiten {
	color: #fff;
	background-color: #666666;
	width: 100%;
	/* margin-bottom: 1px; */
	text-align: center;
}

#historie_mehr_zukunft {
	color: #fff;
	background-color: #666666;
	width: 100%;
	margin-top: 1px;
	text-align: center;
}

#historie_minimize, #historie_minimize_modal  {
	color: #fff;
	background-color: #666666;
	width: 100%;
	margin-top: 1px;
	text-align: center;
}

.header_wide {
	width:100%;
	min-height:130px;
	/* background-image:url('/assets/example/bg_8.jpg'); */ /* die Datei gibt es bei uns nicht?! */
	background-size:cover;
}

.header_wide img {
	width: 100%;
	max-width: 375px;
}

.logo {
	color:#000000;
	font-weight:800;
	font-size:14pt;
	padding:25px;
	text-align:center;
}


.gew_taet_item, .gew_paket_item {
	width: 40%;
	position: relative;
	margin: 0 auto;
	margin-top: 25px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	text-align: left;
	font-size: 16px; /* Gleiche Schriftgröße wie Sidebar-Header */
	padding-top: 0.75rem;
	padding-bottom: 0.75rem;
}

#dropdown_ma_auswahl_neu a {
	height: 90px;
	padding-left:120px;
	background-size: 65px 65px;
	background-position: 8px center;
    	background-repeat: no-repeat;
}

.gew_ma_item {
	width: 40%;
	position: relative;
	margin: 0 auto;
	margin-top: 25px;
	display: block;
	line-height: inherit;
	border: 1px solid #ddd;
	background-color: white;
}

.ma_bild {
	margin-right: 25px;
	border-radius: 30px;
}

#gew_ma_container span.glyphicon {
	vertical-align: middle;
}

.small-font-sidebar-termine {
	font-size: 11px;
	font-weight: bold;
}

.termin_zukunft .table, .termin_vergangenheit .table {
    margin-bottom: 0 !important;
    background: transparent !important;
}

.termin_taetigkeit, .termin_mitarbeiter, .oeffnungszeiten {
	padding-left: 5px;
	font-size: 12px;
}


#termin_uhrzeit {
	margin-bottom: 7px;
}

#termin_taet {
	margin-bottom: 7px;
}

#termin_ma {
	margin-bottom: 15px;
}

/* Anpassungen JB 27.03.2015*/
.gew_taet_item .glyphicon-remove-circle, .gew_ma_item .glyphicon-remove-circle, .gew_paket_item .glyphicon-remove-circle {
    float: right;
    font-size: 22px;
/*    line-height: 0;
    margin-right: 0;
    top: -10px;*/
}
.auswahl_dl {
	width: 95%;
}

.remove_dl, .glyphicon_ma_bild {
	  margin: 0;
	  position: absolute;
	  top: 50%;
	  -ms-transform: translateY(-50%);
	  transform: translateY(-50%);
	  right: 5px;
}


/*.glyphicon_ma_bild{
    float: right !important;
    font-size: 22px !important;
    line-height: 0 !important;
    margin-right: 0 !important;
    top: 29px !important;
}*/

/* Nur Firefox */
@-moz-document url-prefix() {
	.gew_taet_item .glyphicon-remove-circle, .gew_ma_item .glyphicon-remove-circle, .gew_paket_item .glyphicon-remove-circle {
	    float: right;
	    font-size: 22px;
	    line-height: 0;
	    margin-right: 0;
	    /*top: 10px;*/
	}
/*	.glyphicon_ma_bild {
	    float: right !important;
	    font-size: 22px !important;
	    line-height: 0 !important;
	    margin-right: 0 !important;
	    top: 27px !important;
	}*/
}


#login_headline_anmeldung {
	text-align:center;
	font-size:18px;
}
#login_block {
	margin: 10px auto;
	width: 15%;
}
#headline_registrierung {
	text-align:center;
	font-size:18px;
	margin-bottom: 10px;
}
#intro_text_registrierung {
	text-align:center;

}
.inputLabel {
	float: left;
	display: inline;	
	margin-right: 5px;
}

.text-center-desktop {
	text-align:center;
}

/* ENDE Anpassungen JB 27.03.2015*/

/*@media screen and (max-width: 768px) {
    body {
        font-size:12px;
    }
}*/
@media (max-width: 1024px) {
	.small-font-sidebar-termine {
		font-size: 10px;
		font-weight: bold;
	}
	.glyphicon {
    	font-size: 1.0em;
	}
	#sidebar_sektion_salon_adresse, .oeffnungszeiten {
	font-size: 1.0em;
	}
}
 
@media screen and (max-width: 767px)  {
	body {
		 font-size:12px;
	}
	.navbar-brand {
		font-size: 14px;
	}
	.navbar-nav {
		font-size: 14px;
	}

	.modal-title {
		font-size: 14px;
	}

	#meldungModalMessage {
		font-size: 14px;
	}

	.oeffnungszeiten {
		font-size: 14px;
	}

	#ds_content {
		width: 100%;
		height: 130px;
		overflow-x: hidden;
	}
	
	#art_kommunikation_btn, #art_werbung_btn {
		white-space:normal !important;
   		 max-width:100%;
	
	}

	
	.gew_taet_item, .gew_ma_item, .gew_paket_item {
		width: 90%;
	}
	
	#sidebar_left {
		display: none;
	}
	
	#to_login_btn,
	#logout_btn {
		display: none;
	}
	
	#login_mobile_btn {
		display: block;
	}
	
	
	/* Anpassungen JB 20.04.2015*/
	
	#login_headline_anmeldung {
		text-align:center;
		font-size:12px;
	}
	
	.header_wide {
		margin-top: 10px;
	}
	
	.header_wide img {
		width:100%;
	
	}
	/* #kalender-Regel entfernt - wird jetzt durch Desktop-Media Query ersetzt */
	
	.spacer-bmobile {
		margin-bottom: 60px !important;	
	}
	.text-center-desktop {
		text-align:left;
	}
	
	#gebtag {	
		/*width:200px;*/
	
	}
	
	
	/* ENDE Anpassungen JB 20.04.2015*/
	
}


/* --- Formular: Profil bearbeiten --- */


#block_links {
	
}

#block_rechts {
	
}

#namenfeld {
	width: 100%;
	font-weight: bold;
	padding-bottom: 15px;
}

.label_sektion_profil {
	margin-top: 35px;
	margin-bottom: 10px;
}
#label_adresse {
	padding-left: 10px;	

}
.profil_input {
	width: 75%;
	margin-bottom: 3px;
}

.modal-dialog-center { /* Edited classname 10/03/2014 */
    margin: 0 AUTO;
	margin-top: 10%;
    position: relative;
	
   /* top: 50%;
    left: 50%;*/
}
#map-canvas, #location_modal  {  
	margin: 0 auto;  
	padding: 0;  
	/* height: 100%; Entfernt, da dieser Parameter die Seite unnötig groß macht */
}
#map-canvas {  
	width: 100%;  
	height: 280px;
	display: block;
	margin: 0 auto;
}
#map-canvas-sidebar {  
	margin: 0 auto;
	width: 100%;  
	height: 280px;
	display: block;
}

/* Neue CSS-Regel für das Modal-Kontakt-Karten-Container */
#map-canvas-modal-kontakt {
	width: 100%;
	height: 300px;
	display: block;
	margin: 0 auto;
}

/* Karten-Container für bessere Zentrierung */
.map_container {
	margin: 15px auto;
    width: 95%;
	text-align: center;
}

.map_container_sidebar {
	margin-top: 0 !important;
	margin-right: auto;
	margin-bottom: 0;
	margin-left: auto;
	width: 95%;
	text-align: center;
}

/* Karten-Container im Modal */
.map-container {
	margin: 10px auto;
	width: 100%;
	text-align: center;
}

.salonadresse{

	font-size: 14px;
}
#impressum_datenschutz_links_container {
	position: absolute;
	right: 3px;
	bottom: 3px;
}

#impressum_datenschutz_links_container a {
    text-decoration: none;
}

#impressum_datenschutz_links_container a:hover {
    text-decoration: underline;
}

#modal_ds_formular {
	
}

#dropdown_kommunikation {
	top: 75px;
}
#dropdown_werbung {
	top: 121px;
}


#ds_content {
	width: 100%;
	height: 235px;
	overflow-x: hidden;
	background-color: #eeeeee;
	padding: 15px;
}
#checkbox_dsgvo_label {
	padding: 10px;
	margin-top: 20px;
}


#ds_checkboxes {
	font-size: 12px;
}

#art_kommunikation {
	margin-bottom: 15px;
}

#art_kommunikation_label, #art_werbung_label  {
	padding: 10px;
	margin-bottom: 10px;
}

#art_kommunikation_label a {
	color: white;
	font-weight: bold;
	
}

#art_werbung {
	margin-bottom: 45px;
}
#checkbox_dsgvo_headline {
	margin-bottom: 5px;
	font-weight: bold;
}

#art_kommunikation_headline, #art_werbung_headline {
	font-weight: bold;
}
#art_kommunikation_subheadline, #art_werbung_subheadline {
	margin-bottom: 5px;
}

.modal-footer #agb_cbx_container {
	text-align: left!important;
	font-size: 1rem;
	line-height: 1.4;
}

#agb_cbx_container .goldenforms-pro .frm-body {

    padding-top: 10px;
    /*padding-bottom: 20px;*/
    position: relative;

}
#agb_box .frm-body {
	padding-bottom: 0px !important;
}
/* NEU 22.01.2021 JB */
#agb_cbx_container {
	padding-right: 0;
  /*	padding-left: 10 !important;  */
}

#agb_cbx_container .col-xs-12 {
	padding-left: 0 !important;
		
}


#agb_box {
	padding-left: 0;
}


#preis_display {
	font-weight: bold;
}

.popover-title{
    background: #c6e7cf;
}


/* NEU 11.02.2021 JB */

#deaktiv_message_box {

	background-color: white;
	opacity: 0.6;
	padding: 50px;
}

#titel_deaktiv_meldung {

	font-size: 50px;
	color: black;
}

#text_deaktiv_meldung {

		font-size: 20px;
}

#text_deaktiv_saloninfo {

	font-size: 16px;
}

@media only screen and (max-width: 768px) {
	#titel_deaktiv_meldung {
		font-size: 25px;
	}
	#deaktiv_message_box {
		margin-top: 50px;
		padding: 50px;
	}
}





/* Checkbox Design DS Formular*/
.form-group input[type="checkbox"] {
    display: none;
}

.form-group input[type="checkbox"] + .btn-group > label span {
    width: 20px;
	height: 20px;
}

.form-group input[type="checkbox"] + .btn-group > label span:first-child {
    display: none;
}
.form-group input[type="checkbox"] + .btn-group > label span:last-child {
    display: inline-block;   
}

.form-group input[type="checkbox"]:checked + .btn-group > label span:first-child {
    display: inline-block;
}
.form-group input[type="checkbox"]:checked + .btn-group > label span:last-child {
    display: none;   
}

/* ENDE Checkbox Design DS Formular*/


/* Loading Overlay */

html, body {
	width: 100%;
	margin: 0;
}

#loader_overlay {
	z-index: 99999;
	width: 100%;
	height: 100%;
	background-color: rgba(0, 0, 0, 0.7);
	position: absolute;
	top: 0;
	left: 0;
}

#loader {
	z-index: 99999;
	border: 16px solid #f3f3f3;
	border-radius: 50%;
	border-top: 16px solid #3498db;
	width: 120px;
	height: 120px;
	margin: 0 auto;
	margin-top: 220px;
	-webkit-animation: spin 2s linear infinite; /* Safari */
	animation: spin 2s linear infinite;
}

/* Safari */
@-webkit-keyframes spin {
	0% { -webkit-transform: rotate(0deg); }
	100% { -webkit-transform: rotate(360deg); }
}

@keyframes spin {
	0% { transform: rotate(0deg); }
	100% { transform: rotate(360deg); }
}

/* ENDE Loading Overlay */

.sektion_ueberschrift_buchung.dropdown-toggle::after {
    font-size: 1.2em;
    vertical-align: middle;
    margin-left: 0.5em;
}

#qrcode {
    margin-bottom: 0;
    padding-bottom: 1rem;
}

#qrcode img {
    max-width: 100%;
    height: auto;
}

/* Redundante gew_taet_item Definition entfernt - jetzt in der Haupt-Definition bei Zeile 460 */

.gew_taet_item .remove_dl {
    margin-left: 0.5rem;
}

.navbar-toggler {
    border: none;
    padding: 0.5rem;
    margin-right: 1rem;
}

.navbar-toggler:focus {
    box-shadow: none;
}

.navbar-toggler-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(0, 0, 0, 0.75)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

@media (max-width: 767.98px) {
    .navbar-collapse {
        background-color: #fff;
        padding: 1rem;
        box-shadow: 0 2px 5px rgba(0,0,0,0.1);
    }

    .navbar-nav {
        margin-top: 0.5rem;
    }

    .nav-item {
        margin-bottom: 0.5rem;
    }

    .nav-link {
        padding: 0.5rem 0;
        color: #333;
    }

    .nav-link i {
        margin-right: 0.5rem;
    }

    body {
        padding-top: 70px; /* Höhe der mobilen Headerbar angepasst */
    }
    
    .header_wide {
        margin-top: 70px; /* Abstand zur mobilen Headerbar angepasst */
    }
}

@media (min-width: 768px) {
    #sidebar_left {
        display: block !important;
        width: 20% !important;
        flex: 0 0 20% !important;
        max-width: 20% !important;
    }

    #container_buchung {
        width: 80% !important;
        flex: 0 0 80% !important;
        max-width: 80% !important;
    }

    .navbar-toggler {
        display: none;
    }

    body {
        padding-top: 0;
    }
}

.salon-info {
    margin-bottom: 1rem;
    font-size: 1.1rem;
}

.salon-info h6 {
    color: #333;
    margin-bottom: 1rem;
    font-size: 1.3rem;
}

.salon-info p {
    margin-bottom: 0;
    line-height: 1.6;
}

.salon-info a {
    color: #007bff;
    text-decoration: none;
}

.salon-info a:hover {
    text-decoration: underline;
}

.modal-title {
    font-size: 1.4rem;
}

/* Map-Container CSS entfernt für API13-Style */

/* Einfache Map-Canvas CSS wie in API13 - keine Konflikte */

.modal-lg {
    max-width: 800px;
}

@media (max-width: 767.98px) {
    .modal-lg {
        margin: 0.5rem;
    }
}

.oeffnungszeiten {
    font-size: 1.1rem;
    line-height: 1.6;
}

.oeffnungszeiten .row {
    margin-bottom: 0.5rem;
}

.oeffnungszeiten .col-md-5 {
    font-weight: 500;
    color: #333;
}

.oeffnungszeiten .col-md-7 {
    color: #666;
}

.salon-info .oeffnungszeiten {
    margin-top: 0.5rem;
}

.modal-title i {
    margin-right: 0.5rem;
}

/* Mobile Anpassungen für Logo - exakt wie API13 */
@media (max-width: 767px) {
	.header_wide {
		min-height: auto;
		padding: 20px 0;
	}
	
	.header_wide img {
		width: 100%;
		max-width: 200px;
	}
	
	.logo {
		padding: 0;
		text-align: center;
	}
	
	/* Mobile Terminliste Optimierung - 7 Tage nebeneinander */
	#kalender {
		font-size: 1.1em !important;
		width: 100% !important;
		table-layout: fixed !important;
		margin: 0 auto !important;
		text-align: center !important;
	}
	
	#kalender thead th {
		font-size: 1.0em !important;
		padding: 8px 2px !important;
		word-wrap: break-word !important;
		white-space: normal !important;
		min-width: 0 !important;
		text-align: center !important;
		height: 40px !important;
		line-height: 1.2 !important;
	}
	
	#kalender td {
		padding: 8px 1px !important;
		font-size: 1.0em !important;
		word-wrap: break-word !important;
		white-space: normal !important;
		min-width: 0 !important;
		text-align: center !important;
		height: 35px !important;
		line-height: 1.2 !important;
	}
	
	/* Kompakte Darstellung für mobile Termine */
	#kalender .icon-small {
		font-size: 1.1em !important;
	}
	
	/* Container-Ränder für Terminliste reduzieren */
	#container_buchung {
		padding-left: 5px !important;
		padding-right: 5px !important;
		text-align: center !important;
	}
}

/* Safari-spezifische Anpassungen für symmetrische Abstände */
@supports (-webkit-appearance: none) {
	@media (max-width: 767px) {
		.header_wide {
			padding-top: 20px !important;
			padding-bottom: 20px !important;
			margin-top: 15px !important;
			margin-bottom: 15px !important;
		}
		
		/* Safari Container Reset */
		.header_wide .container {
			margin: 0 !important;
			padding: 0 !important;
		}
		
		/* Verhindert horizontales Scrollen in Safari */
		body {
			overflow-x: hidden !important;
			width: 100% !important;
			max-width: 100vw !important;
			position: relative !important;
		}
		
		html {
			overflow-x: hidden !important;
			width: 100% !important;
		}
		
		/* Container-Breite begrenzen */
		.container, .container-xxl {
			max-width: 100% !important;
			overflow-x: hidden !important;
			padding-left: 15px !important;
			padding-right: 15px !important;
		}
		
		/* Row-Breite begrenzen */
		.row {
			margin-left: 0 !important;
			margin-right: 0 !important;
			max-width: 100% !important;
			overflow-x: hidden !important;
		}
		
		/* Alle Spalten begrenzen */
		[class*="col-"] {
			max-width: 100% !important;
			overflow-x: hidden !important;
		}
		
		/* Header-Bereich begrenzen */
		#header, .header_wide {
			max-width: 100% !important;
			overflow-x: hidden !important;
		}
		
		/* Logo-Container begrenzen */
		.logo {
			max-width: 100% !important;
			overflow-x: hidden !important;
		}
	}
}

/* Desktop-spezifische Anpassungen für Kalender */
@media screen and (min-width: 992px) {
	#kalender {
		font-size: 1.0em !important;
		margin-left: 0 !important;
		margin-right: 0 !important;
	}
	
	#kalender thead th {
		font-size: 1.0em !important;
		padding: 5px 2px !important;
	}
	
	#kalender td {
		font-size: 1.0em !important;
		padding: 4px 2px !important;
	}
}

/* DSGVO Modal - Interaktive Kacheln */
.dsgvo-tile {
    background: #f5f5f5 !important;
    border-color: #ccc !important;
    color: #888 !important;
    transition: background 0.2s, border-color 0.2s, color 0.2s;
}
.dsgvo-tile .fas {
    color: #888 !important;
    transition: color 0.2s;
}
.dsgvo-tile.selected {
    background: #e7f1fb !important;
    border-color: #0d6efd !important;
    color: #0d6efd !important;
}
.dsgvo-tile.selected .fas {
    color: #0d6efd !important;
}
.dsgvo-tile:hover {
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.dsgvo-tile.selected {
	border-color: #0d6efd !important;
	background-color: #e7f3ff;
}

.dsgvo-tile.selected.kommunikation {
	border-color: #0dcaf0 !important;
	background-color: #e5f9fc;
}

.dsgvo-tile.selected.marketing {
	border-color: #198754 !important;
	background-color: #e8f5e8;
}

.dsgvo-tile .form-check-input {
	display: none; /* Checkbox verstecken */
}

/* Icons standardmäßig grau */
.dsgvo-tile .fas {
	transition: all 0.3s ease;
	color: #6c757d !important; /* Grau für unausgewählte Kacheln */
	transform: scale(1);
}

/* Icons werden farbig wenn Kachel ausgewählt */
.dsgvo-tile.selected .fas {
	transform: scale(1.1);
}

.dsgvo-tile.selected.kommunikation .fas {
	color: #0dcaf0 !important; /* Cyan für Kommunikation */
}

.dsgvo-tile.selected.marketing .fas {
	color: #198754 !important; /* Grün für Marketing */
}

/* Text wird auch farbig bei Auswahl */
.dsgvo-tile.selected.kommunikation strong {
	color: #0dcaf0 !important;
}

.dsgvo-tile.selected.marketing strong {
	color: #198754 !important;
}

/* Feste Kachel-Breiten für einheitliche Darstellung */
.dsgvo-tiles-container .col-md-4,
.dsgvo-tiles-container [class*="col-"] {
	flex: 0 0 33.333333% !important;
	max-width: 33.333333% !important;
	width: 33.333333% !important;
}

/* Spezifische IDs für Marketing-Container */
#mar_mail_container,
#mar_sms_container,
#mar_post_container,
#tg_mail_container,
#tg_sms_container,
#tg_post_container {
	flex: 0 0 33.333333% !important;
	max-width: 33.333333% !important;
	width: 33.333333% !important;
}

@media (max-width: 767.98px) {
	.dsgvo-tiles-container .col-md-4,
	.dsgvo-tiles-container [class*="col-"],
	#mar_mail_container,
	#mar_sms_container,
	#mar_post_container,
	#tg_mail_container,
	#tg_sms_container,
	#tg_post_container {
		flex: 0 0 100% !important;
		max-width: 100% !important;
		width: 100% !important;
	}
}

/* Versteckte Container behalten ihren Platz */
.dsgvo-tiles-container .col-md-4:not([style*="display: none"]) {
	visibility: visible;
}

.dsgvo-tiles-container .col-md-4[style*="display: none"] {
	visibility: hidden !important;
	display: block !important; /* Überschreibt display: none */
}

/* Alternative: Versteckte Container mit opacity */
#mar_mail_container.hidden,
#mar_sms_container.hidden,
#mar_post_container.hidden,
#tg_mail_container.hidden,
#tg_sms_container.hidden,
#tg_post_container.hidden {
	opacity: 0 !important;
	pointer-events: none !important;
	visibility: hidden !important;
}

.terminblock {
    padding: 6px 0 4px 10px;
    margin: 0;
    border-bottom: 1px solid #fff !important;
    display: block;
    background: none;
    transition: background 0.2s;
}
.terminblock:last-child {
    border-bottom: none;
}
.terminblock-header {
    font-size: 13px;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 2px;
}
.terminblock-header i {
    font-size: 1.1em;
    opacity: 0.7;
}
.terminblock-uhrzeit {
    font-weight: 600;
    margin-left: 8px;
    font-size: 12px;
    color: inherit;
    opacity: 0.85;
    display: flex;
    align-items: center;
    gap: 3px;
}
.terminblock-mitarbeiter {
    font-size: 12px;
    color: inherit;
    display: flex;
    align-items: center;
    gap: 5px;
    margin-bottom: 1px;
}
.terminblock-mitarbeiter i {
    font-size: 1.2em;
    opacity: 0.7;
    font-weight: 600;
    color: inherit;
    display: inline-flex;
    margin-right: 6px;
}
.terminblock-taetigkeit {
    font-size: 11px;
    color: inherit;
    font-style: italic;
    margin-left: 18px;
    margin-bottom: 1px;
}
.terminblock-btns {
    margin-right: 8px !important;
}
.termin_suche_vorlage_btn, .termin_bearbeiten_btn {
    font-size: 1.1em !important;
    opacity: 0.7;
    font-weight: 600;
    color: inherit;
    cursor: pointer;
}
.termin_suche_vorlage_btn:hover, .termin_bearbeiten_btn:hover {
    opacity: 1;
}

/* Moderner, schmaler Scrollbalken für Terminliste */
#terminhistorie_container, #terminhistorie_container_modal {
    scrollbar-width: thin;
    scrollbar-color: #bdbdbd #f5f5f5;
}
#terminhistorie_container::-webkit-scrollbar, #terminhistorie_container_modal::-webkit-scrollbar {
    width: 7px;
    background: #f5f5f5;
    border-radius: 6px;
}
#terminhistorie_container::-webkit-scrollbar-thumb, #terminhistorie_container_modal::-webkit-scrollbar-thumb {
    background: #bdbdbd;
    border-radius: 6px;
}
#terminhistorie_container::-webkit-scrollbar-thumb:hover, #terminhistorie_container_modal::-webkit-scrollbar-thumb:hover {
    background: #888;
}

.terminblock-header i,
.terminblock-uhrzeit i {
    font-size: 1.1em;
    opacity: 0.7;
    font-weight: 600;
    color: inherit;
    display: inline-flex;
    margin-right: 6px;
}

/* Scrollbare Dropdown-Menüs für Filter */
.scrollable-dropdown {
	max-height: 200px;
	overflow-y: auto;
	overflow-x: hidden;
	/* Bessere Sichtbarkeit gegen weißen Hintergrund */
	border: 1px solid #dee2e6 !important;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
	background-color: #ffffff;
	border-radius: 0.375rem;
}

/* Dropdown-Items Hover-Effekt */
.scrollable-dropdown .dropdown-item:hover {
	background-color: #f8f9fa;
}

/* Aktive Dropdown-Items */
.scrollable-dropdown .dropdown-item.active {
	background-color: #0d6efd;
	color: white;
}

.scrollable-dropdown::-webkit-scrollbar {
	width: 6px;
}

.scrollable-dropdown::-webkit-scrollbar-track {
	background: #f1f1f1;
	border-radius: 3px;
}

.scrollable-dropdown::-webkit-scrollbar-thumb {
	background: #c1c1c1;
	border-radius: 3px;
}

.scrollable-dropdown::-webkit-scrollbar-thumb:hover {
	background: #a8a8a8;
}

/* Filter Modal kompakter gestalten */
#modalFilter .modal-body {
	padding: 1rem;
}

#modalFilter .dropdown-toggle {
	font-size: 0.875rem;
	padding: 0.375rem 0.75rem;
}

/* Dropdown-Buttons etwas hervorheben */
#modalFilter .dropdown-toggle {
	border: 1px solid #ced4da;
	background-color: #fff;
}

#modalFilter .dropdown-toggle:focus {
	border-color: #86b7fe;
	box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.25);
}

/* Mouseover-Effekt für Dropdown-Buttons entfernen */
#modalFilter .dropdown-toggle:hover {
	background-color: #fff !important;
	border-color: #ced4da !important;
	color: #212529 !important;
}

/* Auch für den aktiven/gedrückten Zustand */
#modalFilter .dropdown-toggle:active,
#modalFilter .dropdown-toggle.show {
	background-color: #fff !important;
	border-color: #ced4da !important;
	color: #212529 !important;
	box-shadow: none !important;
}

/* PayPal Integration Styles */
#paypal_error {
    font-weight: bold !important;
    color: #dc3545;
}

#buchung_icon_container {
    min-height: 150px;
    padding-top: 35px;
}

#buchung_spinner {
    font-size: 75px;
    color: #007bff;
}

#buchung_success {
    text-align: center;
    color: #28a745;
    clear: both;
}

#paypal_problem {
    text-align: center;
    color: #dc3545;
    clear: both;
}

#buchung_success img {
    width: 75px;
}

#paypal_problem img {
    width: 60px;
}

#buchung_success_texte {
    min-height: 80px; /* Einheitliche Höhe für Text-Container */
}

#buchung_success_text_1, #paypal_success_text_1 {
    margin-top: 15px;
    margin-bottom: 30px;
    font-size: 1.5em;
    min-height: 60px; /* Feste Höhe für Loading-Texte */
}

#buchung_success_text_2, #paypal_success_text_2 {
    margin-top: 15px;
    margin-bottom: 30px;
    font-size: 1.5em;
    min-height: 60px; /* Feste Höhe für Success-Texte */
}

#buchung_success_text_1 i, #paypal_success_text_1 i {
    font-size: 40px;
}

/* PayPal Button Container Styling */
#paypal-button-container {
    margin: 15px 0;
    border-radius: 8px;
    overflow: hidden;
}

/* Moderne Termindetails-Darstellung - kompakt */
.termindetails-row {
    padding: 6px 0;
    border-bottom: 1px solid #e9ecef;
}

.termindetails-row:last-child {
    border-bottom: none;
}

.termindetails-label {
    font-weight: 600;
    color: #6c757d;
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 6px 0;
    margin-bottom: 2px;
}

.termindetails-value {
    font-weight: 500;
    color: #212529;
    padding: 6px 0;
    margin-bottom: 2px;
}

.termindetails-icon {
    color: #0d6efd !important;
    font-size: 1em;
}

/* Spezifische Regel für alle Bootstrap Icons im Modal Termindetails */
#modalTermindetails .termindetails-label i,
#modalTermindetails .termindetails-label .bi {
    color: #0d6efd !important;
}

/* Grid-Anpassung für kompaktere Darstellung */
#modalTermindetails .row.g-2 {
    --bs-gutter-y: 0.25rem;
}

/* Preis-Display Enhancement */
#preis_display {
    background: linear-gradient(135deg, #e3f2fd 0%, #f8f9fa 100%);
    border: 1px solid #dee2e6;
    border-radius: 8px;
    padding: 15px;
    margin: 15px 0;
}

#preis_info {
    font-weight: 600;
    color: #495057;
}

#term_preis {
    font-weight: 700;
    font-size: 1.1em;
    color: #212529;
}

/* Modal Footer Enhancements */
.modal-footer .form-check-label {
    font-size: 1rem;
    line-height: 1.4;
}

.modal-footer .form-check-label a {
    color: #007bff;
    text-decoration: none;
}

.modal-footer .form-check-label a:hover {
    text-decoration: underline;
}

/* Success/Error States */
.booking-state-success {
    background: #d4edda;
    border: 1px solid #c3e6cb;
    border-radius: 8px;
    padding: 20px;
    margin: 15px 0;
}

.booking-state-error {
    background: linear-gradient(135deg, #f8d7da 0%, #f8f9fa 100%);
    border: 1px solid #f5c6cb;
    border-radius: 8px;
    padding: 20px;
    margin: 15px 0;
}

/* Loading Animation Enhancement */
#buchung_spinner {
    animation: spin 2s linear infinite;
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

/* Responsive Adjustments */
@media (max-width: 576px) {
    .termindetails-label,
    .termindetails-value {
        text-align: center !important;
    }
    
    #paypal-button-container {
        margin: 10px 0;
    }
    
    #preis_display {
        padding: 10px;
        margin: 10px 0;
    }
}

/* Buchung Bemerkungsfeld Anpassung */
#buchung_bemerkung {
    height: 45px !important;
    min-height: 45px;
}

/* Success-Modal: Nur grüner Bereich ohne Padding */
#modalTermindetails.success-only .modal-body {
    padding: 0 !important;
}

#modalTermindetails.success-only .modal-content {
    border: none !important;
    border-radius: 0.375rem !important;
    overflow: hidden;
}

#modalTermindetails.success-only .booking-state-success {
    border-radius: 0.375rem !important; /* Rounded corners für den Success-Block */
    margin: 0 !important; /* Kein Margin */
    border: none !important; /* Kein Border */
    background: #d4edda !important;
}

.skip-link {
    position: absolute;
    left: -999px;
    top: 0;
    width: 1px;
    height: 1px;
    overflow: hidden;
    z-index: 9999;
    background: #007bff;
    color: #fff;
    padding: 12px 20px;
    font-weight: bold;
    text-decoration: none;
    border-radius: 0 0 8px 8px;
    font-size: 16px;
    line-height: 1;
}
.skip-link:focus {
    left: 20px;
    top: 20px;
    width: auto;
    height: auto;
    box-shadow: 0 4px 12px rgba(0,0,0,0.25);
    outline: 3px solid #fff;
    outline-offset: 2px;
}

/* Barrierefreiheit für Dropdowns - Tab-Navigation */
.dropdown-item:focus {
	background-color: #e9ecef !important;
	outline: none !important;
	border-radius: 0.375rem;
}

.dropdown-item[aria-disabled="true"] {
	color: #6c757d !important;
	pointer-events: none !important;
	background-color: transparent !important;
}

/* Dropdown-Struktur für bessere Barrierefreiheit */
.dropdown-menu li {
	list-style: none;
}

.dropdown-menu .dropdown-item {
	display: block;
	width: 100%;
	padding: 0.375rem 1rem;
	clear: both;
	font-weight: 400;
	color: #212529;
	text-align: inherit;
	text-decoration: none;
	white-space: nowrap;
	background-color: transparent;
	border: 0;
	border-radius: 0;
	transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out;
}

.dropdown-menu .dropdown-item:hover,
.dropdown-menu .dropdown-item:focus {
	color: #1e2125;
	background-color: #e9ecef;
}

/* Spezielle Styles für Dienstleistungs- und Mitarbeiter-Dropdowns */
#dropdown_taet .dropdown-item,
#dropdown_ma_auswahl .dropdown-item {
	cursor: pointer;
}

#dropdown_taet .dropdown-item:focus,
#dropdown_ma_auswahl .dropdown-item:focus {
	outline: none;
	background-color: #e9ecef;
}

/* Disabled State für Dropdown-Items */
.dropdown-item.disabled,
.dropdown-item:disabled {
	color: #adb5bd;
	pointer-events: none;
	background-color: transparent;
}

#dropdown_ma_auswahl .dropdown-item.active,
#dropdown_ma_auswahl .dropdown-item[aria-selected="true"] {
    background-color: #e9ecef !important;
}

.gew_ma_item .dropdown-item:focus {
    background-color: transparent !important;
    outline: none !important;
}

/* Accessibility Mode Button */
.floating-accessibility-btn {
	position: fixed;
	top: 20px;
	/* right: 250px;  Entfernt, wird jetzt dynamisch gesetzt */
	z-index: 1020;
	display: block;
	transition: right 0.2s;
}
.floating-accessibility-btn.dynamic-right {
	right: var(--accessibility-btn-right, 250px);
}

.btn-floating-accessibility {
	border-radius: 50px !important;
	padding: 10px 20px !important; /* Padding wie .btn-floating */
	font-weight: 600;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
	transition: all 0.3s ease;
	border: none !important;
	min-width: 60px;
	min-height: 45px; /* Höhe wie .btn-floating */
	height: 45px; /* explizite Höhe wie .btn-floating */
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 8px;
	float: none !important;
	background: rgba(255, 255, 255, 0.95);
	color: #6c757d;
	backdrop-filter: blur(10px);
}

.btn-floating-accessibility:hover {
	background: #6c757d;
	color: white;
	transform: translateY(-2px);
	box-shadow: 0 6px 16px rgba(0, 0, 0, 0.2);
}

.btn-floating-accessibility:focus {
	outline: none;
	box-shadow: 0 0 0 3px rgba(108, 117, 125, 0.3);
}

.btn-floating-accessibility.active {
	background: #28a745;
	border-color: #28a745;
	color: white;
}

.btn-floating-accessibility.active:hover {
	background: #218838;
	border-color: #218838;
}

.btn-floating-accessibility i {
	font-size: 1.4em;
	margin-right: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 24px;
	height: 24px;
}

/* Responsive Anpassungen für Accessibility Button */
@media (max-width: 1199px) {
	.btn-floating-accessibility {
		padding: 10px 15px !important;
		min-width: 50px;
	}
}

@media (max-width: 991px) {
	.btn-floating-accessibility {
		padding: 10px 15px !important;
		min-width: 50px;
	}
}

@media (max-width: 767.98px) {
	.btn-floating-accessibility {
		padding: 10px 15px !important;
		min-width: 50px;
	}
	
	/* Auf mobilen Geräten ausblenden, da wir Shortcuts in der Headerbar haben */
	.floating-accessibility-btn {
		display: none !important;
	}
}

/* Accessibility Mode Styles */
body.accessibility-mode {
	--bs-dropdown-link-color: #000 !important;
	--bs-dropdown-link-hover-color: #000 !important;
	--bs-dropdown-link-active-color: #000 !important;
	--bs-dropdown-link-hover-bg: #e9ecef !important;
	--bs-dropdown-link-active-bg: #e9ecef !important;
	--bs-dropdown-bg: #fff !important;
	--bs-dropdown-border-color: #000 !important;
	--bs-dropdown-box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15) !important;
}

body.accessibility-mode .sidebar_header {
	color: #000 !important;
	background-color: #fff !important;
}

body.accessibility-mode .sidebar_header span,
body.accessibility-mode .sidebar_header i {
	color: #000 !important;
}

body.accessibility-mode .sidebar_sektion {
	color: #000 !important;
	background-color: #fff !important;
}

body.accessibility-mode #ozeiten {
	color: #000 !important;
	background-color: #fff !important;
	border: 1px solid #000 !important;
}

body.accessibility-mode .sektion_ueberschrift_buchung {
	color: #000 !important;
	background-color: #fff !important;
	border: 1px solid #000 !important;
	border-radius: 0.5rem !important;
}

body.accessibility-mode .sektion_ueberschrift_buchung .title {
	color: #000 !important;
}

body.accessibility-mode .sektion_ueberschrift_buchung i {
	color: #000 !important;
}

body.accessibility-mode .dropdown-menu {
	background-color: #fff !important;
	border: 2px solid #000 !important;
	color: #000 !important;
}

body.accessibility-mode .dropdown-item {
	color: #000 !important;
	background-color: #fff !important;
}

body.accessibility-mode .dropdown-item:hover,
body.accessibility-mode .dropdown-item:focus {
	color: #000 !important;
	background-color: #e9ecef !important;
	text-decoration: underline !important;
}

body.accessibility-mode #dropdown_ma_auswahl {
	background-color: #fff !important;
	border: 2px solid #000 !important;
}

body.accessibility-mode #dropdown_ma_auswahl .dropdown-item {
	color: #000 !important;
	background-color: #fff !important;
}

body.accessibility-mode #dropdown_ma_auswahl .dropdown-item:hover,
body.accessibility-mode #dropdown_ma_auswahl .dropdown-item:focus {
	color: #000 !important;
	background-color: #e9ecef !important;
	text-decoration: underline !important;
}

body.accessibility-mode #dropdown_ma_auswahl .dropdown-item.active,
body.accessibility-mode #dropdown_ma_auswahl .dropdown-item:active {
	color: #000 !important;
	background-color: #e9ecef !important;
	text-decoration: underline !important;
}

body.accessibility-mode #dropdown_taet {
	background-color: #fff !important;
	border: 2px solid #000 !important;
}

body.accessibility-mode #dropdown_taet .dropdown-item {
	color: #000 !important;
	background-color: #fff !important;
}

body.accessibility-mode #dropdown_taet .dropdown-item:hover,
body.accessibility-mode #dropdown_taet .dropdown-item:focus {
	color: #000 !important;
	background-color: #e9ecef !important;
	text-decoration: underline !important;
}

body.accessibility-mode #dropdown_taet .dropdown-item.active,
body.accessibility-mode #dropdown_taet .dropdown-item:active {
	color: #000 !important;
	background-color: #e9ecef !important;
	text-decoration: underline !important;
}

body.accessibility-mode .sektion_ueberschrift_buchung {
	color: #000 !important;
	background-color: #fff !important;
	border: 1px solid #000 !important;
	border-radius: 0.75rem !important;
}

body.accessibility-mode .sektion_ueberschrift_buchung .title {
	color: #000 !important;
}

body.accessibility-mode .sektion_ueberschrift_buchung i {
	color: #000 !important;
}

body.accessibility-mode .terminblock {
	color: #000 !important;
	background-color: #fff !important;
	border: 1px solid #000 !important;
}

body.accessibility-mode #impressum_datenschutz_links_container {
	color: #000 !important;
	background-color: #fff !important;
}

body.accessibility-mode #impressum_datenschutz_links_container a {
	color: #000 !important;
	text-decoration: underline !important;
	background-color: #fff !important;
}

/* Accessibility Notifications */
.accessibility-notification {
	animation: slideInRight 0.3s ease;
}

.accessibility-notification .notification-content {
	display: flex;
	align-items: center;
	gap: 10px;
}

.accessibility-notification i {
	font-size: 1.2em;
	flex-shrink: 0;
}

@keyframes slideInRight {
	from {
		opacity: 0;
		transform: translateX(100%);
	}
	to {
		opacity: 1;
		transform: translateX(0);
	}
}

/* Floating Login/Logout Button oben rechts */

#ozeiten {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 45px;
	line-height: 45px;
	text-align: center;
}

/* Kalender-Tabelle im Accessibility-Mode */
body.accessibility-mode #kalender {
	background-color: #fff !important;
	border: 2px solid #000 !important;
}

body.accessibility-mode #kalender thead th {
	background-color: #000 !important;
	color: #fff !important;
	border: 1px solid #000 !important;
	font-weight: bold !important;
}

body.accessibility-mode #kalender tbody tr:nth-child(even) {
	background-color: #fff !important;
}

body.accessibility-mode #kalender tbody tr:nth-child(odd) {
	background-color: #f0f0f0 !important;
}

body.accessibility-mode #kalender td {
	color: #000 !important;
	border: 1px solid #000 !important;
	background-color: transparent !important;
}

body.accessibility-mode #kalender td:hover {
	background-color: #e9ecef !important;
	color: #000 !important;
	font-weight: bold !important;
}

body.accessibility-mode #kalender td.kalender_buchbar {
	background-color: #fff !important;
	color: #000 !important;
	border: 2px solid #000 !important;
}

body.accessibility-mode #kalender td.kalender_buchbar:hover {
	background-color: #e9ecef !important;
	color: #000 !important;
	font-weight: bold !important;
}

body.accessibility-mode #kalender td i {
	color: #000 !important;
}

body.accessibility-mode #kalender td.kalender_buchbar i {
	color: #000 !important;
}

/* Zusätzliche Bootstrap CSS-Variablen Überschreibungen */

body.accessibility-mode #kalender tbody tr:hover td {
	background-color: #e9ecef !important;
	font-weight: bold !important;
}

/* Modals im Accessibility-Mode */
body.accessibility-mode .modal-content {
	background-color: #fff !important;
	border: 2px solid #000 !important;
}

body.accessibility-mode .modal-header {
	background-color: #000 !important;
	color: #fff !important;
	border-bottom: 2px solid #000 !important;
}

body.accessibility-mode .modal-title {
	color: #fff !important;
	font-weight: bold !important;
}

body.accessibility-mode .modal-body {
	background-color: #fff !important;
	color: #000 !important;
}

body.accessibility-mode .modal-footer {
	background-color: #f8f9fa !important;
	border-top: 2px solid #000 !important;
}

body.accessibility-mode .btn-close {
	filter: invert(1) !important;
}

body.accessibility-mode .salon-info h6 {
	color: #000 !important;
	font-weight: bold !important;
}

body.accessibility-mode .salon-info p {
	color: #000 !important;
}

body.accessibility-mode .salon-info a {
	color: #000 !important;
	text-decoration: underline !important;
}

body.accessibility-mode .oeffnungszeiten {
	color: #000 !important;
	background-color: #fff !important;
}

/* Fix für sidebar_sektion_salon_zeiten Container im Barrierefrei-Modus */
body.accessibility-mode #sidebar_sektion_salon_zeiten {
	box-sizing: border-box !important;
	max-width: 100% !important;
	overflow: hidden !important;
	word-wrap: break-word !important;
}

/* Mobile Navigation */
.navbar.navbar-expand-sm {
	z-index: 1050;
}

/* Mobile Login Shortcut Button - Icon-Wechsel */
#mobile_login_shortcut i {
	transition: all 0.3s ease;
}

#mobile_login_shortcut:hover i {
	transform: scale(1.1);
}

/* Mobile Login Modal Tabs Optimierung */
@media (max-width: 767.98px) {
	/* Login Modal Tabs kompakter machen */
	#modalLogin .nav-tabs {
		flex-wrap: nowrap;
		border-bottom: 2px solid #dee2e6;
		justify-content: flex-start;
		gap: 0;
	}
	
	#modalLogin .nav-tabs .nav-item {
		flex: 0 0 auto;
		min-width: 0;
		margin-right: 0;
	}
	
	#modalLogin .nav-tabs .nav-link {
		padding: 8px 12px;
		font-size: 12px;
		white-space: nowrap;
		overflow: hidden;
		text-overflow: ellipsis;
		border: none;
		border-radius: 0;
		background-color: #f8f9fa;
		color: #6c757d;
		text-align: center;
		display: flex;
		flex-direction: column;
		align-items: center;
		gap: 2px;
		height: auto;
		min-height: 60px;
		margin-right: 0;
		border-right: 1px solid #dee2e6;
	}
	
	#modalLogin .nav-tabs .nav-link:last-child {
		border-right: none;
	}
	
	#modalLogin .nav-tabs .nav-link i {
		font-size: 14px;
		margin-bottom: 2px;
	}
	
	#modalLogin .nav-tabs .nav-link.active {
		background-color: #0d6efd !important; /* Exakt Bootstrap 5 btn-primary Farbe */
		color: #fff !important;
		border-bottom: 3px solid #0b5ed7 !important; /* Bootstrap 5 btn-primary hover Farbe */
	}
	
	#modalLogin .nav-tabs .nav-link:hover {
		background-color: #0b5ed7 !important; /* Bootstrap 5 btn-primary hover Farbe */
		color: #fff !important;
	}
	
	#modalLogin .nav-tabs .nav-link.active:hover {
		background-color: #0b5ed7 !important; /* Bootstrap 5 btn-primary hover Farbe */
		color: #fff !important;
	}
	
	/* Tab-Inhalte anpassen */
	#modalLogin .modal-body {
		padding: 15px;
	}
	
	#modalLogin .modal-footer {
		padding: 10px 15px;
	}
	
	/* Formular-Felder kompakter */
	#modalLogin .form-label {
		font-size: 14px;
		margin-bottom: 5px;
	}
	
	#modalLogin .input-group {
		margin-bottom: 15px;
	}
	
	#modalLogin .input-group-text {
		font-size: 14px;
		padding: 8px 12px;
	}
	
	#modalLogin .form-control {
		font-size: 14px;
		padding: 8px 12px;
	}
	
	/* Buttons kompakter */
	#modalLogin .btn {
		font-size: 14px;
		padding: 8px 16px;
	}
	
	/* Text kleiner */
	#modalLogin .text-muted {
		font-size: 13px;
		line-height: 1.4;
	}
	
	/* Modal-Dialog anpassen */
	#modalLogin .modal-dialog {
		margin: 10px;
		max-width: calc(100% - 20px);
	}
}

/* Sehr kleine Bildschirme (iPhone SE etc.) */
@media (max-width: 375px) {
	#modalLogin .nav-tabs .nav-link {
		font-size: 11px;
		padding: 6px 2px;
		min-height: 55px;
	}
	
	#modalLogin .nav-tabs .nav-link i {
		font-size: 12px;
	}
	
	#modalLogin .modal-body {
		padding: 10px;
	}
	
	#modalLogin .modal-footer {
		padding: 8px 10px;
	}
}

/* Accessibility Mode für Login Modal */
body.accessibility-mode #modalLogin .nav-tabs .nav-link {
	background-color: #fff !important;
	color: #000 !important;
	border: 2px solid #000 !important;
}

body.accessibility-mode #modalLogin .nav-tabs .nav-link.active {
	background-color: #000 !important;
	color: #fff !important;
	border-bottom: 3px solid #000 !important;
}

body.accessibility-mode #modalLogin .nav-tabs .nav-link:hover {
	background-color: #f0f0f0 !important;
	color: #000 !important;
}

/* Explizite Sidebar-Ausblendung für mobile Geräte */
@media (max-width: 767.98px) {
	#sidebar_left {
		display: none !important;
	}
	
	#container_buchung {
		width: 100% !important;
		max-width: 100% !important;
		flex: 0 0 100% !important;
	}
}

/* Zusätzliche Sicherheit für sehr kleine Bildschirme */
@media (max-width: 575.98px) {
	#sidebar_left {
		display: none !important;
	}
}

/* Mobile Header Bar Styles (wie dkb.de) - nur für mobile Geräte */
@media (max-width: 767.98px) {
    .mobile-header {
        box-shadow: 0 2px 4px rgba(0,0,0,0.1);
        z-index: 10001 !important; /* Höher als Menu (9999) und Backdrop (9998) */
        padding: 0.75rem 0; /* Padding erhöht für größere Buttons */
        background: #fff !important;
        position: fixed;
        top: 0;
        left: 0;
        right: 0;
    }

    /* Content-Padding für mobile Headerbar */
    body {
        padding-top: 70px; /* Höhe der mobilen Headerbar angepasst */
    }
    
    .header_wide {
        margin-top: 70px; /* Abstand zur mobilen Headerbar angepasst */
    }

    .mobile-header .container-fluid {
        padding-left: 1rem;
        padding-right: 1rem;
        display: flex;
        align-items: center;
        justify-content: space-between;
    }

    /* Burger Button Styling */
    .mobile-burger-btn {
        background: transparent !important;
        border: none !important;
        padding: 0.5rem !important;
        border-radius: 4px !important;
        transition: all 0.3s ease !important;
        position: relative !important;
        z-index: 10000 !important; /* Über allem anderen */
    }

    .mobile-burger-btn:hover,
    .mobile-burger-btn:focus {
        background: rgba(0,0,0,0.1) !important;
        box-shadow: none !important;
        outline: none !important;
    }

    /* Burger Button AKTIV Zustand */
    .mobile-burger-btn[aria-expanded="true"] {
        background: rgba(0,0,0,0.1) !important;
        transform: rotate(90deg) !important; /* Leichte Rotation für aktiven Zustand */
    }

    .mobile-burger-btn[aria-expanded="true"]:hover {
        background: rgba(0,0,0,0.15) !important;
    }

    .mobile-burger-btn .navbar-toggler-icon {
        background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%2833, 37, 41, 0.75%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") !important;
        transition: all 0.3s ease !important;
    }

    /* Burger Icon AKTIV Zustand - Dunkleres Icon */
    .mobile-burger-btn[aria-expanded="true"] .navbar-toggler-icon {
        background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%2833, 37, 41, 1%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='3' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") !important;
    }

    .mobile-salon-name {
        font-weight: 600;
        font-size: 1.125rem;
        color: #333;
        margin: 0;
        padding: 0 1rem;
        flex: 1;
        text-align: center;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        line-height: 1.2;
    }

    /* Mobile Shortcuts Container */
    .mobile-shortcuts {
        display: flex;
        gap: 0.5rem;
        align-items: center;
    }

    .mobile-shortcut-btn {
        min-width: 3rem !important;
        height: 3rem !important;
        padding: 0.75rem !important;
        border-radius: 50% !important;
        transition: all 0.3s ease !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        color: #666 !important;
        border: 1px solid transparent !important;
        background: transparent !important;
    }

    .mobile-shortcut-btn:hover,
    .mobile-shortcut-btn:focus {
        background: rgba(0,0,0,0.05) !important;
        color: #333 !important;
        text-decoration: none;
        transform: scale(1.05);
    }

    .mobile-shortcut-btn i {
        font-size: 1.5rem;
    }

    /* Responsive Anpassungen für sehr kleine Bildschirme */
    @media (max-width: 575.98px) {
        .mobile-salon-name {
            font-size: 1rem;
            padding: 0 0.5rem;
        }
        
        .mobile-shortcut-btn {
            min-width: 2.75rem;
            height: 2.75rem;
            font-size: 1.25rem;
            padding: 0.625rem;
        }
        
        .mobile-shortcut-btn i {
            font-size: 1.25rem;
        }
        
        .mobile-nav-list .nav-link {
            padding: 0.875rem 1.25rem;
            font-size: 0.95rem;
        }
    }

    /* Accessibility Mode Anpassungen für mobile Header */
    body.accessibility-mode .mobile-header {
        background: #f8f9fa !important;
        border-bottom: 2px solid #333;
    }

    body.accessibility-mode .mobile-salon-name {
        color: #000;
        font-weight: 700;
    }

    body.accessibility-mode .mobile-shortcut-btn {
        color: #000;
        border: 1px solid #333;
    }

    body.accessibility-mode .mobile-shortcut-btn:hover,
    body.accessibility-mode .mobile-shortcut-btn:focus {
        background: #333;
        color: #fff;
    }
}

/* Desktop: Mobile Header ausblenden */
@media (min-width: 768px) {
    .mobile-header {
        display: none !important;
    }
}

/* Mobile Navigation Menu - Overlay Style (nur für mobile Geräte) */
@media (max-width: 767.98px) {
    .mobile-nav-container {
        background: #fff !important;
        border-top: 1px solid #e9ecef;
        box-shadow: 0 4px 6px rgba(0,0,0,0.1);
        position: fixed !important;
        top: 70px !important; /* Höhe der Headerbar */
        left: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        z-index: 1020 !important;
        overflow-y: auto;
        transform: translateX(-100%) !important;
        transition: transform 0.3s ease !important;
        width: 100% !important; /* Explizite Breite */
        min-height: calc(100vh - 70px) !important; /* Mindesthöhe */
        display: block !important; /* Sicherstellen dass es nicht versteckt wird */
    }

    /* Wenn das Menu geöffnet ist */
    .mobile-nav-container.show {
        transform: translateX(0) !important;
        visibility: visible !important;
    }

    /* Backdrop für das mobile Menu */
    .mobile-nav-backdrop {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        background: rgba(0,0,0,0.5) !important;
        z-index: 1015 !important;
        opacity: 0;
        visibility: hidden;
        transition: opacity 0.3s ease, visibility 0.3s ease;
        pointer-events: none; /* Nicht klickbar wenn ausgeblendet */
        display: block !important; /* Sicherstellen dass es nicht versteckt wird */
    }

    .mobile-nav-backdrop.show {
        opacity: 1 !important;
        visibility: visible !important;
        pointer-events: auto !important; /* Klickbar wenn sichtbar */
    }

    .mobile-nav-list {
        padding: 0;
        margin: 0;
        list-style: none;
    }

    .mobile-nav-list .nav-item {
        border-bottom: 1px solid #f8f9fa;
    }

    .mobile-nav-list .nav-item:last-child {
        border-bottom: none;
    }

    .mobile-nav-list .nav-link {
        padding: 1rem 1.5rem;
        color: #333;
        text-decoration: none;
        display: flex;
        align-items: center;
        gap: 0.75rem;
        font-size: 1rem;
        transition: background-color 0.2s ease;
    }

    .mobile-nav-list .nav-link:hover,
    .mobile-nav-list .nav-link:focus {
        background-color: #f8f9fa;
        color: #333;
        text-decoration: none;
    }

    .mobile-nav-list .nav-link i {
        font-size: 1.1rem;
        width: 1.25rem;
        text-align: center;
    }

    /* iOS-spezifische Anpassungen für das mobile Menu */
    @supports (-webkit-touch-callout: none) {
        .mobile-nav-container {
            /* iOS Safari spezielle Behandlung */
            -webkit-overflow-scrolling: touch;
            /* Verhindert Bounce-Effekt */
            overscroll-behavior: contain;
        }
        
        /* iOS Safari: Verhindert Zoom beim Doppelklick */
        .mobile-nav-container {
            touch-action: manipulation;
        }
    }

    /* Accessibility Mode Anpassungen für mobile Navigation */
    body.accessibility-mode .mobile-nav-container {
        background: #f8f9fa;
        border-top: 2px solid #333;
    }

    body.accessibility-mode .mobile-nav-list .nav-link {
        color: #000;
        font-weight: 500;
    }

    body.accessibility-mode .mobile-nav-list .nav-link:hover,
    body.accessibility-mode .mobile-nav-list .nav-link:focus {
        background: #333;
        color: #fff;
    }
}

/* Desktop: Mobile Navigation ausblenden */
@media (min-width: 768px) {
    .mobile-nav-container,
    .mobile-nav-backdrop {
        display: none !important;
    }
}

/* Modal Backdrop Problem beheben */
.modal-backdrop {
    z-index: 1040;
}

.modal {
    z-index: 1050;
}

/* Sicherstellen, dass das Backdrop korrekt entfernt wird */
body:not(.modal-open) .modal-backdrop {
    display: none !important;
}

body:not(.modal-open) {
    padding-right: 0 !important;
    overflow: auto !important;
}

/* CRITICAL: Mobile Navigation Menu - Override ALL other styles */
@media screen and (max-width: 767.98px) {
    /* Mobile Navigation Container - ABSOLUTE OVERRIDE */
    div.mobile-nav-container#mobileNav {
        background: #ffffff !important;
        border-top: 1px solid #e9ecef !important;
        box-shadow: 0 4px 6px rgba(0,0,0,0.1) !important;
        position: fixed !important;
        top: 70px !important;
        left: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        z-index: 9999 !important; /* Sehr hoher z-index */
        overflow-y: auto !important;
        transform: translateX(-100%) !important;
        transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94) !important; /* Smoother animation */
        width: 100vw !important; /* Viewport width */
        height: calc(100vh - 70px) !important; /* Viewport height minus header */
        display: block !important;
        visibility: hidden !important;
        opacity: 0 !important;
    }

    /* Mobile Navigation Container SHOW state - ABSOLUTE OVERRIDE */
    div.mobile-nav-container#mobileNav.show {
        transform: translateX(0) !important;
        visibility: visible !important;
        opacity: 1 !important;
    }

    /* Mobile Navigation Container CLOSING state - Für sanfte Animation nach links */
    div.mobile-nav-container#mobileNav.closing {
        transform: translateX(-100%) !important;
        visibility: visible !important; /* Während Animation sichtbar bleiben */
        opacity: 1 !important;
    }

    /* Mobile Navigation Backdrop - ABSOLUTE OVERRIDE */
    div.mobile-nav-backdrop#mobileNavBackdrop {
        position: fixed !important;
        top: 70px !important; /* Startet UNTER der Headerbar */
        left: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        background: rgba(0,0,0,0.5) !important;
        z-index: 9998 !important; /* Ein weniger als Menu */
        opacity: 0 !important;
        visibility: hidden !important;
        transition: opacity 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94), visibility 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94) !important;
        pointer-events: none !important;
        display: block !important;
        width: 100vw !important;
        height: calc(100vh - 70px) !important; /* Höhe minus Headerbar */
    }

    /* Mobile Navigation Backdrop SHOW state - ABSOLUTE OVERRIDE */
    div.mobile-nav-backdrop#mobileNavBackdrop.show {
        opacity: 1 !important;
        visibility: visible !important;
        pointer-events: auto !important;
    }

    /* Mobile Navigation Backdrop CLOSING state */
    div.mobile-nav-backdrop#mobileNavBackdrop.closing {
        opacity: 0 !important;
        visibility: visible !important; /* Während Animation sichtbar bleiben */
        pointer-events: none !important;
    }

    /* Mobile Navigation List - ABSOLUTE OVERRIDE */
    div.mobile-nav-container#mobileNav ul.mobile-nav-list {
        padding: 0 !important;
        margin: 0 !important;
        list-style: none !important;
        background: #ffffff !important;
    }

    /* Mobile Navigation Items - ABSOLUTE OVERRIDE */
    div.mobile-nav-container#mobileNav ul.mobile-nav-list li.nav-item {
        border-bottom: 1px solid #f8f9fa !important;
        display: block !important;
    }

    /* Mobile Navigation Links - ABSOLUTE OVERRIDE */
    div.mobile-nav-container#mobileNav ul.mobile-nav-list li.nav-item a.nav-link {
        padding: 1rem 1.5rem !important;
        color: #333 !important;
        text-decoration: none !important;
        display: flex !important;
        align-items: center !important;
        gap: 0.75rem !important;
        font-size: 1rem !important;
        transition: background-color 0.2s ease !important;
        background: transparent !important;
    }

    /* Mobile Navigation Links Hover - ABSOLUTE OVERRIDE */
    div.mobile-nav-container#mobileNav ul.mobile-nav-list li.nav-item a.nav-link:hover,
    div.mobile-nav-container#mobileNav ul.mobile-nav-list li.nav-item a.nav-link:focus {
        background-color: #f8f9fa !important;
        color: #333 !important;
        text-decoration: none !important;
    }
    
    /* BOMBENSICHERE Login/Logout-Button-Steuerung für Mobile Navigation */
    div.mobile-nav-container#mobileNav ul.mobile-nav-list li.nav-item.d-none,
    div.mobile-nav-container#mobileNav ul.mobile-nav-list #mobile_login_section.d-none,
    div.mobile-nav-container#mobileNav ul.mobile-nav-list #mobile_logout_section.d-none {
        display: none !important;
    }
    
    /* Sicherstellen, dass sichtbare Buttons auch wirklich angezeigt werden */
    div.mobile-nav-container#mobileNav ul.mobile-nav-list li.nav-item:not(.d-none),
    div.mobile-nav-container#mobileNav ul.mobile-nav-list #mobile_login_section:not(.d-none),
    div.mobile-nav-container#mobileNav ul.mobile-nav-list #mobile_logout_section:not(.d-none) {
        display: block !important;
    }
    
    /* Mobile Accessibility Button - Active State */
    .mobile-shortcut-btn.active {
        background-color: #0d6efd !important;
        color: white !important;
        border-color: #0d6efd !important;
    }
    
    .mobile-shortcut-btn.active:hover,
    .mobile-shortcut-btn.active:focus {
        background-color: #0b5ed7 !important;
        color: white !important;
        border-color: #0a58ca !important;
    }
    
    /* Accessibility Mode: Angepasste Farben für aktiven Accessibility Button */
    body.accessibility-mode .mobile-shortcut-btn.active {
        background-color: #28a745 !important;
        color: #fff !important;
        border-color: #28a745 !important;
        font-weight: 600 !important;
    }
    
    body.accessibility-mode .mobile-shortcut-btn.active:hover,
    body.accessibility-mode .mobile-shortcut-btn.active:focus {
        background-color: #218838 !important;
        color: #fff !important;
        border-color: #1e7e34 !important;
    }
}

.oeffnungszeiten-table {
  width: 100%;
  max-width: 350px;
  margin: 0 auto;
  border-collapse: separate;
  border-spacing: 0;
}
.oeffnungszeiten-row {
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  align-items: flex-start;
  padding: 2px 0 2px 0;
  font-size: 1em;
  min-height: 28px;
}
.oeffnungszeiten-tag {
  flex: 0 0 auto;
  text-align: left;
  font-weight: 500;
  padding-right: 8px;
  white-space: nowrap;
}
.oeffnungszeiten-zeit {
  flex: 1 1 auto;
  text-align: right;
  font-variant-numeric: tabular-nums;
  white-space: normal;
  word-wrap: break-word;
  overflow-wrap: break-word;
  hyphens: auto;
}
.oeffnungszeiten-row:not(:last-child) {
  border-bottom: none;
}
@media (max-width: 600px) {
  .oeffnungszeiten-table {
    max-width: 100%;
  }
  .oeffnungszeiten-row {
    font-size: 0.97em;
    min-height: 24px;
  }
  .oeffnungszeiten-tag {
    flex: 0 0 auto;
    padding-right: 6px;
  }
  .oeffnungszeiten-zeit {
    flex: 1 1 auto;
    min-width: 0;
    text-align: right;
  }
}

/* Profil Modal - Button-Layout verbessern */
#modalProfil .modal-footer {
  display: flex !important;
  flex-wrap: nowrap !important;
  justify-content: space-between !important;
  align-items: center !important;
  gap: 0.75rem !important;
}

#modalProfil .modal-footer .btn-outline-danger {
  /* Account löschen Button links */
  margin-right: auto !important;
}

#modalProfil .modal-footer .btn-secondary,
#modalProfil .modal-footer .btn-primary {
  /* Abbrechen und Speichern Buttons rechts gruppiert */
  margin-left: 0 !important;
}

/* Responsive Anpassungen für mobile Geräte */
@media (max-width: 767.98px) {
  #modalProfil .modal-footer {
    flex-direction: column !important;
    gap: 0.5rem !important;
  }
  
  #modalProfil .modal-footer .btn {
    width: 100% !important;
    margin: 0 !important;
  }
  
  /* Reihenfolge: Speichern, Abbrechen, Account löschen */
  #modalProfil .modal-footer .btn-primary {
    order: 1;
  }
  
  #modalProfil .modal-footer .btn-secondary {
    order: 2;
  }
  
  #modalProfil .modal-footer .btn-outline-danger {
    order: 3;
    margin-top: 0.5rem !important;
    border-top: 1px solid #dee2e6 !important;
    padding-top: 0.75rem !important;
  }
}

@media (max-width: 575.98px) {
  #modalProfil .modal-footer .btn {
    font-size: 0.9rem !important;
  }
}

/* Spezielle Anpassungen für Öffnungszeiten in der Sidebar */
#sidebar_left .oeffnungszeiten-table {
  max-width: 100%;
  margin: 0;
}

#sidebar_left .oeffnungszeiten-row {
  min-height: 24px;
  padding: 1px 0;
}

#sidebar_left .oeffnungszeiten-tag {
  flex: 0 0 auto;
  padding-right: 6px;
}

#sidebar_left .oeffnungszeiten-zeit {
  flex: 1 1 auto;
  min-width: 0;
  text-align: right;
}

/* Responsive Anpassungen für Sidebar Öffnungszeiten */
@media (max-width: 1200px) {
  #sidebar_left .oeffnungszeiten-tag {
    flex: 0 0 auto;
    padding-right: 5px;
  }
  
  #sidebar_left .oeffnungszeiten-zeit {
    flex: 1 1 auto;
    min-width: 0;
    text-align: right;
  }
}

@media (max-width: 992px) {
  #sidebar_left .oeffnungszeiten-tag {
    flex: 0 0 auto;
    padding-right: 4px;
  }
  
  #sidebar_left .oeffnungszeiten-zeit {
    flex: 1 1 auto;
    min-width: 0;
    text-align: right;
  }
}

/* Filter Modal - Schriftgrößen für bessere Lesbarkeit */
#modalFilter .form-label.small,
#modalFilter .form-check .form-label.small {
  font-size: 1rem !important;
  font-weight: 500;
  color: #212529;
  margin-bottom: 0.5rem;
}

#modalFilter .form-check {
  margin-bottom: 0.75rem;
  display: flex;
  align-items: flex-start;
}

#modalFilter .form-check-input {
  margin-top: 0.125rem;
  margin-right: 0.5rem;
  flex-shrink: 0;
  width: 1rem;
  height: 1rem;
}

#modalFilter .form-check-label,
#modalFilter .form-check .form-label {
  font-size: 1rem !important;
  font-weight: 500;
  color: #212529;
  line-height: 1.4;
  margin: 0;
  cursor: pointer;
  display: flex;
  align-items: flex-start;
}

/* Responsive Anpassungen für mobile Geräte */
@media (max-width: 767.98px) {
  #modalFilter .form-label.small,
  #modalFilter .form-check .form-label.small {
    font-size: 1rem !important;
  }
  
  #modalFilter .form-check-label,
  #modalFilter .form-check .form-label {
    font-size: 1rem !important;
  }
  
  #modalFilter .form-check {
    margin-bottom: 1rem;
  }
}

@media (max-width: 575.98px) {
  #modalFilter .form-label.small,
  #modalFilter .form-check .form-label.small {
    font-size: 1rem !important;
  }
  
  #modalFilter .form-check-label,
  #modalFilter .form-check .form-label {
    font-size: 1rem !important;
  }
}

/* Filter Modal - Layout für Dienstleistungen und Zeitraum */
#modalFilter #filter_mwk_container {
  gap: 0.5rem;
  flex-wrap: nowrap;
}

#modalFilter #filter_mwk_container .form-check {
  margin-bottom: 0;
  flex: 1;
  text-align: center;
  min-width: 0;
}

#modalFilter .d-flex.gap-3 {
  gap: 0.5rem;
  flex-wrap: nowrap;
}

#modalFilter .flex-fill {
  min-width: 0;
}

/* Kompakte Darstellung für kleine Bildschirme */
@media (max-width: 480px) {
  #modalFilter #filter_mwk_container {
    gap: 0.25rem;
  }
  
  #modalFilter #filter_mwk_container .form-check {
    font-size: 0.9rem;
  }
  
  #modalFilter .d-flex.gap-3 {
    gap: 0.25rem;
  }
  
  #modalFilter .btn {
    font-size: 0.875rem;
    padding: 0.375rem 0.5rem;
    }
}

/* Scrollbare Modale für Meine Termine */
#modalTerminhistorie .modal-body {
  max-height: 70vh;
  overflow-y: auto;
}

#modalTerminhistorie .modal-dialog {
  margin-top: 1rem;
}

/* Navbar und Mobile Menu unterhalb von Modals anzeigen */
.navbar, .navbar-fixed-top, .navbar-sticky-top {
  z-index: 1030 !important;
}

/* Mobile Menu immer unter Modals */
.mobile-nav-container, .mobile-nav-backdrop {
  z-index: 1040 !important;
}

/* Modals immer über allem */
.modal {
  z-index: 1050 !important;
}

.modal-backdrop {
  z-index: 1049 !important;
}

#terminhistorie_container_modal .dienstleistung-icon {
  color: #6c757d;
  margin-right: 0.5em;
  font-size: 1.1em;
  vertical-align: middle;
}

#terminhistorie_container_modal .terminblock i {
  color: inherit;
  margin-right: 0.5em;
  font-size: 1.1em;
  vertical-align: middle;
}

#terminhistorie_container_modal .terminblock-taetigkeit,
#terminhistorie_container_modal .terminblock-taetigkeit i {
  margin-left: 0 !important;
  padding-left: 0 !important;
}
#terminhistorie_container_modal .terminblock > div {
  margin-left: 0 !important;
  padding-left: 0 !important;
}

/* Schriftgröße für Termindetails im Modal */
#terminhistorie_container_modal .terminblock {
  font-size: 1rem;
}

#terminhistorie_container_modal .terminblock-header,
#terminhistorie_container_modal .terminblock-uhrzeit,
#terminhistorie_container_modal .terminblock-mitarbeiter,
#terminhistorie_container_modal .terminblock-taetigkeit {
  font-size: 1rem;
}

/* Positionierung der Terminblock-Header und Buttons */
#terminhistorie_container_modal .terminblock-header {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
}

#terminhistorie_container_modal .terminblock-btns {
  margin-left: auto;
  padding-left: 8px;
}

#terminhistorie_container_modal .terminblock-btns i {
  font-size: 1.1em;
  color: inherit;
  opacity: 0.7;
  cursor: pointer;
  transition: opacity 0.2s;
}

#terminhistorie_container_modal .terminblock-btns i:hover {
  opacity: 1;
  color: #0d6efd;
}

/* Modernes Redesign für das Filter-Modal */
#modalFilter .filter-card {
  border-radius: 1rem;
  box-shadow: 0 2px 8px rgba(0,0,0,0.06);
  background: #fff;
  padding: 1.2rem 1rem 1rem 1rem;
  margin-bottom: 1.5rem;
  border: 1px solid #f0f0f0;
}
#modalFilter .filter-card-header {
  font-weight: 600;
  font-size: 1.1rem;
  margin-bottom: 1rem;
  color: #0d6efd;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
#modalFilter .filter-card-body {
  padding: 0;
}
#modalFilter .form-check-input {
  width: 1.3em;
  height: 1.3em;
  margin-right: 0.5em;
}
#modalFilter .form-label.small {
  font-size: 1.05rem !important;
  font-weight: 500;
  color: #212529;
  margin-bottom: 0.5rem;
}
#modalFilter .btn-toggle {
  border-radius: 2rem;
  padding: 0.5rem 1.1rem;
  margin: 0.1rem 0.2rem 0.1rem 0;
  border: 1.5px solid #dee2e6;
  background: #f8f9fa;
  font-weight: 500;
  transition: all 0.15s;
}
#modalFilter .btn-toggle.active, #modalFilter .btn-toggle:active, #modalFilter .btn-toggle:focus, #modalFilter .btn-check:checked + .btn-toggle {
  background: #0d6efd;
  color: #fff;
  border-color: #0d6efd;
  box-shadow: 0 2px 8px rgba(13,110,253,0.08);
}
#modalFilter .btn-toggle {
  min-width: 2.7rem;
  text-align: center;
}
#modalFilter .modal-footer {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  border: none;
  padding-top: 0;
}
#modalFilter .btn-lg {
  font-size: 1.15rem;
  padding: 0.75rem 1rem;
  border-radius: 0.7rem;
}
#modalFilter .btn-outline-secondary {
  background: #fff;
  border: 1.5px solid #dee2e6;
}
#modalFilter .btn-outline-secondary:active, #modalFilter .btn-outline-secondary:focus {
  background: #e9ecef;
  color: #0d6efd;
  border-color: #0d6efd;
}
#modalFilter .dropdown-toggle {
  font-size: 1.05rem;
  padding: 0.6rem 1.1rem;
  border-radius: 0.7rem;
  border: 1.5px solid #dee2e6;
  background: #f8f9fa;
  color: #212529;
  font-weight: 500;
}
#modalFilter .dropdown-toggle:focus, #modalFilter .dropdown-toggle:active {
  border-color: #0d6efd;
  box-shadow: 0 0 0 0.15rem rgba(13,110,253,0.12);
}
#modalFilter .dropdown-menu {
  border-radius: 0.7rem;
  box-shadow: 0 4px 16px rgba(0,0,0,0.08);
  font-size: 1.05rem;
}
#modalFilter .dropdown-item {
  padding: 0.7rem 1.2rem;
}
#modalFilter .dropdown-item.active, #modalFilter .dropdown-item:active {
  background: #0d6efd;
  color: #fff;
}
@media (max-width: 575.98px) {
  #modalFilter .modal-dialog {
    margin: 0.5rem;
  }
  #modalFilter .filter-card {
    padding: 1rem 0.5rem 0.7rem 0.5rem;
  }
  #modalFilter .btn-lg {
    font-size: 1rem;
    padding: 0.6rem 0.7rem;
  }
}

/* Modernes Redesign für das Mein Profil Modal */
#modalProfil .filter-card {
  border-radius: 1rem;
  box-shadow: 0 2px 8px rgba(0,0,0,0.06);
  background: #fff;
  padding: 1.2rem 1rem 1rem 1rem;
  margin-bottom: 1.5rem;
  border: 1px solid #f0f0f0;
}
#modalProfil .filter-card-header {
  font-weight: 600;
  font-size: 1.1rem;
  margin-bottom: 1rem;
  color: #0d6efd;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
#modalProfil .filter-card-body {
  padding: 0;
}
#modalProfil .form-label.small {
  font-size: 1.05rem !important;
  font-weight: 500;
  color: #212529;
}
#modalProfil .input-group {
  border-radius: 0.5rem;
  overflow: hidden;
  box-shadow: 0 1px 2px rgba(0,0,0,0.03);
}
#modalProfil .input-group-text {
  background: #f8f9fa;
  border: none;
  color: #0d6efd;
  font-size: 1.2em;
}
#modalProfil .form-control {
  font-size: 1.08em;
  padding: 0.7em 1em;
  border-radius: 0.5rem;
  border: 1px solid #e0e0e0;
}
#modalProfil .modal-footer {
  background: none;
  border: none;
  padding-top: 0;
  flex-direction: column;
  gap: 0.7rem;
}
#modalProfil .btn-lg {
  font-size: 1.15em;
  padding: 0.9em 1em;
  border-radius: 0.7em;
}
#modalProfil .btn-outline-secondary {
  border: 1px solid #ced4da;
  color: #495057;
  background: #fff;
}
#modalProfil .btn-outline-secondary:hover {
  background: #f8f9fa;
  color: #0d6efd;
  border-color: #0d6efd;
}
#modalProfil .btn-outline-danger {
  border: 1px solid #f5c2c7;
  color: #dc3545;
  background: #fff;
}
#modalProfil .btn-outline-danger:hover {
  background: #f8d7da;
  color: #a71d2a;
  border-color: #a71d2a;
}
#modalProfil .btn-primary {
  background: #0d6efd;
  border: none;
}
#modalProfil .btn-primary:hover {
  background: #0b5ed7;
}
#modalProfil .modal-title {
  font-size: 1.35em;
  font-weight: 700;
  color: #212529;
}

#modalKontakt .address-text, #modalKontakt .address-text a {
  text-decoration: none !important;
  border-bottom: none !important;
  color: inherit;
}

.floating-btn-group {
  position: fixed;
  top: 20px;
  right: 20px;
  z-index: 1021;
  display: flex;
  gap: 20px;
}
.floating-login-btn, .floating-accessibility-btn {
  position: static !important;
  top: auto !important;
  right: auto !important;
  z-index: auto !important;
}

/* Modernes Accordion für Dienstleistungen */
#dienstleistungen_accordion {
  margin-top: 1rem;
}
#dienstleistungen_accordion .accordion-item {
  border: 1px solid #e0e0e0;
  border-radius: 0.75rem !important;
  margin-bottom: 0.75rem;
  box-shadow: 0 2px 4px rgba(0,0,0,0.04);
  overflow: hidden;
}
#dienstleistungen_accordion .accordion-header {
  margin: 0;
}
#dienstleistungen_accordion .accordion-button {
  background: #ffffff;
  color: #495057;
  border: none;
  padding: 1rem 1.25rem;
  font-weight: 600;
  font-size: 1.1rem;
  border-radius: 0.75rem !important;
}

/* Accordion-Buttons im geöffneten Zustand - nur Bootstrap-Styles überschreiben */
#dienstleistungen_accordion .accordion-button:not(.collapsed) {
  /* Entferne Bootstrap-Styles, damit client.css.php wirken kann */
  border-color: unset !important;
  box-shadow: none !important;
}

#dienstleistungen_accordion .accordion-button:not(.collapsed) {
  box-shadow: none;
}
#dienstleistungen_accordion .accordion-button:focus {
  box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.25);
}
#dienstleistungen_accordion .accordion-body {
  padding: 2px;
  background: #fff;
}
.dienstleistung-item {
  position: relative;
  padding: 0.85rem 1.25rem;
  border-bottom: 1px solid #f0f0f0;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  transition: all 0.2s;
  cursor: pointer;
}
.dienstleistung-item:last-child {
  border-bottom: none;
}
.dienstleistung-item:hover {
  background: #f8f9fa;
}
.dienstleistung-item.selected {
  background: linear-gradient(135deg, #e3f2fd 0%, #f0f8ff 100%);
  border-left: 4px solid #0d6efd;
  box-shadow: 0 2px 8px rgba(13, 110, 253, 0.15);
}
.dienstleistung-item.selected .dienstleistung-name {
  color: #0d6efd;
  font-weight: 600;
}
.dienstleistung-item.selected .dienstleistung-preis {
  color: #0b5ed7;
  font-weight: 700;
}
.dienstleistung-item.selected::after {
  content: '\2713'; /* Check-Symbol */
  position: absolute;
  right: 1rem;
  top: 50%;
  transform: translateY(-50%);
  color: #0d6efd;
  font-weight: bold;
  font-size: 1.2rem;
  background: #fff;
  border-radius: 50%;
  width: 1.5rem;
  height: 1.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 4px rgba(13, 110, 253, 0.2);
}
.dienstleistung-item.disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.dienstleistung-item.disabled:hover {
  background: inherit;
}
.dienstleistung-item.disabled .dienstleistung-name {
  color: #999;
}
.dienstleistung-item:focus {
  outline: 2px solid #0d6efd !important;
  outline-offset: 1px !important;
  box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.25) !important;
}
/* Checkboxes verstecken aber funktional beibehalten */
.dienstleistung-item input[type="checkbox"] {
  display: none;
}
.dienstleistung-info {
  flex: 1;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.dienstleistung-name {
  font-weight: 500;
  color: #212529;
  font-size: 1rem;
}
.dienstleistung-preis {
  font-weight: 600;
  color: #0d6efd;
  font-size: 0.95rem;
}
.dienstleistung-dauer {
  font-size: 0.85rem;
  color: #6c757d;
  margin-left: 0.5rem;
}
@media (max-width: 767.98px) {
  #dienstleistungen_accordion .accordion-button {
    padding: 0.75rem 1rem;
    font-size: 1rem;
  }
  .dienstleistung-item {
    padding: 0.75rem 1rem;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.5rem;
  }
  .dienstleistung-info {
    width: 100%;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.25rem;
  }
  .dienstleistung-name {
    font-size: 0.95rem;
  }
  .dienstleistung-preis {
    font-size: 0.9rem;
  }
}

/* Modernes Badge-System für gewählte Dienstleistungen */
.selected-services-container {
  margin-top: 1rem;
  margin-bottom: 1.5rem;
  animation: fadeInDown 0.3s ease-out;
}



.selected-services-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 0.5rem;
}

.service-badge {
  background: linear-gradient(135deg, #0d6efd 0%, #0b5ed7 100%);
  color: white;
  padding: 0.5rem 0.75rem;
  border-radius: 2rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.9rem;
  font-weight: 500;
  box-shadow: 0 2px 4px rgba(13, 110, 253, 0.2);
  transition: all 0.2s ease;
  animation: fadeInUp 0.3s ease-out;
  border: none;
  cursor: default;
}

.service-badge:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 8px rgba(13, 110, 253, 0.3);
}

.service-badge .service-name {
  flex: 1;
}

.service-badge .remove-service {
  background: rgba(255, 255, 255, 0.2);
  border-radius: 50%;
  width: 1.5rem;
  height: 1.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.2s ease;
  border: none;
  color: white;
}

.service-badge .remove-service:hover {
  background: rgba(255, 255, 255, 0.3);
  transform: scale(1.1);
}

.service-badge.paket-badge {
  background: linear-gradient(135deg, #198754 0%, #157347 100%);
  box-shadow: 0 2px 4px rgba(25, 135, 84, 0.2);
  margin-right: 0.75rem; /* Mehr Abstand zu den Tätigkeiten */
}

.service-badge.paket-badge:hover {
  box-shadow: 0 4px 8px rgba(25, 135, 84, 0.3);
}

.service-badge.paket-badge:last-of-type {
  margin-right: 0.5rem; /* Standard-Abstand */
}

.service-badge.paket-badge .service-name::before {
  content: '';
  display: inline-block;
  vertical-align: middle;
  margin-right: 0.25rem;
  /* Bootstrap Icon als Pseudo-Element */
  width: 1em;
  height: 1em;
  background: none;
}
.service-badge.paket-badge .service-name {
  position: relative;
  padding-left: 1.3em;
}
.service-badge.paket-badge .service-name::before {
  content: '';
  display: inline-block;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 1em;
  height: 1em;
  background: none;
  mask: url("../bootstrap_5/icons/box.svg") no-repeat center / contain;
  -webkit-mask: url("../bootstrap_5/icons/box.svg") no-repeat center / contain;
  background-color: currentColor;
}

@keyframes fadeInDown {
  from {
    opacity: 0;
    transform: translateY(-10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes fadeOut {
  from {
    opacity: 1;
    transform: scale(1);
  }
  to {
    opacity: 0;
    transform: scale(0.8);
  }
}

.service-badge.removing {
  animation: fadeOut 0.2s ease-out forwards;
}

/* Mobile Responsivität */
@media (max-width: 767.98px) {
  .service-badge {
    font-size: 0.85rem;
    padding: 0.4rem 0.6rem;
  }
  
  .selected-services-badges {
    gap: 0.4rem;
  }
}

/* Smooth transitions when hiding/showing */
.selected-services-container.hiding {
  animation: fadeOut 0.3s ease-out forwards;
}

/* ===========================================
   MITARBEITER ACCORDION STYLES
   =========================================== */

/* Grundlegendes Accordion Layout für Mitarbeiter */
#mitarbeiter_accordion {
  margin-top: 0rem; /* Standard: kein margin für ausgeloggte User */
  border-radius: 0.5rem;
  overflow: hidden;
  box-shadow: 0 2px 4px rgba(0,0,0,0.04);
  display: none; /* Initial versteckt, wird per JavaScript angezeigt wenn Dienstleistungen gewählt sind */
}

/* Verstecken der gesamten Mitarbeiter-Sektion wenn nötig */
.sektion_buchung.hidden {
  display: none !important;
}

/* Margin nur anzeigen wenn User eingeloggt ist */
body[data-login-mode="LOGGED_IN"] #mitarbeiter_accordion {
  margin-top: 1rem;
}

#mitarbeiter_accordion .accordion-item {
  border: 1px solid #e0e0e0;
  margin-bottom: 0.5rem;
  border-radius: 0.5rem !important;
  box-shadow: 0 2px 4px rgba(0,0,0,0.04);
  overflow: hidden;
}

#mitarbeiter_accordion .accordion-header {
  margin: 0;
}

#mitarbeiter_accordion .accordion-button {
  background: #ffffff;
  color: #495057;
  border: none;
  padding: 1rem 1.25rem;
  font-weight: 600;
  font-size: 1.1rem;
  border-radius: 0 !important;
}

/* Accordion-Buttons im geöffneten Zustand */
#mitarbeiter_accordion .accordion-button:not(.collapsed) {
  border-color: unset !important;
  box-shadow: none !important;
}

#mitarbeiter_accordion .accordion-button:focus {
  box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.25);
}

#mitarbeiter_accordion .accordion-body {
  padding: 2px;
  background: #fff;
}

/* Mitarbeiter-Items Styling */
.mitarbeiter-item {
  position: relative;
  padding: 0.85rem 1.25rem;
  border-bottom: 1px solid #f0f0f0;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  transition: all 0.2s;
  cursor: pointer;
}

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

.mitarbeiter-item:hover {
  background: #f8f9fa;
}

.mitarbeiter-item.selected {
  background: linear-gradient(135deg, #e8f5e8 0%, #f0fff0 100%);
  border-left: 4px solid #198754;
  box-shadow: 0 2px 8px rgba(25, 135, 84, 0.15);
}

.mitarbeiter-item.selected .mitarbeiter-name {
  color: #198754;
  font-weight: 600;
}

.mitarbeiter-item.selected::after {
  content: '\2713'; /* Check-Symbol */
  position: absolute;
  right: 1rem;
  top: 50%;
  transform: translateY(-50%);
  color: #198754;
  font-weight: bold;
  font-size: 1.2rem;
  background: #fff;
  border-radius: 50%;
  width: 1.5rem;
  height: 1.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 4px rgba(25, 135, 84, 0.2);
}

.mitarbeiter-item.disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.mitarbeiter-item.disabled:hover {
  background: inherit;
}

.mitarbeiter-item.disabled .mitarbeiter-name {
  color: #999;
}

.mitarbeiter-item:focus {
  outline: 2px solid #198754 !important;
  outline-offset: 1px !important;
  box-shadow: 0 0 0 0.25rem rgba(25, 135, 84, 0.25) !important;
}

/* Checkboxes verstecken aber funktional beibehalten */
.mitarbeiter-item input[type="radio"],
.mitarbeiter-item input[type="checkbox"] {
  display: none;
}

/* Mitarbeiter-Bild Styling */
.mitarbeiter-bild {
  width: 3rem;
  height: 3rem;
  border-radius: 50%;
  object-fit: cover;
  border: 2px solid #e0e0e0;
  flex-shrink: 0;
}

.mitarbeiter-item.selected .mitarbeiter-bild {
  border-color: #198754;
}

/* Mitarbeiter-Info Styling */
.mitarbeiter-info {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.mitarbeiter-name {
  font-weight: 500;
  color: #212529;
  font-size: 1rem;
  margin: 0;
}

.mitarbeiter-spezialisierung {
  font-size: 0.85rem;
  color: #6c757d;
  margin: 0;
}

/* Badge-System für gewählte Mitarbeiter */
.selected-mitarbeiter-container {
  margin-top: 1rem;
  margin-bottom: 1.5rem;
  animation: fadeInDown 0.3s ease-out;
}

.selected-mitarbeiter-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 0.5rem;
}

.mitarbeiter-badge {
  background: linear-gradient(135deg, #198754 0%, #157347 100%);
  color: white;
  padding: 0.5rem 0.75rem;
  border-radius: 2rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.9rem;
  font-weight: 500;
  box-shadow: 0 2px 4px rgba(25, 135, 84, 0.2);
  transition: all 0.2s ease;
  animation: fadeInUp 0.3s ease-out;
  border: none;
  cursor: default;
}

.mitarbeiter-badge:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 8px rgba(25, 135, 84, 0.3);
}

.mitarbeiter-badge .mitarbeiter-bild-small {
  width: 1.5rem;
  height: 1.5rem;
  border-radius: 50%;
  object-fit: cover;
  border: 1px solid rgba(255, 255, 255, 0.3);
}

.mitarbeiter-badge .mitarbeiter-name {
  flex: 1;
  color: white;
}

.mitarbeiter-badge .remove-mitarbeiter {
  background: rgba(255, 255, 255, 0.2);
  border-radius: 50%;
  width: 1.5rem;
  height: 1.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.2s ease;
  border: none;
  color: white;
}

.mitarbeiter-badge .remove-mitarbeiter:hover {
  background: rgba(255, 255, 255, 0.3);
  transform: scale(1.1);
}

/* Mobile Responsivität für Mitarbeiter */
@media (max-width: 767.98px) {
  #mitarbeiter_accordion .accordion-button {
    padding: 0.75rem 1rem;
    font-size: 1rem;
  }
  
  .mitarbeiter-item {
    padding: 0.75rem 1rem;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.5rem;
  }
  
  .mitarbeiter-info {
    width: 100%;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.25rem;
  }
  
  .mitarbeiter-bild {
    width: 2.5rem;
    height: 2.5rem;
  }
  
  .mitarbeiter-name {
    font-size: 0.95rem;
  }
  
  .mitarbeiter-spezialisierung {
    font-size: 0.8rem;
  }
  
  .mitarbeiter-badge {
    font-size: 0.85rem;
    padding: 0.4rem 0.6rem;
  }
  
  .selected-mitarbeiter-badges {
    gap: 0.4rem;
  }
}

/* Smooth transitions when hiding/showing mitarbeiter */
.selected-mitarbeiter-container.hiding {
  animation: fadeOut 0.3s ease-out forwards;
}

.mitarbeiter-badge.removing {
  animation: fadeOut 0.2s ease-out forwards;
}

/* Forced height matching for mitarbeiter and dienstleistung items */
.mitarbeiter-item {
  padding: 0.85rem 1.25rem !important;
  gap: 0.75rem !important;
}

@media (max-width: 767.98px) {
  .mitarbeiter-item {
    flex-direction: row !important;
    align-items: center !important;
    padding: 0.1rem 0.5rem !important;
    gap: 0.5rem !important;
  }
  .mitarbeiter-bild {
    width: 1.5rem !important;
    height: 1.5rem !important;
  }
  .mitarbeiter-info {
    flex-direction: row !important;
    align-items: center !important;
    gap: 0.5rem !important;
  }
  .mitarbeiter-spezialisierung {
    font-size: 0.8rem;
    margin-left: 0.5rem;
  }
}

/* Mitarbeiter-Info jetzt einzeilig wie Dienstleistungen */
.mitarbeiter-info {
  flex: 1 !important;
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 0.5rem !important;
  min-height: 3rem !important;
}
.mitarbeiter-spezialisierung {
  font-size: 0.85rem;
  color: #6c757d;
  margin-left: 0.5rem;
  margin-bottom: 0 !important;
  display: inline !important;
}

@media (max-width: 767.98px) {
  .mitarbeiter-info {
    flex-direction: row !important;
    align-items: center !important;
    gap: 0.5rem !important;
    min-height: 2.5rem !important;
  }
  .mitarbeiter-spezialisierung {
    font-size: 0.8rem;
    margin-left: 0.5rem;
  }
}

/* Kompaktes Padding für Mitarbeiter-Zeile */
.mitarbeiter-item {
  padding: 0.1rem 0.75rem !important;
}
@media (max-width: 767.98px) {
  .mitarbeiter-item {
    padding: 0.1rem 0.5rem !important;
  }
}

/* Kleinere Mitarbeiter-Bilder für kompaktere Zeilen */
.mitarbeiter-bild {
  width: 2rem !important;
  height: 2rem !important;
}
@media (max-width: 767.98px) {
  .mitarbeiter-bild {
    width: 1.5rem !important;
    height: 1.5rem !important;
  }
}

/* Mitarbeiter-Bild etwas größer, Zeile bleibt kompakt */
.mitarbeiter-bild {
  width: 2.3rem !important;
  height: 2.3rem !important;
}
@media (max-width: 767.98px) {
  .mitarbeiter-bild {
    width: 1.8rem !important;
    height: 1.8rem !important;
  }
}

/* Einheitlicher Border-Radius für modernes, konsistentes Design */
.accordion-item,
.accordion-button,
.selected-mitarbeiter-container,
.selected-mitarbeiter-badges,
.mitarbeiter-item,
.dienstleistung-item,
.form-control,
.btn,
.service-badge,
.mitarbeiter-badge,
.modal-content,
.table,
.dropdown-menu {
  border-radius: 0.5rem !important;
}

/* Für Pill-Badges (runde Badges) etwas mehr, falls gewünscht */
.service-badge,
.mitarbeiter-badge {
  border-radius: 1.5rem !important;
}

/* Modernes Grid für Termine */
.termine-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 1rem;
  margin: 1.5rem 0;
}
.termine-grid-day {
  background: #fff;
  border-radius: 0.5rem;
  box-shadow: 0 2px 8px rgba(0,0,0,0.04);
  padding: 1rem 0.5rem 0.5rem 0.5rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  min-width: 0;
}
.termine-grid-date {
  font-weight: bold;
  font-size: 1.1rem;
  margin-bottom: 0.5rem;
  color: #333;
}
.termine-grid-weekday {
  font-size: 0.95rem;
  color: #888;
  margin-bottom: 0.5rem;
}
.termine-grid-timeslot {
  display: block;
  width: 80%;
  min-width: 90px;
  max-width: 100%;
  margin: 0.6rem auto;
  padding: 0.45rem 0;
  border-radius: 1.2rem;
  background: #e3f2fd;
  color: #007bff;
  font-weight: 500;
  font-size: 1rem;
  border: none;
  cursor: pointer;
  transition: background 0.2s, color 0.2s;
  text-align: center;
}
.termine-grid-timeslot:hover, .termine-grid-timeslot:focus {
  background: #007bff;
  color: #fff;
}
.termine-grid-timeslot.disabled {
  background: #f1f1f1;
  color: #bbb;
  cursor: not-allowed;
}
@media (max-width: 991.98px) {
  .termine-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
  }
}
@media (max-width: 575.98px) {
  .termine-grid {
    grid-template-columns: 1fr;
    gap: 0.7rem;
  }
  .termine-grid-day {
    padding: 0.7rem 0.3rem 0.3rem 0.3rem;
  }
}

.termine-grid-block {
  width: 100%;
  margin-bottom: 0.5rem;
  text-align: left;
}
.termine-grid-block-label {
  font-size: 0.95rem;
  font-weight: 600;
  color: #007bff;
  margin-bottom: 0.2rem;
  margin-top: 0.3rem;
  letter-spacing: 0.01em;
  text-align: center; /* Zwischenüberschriften zentrieren */
}
@media (max-width: 575.98px) {
  .termine-grid-block-label {
    font-size: 1rem;
    margin-top: 0.5rem;
  }
}

@media (max-width: 575.98px) {
  .termine-grid-day {
    padding-left: 0.5rem;
    padding-right: 0.5rem;
  }
  .termine-grid-times {
    display: flex;
    flex-wrap: wrap;
    gap: 0.8rem;
    justify-content: center;
    padding: 0.3rem;
  }
  .termine-grid-timeslot {
    display: inline-block;
    width: 22%;
    min-width: 70px;
    max-width: 100%;
    margin: 0.3rem 0.2rem !important;
    padding: 0.55rem 0.2rem;
    box-sizing: border-box;
  }
}




@media (max-width: 575.98px) {
  .termine-grid-day {
    padding: 12px 8px;
  }
  
  .termine-grid-times {
    gap: 8px;
  }

  .termine-grid-timeslot {
    padding: 6px 10px;
    font-size: 13px;
  }
}

/* Bootstrap 5 Tooltip-Styles */
.tooltip {
	z-index: 1070;
}

.tooltip .tooltip-inner {
	background: linear-gradient(135deg, #2c3e50 0%, #34495e 100%);
	color: #ffffff;
	padding: 12px 16px;
	border-radius: 12px;
	font-size: 14px;
	font-weight: 500;
	line-height: 1.4;
	box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15), 0 4px 10px rgba(0, 0, 0, 0.1);
	border: 1px solid rgba(255, 255, 255, 0.1);
	max-width: 280px;
	text-align: center;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

.tooltip .tooltip-arrow {
	display: none;
}

.tooltip .tooltip-inner::before {
	content: '';
	position: absolute;
	top: -6px;
	left: 50%;
	transform: translateX(-50%);
	width: 0;
	height: 0;
	border-left: 6px solid transparent;
	border-right: 6px solid transparent;
	border-bottom: 6px solid #2c3e50;
	filter: drop-shadow(0 -2px 4px rgba(0, 0, 0, 0.1));
}

/* Tooltip Animation */
.tooltip {
	transition: opacity 0.2s ease-in-out, transform 0.2s ease-in-out;
}

.tooltip.show {
	opacity: 1;
	transform: translateY(-2px);
}

.tooltip.fade {
	opacity: 0;
	transform: translateY(0px);
}

/* Spezielle Tooltip-Styles für Termine */
.tooltip .tooltip-inner br {
	line-height: 1.6;
}

/* Responsive Tooltip */
@media (max-width: 767.98px) {
	.tooltip .tooltip-inner {
		font-size: 13px;
		padding: 10px 14px;
		max-width: 250px;
	}
}

@media (max-width: 575.98px) {
	.tooltip .tooltip-inner {
		font-size: 12px;
		padding: 8px 12px;
		max-width: 220px;
	}
}

/* Accessibility Mode Tooltip */
body.accessibility-mode .tooltip .tooltip-inner {
	background: linear-gradient(135deg, #000000 0%, #1a1a1a 100%);
	color: #ffffff;
	border: 2px solid #ffffff;
	font-weight: 600;
	font-size: 15px;
}

body.accessibility-mode .tooltip .tooltip-inner::before {
	border-bottom-color: #000000;
}

/* Hover-Effekt für Termine mit Tooltips */
.termine-grid-timeslot[data-bs-toggle="tooltip"]:hover {
	transform: translateY(-1px);
	box-shadow: 0 4px 12px rgba(0, 123, 255, 0.3);
	transition: all 0.2s ease;
}

.termine-grid-timeslot[data-bs-toggle="tooltip"]:focus {
	outline: 2px solid #007bff;
	outline-offset: 2px;
}

/* Spezielle Icons für Tooltip-Inhalte */
.tooltip .tooltip-inner::after {
	content: '⏰';
	position: absolute;
	top: -20px;
	left: 50%;
	transform: translateX(-50%);
	font-size: 16px;
	opacity: 0.8;
}

/* === EIGENE TOOLTIP-LÖSUNG (Bootstrap umgehen) === */

/* Bootstrap Tooltips komplett deaktivieren */
.tooltip,
.bs-tooltip-top,
.bs-tooltip-bottom,
.bs-tooltip-start,
.bs-tooltip-end {
	display: none !important;
}

/* Eigene Custom Tooltip-Lösung */
.custom-tooltip {
	position: fixed !important;
	z-index: 99999 !important;
	background: linear-gradient(135deg, #2c3e50 0%, #34495e 100%) !important;
	color: #ffffff !important;
	padding: 12px 16px !important;
	border-radius: 12px !important;
	font-size: 14px !important;
	font-weight: 500 !important;
	line-height: 1.4 !important;
	box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15), 0 4px 10px rgba(0, 0, 0, 0.1) !important;
	border: 1px solid rgba(255, 255, 255, 0.1) !important;
	max-width: 280px !important;
	text-align: center !important;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif !important;
	pointer-events: none !important;
	opacity: 0;
	transition: opacity 0.2s ease;
}

.custom-tooltip.show {
	opacity: 1 !important;
}

/* Pfeil für Custom Tooltip - dynamisch positioniert */
.custom-tooltip::before {
	content: '';
	position: absolute;
	top: 100%;
	left: var(--arrow-pos, 50%);
	transform: translateX(-10px); /* Zentriere den Pfeil (Pfeilbreite = 20px, also -10px) */
	width: 0;
	height: 0;
	border-left: 10px solid transparent;
	border-right: 10px solid transparent;
	border-top: 12px solid #2c3e50;
	filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.1));
}

.tooltip.show,
.bs-tooltip-top.show,
.bs-tooltip-bottom.show,
.bs-tooltip-start.show,
.bs-tooltip-end.show {
	opacity: 1 !important;
	visibility: visible !important;
	display: block !important;
}

.tooltip .tooltip-inner,
.bs-tooltip-top .tooltip-inner,
.bs-tooltip-bottom .tooltip-inner,
.bs-tooltip-start .tooltip-inner,
.bs-tooltip-end .tooltip-inner {
	/* Schöne Optik statt Debug-Rot */
	background: linear-gradient(135deg, #2c3e50 0%, #34495e 100%) !important;
	color: #ffffff !important;
	border: 1px solid rgba(255, 255, 255, 0.1) !important;
	font-size: 14px !important;
	font-weight: 500 !important;
	padding: 12px 16px !important;
	border-radius: 12px !important;
	max-width: 280px !important;
	min-width: 200px !important;
	min-height: auto !important;
	line-height: 1.4 !important;
	text-align: center !important;
	box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15), 0 4px 10px rgba(0, 0, 0, 0.1) !important;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif !important;
}

/* Spezielle Styles für Termine-Tooltips */
.termine-grid-timeslot[data-bs-toggle="tooltip"]:hover {
	transform: translateY(-1px) !important;
	box-shadow: 0 4px 12px rgba(0, 123, 255, 0.3) !important;
	transition: all 0.2s ease !important;
}

/* Responsive Tooltip */
@media (max-width: 767.98px) {
	.tooltip .tooltip-inner,
	.bs-tooltip-top .tooltip-inner,
	.bs-tooltip-bottom .tooltip-inner,
	.bs-tooltip-start .tooltip-inner,
	.bs-tooltip-end .tooltip-inner {
		font-size: 13px !important;
		padding: 10px 14px !important;
		max-width: 250px !important;
		min-width: 180px !important;
	}
}

@media (max-width: 575.98px) {
	.tooltip .tooltip-inner,
	.bs-tooltip-top .tooltip-inner,
	.bs-tooltip-bottom .tooltip-inner,
	.bs-tooltip-start .tooltip-inner,
	.bs-tooltip-end .tooltip-inner {
		font-size: 12px !important;
		padding: 8px 12px !important;
		max-width: 220px !important;
		min-width: 160px !important;
	}
}

/* Terminzusammenfassung Card-Design */
#modalTermindetails .filter-card {
  background: #fff;
  border-radius: 1rem;
  box-shadow: 0 2px 12px rgba(0,0,0,0.07);
  border: 1px solid #e5e5e5;
  margin-bottom: 1.5rem;
}
#modalTermindetails .filter-card-header {
  background: #f8f9fa;
  border-bottom: 1px solid #e5e5e5;
  border-radius: 1rem 1rem 0 0;
  font-weight: 600;
  font-size: 1.15rem;
  padding: 0.75rem 1.25rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  /* color: #0d6efd; entfernt, damit nur die Überschrift "Termindetails" blau ist */
}
#modalTermindetails .filter-card-body {
  padding: 1.25rem;
}
#modalTermindetails .termindetails-label {
  font-size: 1rem;
  color: #495057;
  font-weight: 500;
  display: flex;
  align-items: center;
  gap: 0.4rem;
}
#modalTermindetails .termindetails-value {
  font-size: 1.05rem;
  color: #212529;
  font-weight: 400;
}
#modalTermindetails .termindetails-icon {
  color: #0d6efd; /* Bootstrap-Blau */
  font-size: 1.1em;
  margin-right: 0.3em;
}
#modalTermindetails .filter-card textarea.form-control {
  font-size: 1rem;
}

/* Schriftgrößen für Modal auf Mobilgeräten anpassen */
@media (max-width: 767.98px) {
  #modalTermindetails .modal-title {
    font-size: 1.15rem;
  }
  #modalTermindetails .filter-card-header {
    font-size: 1rem;
    padding: 0.65rem 1rem;
  }
  #modalTermindetails .filter-card-body {
    padding: 1rem;
  }
  #modalTermindetails .termindetails-label,
  #modalTermindetails .termindetails-value {
    font-size: 0.98rem;
  }
  #modalTermindetails .filter-card textarea.form-control {
    font-size: 0.98rem;
  }
}

/* Modal-Body Hintergrund leicht absetzen */
#modalTermindetails .modal-body {
  background: #f6f7fa;
  border-radius: 0 0 1rem 1rem;
}

/* Titel-Umbruch verhindern, ggf. mit Ellipsis */
#modalTermindetails .modal-title {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 90%;
}
@media (max-width: 767.98px) {
  #modalTermindetails .modal-title {
    font-size: 1.05rem;
    max-width: 80vw;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
}

/* Rechte Spalte linksbündig */
#modalTermindetails .termindetails-value {
  text-align: left;
}

#modalTermindetails h3.fs-5.text-secondary.mb-2 {
  color: #0d6efd !important;
}

#modalTermindetails .termindetails-value,
#modalTermindetails #term_vorschlag_datum,
#modalTermindetails #term_vorschlag_taet,
#modalTermindetails #term_vorschlag_ma {
  text-align: left !important;
  justify-content: flex-start !important;
}

/* Modal Close-Button sicherstellen */
#modalTermindetails #close_termindetails {
  z-index: 1051 !important;
  position: relative !important;
  pointer-events: auto !important;
}

#modalTermindetails .modal-header {
  position: relative;
  z-index: 1050;
}

/* Bei success-only Modal den Close-Button verstecken */
#modalTermindetails.success-only #close_termindetails {
  display: none !important;
}

/* Fix für Hintergrundbild-Bewegung bei Accordion-Öffnung auf Mobilgeräten */
@media (max-width: 767.98px) {
  /* Stabiles Hintergrundbild ohne fixed attachment */
  body {
    background-attachment: scroll !important;
    background-position: center top !important;
    background-repeat: no-repeat !important;
    background-size: cover !important;
    min-height: 100vh;
  }
  
  /* Virtueller Container für stabiles Hintergrundbild */
  body::before {
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background: inherit;
    background-attachment: scroll;
    background-position: center top;
    background-repeat: no-repeat;
    background-size: cover;
    z-index: -1;
    will-change: transform;
    transform: translateZ(0);
  }
  
  /* Hauptinhalt über Hintergrundbild */
  body > * {
    position: relative;
    z-index: 1;
  }
  
  /* Accordion-Container stabilisieren */
  #dienstleistungen_accordion,
  #mitarbeiter_accordion {
    transform: translateZ(0);
    backface-visibility: hidden;
    will-change: height;
  }
  
  /* Smoothere Accordion-Animationen */
  #dienstleistungen_accordion .accordion-collapse,
  #mitarbeiter_accordion .accordion-collapse {
    transition: height 0.25s cubic-bezier(0.4, 0, 0.2, 1) !important;
  }
  
  /* Container für bessere Performance */
  #container_buchung,
  #sidebar_left {
    transform: translateZ(0);
    backface-visibility: hidden;
  }
}

/* Modal-Scroll-Fix für mobile Geräte */
@media (max-width: 767.98px) {
  /* Body-Scroll verhindern wenn Modal offen ist */
  body.modal-open {
    overflow: hidden !important;
    position: fixed !important;
    width: 100% !important;
    height: 100% !important;
  }
  
  /* Modal-Backdrop darf nicht gescrollt werden */
  .modal-backdrop {
    touch-action: none !important;
  }
  
  /* Modal fest in der Mitte positionieren - nur das nötigste */
  #modalTermindetails .modal-dialog {
    position: fixed !important;
    top: 50% !important;
    left: 50% !important;
    transform: translate(-50%, -50%) !important;
    margin: 0 !important;
    width: calc(100vw - 2rem) !important;
    max-height: calc(100vh - 2rem) !important;
  }
  
  #modalTermindetails .modal-content {
    max-height: calc(100vh - 2rem) !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }
}

/* Login Required Styles */
.sektion_buchung.login-required {
    opacity: 1.0;
    position: relative;
    transition: opacity 0.3s ease;
}

.sektion_buchung.login-required:hover {
    opacity: 0.9;
}

.sektion_buchung.login-required::after {
    /* 
    content: ''; 
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    pointer-events: none;
    z-index: 1;
    */
}

.sektion_buchung.login-required .sektion_ueberschrift_buchung {
    position: relative;
    z-index: 2;
}

/* Login Modal Enhancements */
#loginHinweisModal .modal-content {
    border: none;
    border-radius: 16px;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15);
}

#loginHinweisModal .btn-primary {
    border-radius: 12px;
    padding: 12px 24px;
    font-weight: 600;
    box-shadow: 0 4px 15px rgba(13, 110, 253, 0.3);
    transition: all 0.3s ease;
}

#loginHinweisModal .btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(13, 110, 253, 0.4);
}

#loginHinweisModal .btn-outline-primary {
    border-radius: 12px;
    padding: 12px 24px;
    font-weight: 500;
    transition: all 0.3s ease;
}

#loginHinweisModal .btn-outline-secondary {
    border-radius: 12px;
    padding: 8px 16px;
}

/* Login Error Messages Styling */
.invalid-feedback {
    display: block !important;
    margin-top: 0.5rem;
    padding: 0.5rem 0.75rem;
    background: linear-gradient(135deg, #dc3545 0%, #c82333 100%);
    color: white !important;
    border-radius: 8px;
    font-size: 0.875rem;
    font-weight: 500;
    box-shadow: 0 2px 8px rgba(220, 53, 69, 0.2);
    border-left: 4px solid #a71e2a;
    animation: errorSlideIn 0.3s ease-out;
    position: relative;
    z-index: 1000;
}

.invalid-feedback:empty {
    display: none !important;
}

/* Force visibility for debugging */
.invalid-feedback[style*="display: block"],
.invalid-feedback:not(:empty) {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
}

.invalid-feedback::before {
    content: '⚠ ';
    font-weight: bold;
    margin-right: 0.25rem;
}

@keyframes errorSlideIn {
    0% {
        opacity: 0;
        transform: translateY(-10px);
    }
    100% {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Enhanced form field styling for error state */
.form-control.is-invalid {
    border-color: #dc3545;
    box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.15);
    background-image: none;
}

.form-control.is-invalid:focus {
    border-color: #dc3545;
    box-shadow: 0 0 0 0.25rem rgba(220, 53, 69, 0.25);
}

/* Login Modal specific enhancements */
#modalLogin .form-control {
    transition: all 0.3s ease;
    border-radius: 8px;
}

#modalLogin .form-control:focus {
    box-shadow: 0 0 0 0.2rem rgba(13, 110, 253, 0.15);
    border-color: #86b7fe;
}

#modalLogin .input-group-text {
    border-radius: 8px 0 0 8px;
    background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
    border-color: #ced4da;
    color: #6c757d;
}

/* Datenschutz-Modal kompakt & einfarbig */
#modal_ds_formular .modal-header {
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
}
#modal_ds_formular .modal-title {
    font-size: 1.2rem;
}
#modal_ds_formular .modal-body {
    padding: 1rem 1.5rem;
}
#modal_ds_formular .bg-light {
    background: #f8f9fa !important;
}
#modal_ds_formular .form-check-input {
    margin-top: 0;
}
#modal_ds_formular .form-check-label {
    font-size: 0.98rem;
}
#modal_ds_formular .dsgvo-tile {
    padding: 0.25rem 0.1rem !important;
    min-height: 60px;
    background: #f8f9fa !important;
    border: 2px solid #0d6efd !important;
    border-radius: 10px !important;
    transition: box-shadow 0.2s;
    box-shadow: none;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}
#modal_ds_formular .dsgvo-tile i {
    font-size: 1.1rem !important;
    margin-bottom: 0.2rem !important;
}
#modal_ds_formular .dsgvo-tile .form-check-label,
#modal_ds_formular .dsgvo-tile span {
    color: #888 !important;
    transition: color 0.2s;
}
#modal_ds_formular .dsgvo-tile.selected .form-check-label,
#modal_ds_formular .dsgvo-tile.selected span {
    color: #0d6efd !important;
}
#modal_ds_formular .dsgvo-tile input[type="checkbox"] {
    margin-bottom: 0.1rem;
}

/* DSGVO-Kacheln: Initial grau, bei Auswahl blau */
#modal_ds_formular .dsgvo-tile {
    background: #f5f5f5 !important;
    border-color: #ccc !important;
    color: #888 !important;
    transition: background 0.2s, border-color 0.2s, color 0.2s;
}
#modal_ds_formular .dsgvo-tile .fas {
    color: #888 !important;
    transition: color 0.2s;
}
#modal_ds_formular .dsgvo-tile.selected {
    background: #e7f1fb !important;
    border-color: #0d6efd !important;
    color: #0d6efd !important;
}
#modal_ds_formular .dsgvo-tile.selected .fas {
    color: #0d6efd !important;
}

/* Modal-Body begrenzen, damit Footer immer sichtbar bleibt */
#modal_ds_formular .modal-body {
  max-height: 65vh;
  overflow-y: auto;
  /* Filigranerer Scrollbalken für Firefox */
  scrollbar-width: thin;
  scrollbar-color: #bdbdbd #f8f9fa;
}

/* Filigranerer Scrollbalken für Webkit-Browser (Chrome, Safari, Edge) */
#modal_ds_formular .modal-body::-webkit-scrollbar {
  width: 6px;
  background: #f8f9fa;
  border-radius: 3px;
}

#modal_ds_formular .modal-body::-webkit-scrollbar-track {
  background: #f8f9fa;
  border-radius: 3px;
}

#modal_ds_formular .modal-body::-webkit-scrollbar-thumb {
  background: #bdbdbd;
  border-radius: 3px;
  transition: background 0.2s ease;
}

#modal_ds_formular .modal-body::-webkit-scrollbar-thumb:hover {
  background: #9e9e9e;
}

/* Filigranerer Scrollbalken für ds_content */
#ds_content {
  /* Filigranerer Scrollbalken für Firefox */
  scrollbar-width: thin;
  scrollbar-color: #bdbdbd #f8f9fa;
}

/* Filigranerer Scrollbalken für ds_content - Webkit-Browser */
#ds_content::-webkit-scrollbar {
  width: 6px;
  background: #f8f9fa;
  border-radius: 3px;
}

#ds_content::-webkit-scrollbar-track {
  background: #f8f9fa;
  border-radius: 3px;
}

#ds_content::-webkit-scrollbar-thumb {
  background: #bdbdbd;
  border-radius: 3px;
  transition: background 0.2s ease;
}

#ds_content::-webkit-scrollbar-thumb:hover {
  background: #9e9e9e;
}

/* Modal-Footer für Datenschutz-Modal */
#modal_ds_formular .modal-footer {
  position: sticky;
  bottom: 0;
  z-index: 10;
  box-shadow: 0 -2px 8px rgba(0,0,0,0.1);
}

@media (max-width: 767.98px) {
  #modal_ds_formular .modal-body {
    max-height: 55vh;
  }
}

/* Bereiche ausblenden, wenn keine Kacheln sichtbar sind */
#kommunikation_section:has(#tg_mail_container.hidden, #tg_sms_container.hidden, #tg_post_container.hidden) {
  display: none !important;
}

#marketing_section:has(#mar_mail_container.hidden, #mar_sms_container.hidden, #mar_post_container.hidden) {
  display: none !important;
}

/* Fallback für Browser ohne :has() Support */
#kommunikation_section.hide-section,
#marketing_section.hide-section {
  display: none !important;
}

@media (max-width: 767.98px) {
  #modalLogin .form-control {
    font-size: 16px !important;
  }
}

/* Datenschutz-Einwilligung Text größer machen */
#datenschutz_initial_link {
  font-size: 1rem !important;
  font-weight: 500 !important;
}

/* Datenschutzerklärung Inhalt Text größer machen */
#ds_content {
  font-size: 1rem !important;
  line-height: 1.5 !important;
  text-align: left !important;
}

body.accessibility-mode .dienstleistung-item.selected,
body.accessibility-mode .mitarbeiter-item.selected {
  background: #fff !important;
  border-left: 4px solid #000 !important;
  box-shadow: 0 2px 8px rgba(0,0,0,0.10) !important;
}
body.accessibility-mode .dienstleistung-item.selected .dienstleistung-name,
body.accessibility-mode .mitarbeiter-item.selected .mitarbeiter-name {
  color: #000 !important;
}
body.accessibility-mode .dienstleistung-item.selected .dienstleistung-preis {
  color: #000 !important;
}
body.accessibility-mode .dienstleistung-item.selected::after,
body.accessibility-mode .mitarbeiter-item.selected::after {
  color: #000 !important;
  background: #fff !important;
  box-shadow: 0 2px 4px rgba(0,0,0,0.10) !important;
}
body.accessibility-mode .service-badge,
body.accessibility-mode .mitarbeiter-badge {
  background: #fff !important;
  color: #000 !important;
  box-shadow: 0 2px 4px rgba(0,0,0,0.10) !important;
  border: 1px solid #000 !important;
}
body.accessibility-mode .service-badge .service-name,
body.accessibility-mode .mitarbeiter-badge .mitarbeiter-name {
  color: #000 !important;
}
body.accessibility-mode .dsgvo-tile.selected {
  background: #fff !important;
  border-color: #000 !important;
  color: #000 !important;
}
body.accessibility-mode .dsgvo-tile.selected .fas,
body.accessibility-mode .dsgvo-tile.selected strong {
  color: #000 !important;
}

body.accessibility-mode .service-badge,
body.accessibility-mode .mitarbeiter-badge {
  background: #fff !important;
  color: #000 !important;
  border: 1px solid #000 !important;
  box-shadow: 0 2px 8px rgba(0,0,0,0.10) !important;
}
body.accessibility-mode .service-badge .service-name,
body.accessibility-mode .mitarbeiter-badge .mitarbeiter-name {
  color: #000 !important;
}
body.accessibility-mode .service-badge .remove-service,
body.accessibility-mode .mitarbeiter-badge .remove-mitarbeiter {
  background: #fff !important;
  color: #000 !important;
  border: 1px solid #000 !important;
}

body.accessibility-mode #selected_services_badges .service-badge,
body.accessibility-mode #selected_mitarbeiter_badges .mitarbeiter-badge {
  background: #fff !important;
  color: #000 !important;
  border: 1px solid #000 !important;
  box-shadow: 0 2px 8px rgba(0,0,0,0.10) !important;
}
body.accessibility-mode #selected_services_badges .service-badge .service-name,
body.accessibility-mode #selected_mitarbeiter_badges .mitarbeiter-badge .mitarbeiter-name {
  color: #000 !important;
}
body.accessibility-mode #selected_services_badges .service-badge .remove-service,
body.accessibility-mode #selected_mitarbeiter_badges .mitarbeiter-badge .remove-mitarbeiter {
  background: #fff !important;
  color: #000 !important;
  border: 1px solid #000 !important;
}

body.accessibility-mode .termine-grid-timeslot {
  background: #fff !important;
  color: #000 !important;
  border: 2px solid #000 !important;
  box-shadow: none !important;
}
body.accessibility-mode .termine-grid-timeslot:hover,
body.accessibility-mode .termine-grid-timeslot:focus {
  background: #e9ecef !important;
  color: #000 !important;
}
body.accessibility-mode .termine-grid-block-label {
  color: #000 !important;
}

/* Accordion-Button: Lange Texte und Icon direkt neben dem Text */
.accordion-button.sektion_ueberschrift_buchung {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  white-space: normal;
  word-break: break-word;
  padding-right: 1.5rem;
}

.accordion-button .accordion-text {
  flex: 0 1 auto;
  min-width: 0;
  white-space: normal;
  word-break: break-word;
  margin-right: 0.5rem;
}

.accordion-button .fa,
.accordion-button .bi {
  flex-shrink: 0;
  margin-left: 0;
  margin-right: auto;
}

@media (max-width: 576px) {
  .accordion-button.sektion_ueberschrift_buchung {
    padding-left: 0.75rem;
    padding-right: 0.75rem;
    font-size: 15px;
  }
}

@media (max-width: 767.98px) {
  .dienstleistung-name {
    text-align: left !important;
    width: 100%;
    display: block;
  }
}

/* Internetverbindungsproblem Modal Styles */
#internetProblemModal .modal-header {
  border-bottom: 3px solid #ffc107;
}

#internetProblemModal .problem-icon {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 120px;
  background: linear-gradient(135deg, #fff3cd 0%, #ffeaa7 100%);
  border-radius: 50%;
  margin: 0 auto;
  width: 120px;
  box-shadow: 0 4px 12px rgba(255, 193, 7, 0.3);
}

#internetProblemModal .problem-content h6 {
  font-weight: 600;
  color: #856404;
}

#internetProblemModal .alert-info {
  border-left: 4px solid #17a2b8;
  background: linear-gradient(135deg, #d1ecf1 0%, #bee5eb 100%);
}

#internetProblemModal .salon-contact-info {
  border: 1px solid #dee2e6;
  background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
}

#internetProblemModal .salon-contact-info h6 {
  color: #495057;
  font-weight: 600;
}

#internetProblemModal .btn-primary {
  background: var(--bs-primary) !important;
  color: #fff !important;
  border: none;
  box-shadow: none;
  transition: background 0.2s;
}

#internetProblemModal .btn-primary:hover, #internetProblemModal .btn-primary:focus {
  background: var(--bs-primary-dark, #0a58ca) !important;
  color: #fff !important;
  box-shadow: none;
  transform: none;
}

#internetProblemModal .btn-secondary {
  background: linear-gradient(135deg, #6c757d 0%, #545b62 100%);
  border: none;
  box-shadow: 0 2px 8px rgba(108, 117, 125, 0.3);
  transition: all 0.3s ease;
}

#internetProblemModal .btn-secondary:hover {
  background: linear-gradient(135deg, #545b62 0%, #3d4449 100%);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(108, 117, 125, 0.4);
}

/* Responsive Anpassungen für das Modal */
@media (max-width: 767.98px) {
  #internetProblemModal .modal-dialog {
    margin: 0.5rem;
  }
  
  #internetProblemModal .problem-icon {
    width: 80px;
    height: 80px;
  }
  
  #internetProblemModal .problem-icon i {
    font-size: 2.5rem !important;
  }
  
  #internetProblemModal .col-md-3 {
    margin-bottom: 1rem;
  }
}

/* Animation für das Modal */
#internetProblemModal .modal-content {
  animation: slideInDown 0.3s ease-out;
}

@keyframes slideInDown {
  from {
    transform: translateY(-50px);
    opacity: 0;
  }
  to {
    transform: translateY(0);
    opacity: 1;
  }
}

/* Hover-Effekte für Links */
#internetProblemModal a {
  transition: all 0.2s ease;
}

#internetProblemModal a:hover {
  color: #0056b3 !important;
  text-decoration: underline !important;
}

/* Accessibility-Verbesserungen */
#internetProblemModal .btn:focus {
  box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25);
}

#internetProblemModal .btn-close:focus {
  box-shadow: 0 0 0 0.2rem rgba(0, 0, 0, 0.25);
}

#modalTermindetails #agb_cbx_container .form-check-input[type="checkbox"] {
    border: 2px solid #333 !important;
    box-shadow: 0 0 2px #222;
    width: 1.2em;
    height: 1.2em;
}

/* Datenschutzmodal: Höhe begrenzen und scrollbar machen */
#modal_datenschutz .modal-dialog {
  max-width: 800px;
  max-height: 90vh;
  margin: 30px auto;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
#modal_datenschutz .modal-content {
  max-height: 90vh;
  display: flex;
  flex-direction: column;
}
#modal_datenschutz .modal-body {
  overflow-y: auto;
  max-height: 65vh;
  /* für Footer und Header Platz lassen */
  padding-right: 12px;
  scrollbar-width: thin;
  scrollbar-color: #b0b0b0 #f5f5f5;
}
#modal_datenschutz .modal-body::-webkit-scrollbar {
  width: 7px;
  background: #f5f5f5;
}
#modal_datenschutz .modal-body::-webkit-scrollbar-thumb {
  background: #b0b0b0;
  border-radius: 4px;
}
#modal_datenschutz .modal-body::-webkit-scrollbar-thumb:hover {
  background: #888;
}

/* Impressum-Modal: Höhe begrenzen und scrollbar machen */
#modal_impressum .modal-dialog {
  max-width: 800px;
  max-height: 90vh;
  margin: 30px auto;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
#modal_impressum .modal-content {
  max-height: 90vh;
  display: flex;
  flex-direction: column;
}
#modal_impressum .modal-body {
  overflow-y: auto;
  max-height: 65vh;
  /* für Footer und Header Platz lassen */
  padding-right: 12px;
  scrollbar-width: thin;
  scrollbar-color: #b0b0b0 #f5f5f5;
}
#modal_impressum .modal-body::-webkit-scrollbar {
  width: 7px;
  background: #f5f5f5;
}
#modal_impressum .modal-body::-webkit-scrollbar-thumb {
  background: #b0b0b0;
  border-radius: 4px;
}
#modal_impressum .modal-body::-webkit-scrollbar-thumb:hover {
  background: #888;
}
