/* Header */
.headerSearch { margin-bottom: 25px; }
.headerSearch input { border: 0; color: #000; background: rgba(255, 255, 255, .75); padding: 10px; font-size: 13px; font-family: Muli, sans-serif; width: 50%; min-width: 220px; }
.headerSearch ::-webkit-input-placeholder { color: rgba(0, 0, 0, .75); }
.headerSearch button { background:#A80B7A; border: 0; color: #FFF; padding: 9px 11px 10px; font-size: 17px; cursor: pointer; }
.headerSearch button.eat { background:#1FBBDA; }
.headerSearch button.play { background:#EF2755; }
.headerSearch button.stay { background:#84C661; }
.headerSearch button.venues { background:#F5EB00; color: #142831; }
#headerListingsNav { padding: 10px 40px 15px; width: calc(100% - 80px); max-width: 1840px; margin: 0 auto; }
#headerListingsNav.eat { background: #1FBBDA; }
#headerListingsNav.play { background: #EF2755; }
#headerListingsNav.stay { background: #84C661; }
#headerListingsNav.venues { background: #F5EB00; }
#headerListingsNav.single { padding-top: 15px; }

/* Listings */
#pageListings { width: calc(100% - 20px); max-width: 1900px; margin: 20px auto; padding: 0 0 0 20px; }

.listing { width: calc(25% - 20px); height: 220px; margin-bottom: 10px; /*padding:15px;*/ }

.gutterSizer { width: 10px; }
.listing2xHeight { height: 440px; }
.listing img { width: 100%; height: auto; }
.listingSize { width: calc(33.3% - 20px); }
.listingPhoto { height: 220px; background-size: cover; background-position: center center; background-repeat: no-repeat; background-color: #EEE; }
.listingPhoto a { display: block; width: 100%; height: 100%; }

.listingDetail { border-top: 5px solid #991E66; width: calc(100% - 20px); padding: 10px; }
.listingDetail.typeEat { border-top: 5px solid #1FBBDA; }
.listingDetail.typePlay { border-top: 5px solid #EF2755; }
.listingDetail.typeStay { border-top: 5px solid #84C661; }
.listingDetail.typeVenues { border-top: 5px solid #142831; }
.listingDetail h3 { font-family: Oswald, sans-serif; font-size: 24px; margin: 0 0 10px; font-weight: 400; line-height: 28px; }
.listingDetail h3 a { text-decoration: none; }
.listingDetail.typeEat h3 a, button.is-checked.typeEat, button.typeEat:hover, .listingDetail.typeEat a i:hover, .listingDetail.typeEat .listingContact a { color: #1FBBDA; }
.listingDetail.typePlay h3 a, button.is-checked.typePlay, button.typePlay:hover, .listingDetail.typePlay a i:hover, .listingIcons a.red i { color: #EF2755; }
.listingDetail.typeVenues h3 a, button.is-checked.typeVenues, button.typeVenues:hover, .listingDetail.typeVenues a i:hover, .listingIcons a.yellow i { color: #142831; }
.listingDetail.typeStay h3 a, button.is-checked.typeStay, button.typeStay:hover, .listingDetail.typeStay a i:hover, .listingIcons a.green i { color: #84C661; }
.listingPromoted .listingPhoto a i { margin: 10px; border: 1px solid #1FBBDA; border-radius: 50%; background-color: rgba(255,255,255,.8); line-height: 30px; width: 35px; text-align: center; font-size: 22px; padding-top: 5px; color: #1FBBDA; }
.promoted { position: absolute; top: 192px; color: #FFF; font-size: 12px; text-transform: uppercase; left: 10px; font-weight: 700; }
.alertStatus { position: absolute; top: 0px; text-align: center; color: #FFF; font-size: 12px; text-transform: uppercase; font-weight: 700; width: 100%; text-decoration: none; }
.alertStatus.typeVenues { background: rgba(20, 40, 49, .7); }
.alertStatus.typeEvents { background: rgba(184, 54, 150, .7); position: relative; }
.alertStatus.typeEat { background: rgba(31, 187, 218, .7); }
.alertStatus.typePlay { background: rgba(239, 39, 85, .7); }
.alertStatus.typeStay { background: rgba(132, 198, 97, .7); }
.printAlert { display: none; }

.listingContact { font-size: 14px; line-height: 22px; }

.listingIcons { margin: 10px 0 0; height: 34px; text-align: center; padding: 10px 0 0; border-top: 1px dotted #CCC; width: 100%; }
.listingIcons i { font-size: 24px; margin: 5px; }
.listingIcons a i, .listingIconsSingle a i { color: #000; }
.listingIconsSingle a i:hover, .listingIcons a.purple i { color: #991E66; }
.listingIconsSingle.eat a i:hover, h3.eat { color: #1FBBDA; }
.listingIconsSingle.play a i:hover, h3.play { color: #EF2755; }
.listingIconsSingle.stay a i:hover, h3.stay { color: #84C661; }

.listingGallery { display: flex; flex-wrap: wrap; }
.galleryImage { width: calc(50% - 20px); margin: 0 20px 20px 0; position: relative; }
.galleryImage.even { margin-right: 0; }
.galleryImage a { display: block; background: rgba(75, 79, 84, .4); color: #FFF; padding-bottom: 66.6%; }
.galleryImage a:hover { background: none; transition: 1s; }
.galleryImage a > .photoCaption { position: absolute; bottom: 10px; left: 10px; width: calc(100% - 20px); text-align: center; font-weight: 700; }

.listingCollapsed { margin-top: 0 !important }
.vrview { width: 100%; max-width: 1200px; height: 600px; margin: 0 auto; }
.fancybox-slide>* { padding: 40px; }

.local { float: left; margin: 10px 0 0 10px; font-size: 12px; text-transform: uppercase; font-weight:700; padding: 2px 8px 1px 9px; background-color: #1FBBDA; color: #FFF; border-radius: 5px; line-height: 20px; }
.local.withAlert { margin-top: 38px; }

/* A - Z Listings */
.button15 { width: calc(15% - 10px); padding: 0 5px; float: left; text-align: center; color: #FFF; }
.button25 { width: calc((85% / 3) - 10px); padding: 0 5px; float: left; text-align: center; color: #142831; }
.button25 button { display: block; margin: 10px auto !important; }
.button-group { text-align: center; }
.button-group.a-z { padding: 20px 0 0; line-height: 40px; text-align: left; }
.a-z-list { width: calc(100% - 140px); }
.button-group button { font-family: Muli, sans-serif; font-size: 20px; color: #AAA; }
button.button { border: 0; background: #FFF; cursor: pointer; }
button.button:hover { color: #991e66; }
button.is-checked { color: #991e66; font-weight: 700; }
button.button.eat:hover { color: #1FBBDA; }
button.eat.is-checked { color: #1FBBDA; font-weight: 700; }
button.button.play:hover { color: #EF2755; }
button.play.is-checked { color: #EF2755; font-weight: 700; }
button.button.stay:hover { color: #84C661; }
button.stay.is-checked { color: #84C661; font-weight: 700; }
button.button.venues:hover { color: #142831; }
button.venues.is-checked { color: #142831; font-weight: 700; }
button.noClick { border: 0; background: #FFF; color: #DDD; }
button.nLEat { color: #FFF; background: none; border: 2px solid #FFF; text-transform: uppercase; margin: 10px; padding: 5px 15px; }
button.nLEat:hover, button.nLEat.button.is-checked { color: #FFF; background: #1392A7; border: 2px solid #1392A7; }
button.nLPlay, a.nLPlay, a.nLEvents { color: #FFF; background: none; border: 2px solid #FFF; text-transform: uppercase; margin: 10px; padding: 5px 15px; }
a.nLPlay, a.nLEat, a.nLStay { font-size: 20px; color: #FFF; text-decoration: none; display: inline-block; }
button.nLPlay:hover, a.nLPlay:hover, button.nLPlay.button.is-checked { color: #FFF; background: #B4002A; border: 2px solid #B4002A; }
a.nLEvents:hover, a.nLEvents.is-checked { color: #FFF !important; background: #860967 !important; border: 2px solid #860967 !important; }
button.nLStay { color: #FFF; background: none; border: 2px solid #FFF; text-transform: uppercase; margin: 10px; padding: 5px 15px; }
button.nLStay:hover, button.nLStay.button.is-checked { color: #FFF; background: #40851B; border: 2px solid #40851B; }
button.nLVenues { color: #142831; background: none; border: 2px solid #142831; text-transform: uppercase; margin: 10px; padding: 5px 15px; }
button.nLVenues:hover, button.nLVenues.button.is-checked { color: #FFF; background: #979100; border: 2px solid #979100; }

/* Single Listings */
#singleHeader { margin-bottom: 25px; border-bottom: 1px dotted #CCC; }
.listingPhotoSingle { float: right; width: 400px; border-bottom-width: 5px; border-bottom-style: solid; margin: 0 0 20px 20px; }
.listingPhotoSingle img { width: 100%; max-height: 600px; }
.listingPhotoSingle.eat { border-bottom-color: #1FBBDA; }
.listingPhotoSingle.play { border-bottom-color: #EF2755; }
.listingPhotoSingle.stay { border-bottom-color: #84C661; }
.listingPhotoSingle.venues { border-bottom-color: #FBEB00; }
.listingPhotoSingle.withStatement { border-bottom: none !important; }
.listingPhotoSingle.withStatement.eat img { border-bottom: 5px solid #1FBBDA; }
.listingPhotoSingle.withStatement.play img { border-bottom: 5px solid #EF2755; }
.listingPhotoSingle.withStatement.stay img { border-bottom: 5px solid #84C661; }
.listingPhotoSingle.withStatement.venues img { border-bottom: 5px solid #FBEB00; }
.listingIconsSingle { float: none; width: 360px; max-width: 100%; text-align: center; height: 36px; padding: 0 0 60px; margin: 0 auto; }
.listingIconsSingle i { font-size: 32px; margin: 10px; }
a.statementButton { width: 250px; text-align: center; display: block; margin: 10px auto; color: #FFF; font-size: 18px; font-weight: 700; text-decoration: none; border-radius: 10px; padding: 2px 5px; }
a.statementButton.stay { background: #84C661; }
a.statementButton.eat { background: #1FBBDA; }
a.statementButton.play { background: #EF2755; }
a.statementButton.venues { background: #FBEB00; }

/* Caucus + Individual Listings Maps */
#homeMap { width: 100%; height: 500px; }
#homeMap.fullSize { height: 700px; }
#fullScreenMap { width: 100%; background: #EEE; text-align: center; }
#fullScreenMap iframe { width: 100%; max-width: 1920px; height: 400px; border: 0; margin: 0 auto; }

@media screen and (max-width: 1440px) {
	.listing, .listingSize { width: calc((100% / 3) - 20px); }
}
@media screen and (max-width: 1040px) {
	.listing, .listingSize { width: calc(50% - 20px); }
	.listingPhoto { height: 200px; }
}
@media screen and (max-width: 800px) {
	#singleHeader h2 { display: none; }
	.listingPhotoSingle { display: none; }
	.listingPhotoSingle.withStatement { display: block; float: none; width: 100%; border-bottom: none !important; margin: 0; }
	.listingPhotoSingle.withStatement img { display: none; }
	.altsocialSingle { float: none !important; margin: 25px auto 20px; text-align: center; }
	.listingIconsSingle { padding: 20px 0 40px; }
}
@media screen and (max-width: 640px) {
	#pageListings { width: calc(100% - 15px); margin: 0; padding: 15px 0 15px 15px; }
	#headerListingsNav { padding: 10px 15px 15px; width: calc(100% - 30px); }
	#headerListingsNav.single { padding-top: 15px; }
	.altSocial { float: none !important; width: 300px; margin: 20px auto; text-align: center; }

	.listing { margin-bottom: 30px; }
	.listing, .listingSize { width: calc(100% - 20px); }
	.listing2xHeight { height: auto; }
	.listingPhoto { height: 200px; }

	.a-z-list { width: 100%; }
	.button25, .button15 { width: calc(100% - 10px); margin-bottom: 10px; }
	.button-group.a-z { line-height: 30px; text-align: center; font-size: 18px; padding: 15px 0 0; }
	.button-group button { font-size: 18px; }
	.button.nLEat, .button.nLPlay { padding: 3px 10px; margin: 7.5px; }

	.galleryImage { width: 100%; margin: 0 0 20px; position: relative; }
}
