/* ============== TYPO / HEADINGS ============== */
h1 {
	font-size: clamp(2rem, 2vw + 1.5rem, 3.5rem);
	line-height: 1.15;
	margin-block: 1rem 2rem;
}

sup {
	font-size: 60%;
}

/* ============== INTRO ============== */
.intro-text {
	background: #fff;
	position: relative;
	text-align: center;
	z-index: 1;
	width: 100%;
	padding-block: 2rem 0;
	margin-inline: auto;
}

.intro-text.up{
	margin-top:-5rem;
}

.intro-text p {
	font-size: 1rem;
	line-height: 1.8rem;
	text-wrap: balance; /* experimentell, fallback ok */
	hyphens: auto;
	overflow-wrap: break-word;
}

.intro-text p,
.intro-text p:nth-child(3) {
	font-size: 1rem;
}

/* ============== IBERIA INTRO COLORS ============== */
.black-bg{
	background:#000;
	color:#fff;
}

.black-bg .intro-text,
.black-bg .dealer-text{
	background: transparent;
	color:#fff;
	margin-top: 0;
	margin-bottom: 0;
	padding: 3rem 0;
}

.black-bg .intro-text p,
.black-bg .intro-text a,
.black-bg .intro-text h1,
.black-bg .intro-text h2{
	color:#fff;
}

.black-bg .intro-text h1{
	color:#ffd20a;
}

.black-bg .intro-text em{
	font-size:14px;
	line-height:18px;
}

.yellow-bg{
	background:#ffd20a;
	color:#000;
	padding: 3rem 0;
}

.yellow-bg .instructions-wrapper{
	display: flex;
	flex-direction: row;
}

.yellow-bg .instructions-wrapper .instructions-box{
	width: 33%;
	display: block;
	text-align: center;
}

.yellow-bg .instructions-wrapper .instructions-box p{
	padding-bottom: 0;
	margin-bottom: 0;
}

.yellow-bg .instructions-wrapper .instructions-box img{
	max-width:150px;
}

.black-bg .dealer-text .btn{
	margin: 0 auto;
	max-width: 300px;
	display: block;
	padding: 1rem 2rem;
	background: #ffd20a;
	color: #000;
	border-radius: 0;
}

.space-bottom{
	margin-bottom:2rem;
}

/* ============== NAVBAR / GLOBAL ============== */
.navbar-left .nav-link {
	font-size: 16px;
	font-weight: 700 !important;
}

.navbar-main {
	font-family: Helvetica, Arial, sans-serif;
}

nav .container-fluid,
#ctl00_header_nav .container-fluid {
	padding-inline: 0;
}

/* ============== FORM ============== */
.campaign-form p {
	text-align: center;
	font-size: 14px;
	margin: 0;
}

	.campaign-form p.error {
		text-align: center;
		font-size: 16px;
		font-weight: 700;
		margin: 0 0 1.5rem;
	}

	.campaign-form p:last-child:not(.help-text) {
		margin-bottom: 2rem;
	}

	.campaign-form .help-text {
		text-align:left;
		margin-left: 0.2rem;
	}
/*
	.campaign-form .form-group #col-left.no-padding .form-group {
		padding: 0 !important;
	}

	.campaign-form .form-group #col-right.no-padding .form-group {
		padding: 0 !important;
	}*/
	
/* Required-Kennzeichnung */
.form-group.required > label:not(#pleasechoosefile)::after {
	content: " **";
}

/* Pflichtfeld-Rahmen konsistent */
input.mandatory,
select.mandatory,
textarea.mandatory,
.choices__inner.mandatory {
	border: 2px solid #f00 !important;
}

/* Newsletter/Optins inline */
.campaign-form .newsletter-retaileroptin,
.campaign-form .tcagree-optin,
.campaign-form .newsletter-optin {
	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content: center;
	gap: .3rem;
}

	.campaign-form .newsletter-retaileroptin label {
		margin: 0;
	}

/* Purchase */
.campaign-form .purchase-information h3::after {
	display: none;
}

.purchase-information .col-md-8 {
	margin-bottom: 0;
}

.has-prepend {
	width: auto !important;
}

.input-group-text {
	border: 1px solid #c4c4c4;
	font-size: 0.875rem;
	padding: 1rem;
	background: #fafafa;
	width: 100%;
	-webkit-border-radius: 0.125rem;
	border-radius: 0.125rem;
}

/* Choices.js Feinschliff */
.choices {
	margin-bottom: .5rem !important;
}

.choices__inner {
	border: 1px solid #c4c4c4 !important;
	border-radius: 0;
}

.choices__list--multiple .choices__item {
	display: inline-block;
	vertical-align: middle;
	border-radius: 0 !important;
	padding: 4px 10px;
	font-size: 12px;
	font-weight: 500;
	margin: 0 3.75px 3.75px 0;
	background: #444 !important;
	border: 0 !important;
	color: #fff !important;
	word-break: break-all;
}

/* Fileupload ? zusammengeführt, ohne Duplikate */
.control-fileupload {
	position: relative;
	display: block;
	width: 100%;
	border: 1px solid #ccc;
	padding: .75rem 1rem;
	background: #fff;
	height: auto; /* keine fixe Höhe, Layout stabiler */
}

	.control-fileupload input[type="file"] {
		position: absolute;
		inset: 0;
		width: 100%;
		height: 100%;
		opacity: 0;
		cursor: pointer;
	}

	.control-fileupload.mandatory-file {
		border: 2px solid #f00 !important;
	}

.box.mandatory-file > .control-fileupload {
	border: 2px solid #f00;
}

.campaign-form .control-fileupload label {
	font-size: .875rem;
	font-weight: 400;
	margin: 0 !important;
}

.campaign-form .control-fileupload {
	padding: 10px 30px !important;
}

.control-fileupload label#pleasechoosefile {
	position: relative;
	padding-inline-start: .3rem;
	text-align: left;
}

	.control-fileupload label#pleasechoosefile::before {
		content: "\f07c";
		font-family: "Font Awesome 6 Free";
		font-weight: 400;
		font-size: 1rem;
		padding-right: .2rem;
		color: #444;
	}

.control-fileupload label#receipt_filelabel {
	position: relative;
	padding-inline-start: .3rem;
	text-align: left;
	padding-left: 10px !important;
}

	.control-fileupload label#receipt_filelabel::before {
		content: "\f07c";
		font-family: "Font Awesome 6 Free";
		font-weight: 400;
		font-size: 1rem;
		padding-right: .2rem;
		color: #444;
	}

/* Checkbox-Reihen */
.checkbox-row {
	display: flex;
	flex-direction: row;
	align-items: center;
	gap: .5rem;
	margin-bottom: .5rem;
}

	.checkbox-row label {
		margin: 0;
		padding: 0;
	}

/* Intro H3 */
.intro-text h3 {
	font-size: 1.5rem;
	line-height: 1.3;
	margin-bottom: 1rem;
	text-transform: none;
}

/* Sticky page (Header/Footer variabel) */
:root {
	--hdr: 0px;
	--ftr: 0px;
}

#sticky-page {
	min-height: calc(100dvh - var(--hdr) - var(--ftr));
	display: flex;
	align-items: center;
}

.thankyoumessage {
	text-align: center;
}

/* ============== STEPS ============== */
.steps {
	display: block;
	margin: auto;
}

/* Regel nach allen anderen .steps-Regeln platzieren */
.container.steps {
	margin-block: 3rem;
	margin-inline: auto;
}

	/* Inneres steps-Element neutralisieren */
	.container.steps > .steps {
		margin: 0;
	}

.step {
	display: flex;
	flex-direction: row;
	gap: 2rem;
	background: #fdcd00;
	padding: 1.5rem;
	margin-bottom: 1rem;
}

	.step .text {
		text-align: left;
	}

	.step .number {
		color: #000;
		font-size: 30px;
		font-weight: 700;
	}

/* ============== CHECKLISTE ============== */
.checklist {
	margin-bottom: 4rem;
	padding-inline: 9%;
	position: relative;
	text-align: left;
	z-index: 1;
}

	.checklist h2 {
		margin-bottom: 2rem;
	}

	.checklist ul {
		margin: 2rem 0;
	}

/* ============== RESPONSIVE ============== */
@media (max-width: 991.98px) {
	.intro-text {
		margin: 0 auto;
		padding: 1rem;
		width: auto;
	}

	.prize-box {
		padding: .5rem;
		flex-basis: 50%;
	}

	.prizes {
		margin: 1rem auto 2rem;
	}
}

@media (max-width: 768px) {
	footer .footer-tagline img {
		padding: 1rem;
		width: 100%;
	}

	.prize-box {
		padding: 0 1.5rem;
		flex-basis: 100%;
	}

	.campaign-form .form-container > .row {
		padding: 1rem;
		background: #eee;
		margin-bottom: 2rem;
	}
}

/* Kleines Utility */
.dropdown-help {
	position: relative;
	top: -2px;
	margin: 0;
	padding: 0 1px;
	font-size: 12px;
}

/* Footer/Privacy ? nur einmal definieren */
.privacy-policy {
	font-size: 14px;
	text-align: center;
	padding-block-end: 2rem;
}
