body {
	font-family: 'BentonSans', 'Helvetica Neue', Helvetica, sans-serif;
	letter-spacing: 0;
}

.pc-with-map .pc-right .pc-arrow { display: none; }
html, body { scroll-behavior: smooth; }
.section100 { width: 100%; }

:root {
	--sectionBottom: 30px;
	--amex-blue: #006FCF;
	--dq0-color-primary-hsl: 208, 100%, 40.6%;
	--amex-grey-offers: #727578;
}

.subnav { z-index: 7; }
.subnav-25BG { z-index: 7; }

		.top-hero-boxBG { background: none; }

		.top-hero-home .top-hero { padding-top: 0; height: 560px; background: none; position: relative;  }
		.top-hero img:not(.svg) { object-position: 50%; width: 100%; height: 100%; object-fit: cover; filter: brightness(60%); }
		.offer-hero-text { width: 90%; height: 100%; position: absolute; margin: auto; inset: 0; max-width: 1200px; text-align: left; display: flex; flex-direction: column; justify-content: center; color: #fff; }

		@media (max-width: 1200px) { .top-hero-home .top-hero { height: 430px; } }
		@media (max-width: 800px) { .top-hero-home .top-hero { height: 400px; } }
		@media (max-width: 620px) { .top-hero-home .top-hero { height: 250px; }  }
		
		.offer-hero-head {
			font-size: clamp(calc(3rem * .625), 4vw, calc(4.5rem * .625));
			font-weight: 700;
			margin-bottom: .5em;
			max-width: 440px;
		}
		
		.offer-hero-subhead {
			font-weight: 500;
			font-size: calc(1.6rem * .625);
		}
		
			.offer-hero-subhead a { color: inherit; }

.hotel-finder-filters {
	margin-top: -150px;
	scroll-margin-top: 80px;
}

.offer-search-head {
	font-size: calc(2.5rem * .625);
	margin-bottom: 1em;
}

.offer-criteria {
	display: flex;
	align-items: flex-end;
	flex-wrap: wrap;
	gap: 40px;
	margin-top: 20px;
}

.resetFilters {
	position: relative;
	top: -.5em;
	color: var(--amex-blue);
}

.cta-offers {
	border-radius: 4px;
	color: #fff;
	border: 0;
	appearance: none;
	-webkit-appearance: none;
	font-size: calc(1.5rem * .625);
	padding: 10px 20px;
	display: block;
	/* max-width: 120px; */
	background: var(--amex-blue);
	cursor: pointer; 
	border: 2px solid transparent;
	transition: all .125s;
	text-decoration: none;
	font-weight: normal;
}

	.cta-offers:hover {
		border: 2px solid var(--amex-blue);
		background: #fff;
		color: var(--amex-blue);
	}

/* cards */

		.card { padding-bottom: 0; display: flex; flex-direction: column; }
		
		.card-text { height: 100%; display: flex; flex-direction: column; }
		
		.card-location { margin-bottom: 1em; }
		
		.card-offer-wrap {
			padding: 10px 10px;
			background: #f6f6f6;
			border: 1px solid #ededed;
			margin: auto -12px 0 -12px;
			width: calc(100% + 24px);
		}
		
		.card-offer {
			margin-top: .25em;
		}
		
		.card-offer span {font-size: calc(1.2rem * .625); }
		
		.card:hover, .card:focus-within { transform: translateY(0); box-shadow: none; cursor: auto; }

		.card-supplierName::before { display: none; }
		.property-bookNow { margin-top: auto; color: #006fcf; display: block; font-weight: 500;font-size: calc(1.4rem * .625); }
		
		strong { font-weight: 500; }
		.allTandC { font-size: calc(1.4rem * .625); font-family: "Helvetica",sans-serif; color: #333; text-decoration: underline; display: block; margin-bottom: 1em; background: url(../../img/offers/arrow.svg) no-repeat 0 50%; background-size: 5px; padding-left: 9px; }

		.card-supplierName a { color: inherit; }

.offer-types {
	display: flex;
	gap: 20px;
	margin-bottom: calc(var(--sectionBottom) * 2);
}

.offer-type {
	width: 25%;
	aspect-ratio: 43 / 55;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	background-size: cover;
	color: #fff;
	text-decoration: none;
	padding: 30px;
	font-size: calc(1.7rem * .625);
	position: relative;
	
}

	.offer-type::after {
		content: '';
		position: absolute;
		left: 0;
		bottom: 0;
		width: 100%;
		height: 100%;
		background-image: linear-gradient(to top, rgba(0,0,0,1), rgba(0,0,0,.5) 30%, rgba(0,0,0,0) 60%);
	}

	.offer-type span { display: block; margin-top: 1em; text-decoration: underline; font-size: calc(1.5rem * .625);}
	.offer-type div { position: relative; z-index: 5; }

.offer-section-head {
	font-size: clamp(calc(2rem * .625), 4vw, calc(4rem * .625));
	font-weight: 400;
	line-height: normal;
	margin-top: 1em;
	margin-bottom: .25em;
}

label {
	font-size: calc(1.5rem * .625);
	font-weight: 700;
	display: block;
	margin-bottom: 5px;
}

	label span { font-weight: 400; }

.select-css {
	display: block;
	font-size: 16px;
	font-family: sans-serif;
	color: #444;
	line-height: 1.3;
	padding: .6em 1.8em .5em .8em;
	width: 100%;
	max-width: 100%; 
	box-sizing: border-box;
	border: 1px solid #aaa;
	box-shadow: 0 1px 0 1px rgba(0,0,0,.04);
	border-radius: 2px;
	-moz-appearance: none;
	-webkit-appearance: none;
	appearance: none;
	background-color: #fff;
	background-image: url('data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%23007CB2%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22%2F%3E%3C%2Fsvg%3E');
	background-repeat: no-repeat;
	background-position: right .7em top 50%;
	background-size: .65em auto;
}
.select-css::-ms-expand {
	display: none;
}
.select-css:hover {
	border-color: #888;
}
.select-css:focus {
	border-color: #aaa;
	box-shadow: 0 0 1px 3px rgba(59, 153, 252, .7);
	box-shadow: 0 0 0 3px -moz-mac-focusring;
	color: #222; 
	outline: none;
}
.select-css option {
	font-weight:normal;
}

.dateEntry {
	font-size: 16px;
	font-family:"Helvetica",sans-serif;
	padding: .85em;
	display: block;
	border: 1px solid #ccc;
	width: 100%;
	border-radius: 3px;
	background: #fff;
	margin-top: 4px;
}

.benefitsBG {
	background: var(--amex-grey-offers);
	padding: 80px 0;
}

.ob-logo { width: 370px; margin-bottom: 20px;}

.offer-benefits-cols {
	display: flex;
	gap: 80px;
}

.offer-benefits-head {
	color: #fff;
	font-size: clamp(calc(3rem * .625), 4vw, calc(4rem * .625));
	line-height: 1.25em;
	margin-bottom: .75em;
}

.offer-benefits-intro, .offer-benefits-details { width: 50%; color: #fff; }

.offer-benefits {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
	margin-bottom: 40px;
}

.ob {
	width: calc(50% - 10px); 
	font-weight: 500;
	padding-left: 45px;
	position: relative;
	/* min-height: 140px; */
}

	.ob::before {
		content: '';
		position: absolute;
		left: 0;
		top: 0;
		background-color: #fff;
		width: 34px;
		height: 34px;
		border-radius: 17px;
		background-size: 24px;
		background-repeat: no-repeat;
		background-position: 5px 5px;
	}

.ob-desc { font-size: calc(1.4rem * .625); margin-top: 4px; font-weight: 400; }

	.ob-checkin::before { background-image: url(../../img/dls-icon-benefit-early-check-in.svg); }
	.ob-breakfast::before { background-image: url(../../img/dls-icon-benefit-food.svg); background-size: 16px; background-position: 8px 5px;}
	.ob-checkout::before { background-image: url(../../img/dls-icon-benefit-late-checkout.svg); }
	.ob-wifi::before { background-image: url(../../img/dls-icon-benefit-wifi.svg);background-position: 5px 7px; }
	.ob-upgrade::before { background-image: url(../../img/dls-icon-benefit-hotel.svg); background-size: 22px;  background-position: 8px 5px;}
	.ob-amenity::before { background-image: url(../../img/dls-icon-benefit-reward.svg); }

.offer-fineprint p {
	font-family: 'Helvetica Neue', Helvetica, sans-serif;
	font-size: calc(1.2rem * .625);
	line-height: 1.3em; margin-bottom: .5em;
}

.ob-cta { color: #fff; font-size: calc(1.8rem * .625); margin-bottom: 1em; display: block;}

.offer-resultsBG {
	padding: var(--sectionBottom) 0;
	margin-bottom: calc(2 * var(--sectionBottom));
	background: #f6f6f6;
	box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
	position: sticky;
	top: 10px;
	z-index: 6;
}

.offer-results-wrap {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	width: 100%;
	gap: 40px;
}

.offer-results-head {
	font-size: calc(2.4rem * .625);
	margin-bottom: 1em;
}

.offer-results-details {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 40px;
	font-size: calc(1.5rem * .625);
	width: 100%;
}

.offer-result-label { line-height: 1.6em; }

.offer-result-label strong { font-weight: 700; }

.offer-result-item a { color: var(--amex-blue); }

.offer-results-totals {
	width: 150px;
	flex-shrink: 0;
}

.offer-results-total span { font-weight: 700; display: block; margin-bottom: 1em; }

.rh { scroll-margin-top: 230px; }

@media all and (max-width: 1200px) {
	.offer-type::after { background-image: linear-gradient(to top, rgba(0,0,0,1), rgba(0,0,0,.5) 50%, rgba(0,0,0,0) 100%); }
	.hotel-finder-filters { margin-top: -50px; }
}

@media all and (max-width: 1000px) {
	.offer-types { flex-wrap: wrap; justify-content: space-between;  } 
	.offer-type { width: 46%; aspect-ratio: 1 / 1; }
	.offer-benefits-cols { flex-direction: column;}
	.offer-benefits-intro, .offer-benefits-details { width: 100%; }
	.offer-benefits-intro img { display: none;}
}

@media all and (max-width: 620px) {
	.hotel-finder-filters { margin-top: -10px; }
}

@media all and (max-width: 500px) {
	.offer-type { font-size: calc(1.6rem * .625); padding: 15px; width: 100%; aspect-ratio: 16 / 9; background-position: 0 50%;}
	.ob { width: 100%; margin-bottom: 10px; }
	.fo-padding { padding-bottom: 40px;}
	.benefitsBG { padding: 30px 0;}
}

.dm5-btn { border-radius: 2px; }
.dm5-btn--subtle { border: 1px solid #aaa; box-shadow: none; }

