/* -- TODO: extract into unique location (css/phtml) -- */
:root {
	--cl-header-dark: rgba(0, 43, 76, .9);
	
	--cl-primary: #0066b3;
	--cl-primary-dark: #103152;
	--cl-primary-tint: #005236e6;
	--cl-secondary: #ff6600;
	
	--cl-muted: #707070;
	--cl-light: #ececec;
	
	--cl-header-dark: rgba(0, 43, 76, .9);
}

body {
	padding-top: 100px;
	padding-top: 25px;
	
	padding-top: 0;
	
	line-height: 1.6;
}
body.content {
	background: #ececec;
}
body.admin {
	/*padding-top: 100px;*/
	background: #ececec;
}


body.area-promotion main > .section-default:first-child {
	padding-top: 0;
}


.meta-header {
	position: sticky;
}

/* -- admin area page wrap -- */
.admin-wrap {
	background: white;
	padding: 40px 40px 80px;
}


/* -- admin full page dialog -- */
.dialog-wrap {
	margin: 100px 0 200px;
	background: white;
	padding: 40px;
	border-radius: 0 24px 0 24px;
}
@media (min-width: 992px) {
	.dialog-wrap {
		margin: 100px 200px 200px;
	}
}

	.dialog-wrap.dialog-shadow {
		box-shadow: 0 0 8px #0000001a;
	}

.dialog-wrap h1 {
	margin-top: 0;
	margin-bottom: 20px;
}

h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
	color: #707070;
	font-weight: normal;
}

.label .fe {
	font-size: 15px;
	vertical-align: middle;
}

.fe-10 {
	font-size: 10px;
}
.fe-12 {
	font-size: 12px;
}
.fe-14 {
	font-size: 14px;
}
.fe-16 {
	font-size: 16px;
}
.fe-18 {
	font-size: 18px;
}
.fe-20 {
	font-size: 20px;
}
.fe-22 {
	font-size: 22px;
}
.fe-24 {
	font-size: 24px;
}
.fe-26 {
	font-size: 26px;
}
.fe-28 {
	font-size: 28px;
}
.fe-30 {
	font-size: 30px;
}
.fe-32 {
	font-size: 32px;
}
.fe-34 {
	font-size: 34px;
}
.fe-36 {
	font-size: 36px;
}



/* debug: make title attributes visible */
table.table-debug td:before {
	content: attr(title);
	display: block;
	font-size: 75%;
}

.hint-admin:before {
	content: "ADMIN";
	font-size: .6em;
	position: absolute;
	top: 0px;
	right: 0;
	background: rgba(255, 102, 0, .6);
	padding: 2px 6px;
	opacity: 1;
	border-radius: 0 0 0 5px;
	color: white;
	letter-spacing: 1px;
}

.text-help {
	border-bottom: 3px dashed #0066b3;
	cursor: help;
}


.btn .fe:first-child {
	/* does not work: table buttons misaligned */
	/*margin-left: 0;*/
}
.nav-tabs.nav-tabs-large {
	font-size: 16px;
	font-weight: bold;
}
.nav-tabs.nav-tabs-large > li:first-child {
	margin-left: 5px;
}


.btn.btn-nowrap,
.box-content .bootstrap-table .btn {
	white-space: nowrap;
}


/* -- tab icons -- */
.nav-tabs a>i.fe {
	font-size: 18px;
	margin-right: 4px;
}


.anchor-offset {
	position: relative; top: -130px;
}


input.form-radio {
	border: 2px solid black;
	background: blue;
}

input.form-radio:after {
	content: "";
	display: block;
	background: white;
	width: 16px;
	height: 16px;
	border: 1px solid #ccc;
	background: white;
	border: 5px solid white;
	box-shadow: 0 0 0 1px #ccc;
}

input.form-radio:checked:after {
	background: #0066b3;
	border: 5px solid white;
	box-shadow: 0 0 0 1px #0066b3;
}

input.form-radio {
	margin-right: 10px;
	margin-bottom: 10px;
}




.promotion-form .message.message-error {
	background: red;
	border-color: #9f0000;
}

.section-default h2 {
	text-transform: none;
}


img.image-default {
	max-width: 100%;
	border-radius: 0 8px 0 8px;
}

img.full-width {
	width: 100%;
}

img.img-dom {
	max-width: 100%;width: 100%;
}

.content-wrap.grey {
	background: #f4f4f4;
}

	@media (max-width: 768px) {
		.section-default h2 {
			text-align: left;
		}
		.admin-wrap {
			padding: 40px 20px;
		}
	}

.section-default {
	background-color: transparent;
}

.section-default.no-padding {
	padding: 0;
}
	.section-default.no-padding-top {
		padding-top: 0;
	}
	.section-default.no-padding-bottom {
		padding-bottom: 0;
	}

.section-default.section-white {
	background: white;
}
.section-default.section-grey {
	background-color: #f9f9f9;
	margin: 40px 0;
}



.section-default.section-promotions {
	padding-bottom: 200px;
}




.text-primary {
	color: var(--cl-primary);
}

.text-secondary {
	color: var(--cl-secondary);
}


.background-primary {
	background-color: var(--cl-primary);
	color: white;
}
	.background-primary h1,
	.background-primary h2,
	.background-primary h3,
	.background-primary h4,
	.background-primary h5,
	.background-primary h6,
	.background-primary .h1,
	.background-primary .h2,
	.background-primary .h3,
	.background-primary .h4,
	.background-primary .h5,
	.background-primary .h6 {
		color: white;
	}



.section-default.section-dark {
	background-color: var(--cl-header-dark);
	background-color: var(--cl-primary-dark);
	color: white;
}

	.text-white h1,
	.text-white h2,
	.text-white h3,
	.text-white h4,
	.text-white h5,
	.text-white h6,
	.text-white .h1,
	.text-white .h2,
	.text-white .h3,
	.text-white .h4,
	.text-white .h5,
	.text-white .h6 {
		color: white;
	}
	
	.section-default.section-dark h1,
	.section-default.section-dark h2,
	.section-default.section-dark h3,
	.section-default.section-dark h4,
	.section-default.section-dark h5,
	.section-default.section-dark h6,
	.section-default.section-dark .h1,
	.section-default.section-dark .h2,
	.section-default.section-dark .h3,
	.section-default.section-dark .h4,
	.section-default.section-dark .h5,
	.section-default.section-dark .h6 {
		color: white;
	}



.section.section-dashboard {
	margin-bottom: 100px;
}

.text-upper {
	text-transform: uppercase;
}

.logo-claim {
	white-space: nowrap;
}

.btn-label {
	display: none;
}
.btn {
	border: 0;
	padding: 8px 20px;
	border-radius: 0 12px 0 12px;
}
/* @todo check
	.btn + .btn {
		margin: 1em 0.5em;
	}
*/

.btn-delete-confirm {
	/*margin-left: 20px;*/
}

.btn-xs {
	padding: 2px 8px;
	font-size: 1em;
}
.btn-xs .fe {
	font-size: 1em;
}


.btn-square {
	border-radius: 0;
}





.login-wrap {
	background-color: #f9f9f9;
	padding: 40px;
}


.section-default a.btn {
	color: white;
}

.btn-primary {
	background-color: var(--cl-primary);
	border-color: var(--cl-primary);
}
.btn-primary:hover {
	background-color: var(--cl-primary-dark);
	border-color: var(--cl-primary-dark);
}

.section-default a.btn.btn-white {
	color: var(--cl-secondary);
	background-color: white;
}
.section-default a.btn.btn-transparent {
	color: var(--cl-secondary);
	background-color: transparent;
}














/* -- CONTENT ELEMENTS -- */

@media (min-width: 991px) {
	
	.hero-teaser .column-text {
		position: absolute;
		top: 50px;
		right: 0;
	}
	
}

.hero-teaser .box {
	padding: 30px 0;
	background: rgb(255 255 255 / 90%);
	border-radius: 0 8px 0 8px;
}

@media (min-width: 991px) {
	
	.hero-teaser .box {
		padding: 30px;
	}
}


.hero-teaser .box h1,
.hero-teaser .box h2 {
	margin: 0;
	font-size: 32px;
	line-height: 1.25;
}

.hero-teaser {
	margin-bottom: 40px;
}



	@media (max-width: 991px) {
	
		.text-image .column-image {
			order: 0;
			margin-bottom: 20px;
		}
	
		.text-image .column-text {
			order: 1;
		}
	
		.row.text-image {
			display: flex;
			flex-direction: column;
		}
		
	}




.section-container {
	margin: 80px 0;
}

.section-container:last-child {
	margin-bottom: 0;
}

h3 {
	color: var(--cl-secondary);
}







.promo-image-side {
	max-width: 100%;
	border-radius: 8px;
}

@media (min-width: 768px) {
	.promo-image-side {
		float: right;
		max-width: calc(35% + 40px);
		margin: 0 0 40px 40px;
		border-radius: 0 8px 0 8px;
	}
	
}





.promotion-teaser h2 {
	margin-bottom: 0;
}





/* -- promotion modules -- */

.promotion-wrap {
	background-color: #ececec;
	/*padding-top: 80px;*/
}

.promotion-wrap h1 {
	font-weight: bold;
}




.background-white,
.section-default.background-white {
	background: white;
}


.section-default.section-hero {
	padding-bottom: 100px;
}

.section-default.section-pull-up {
	margin-top: -80px;
}

.content-container {
	padding: 60px;
	background-color: white;
}

.content-container.background-primary {
	background-color: var(--cl-primary);
}
.content-container.background-primary:not(.padding-default) {
	padding: 30px;
}

.background-primary-dark,
.content-container.background-primary-dark {
	color: white;
	background-color: var(--cl-primary-dark);
	padding: 30px;
}

.text-white {
	color: white;
}

.box-background {
	padding: 20px;
	background-position: 50% 50%;
	background-size: cover;
	background-repeat: no-repeat;
	
}
.box-background h1,
.box-background h2,
.box-background h3 {
	margin-top: 0;
}

@media (max-width: 767px) {
	.content-container {
		padding: 40px;
	}
}











span.number-badge {
	width: 40px;
	height: 40px;
	background: var(--cl-secondary);
	border-radius: 50%;
	position: relative;
	display: block;
	position: absolute;
	top: 0;
	left: 0;
}

.number-badge span.number {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	line-height: 1;
	text-shadow: 1px 1px 4px hsl(0deg 0% 0% / 80%);

}

ul.numbers li {
	position: relative;
	list-style-type: none;
	padding: 0 0 0 50px;
	margin-bottom: 20px;
	font-size: 1.25em;
}

ul.lead.numbers {
	padding-left: 0;
	margin: 40px 0;

}

ul.numbers li strong {
	color: var(--cl-secondary);
}




/* -- tabs -- */

.promotion-tabs .tab-content {
	padding: 30px;
	color: #333;
	background: white;
}


.promotion-tabs .nav-tabs>li {
/*	order: 1;*/
	float: none;
	flex-grow: 1;
	margin-top: 3px;
}


.promotion-tabs .nav-tabs>li>a {
	border-radius: 0;
	padding: 10px 20px;
	
	background: white;
	color: #333;
}




.promotion-tabs .nav-tabs>li:first-child a {
	/*margin-left: 10px;*/
}
.promotion-tabs .nav-tabs>li:last-child a {
	/*margin-right: 0;*/
}
.promotion-tabs .nav-tabs>li.active {
}

.promotion-tabs .nav-tabs>li>a {
	margin-right: 0;
	border-top: 2px solid transparent;
	border-bottom: 1px solid var(--cl-primary);
}
	.promotion-tabs .nav-tabs>li.active>a {
		border-bottom-color: transparent;
	}
	
	.promotion-tabs .nav-tabs>li.active>a,
	.promotion-tabs .nav-tabs>li.active>a:focus,
	.promotion-tabs .nav-tabs>li.active>a:hover {
		border-left: 3px solid var(--cl-secondary);
	}

.promotion-tabs .nav-tabs {
	display: flex;
	flex-direction: column;
	flex: 1 1 0px;
	flex-wrap: wrap;
	
	margin-bottom: 3px;
}

@media (min-width: 992px) {
	
	.promotion-tabs .nav-tabs {
		flex-direction: row;
		margin-bottom: 0;
	}
	.promotion-tabs .nav-tabs>li>a {
		margin-right: 10px;
	}
	
	.promotion-tabs .nav-tabs>li.active>a,
	.promotion-tabs .nav-tabs>li.active>a:focus,
	.promotion-tabs .nav-tabs>li.active>a:hover {
		border-left: 0;
		border-top: 3px solid var(--cl-secondary);
	}
	
}




i.icon-help {
	font-size: 100%;
	color: var(--cl-secondary);
	vertical-align: baseline;
}


.tooltip.top .tooltip-arrow {
	border-top-color: var(--cl-primary);
}
.tooltip .tooltip-inner {
	text-align: left;
	background-color: var(--cl-primary);
}




.icon-success {
	color: #5cb85c;
}
.icon-warning {
	color: #c89132;
}
.icon-danger {
	color: #d9534f;
	color: #c8231e;
}


.promotion-form {
	padding: 60px 80px;
	background: var(--cl-secondary);
	color: white;
	
	margin-bottom: 80px;
}

.promotion-form h2 {
	color: white;
}

.promotion-form label.control-label {
	text-align: left;
}

.promotion-form a {color: var(--cl-primary);}

@media (max-width: 767px) {

	.promotion-form {
		padding: 40px;
	}

}





body.embed {
	padding: 0;
}
body.embed .promotion-wrap {
	padding: 0;
	background: transparent;
}
body.embed .meta-footer {
	display: none;
}
body.embed .section-default {
	padding: 0;
}
body.embed .promotion-form {
	margin-bottom: 0;
}





div.lead {
	color: var(--cl-secondary);
}






/*
.faq h3 {
	color: var(--cl-primary);
}
*/





div#promo-terms {
	padding: 30px;
	background: white;
	color: #555;
	margin: 40px 0;
}


.promotion-teaser {
	margin-top: 40px;
}









.hero-banner {
	margin: 60px 0;
	padding: 20px;
	padding: 30px;
	overflow: hidden;
	border-radius: 0 8px 0 8px;
	font-size: 20px;
	
	background-position: 50% 0;
	background-size: cover;
	background-image: url(/media/entertain-member/img/information/pic_vre_lp_vbrb_teaser_hotline.jpg);
	
	min-height: 290px;
}
.hero-banner:last-child {
	margin-bottom: 0;
}

.hero-banner .column-image {
}
.hero-banner .box {
	background: rgb(16 49 82 / 90%);
	color: white;
	
	/*
	position: absolute;
	top: 20px;
	left: 35px;
	bottom: 20px;
	*/
	padding: 20px;
	max-width: 50%;
	border-radius: 0 8px 0 8px;
	/*margin: 20px 5px;*/
}
.hero-banner.box-transparent .box {
	background: transparent;
	padding: 0;
	border: 0;
	box-shadow: none;
}
.hero-banner .box h2 {
	margin-bottom: 20px;
	margin-top: 0;
	color: white;
	font-size: 24px;
	font-size: 32px;
	line-height: 1.2;
}

.hero-banner .btn {
	margin: 25px 0 0;
}

.hero-banner p:last-child {
	margin-bottom: 0;
}

@media (max-width: 767px) {
	.hero-banner {
		background-image: none !important;
		background-color: #1d476f;
		min-height: 0;
	}
	.hero-banner .box {
		margin: 0;
		max-width: none;
	}
}











/* -- DASHBOARD ------------------------------------------------------------ */


ul.menu li>a {
	color: #555;
}


.row-card {
	display:flex;
	gap: 20px;
	flex-wrap: wrap;
	margin-bottom: 30px;
}
[class^="colx-md-"] {
	flex-grow: 1;
	max-width: 100%;
}
.colx-md-3 {
	max-width: calc(25% - 15px);
}
.colx-md-6 {
	max-width: calc(50% - 10px);
}



.strong {
	font-weight: bold;
}


/* -- DASHBOARD BOX -------------------------------------------------------- */

.box {
	height: calc(100%);
	margin-bottom: 0;
	border-radius: 0.25rem;
	/*box-shadow: rgba(154,161,171,.15) 0px 0px 35px 0px;*/
	box-shadow: rgba(154,161,171,.15) 0px 0px 15px 0px;
	line-height: 1.25;
	padding: 10px 15px;
	padding: 0;
	
	border: 1px solid rgb(0 0 0 / 7%);
	position: relative;
	
}
.box .box-content {
	/* overflow-x: auto; */
}
	.box .icon-help.icon-absolute {
		position: absolute;
		top: 15px;
		right: 15px;
		color: var(--cl-primary);
	}
	.row-card .box .box-content {
		margin-top: 20px;
	}
	
.box .box-header {
	padding: 15px;
}
	.box .box-header .box-super,
	.box .box-header .box-headline,
	.box .box-header .box-sub {
		display: block;
	}
	.box .box-header .box-super,
	.box .box-header .box-sub {
		font-size: .85em;
	}
	.box .box-header .box-headline {
		font-weight: bold;
		color: #777;
	}
	.box.box-large .box-header {
		font-size: 1.2em;
	}

.box .box-value,
.box .box-content {
	padding: 0 15px 15px;
}
.box .box-content:first-child {
	padding-top: 15px;
}


.box .box-value {
	font-size: 1.6em;
	font-weight: bold;
	color: var(--cl-primary);
}
	.box .box-value.orange {
		color: var(--cl-secondary);
	}

ul.dropdown-menu.menu-regions {
	max-height: 400px;
	overflow-y: auto;
	min-width: 100%;
}


.box .text-placeholder {
	color: #777;
	font-style: italic;
	text-align: center;
}
.box p.text-placeholder {
	padding: 20px 10px;
}



.box.box-flex .box-content {
	flex-grow: 1;
}

.box.box-flex {
	display: flex;
	flex-direction: column;
}




.box .box-content .table:last-child {
	margin-bottom: 0;
}




/* -- flex rows */

.row.row-flex {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	align-items: stretch;
}

.row.row-flex div[class^="col-"] {
	float: none;
	display: flex;
	flex-direction: column;
}

@media (max-width: 991px) {
	
	.row.row-flex div[class^="col-"] {
		width: 100%;
	}
}

.box.header-grey {
	background-color: #f7f7f7;
}
.box.header-grey .box-content {
	background-color: white;
}
.box.header-grey ul.nav.nav-tabs {
	padding-left: 15px;
	padding-right: 15px;
}
.box.header-grey ul.nav.nav-tabs a {
	padding: 6px 12px;
	font-size: 0.85em;
}