/* LISTINGS */

/* 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; }

/* Rotator */
.rotator__video-overlay { padding: 80px 40px; }
@media only screen and (max-width: 1440px) {
	.rotator__video-overlay { padding: 70px 40px; }
}
@media screen and (max-width: 1040px) {
	.rotator__video-overlay { padding: 40px 40px; }
}
@media screen and (max-width: 800px) {
	.rotator__video-overlay { padding: 20px 20px; }
}
div#rotator.rotator { position: relative; padding: 0; width: 100%; max-width: 100%; overflow: hidden; }
div#rotator.rotator > .rotator__video { width: 100%; height: 100%; object-fit: cover; position: absolute; z-index: 1; }
div#rotator.rotator > .rotator__video-overlay { position: relative; z-index: 2; background: rgba(56, 72, 79, 0.3); }

/* Site Search */
#homeSearch { background: #38484F; width: calc(100% - 40px); padding: 20px; }
.searchForm20 { display: flex; width: 100%; max-width: 800px; margin: 0 auto; }
.searchForm20 input { margin: 0; border: 0; padding: 8px 12px; height: 40px; font-size: 16px; width: 100%; font-family: 'Lato', sans-serif; border-top-left-radius: 12px; border-bottom-left-radius: 12px; }
.searchForm20 button { width: 125px; background: #B83696; height: 40px; padding: 8px 4px; font-size: 16px; font-weight: 700; color: #FFF; font-family: 'Muli', sans-serif; border: 0; border-radius: 0 12px 12px 0; }
.searchForm20 input::placeholder { color: #38484F; }

#homeSearch nl-autocomplete { height: auto; width: 100%; }
#homeSearch nl-autocomplete .awesomplete { height: auto }

/* Listings */
#pageListings { width: calc(100% - 20px); max-width: 1900px; margin: 20px auto; padding: 0 0 0 20px; }
#pageListings.events { width: calc(100% - 40px); padding: 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; }

.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; }

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

/* 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 { 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; }
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; }
.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; }

/* 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; }
	.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; }
	#pageListings.events { width: calc(100% - 40px); margin: 20px auto; padding: 0 20px; height: 300px; }
	#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: 100%; }
	.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; }
}

/* BLOG */
/* Homepage + Blog Page Blogs */
.moduleButton.blogButton { background: #5C636B; }
.moduleButton.blogButton a { color: #FFF; text-decoration: none; }

#blogListings { width: calc(100% - 20px); max-width: 1900px; margin: 20px auto; padding: 0 0 0 20px; }
#blogHome { text-align: center; }
#blogPage .blogCard { width: calc((100% - 60px) / 3); margin: 0 20px 20px 0; float: left; }
#blogHome .blogCard { width: 100%; margin: 0; float: left; text-align: left; }

#blogPage h2.listingsHeader, #blogHome h2.listingsHeader { margin-top: 0; }
#blogPage .blogImage, #blogHome .blogImage { width: 100%; height: 200px; background-size: cover !important; position: relative; }
#blogPage .blogImage a, #blogHome .blogImage a { width: 100%; height: 100%; display: block; }
#blogPage .blogHeadline, #blogHome .blogHeadline { background: #5C636B; padding: 0; font-weight: 700; line-height: 20px; height: 70px; position: relative; border-bottom: 5px solid #4B4F54; }
#blogPage .blogInfo, #blogHome .blogInfo { position: absolute; bottom: 12px; right: 12px; width: calc(100% - 24px); }
#blogPage .blogHeadline a, #blogHome .blogHeadline a { text-decoration: none; color: #FFF; }
#blogPage .blogMore, #blogHome .blogMore { margin-top: 5px; font-size: 12px; line-height: 16px; font-weight: 400; color: #FFF; }
#blogPage .moreBlogs, #blogHome .moreBlogs { display: none; }

/* Search */
.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; }
.moreBlogsButton { width: calc(100% - 20px); }
.moreBlogsButton a { font-family: Oswald, sans-serif; font-size: 30px; line-height: 40px; font-weight: 300; text-transform: uppercase; border: #AAA 2px solid; display: block; padding: 2px 10px; border-radius: 20px; color: #AAA; text-decoration: none; width: calc(100% - 24px); max-width: 400px; margin: 30px auto; text-align: center; cursor: pointer;  }
.moreBlogsButton a:hover { background: #AAA; color: #FFF; }

/* Right Column */
#pageRight { margin-right: 20px; text-align: center; }
#pageRight h3 { margin-top: 0; }
#pageRight a.button { font-family: Oswald, sans-serif; font-size: 18px; line-height: 30px; font-weight: 300; text-transform: uppercase; border: #AAA 2px solid; display: block; padding: 2px; border-radius: 10px; color: #AAA; text-decoration: none; width: calc(100% - 8px); margin: 10px auto; text-align: center; }
#pageRight a.button:hover { background: #AAA; color: #FFF; }

@media screen and (max-width: 1380px) {
  #blogPage .blogCard { width: calc((100% - 40px) / 2); margin: 0 20px 20px 0; float: left; }
}

@media screen and (max-width: 980px) {
  #blogPage .blogCard { width: calc(100% - 20px); margin: 0 20px 20px 0; float: left; }
}

@media screen and (max-width: 800px) {
  #pageRight { width: calc(100% - 20px); }
}

@media screen and (max-width: 640px) {
}

/* EVENTS */
/* Events Page */
.moduleButton.eventButton { background: #B83696; }
.moduleButton.eventButton a { color: #FFF; text-decoration: none; }

#eventsListings { width: calc(100% - 20px); max-width: 1900px; margin: 20px auto; padding: 0 0 0 20px; }
#eventsHome { text-align: center; }
#eventsPage .eventCard, #eventsHome .eventCard { width: 100%; margin: 0; float: none; text-align: left; }

#eventsPage h2.listingsHeader, #eventsHome h2.listingsHeader { margin-top: 0; }
#eventsPage .eventImage, #eventsHome .eventImage { width: 100%; height: 250px; background-size: cover !important; position: relative; }
#eventsHome .eventImage { height: 200px; }
#eventsPage .eventImage a, #eventsHome .eventImage a { width: 100%; height: 100%; display: block; }
#eventsPage .eventHeadline, #eventsHome .eventHeadline { background: #5C636B; padding: 0; font-weight: 700; line-height: 22px; height: 70px; position: relative; border-bottom: 5px solid #B83696; }
#eventsPage .eventInfo, #eventsHome .eventInfo { position: absolute; bottom: 12px; right: 12px; width: calc(100% - 24px); }
#eventsPage .eventHeadline a, #eventsHome .eventHeadline a { text-decoration: none; color: #FFF; }
#eventsPage .eventDate, #eventsHome .eventDate { color: #FFF; }
#eventsPage .eventMore, #eventsHome .eventMore { font-size: 12px; line-height: 18px; font-weight: 400; color: #FFF; width: calc(100% - 90px); float: left; }
#eventsPage .eventLinks, #eventsHome .eventLinks { width: 90px; float: right; text-align: right; line-height: 36px; font-size: 20px; }
#eventsPage .eventLinks a i, #eventsHome .eventLinks a i { margin-left: 5px; }
#eventsPage .moreEvents, #eventsHome .moreEvents { display: none; }

.moreEventsButton { width: calc(100% - 20px); }
.moreEventsButton a { font-family: Oswald, sans-serif; font-size: 30px; line-height: 40px; font-weight: 300; text-transform: uppercase; border: #AAA 2px solid; display: block; padding: 2px 10px; border-radius: 20px; color: #AAA; text-decoration: none; width: calc(100% - 24px); max-width: 400px; margin: 30px auto; text-align: center; cursor: pointer;  }
.moreEventsButton a:hover { background: #AAA; color: #FFF; }

/* Event Search */
.eventField { width: calc(100% / 3); float: left; font-size: 30px; text-align: center; }
.eventField label { font-size: 23px; }
.eventField input, .eventField select { width: calc(100% - 50px); font-size: 16px; font-family: Muli, sans-serif; padding: 7px 10px; border: 1px solid #4B4F54; }
.eventField select { margin-top: 8px; }
#pageContent.eventForm h3 { margin: 0 0 21px; text-align: center; }
#pageContent.eventForm input[type="submit"] { font-family: Oswald, sans-serif; background: #B83696; color: #FFF; cursor: pointer; width: 150px; float: none; border: 0 solid #4B4F54; font-size: 24px; text-transform: uppercase; display: block; text-align: center; padding: 2px 0 5px; line-height: 30px; -webkit-appearance: none; margin: 20px auto 0; }
.eventField.fullWidth { width: 100%; text-align: center; }

/* Right Column */
#pageRight { margin-right: 20px; text-align: center; }
#pageRight h3 { margin-top: 0; }
#pageRight a.button { font-family: Oswald, sans-serif; font-size: 18px; line-height: 30px; font-weight: 300; text-transform: uppercase; border: #AAA 2px solid; display: block; padding: 2px; border-radius: 10px; color: #AAA; text-decoration: none; width: calc(100% - 8px); margin: 10px auto; text-align: center; }
#pageRight a.button:hover { background: #AAA; color: #FFF; }

@media screen and (max-width: 1380px) {
  #eventsPage .eventCard { width: calc((100% - 60px) / 3); margin: 0 20px 20px 0; float: left; }
  #eventsPage .eventImage { height: 200px; background-size: cover !important; }
}

@media screen and (max-width: 980px) {
  #eventsPage .eventCard { width: calc((100% - 40px) / 2); margin: 0 20px 20px 0; float: left; }
}

@media screen and (max-width: 800px) {
  .eventField { width: 100%; max-width: 400px; margin: 0 auto; float: none; padding: 10px 0; }
}

@media screen and (max-width: 640px) {
  #eventsPage .eventCard { width: calc(100% - 15px); margin: 0 20px 20px 0; float: left; }
}

/* SOCIAL */
.socialWall { width: 100%; max-width: 1920px; max-height: 960px; overflow: hidden; margin: 0 auto 20px; }
.moduleHeader.moduleSocial { color: #EF2755; }

.socialIcons { width: 100%; margin: 30px 0; text-align: center; }
.socialIcons a { color: #EF2755; text-decoration: none; font-size: 40px; margin: 0 5px; }

/* ROTATOR */
#rotator { width: calc(100% - 80px); max-width: 1840px; background: #CCC; margin: 0 auto; margin-top: 90px; padding: 80px 40px; }
#rotator img { display: block; margin: 0 auto 30px; max-height: 280px; max-width: calc(100% - 40px); }
#rotator h2 { text-transform: uppercase; text-align: center; color: #FFF; font-family: Oswald, sans-serif; text-shadow: 0 0 8px #000; }
#rotator span.emphasis { font-weight: 600; }

#featuredContent { width: 33.3%; float: none; display: table-cell; text-align: center; background-size: cover !important; background-position: center center; color: #FFF; font-size: 20px; }
#featuredContent h3 { font-family: Oswald, sans-serif; font-weight: 400; font-size: 35px; margin: 15px 0; line-height: 45px; }
#featuredContent a { display: inline-block; margin: 35px auto 50px; border: 2px solid #FFF; padding: 12px 20px; color: #FFF; text-decoration: none; text-transform: uppercase; font-size: 24px; font-weight: 700; letter-spacing: 1px; }
#featuredContent.middle { width: 33.4%; }
.featuredText { padding: 40px 50px 0; }
.sectionFull { text-align: center; }

@media only screen and (max-width: 1440px) {
  #rotator { padding: 70px 40px; }
}

@media screen and (max-width: 1040px) {
  #rotator { margin-top: 80px; padding: 40px 40px; }
  .featuredText { padding: 40px 25px 0; }
}

@media screen and (max-width: 800px) {
  #featuredContent { font-size: 16px; }
  #featuredContent, #featuredContent.middle { width: 100%; display: block; }
  #featuredContent h3 { font-size: 28px; line-height: 35px; }
  .featuredText { padding: 20px 20px 0; }
  #featuredContent a { margin: 20px auto 30px; padding: 5px 20px; font-size: 18px; }
  #rotator { margin-top: 80px; padding: 20px 20px; width: calc(100% - 40px); }
}
