:root {
    --main-font-family: "Noto Sans", Helvetica;
    --headline-font-family: "Inter", sans-serif;
    --color-blue-100: #014997;
    --color-black: #000000;
    --color-blue-light: #f6faff;
    --color-grey-light: #f4f4f4;
    --color-blue-dark: #013A77;
    --color-blue-ccag: #004799;
    --color-orange: #f59b00;
    --color-orange-light: #fef6e8;
    --color-black-2: #333333;
    --color-white: #ffffff;
    --default-font-size: 16px;
    --bs-navbar-toggler-icon-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%280, 0, 0, 0.55%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}
/** Variables */

body {
    font-family: var(--main-font-family);
    color: var(--color-black-2);
    hyphens: auto;
}

.nurmobil{display:inline;}
.mobilth { display: inline-grid;}
.nichtmobil{display:none;}


/** Container */
.container {
    max-width: 1200px;
}

.container.large {
    max-width: 1440px;
}


input.submitbutton, input.submitbuttonblau{background-color:#004799;color:#ffffff;}

/* direktbuchungsmenue unten*/
div#xmenu_direktbuchung2  {
	display: block; 
	color: #ffffff; 
	min-height: 1.5em;	
	position:relative;
	top:0;left:0;
	width: 280px;
	margin-left: 0;
	margin-right: auto;
	margin-bottom: 0;
	padding: .5em  .5em  .5em 0;
	border-radius: 30px;
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	line-height: 18px;
	letter-spacing: 0px;
	
}
div#xmenu_direktbuchung2 span.menu_blanko_nav, 
div#xmenu_direktbuchung2 span.menu_blanko_nava{display:none;}
div#xmenu_direktbuchung2:hover span{	animation:600ms ease 0s normal none 1 running fadeIn;		margin-left:0px;	margin-right:10px; margin-top:0.4em;	margin-bottom:0.4em;	padding:0.4em 0.4em 0.4em 1em;	text-align:left;	display: block;	color:#fff;	background-color:#004799;	/*border: solid 1px #545353;box-shadow: 0 1px 2px rgba(0,0,0,.3);*/	border-radius: 30px;	}
div#xmenu_direktbuchung2 a:link,
div#xmenu_direktbuchung2 a:visited, 
div#xmenu_direktbuchung2 a:hover, 
div#xmenu_direktbuchung2 a:active{text-transform: none;white-space:nowrap;font-size:12px;font-weight:normal;color:#fff;text-decoration:none;}
div#xmenu_direktbuchung2:hover span.menu_blanko_nav, 
div#xmenu_direktbuchung2:hover span.menu_blanko_nav a.menu33 {background-color:#004799; color:#fff;}   	
div#xmenu_direktbuchung2:hover span.menu_blanko_nav, 
div#xmenu_direktbuchung2:hover span.menu_blanko_nav a:link, 
div#xmenu_direktbuchung2:hover span.menu_blanko_nav a:hover,
div#xmenu_direktbuchung2:hover span.menu_blanko_nav a:visited,
div#xmenu_direktbuchung2:hover span.menu_blanko_nav a:active { color:#fff;}   	
div#xmenu_direktbuchung2:hover span.menu_blanko_nav:hover, 
div#xmenu_direktbuchung2:hover span.menu_blanko_nav:hover a {background-color:#013A77; color:#fff;}   	
div#xmenu_direktbuchung2:hover span.menu_blanko_nav a.menu33:hover  { background-color:#013A77; color:#fff;display:block;}  




@media all and (min-width: 1200px) {
    .offset-left {
        margin-left: calc((100% - 1200px) / 2);
        width: calc(100% - ((100% - 1200px) / 2));
    }
}

.main-container {
    padding-top: 26px;
    margin-top: 233px;
}

@media all and (max-width: 767px) {
    .content .container,
    .content .container-fluid {
        margin-bottom: 50px;
    }

    .page.content {
        margin-top: 95px;
    }
    .content .container-fluid.container-produebersicht { margin-bottom: 30px; }
		
	/* Offset für Sprungmarken */
a.anker{scroll-margin-top:95px;}
		
}

@media all and (min-width: 768px) {
	.content .container,
    .content .container-fluid {
       /* für sprachschueler einleitung von 140 auf 80px runtergesetzt: margin-bottom: 140px;*/
        margin-bottom: 80px;
    }
    .page.content {
        margin-top: 275px;
    }
    .content .container-fluid.container-produebersicht {margin-bottom: 30px;}

 div#xmenu_direktbuchung2  {display: none;} 
	
/* Offset für Sprungmarken */
a.anker{scroll-margin-top:275px;}	
		
}

@media all and (min-width: 768px) and (max-width: 1230px){
    .page.content {
        padding-left: 12px;
        padding-right: 12px;
    }
}

/** Typography */
.semi, .semi-18 {
    font-weight: 600;
    color: var(--color-black-2);
}

.h1 {
    font-weight: 500;
}

.h2 {
    font-weight: 500;
}

.h3 {
    font-weight: 400;
}

.h4 {
    font-weight: 500;
}

.h5 {
    font-weight: 500;
}

@media all and (max-width: 767px) {
    .semi {
        font-size:14px;
        line-height: 20px;
    }

    .semi-18 {
        font-size: 16px;
        line-height: 24px;
    }
}

@media all and (min-width: 768px) {
    .semi {
        font-size: 16px;
        font-weight: 600;
        line-height: 24px;
    }

    .semi-18 {
        font-size: 18px;
        line-height: 26px;
    }

    .h1 {
        /*font-size: 58px;
        line-height: 79px;*/
        font-size: 50px;
        line-height: 71px;
		hyphens:none;
    }

    .h2 {
        font-size: 44px;
        line-height: 60px;
		hyphens:none;
    }

    .h3 {
        font-size: 30px;
        line-height: 43px;
		hyphens:none;
    }

    .h4 {
        font-size: 24px;
        line-height: 33px;
		hyphens:none;
    }

    .h5 {
        font-size: 18px;
        font-weight: 500;
        line-height: 25px;
		hyphens:none;
    }
}

/** Buttons */
button.primary, a.button.primary {
    display: inline-block;
    background-color: var(--color-blue-100);
    border-radius: 30px;
    color: var(--color-white);
    font-weight: 600;
    text-align: center;
    border: none;
    text-decoration: none;
}
button.primary.orange, a.button.primary.orange {
    background-color: var(--color-orange);
}
button.chip, a.button.chip, button.chip_sm, a.button.chip_sm {
    display: inline-block;
    color: var(--color-blue-100);
    border-radius: 30px;
    background-color: var(--color-blue-light);
    font-weight: 500;
    text-align: center;
    border: 1px solid #dee2e6 !important;
    text-decoration: none;
	margin-bottom:1em;
}
@media all and (max-width: 767px) {
    button.primary, a.button.primary {
        min-height: 40px;
        padding: 10px 15px;
        border-radius: 30px;
        font-size: 14px;
        line-height: 16px;
    }
	
.produktbanner button.primary,.produktbanner  a.button.primary {min-height: 30px;
        padding: 5px 15px;
        border-radius: 30px;
        font-size: 13px;
        line-height: 16px;}
    button.chip, a.button.chip {
        min-height: 40px;
        padding: 10px 15px;
        border-radius: 30px;
        font-size: 14px;
        line-height: 16px;
    }
	button.chip_sm, a.button.chip_sm {
		min-height: 30px;
        padding: 3px 5px;
        border-radius: 20px;
        font-size: 12px;
        line-height: 20px;}
	
	
}

@media all and (min-width: 768px) {
    button.primary, a.button.primary {
        min-height: 55px;
        padding: 15px 24px;
        border-radius: 30px;
        font-size: 18px;
        line-height: 25px;
    }
    button.chip, a.button.chip {
        min-height: 55px;
        padding: 15px 24px;
        border-radius: 30px;
        font-size: 18px;
        line-height: 25px;
		margin-bottom:1em;
    }
    button.chip_sm, a.button.chip_sm {
        min-height: 37px;
        padding: 5px 16px;
        border-radius: 15px;
        font-size: 14px;
        line-height: 22px;
		margin-bottom:1em;
    }

.nurmobil{display:none;}
.nichtmobil{display:block;}
}

button.sm, a.button.sm {
    padding: 10px 24px;
}

button.primary:hover, a.button.primary:hover {
    background-color: var(--color-blue-dark);
    box-shadow: 10px 10px 25px 0 #00000026;
}


button.primary.orange:hover, a.button.primary.orange:hover {
    background-color: var(--color-orange);
    box-shadow: 10px 10px 25px 0 #00000026;
}

button.chip:hover, a.button.chip:hover {
    background-color: var(--color-white);
    box-shadow: 10px 10px 25px 0 #00000026;
}

button.chip.aktiv, a.button.chip.aktiv {
     color: var(--color-white);
   background-color: var(--color-blue-ccag);
    box-shadow: 10px 10px 25px 0 #00000026;
}

button.secondary, a.button.secondary {
    background-color: var(--color-white);
    color: var(--color-blue-100);
    display: inline-block;
    text-decoration: none;
    border: none;
    padding: 15px 24px;
    font-size: 16px;
    line-height: 22px;
    font-weight: 600;
}

button.secondary:hover, a.button.secondary:hover {
    box-shadow: 10px 10px 25px 0 #00000026;
    cursor: pointer;
}


/** links */
a {
    font-weight: 600;
    color: var(--color-black-2);
}

a:hover {
    color: var(--color-blue-100);
}

/** colors */
.color-orange {
    color: var(--color-orange);
}

.color-white {
    color: var(--color-white);
}
.bg-color-orange {
    background-color: var(--color-orange);
}

.bg-light-orange {
    background-color: var(--color-orange-light);
}

.bg-light-blue {
    background-color: var(--color-blue-light);
}

.bg-color-blue {
    background-color: var(--color-blue-100);
}


.bg-light-grey {
    background-color: var(--color-grey-light);
}

.border-orange { border:1px solid var(--color-orange);}
/** borders */
.border-radius-30 {    border-radius: 30px;}

@media all and (min-width: 768px) {
    .border-radius-desktop-30 {        border-radius: 30px;    }
}

/** toolbar */
.toolbar, .toolbar2 {    z-index: 1;    right: 20px;    gap: 15px;
}

.toolbar .tool, .toolbar2 .t0ol {    border-radius: 50%;    background-color: var(--color-orange);}

.tool img {    width: 28px;    height: 28px;}

@media all and (max-width: 1200px) {
	.toolbar {		/*bottom: 15px;*/		bottom: 85px;	}
	.toolbar2{top: 50px;}
    .tool {        width: 50px;        height: 50px;    }
}
@media all and (min-width: 1201px) {
    /*.toolbar {
        top: 419px;
        height: 345px;
    }*/
	.toolbar2{top: 250px;  height: 345px;}
    .toolbar {bottom: 30px; height: 170px;}
    .tool {width: 50px; height: 50px;}
}

/** FAQ Index Cards */
.faq-card {
	border: 1px solid #dee2e6;
	border-radius: 0.75rem;
	transition: all 0.3s ease;
	background: white;
}

.faq-card:hover {
	border-color: var(--color-blue-100, #014997);
	box-shadow: 0 4px 15px rgba(1, 73, 151, 0.15);
	transform: translateY(-2px);
}

.faq-card .card-body {
	padding: 1.25rem;
}

.faq-icon {
	width: 48px;
	height: 48px;
	border-radius: 0.5rem;
	background: linear-gradient(135deg, #e8f4fd 0%, #d0e8f9 100%);
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--color-blue-100, #014997);
	flex-shrink: 0;
}

.faq-card:hover .faq-icon {
	background: linear-gradient(135deg, var(--color-blue-100, #014997) 0%, #0056b3 100%);
	color: white;
}

.faq-card .card-title {
	color: #333;
	font-weight: 600;
}

.faq-card:hover .card-title {
	color: var(--color-blue-100, #014997);
}

/** Responsive Tables - Desktop */
.responsive-table-wrapper {
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}

.responsive-table {
	font-size: 0.9em;
	table-layout: fixed;
	width: 100%;
}

.responsive-table .highlight-row {
	background-color: rgba(13, 110, 253, 0.05);
}

.responsive-table .table-light th {
    background-color: #f8f9fa;
    /* border: 2px solid #dee2e6; */
    font-weight: 600;
    color: #212529;
    padding: 1rem 0rem;
}

.responsive-table td,
.responsive-table th {
	white-space: normal;
	word-wrap: break-word;
	overflow-wrap: break-word;
}

.responsive-table .pramie{
    background-color: #014997;
    color: white;
    padding: 1rem;
    border-radius: 0px 0px 1rem 1rem;
}

/** Responsive Tables - Mobile */
@media screen and (max-width: 767px) {
	.responsive-table thead {
		display: none;
	}
	
	.responsive-table,
	.responsive-table tbody,
	.responsive-table tr {
		display: block;
		width: 100%;
	}
	
	.responsive-table tr {
		margin-bottom: 1rem;
		background: white;
		border: 1px solid #dee2e6;
		border-radius: 0.375rem;
		padding: 0.75rem;
		box-shadow: 0 0.125rem 0.25rem rgba(0,0,0,0.075);
	}

	.responsive-table tr:nth-of-type(odd) {
		background-color: var(--color-grey-light);
	}
	
	.responsive-table tr.highlight-row {
		border-left: 4px solid var(--color-blue-ccag);
		background-color: var(--color-blue-light);
	}
	
	.responsive-table td {
		display: block;
		text-align: left !important;
		border: none;
		padding: 0.5rem 0;
		position: relative;
	}
	
	.responsive-table td[data-label]:not([data-label=""]):before {
		content: attr(data-label);
		display: block;
		font-weight: 600;
		color: var(--color-blue-ccag);
		font-size: 0.875rem;
		margin-bottom: 0.25rem;
	}
	
	.responsive-table td[colspan] {
		padding-top: 0.75rem;
		background: none;
	}

	.responsive-table td:empty {
		display: none;
	}
	
	.responsive-table tfoot tr {
		background-color: var(--color-blue-light);
		border: 2px solid #dee2e6;
	}
	
	.responsive-table tfoot td {
		text-align: center !important;
		font-size: 1rem;
		padding: 1rem 0.5rem;
	}
}

/* ============================================
   PRICING TABLE RESPONSIVE - Care College
   ============================================ */

.pricing-table-responsive {
	font-size: 0.9em;
}

/* Desktop Styles */
@media screen and (min-width: 768px) {
	.pricing-table-responsive .bestseller-banner th {
		border: none;
		background: transparent;
		padding: 0px;
	}
	
	.pricing-table-responsive .bestseller-badge {
		background: linear-gradient(135deg, #f59b00 0%, #ff6b35 100%);
		color: white;
		padding: 0.4rem 1rem;
		border-radius: 1.5rem 1.5rem 0 0;
		font-weight: 700;
		font-size: 0.8rem;
		text-transform: uppercase;
		letter-spacing: 0.5px;
		box-shadow: 0 2px 8px rgba(245, 155, 0, 0.3);
        text-align: center;
	}
	
	.pricing-table-responsive .plan-headers th {
		padding: 1.25rem 0.75rem;
		vertical-align: bottom;
		text-align: center;
		/* border-bottom: 2px solid #004799; */
	}
	
	.pricing-table-responsive {
		max-width: 100%;
		table-layout: fixed;
		width: 100%;
	}
	
	.pricing-table-responsive .feature-col {
		text-align: left !important;
		font-weight: 600;
		color: #004799;
		width: 35%;
	}
	
	.pricing-table-responsive .plan-col {
		width: 21.66%;
	}
	
	.pricing-table-responsive .plan-subtitle {
		font-size: 0.85em;
		font-weight: normal;
		color: #666;
	}
	
	.pricing-table-responsive .plan-name {
		display: block;
		font-size: 1.1em;
		font-weight: 700;
		color: #004799;
		text-transform: uppercase;
		margin-bottom: 0.25rem;
	}
	
	.pricing-table-responsive .plan-price {
		font-size: 0.85em;
		color: #666;
	}
	
	.pricing-table-responsive .plan-price strong {
		font-size: 1.3em;
		color: #004799;
	}
	
	.pricing-table-responsive .bestseller-col {
		background: linear-gradient(180deg, #fffbf0 0%, #fff8e6 100%);
		border-left: 1px solid #f59b00;
		border-right: 1px solid #f59b00;
		position: relative;
	}
	
	.pricing-table-responsive .plan-headers .bestseller-col {
		border-top: 3px solid #f59b00;
	}
	
	.pricing-table-responsive tbody .section-row {
		background: transparent;
	}
	
	.pricing-table-responsive .section-header {
		background-color: #ddedff;
		color: var(--color-blue-dark);
		font-weight: 700;
		text-align: left;
		padding: 0.75rem 1rem;
		font-size: 1em;
		text-transform: uppercase;
		letter-spacing: 0.5px;
	}
	
	.pricing-table-responsive .feature-cell {
		text-align: left;
		padding: 0.875rem 1rem;
		font-weight: 500;
		color: #333;
		white-space: normal;
		word-wrap: break-word;
		overflow-wrap: break-word;
		hyphens: auto;
	}
	
	.pricing-table-responsive .value-cell {
		text-align: center;
		padding: 0.875rem 0.5rem;
		vertical-align: middle;
		white-space: normal;
		word-wrap: break-word;
		overflow-wrap: break-word;
	}
	
	.pricing-table-responsive tbody tr:hover:not(.section-row):not(.cta-row) {
		background-color: #f8f9fa;
	}
	
	.pricing-table-responsive img {
		max-width: 20px;
		height: auto;
	}
	
	.pricing-table-responsive .cta-row {
		background: transparent;
		border: none;
	}
	
	.pricing-table-responsive .cta-row td {
		border: none;
		padding-top: 2rem;
	}
    .title-text-block .text-center .button {
        margin-top: 10px;
        margin-bottom: 40px;
    }
}

/* Mobile Transformation */
@media screen and (max-width: 767px) {
	.pricing-table-responsive .bestseller-banner {
		display: none;
	}
	
	.pricing-table-responsive .plan-headers {
		display: none;
	}
	
	.pricing-table-responsive,
	.pricing-table-responsive tbody {
		display: block;
		width: 100%;
	}
	
	.pricing-table-responsive tbody tr {
		display: block;
		margin-bottom: 1.5rem;
		background: white;
		border: 1px solid #dee2e6;
		border-radius: 0.5rem;
		padding: 0;
		box-shadow: 0 2px 8px rgba(0,0,0,0.1);
		overflow: hidden;
	}
	
	/* Section Headers - Full Width Blue Bar */
	.pricing-table-responsive .section-row {
		background: transparent;
		border: none;
		box-shadow: none;
		padding: 0;
		margin: 2rem 0 0 0;
        border-radius: 10px 10px 0px 0px;
	}
	
	.pricing-table-responsive .section-header {
		display: block;
		background-color: #ddedff;
		color: var(--color-blue-dark);
		padding: 0.75rem 1rem;
		margin: 0;
		font-weight: 700;
		font-size: 1em;
		text-transform: uppercase;
		text-align: center;
		border-radius: 0rem;
        border-bottom-width: 0px;
	}
	
	/* Feature Rows */
	.pricing-table-responsive tbody tr:not(.section-row):not(.cta-row) {
		display: grid;
		grid-template-columns: 1fr;
		gap: 0;
		padding: 1rem;
	}
	
	/* Feature Name - Top of Card */
	.pricing-table-responsive .feature-cell {
		display: block;
		font-weight: 600;
		color: #004799;
		padding: 0 0 0.75rem 0;
		border-bottom: 2px solid #e9ecef;
		margin-bottom: 0.75rem;
		text-align: left;
		font-size: 0.95em;
	}
	
	/* Plan Values - 3 Boxes */
	.pricing-table-responsive .value-cell {
		display: flex;
		align-items: center;
		justify-content: space-between;
		padding: 0.65rem 0.75rem;
		margin: 0.3rem 0;
		border-radius: 0.375rem;
		background-color: #f8f9fa;
		border: 1px solid #dee2e6;
	}
	
	/* Bestseller Box Highlight */
	.pricing-table-responsive .value-cell.bestseller-col {
		background: linear-gradient(135deg, #fff8e6 0%, #fffbf0 100%);
		border: 2px solid #f59b00;
		font-weight: 600;
		box-shadow: 0 2px 4px rgba(245, 155, 0, 0.15);
	}
	
	/* Plan Labels */
	.pricing-table-responsive .value-cell::before {
		content: attr(data-label) ": ";
		font-weight: 700;
		color: #004799;
		font-size: 0.85em;
		text-transform: uppercase;
		letter-spacing: 0.3px;
	}
	
	.pricing-table-responsive .value-cell.bestseller-col::before {
		color: #f59b00;
	}
	
	/* Icons */
	.pricing-table-responsive .value-cell img {
		max-width: 18px;
		height: auto;
		margin-left: auto;
	}
	
	/* CTA Row */
	.pricing-table-responsive .cta-row {
		background: transparent;
		border: none;
		box-shadow: none;
		text-align: center;
		margin-top: 1rem;
	}
	
	.pricing-table-responsive .cta-row td {
		display: block;
		border: none;
		padding: 0;
	}
	
	.pricing-table-responsive .cta-row .button {
		width: 100%;
		max-width: 300px;
		margin: 0 auto;
		display: block;
	}
}