/*
 Theme Name:   Divi Child Theme
 Theme URI:    https://visualizedigital.com
 Description:  Divi Child Theme
 Author:       Ryan McBride
 Author URI:   https://visualizedigital.com
 Template:     Divi
 Version:      1.0.0
 License:      GNU General Public License v2 or later
 License URI:  http://www.gnu.org/licenses/gpl-2.0.html
 Tags:         light, dark, two-columns, right-sidebar, responsive-layout, accessibility-ready
 Text Domain:  divi
*/

p {
	font-weight: 300;
}
p sup {
    bottom: 0.3em;
    font-size: 0.8em;
}
.header_top_section .right_side {
    display: flex;
    justify-content: end;
}
.header_top_section .et_pb_blurb_position_left .et_pb_main_blurb_image{
	  vertical-align: middle;
    line-height: 1;
}
.header_top_section .et_pb_blurb_position_left .et_pb_blurb_container {
    padding-left: 3px;
}
.header_top_section .et_pb_blurb_description {
    line-height: 1.2;
}
.header_top_section .right_side .et_pb_module {
    padding-left: 5%;
}
.header_top_section .right_side .et_pb_module a {
   color:#5b5b5d;
}
.et-menu .menu-item-has-children>a:first-child:after {
    top: -3px;
}
.main_slider{
	margin-top:-60px;
}
 .et_pb_section_0 {
    min-height: auto !important;
}
.company_btn .et_pb_button_module_wrapper {
    display: inline-block;
    margin-right: 12px;
}
.callto_action {
    display: flex;
    align-items: center;
    justify-content: space-around;
}
.callto_action .et_pb_promo_description {
    padding-bottom: 0px;
}
.footer_menu ul li {
    padding: 0 35px !important;
}
.inner_blog h3 {
    font-size: 18px;
    padding-top: 25px;
}
.inner_slider{
	padding:60px 15px 15px;
}
.main_short_date {
    display: flex;
    align-items: center;
}

.main_short_date div {
    font-size: 18px;
    line-height: 18px;
}

.short_date {
    border-right: 1px solid #353536;
    padding-right: 20px;
    margin-right: 20px;
}
.blog_slider button:before{
	display:none !important;
}  

.explore-season .et_pb_column:first-child:after {
    content: "";
    position: absolute;
    right: 38px;
    top: 30px;
    background-image: url(images/divider.png);
	width: 5px;
	height: 132px;
}

.carousel-navigation {
	padding-top: 30px;
}

.carousel-navigation img {
	cursor: pointer;
	padding: 0 10px;
	opacity: 0.3;
	-webkit-transition: all 0.2s ease-in-out;
	-moz-transition: all 0.2s ease-in-out;
	-o-transition: all 0.2s ease-in-out;
	transition: all 0.2s ease-in-out;
}

.carousel-navigation img:hover {
	opacity: 1;
}

.owl-carousel .owl-item {
	padding: 0 20px;
}

.owl-carousel .item {
    padding: 20px 0;
}

.owl-carousel .item img {
	-webkit-transition: all 0.2s ease-in-out;
	-moz-transition: all 0.2s ease-in-out;
	-o-transition: all 0.2s ease-in-out;
	transition: all 0.2s ease-in-out;
	position: relative;
	top: 0;
}

.owl-carousel .item img:hover {
	top: -10px;
    box-shadow: 0 10px 20px rgba(0,0,0,0.3);
}

.owl-carousel .item h3 {
    font-size: 24px;
    padding-top: 30px;
    font-weight: 700;
    color: #6b0303;
}

.inline-buttons .et_pb_button_module_wrapper {
    display: inline-block;
    margin-right: 20px;
}

.custom_synopsis_tabs {
    display: flex;
    background: #efefef;
    padding: 40px 0;
    box-shadow: 2px 2px 5px rgba(0,0,0,0.2);
}

.custom_synopsis_tabs .et_pb_tabs_controls {
    border-right: 1px solid #dedede;
	position: relative;
	background: #efefef;
}

.custom_synopsis_tabs .et_pb_tabs_controls li {
    display: block;
    width: auto;
    padding-bottom: 5px;
	width: 100px;
	float: none;
}

.custom_synopsis_tabs ul.et_pb_tabs_controls:after {
	display: none;
}

.custom_synopsis_tabs .et_pb_tabs_controls a {
    display: block;
    text-align: left;
    padding: 10px 15px;
    color: #6b0303;
	margin-left: 12px;
}

.custom_synopsis_tabs .et_pb_all_tabs {
    width: 100%;
	background: #efefef;
}

.custom_synopsis_tabs .et_pb_tab {
    display: none;
    padding: 0px 7% 0 5%;
}

.custom_synopsis_tabs li.et_pb_tab_active a:after {
    content: "\45";
    font-family: 'etModules';
    margin-top: -1px;
    position: absolute;
    right: 5px;
    font-size: 20px;
    color: #6b0303;
}

.custom_synopsis_tabs .et_pb_tab.et-pb-active-slide {
    display: block;
}

header .primary-nav {
	padding-top: 0 !important;
	padding-bottom: 0 !important;
}
header .primary-nav .et_pb_menu__menu nav>ul>li>a {
	padding: 21px 0 !important;
}
header .primary-nav .menu-item-has-children>a:first-child {
    padding-right: 20px !important;
}
header .primary-nav li.et_pb_menu__logo-slot {
	width: 0 !important;
	padding: 0 !important;
	-webkit-transition: all 0.2s ease-in-out;
	-moz-transition: all 0.2s ease-in-out;
	-o-transition: all 0.2s ease-in-out;
	transition: all 0.2s ease-in-out;
}
header .et_pb_sticky .primary-nav li.et_pb_menu__logo-slot {
	padding: 0 11px !important;
	width: 80px !important;
}
header .et_pb_sticky .et_pb_row_1_tb_header {
	background: #000 !important;
}

.performance {
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
    align-items: center;
    position: relative;
    color: #000;
    border-radius: 2px;
    border: 1px solid #440102;
	border-top: 5px solid #440102;
    padding: 20px;
    background: #efefef;
    margin-bottom: 20px;
}

.performance-date {
    font-size: 26px;
    font-weight: 700;
}

.performance-time {
    font-size: 20px;
    margin-top: 10px;
    font-weight: 300;
}

.performance a.et_pb_button {
	background: #ffbd01;
    font-family: 'Cinzel',Georgia,"Times New Roman",serif;
	border: none !important;
	color: #000;
	display: inline-block;
}

.production-title-sticky {
    height: 0;
    overflow: hidden;
    margin: 0 !important;
    padding: 0;
}

.et_pb_sticky .production-title-sticky {
    height: auto;
	color: #FFF;
}

.et_pb_sticky a.tickets-button, .et_pb_sticky a.subscribe-button {
    padding: 2px 2em 2px 0.7em !important;
}

.et_pb_sticky a.tickets-button:after, .et_pb_sticky a.subscribe-button:after {
    opacity: 1 !important;
    margin-left: 0.3em !important;
}

body #page-container .et_pb_sticky a.subscribe-button:after {
	font-size: 18px;
}

.acf-map {
    width: 100%;
    height: 400px;
    position: relative;
}

.acf-map .marker {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
}

.cast-members-container {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2rem;
    margin-bottom: 2rem;
}

.cast-member {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.artist-name {
    text-align: center;
    font-size: 21px;
    font-family: 'Cinzel',Georgia,"Times New Roman",serif;
	color: #440102;
}

.artist {
    margin-bottom: 0.5rem;
}

.artist img {
    max-width: 100%;
    height: 400px;
	object-fit: cover;
    border-radius: 4px;
	box-shadow: 0px 0px 20px rgba(0,0,0,0);
	position: relative;
	top: 0;
	-webkit-transition: all 0.2s ease-in-out;
	-moz-transition: all 0.2s ease-in-out;
	-o-transition: all 0.2s ease-in-out;
	transition: all 0.2s ease-in-out;
}

.artist img:hover {
    box-shadow: 0px 0px 20px rgba(0,0,0,0.2);
    top: -5px;
}

.artist .artist-name {
    margin-top: 0.5rem;
}

.character-name,
.voice-type {
    margin: 0.25rem 0;
}

.character-name {
    font-size: 18px;
    color: #6a0303;
	font-weight: 500;
}

.voice-type {
    font-size: 16px;
    font-weight: 300;
    color: #000;
}

/* Container holding the grid */
.production-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 30px;
}

/* Styles for the images and content */
.production-item img {
    width: 100%;
    height: auto;
}

.production-item .entry-title {
    margin-top: 15px;
    margin-bottom: 5px;
}

.production-item .performance-date {
    font-size: 0.9em;
    color: #5e0304;
}

.production-item .entry-summary {
    margin-top: 10px;
    margin-bottom: 20px;
}

.production-item .et_pb_button {
    display: inline-block;
    text-decoration: none;
    font-family: 'Cinzel',Georgia,"Times New Roman",serif;
    background-color: #6b0303 !important;
    color: #fff !important;
    padding: 10px 20px;
    border-radius: 2px;
    transition: background-color 0.3s ease;
}

.production-item .et_pb_button:hover {
    background-color: #000 !important;
}

.available-date {
    margin-top: 20px;
    margin-bottom: -10px;
}

.production-sticky.et_pb_sticky {
    box-shadow: 0px 0px 20px rgba(0,0,0,0.1);
}

.production-sticky .buttons-container {
    display: flex;
    column-gap: 20px;
    justify-content: center;
}

.production-sticky .buttons-container .et_pb_button_module_wrapper {
	margin: 0;
}

.availability-message {
    padding: 3em;
    margin-bottom: 3em;
    margin-top: 2em;
    background: #fbe8d5;
    border: 1px solid #440102;
}

.availability-message h3 {
    font-size: 24px;
	color: #000;
	font-weight: 700;
    font-family: 'Anek Devanagari',Helvetica,Arial,Lucida,sans-serif;
}

.availability-message p {
	color: #000;
	font-weight: 300;
	padding: 10px 0;
}

.availability-message p a {
	font-weight: 700;
	color: #440102;
}

.dcf-txt-center {
  text-align: center!important
}

.dcf-txt-left {
  text-align: left!important
}

.dcf-txt-right {
  text-align: right!important
}
    
.dcf-table caption {
  color: var(--caption);
  font-size: 1.13em;
  font-weight: 700;
  padding-bottom: .56rem
}

.dcf-table thead {
  font-size: .84em
}

.dcf-table tbody {
  border-bottom: 1px solid var(--b-table);
  border-top: 1px solid var(--b-table);
  font-size: .84em
}

.dcf-table tfoot {
  font-size: .84em
}

.dcf-table td, .dcf-table th {
  padding-right: 1.78em
}

.dcf-table-bordered, .dcf-table-bordered td, .dcf-table-bordered th {
  border: 1px solid var(--b-table)
}

.dcf-table-bordered td, .dcf-table-bordered th, .dcf-table-striped td, .dcf-table-striped th {
  padding-left: 1em;
  padding-right: 1em
}

.dcf-table-bordered tr:not(:last-child), .dcf-table-striped tr:not(:last-child) {
  border-bottom: 1px solid var(--b-table)
}

.dcf-table-striped tbody tr:nth-of-type(2n) {
  background-color: var(--bg-table-stripe)
}

.dcf-table thead td, .dcf-table thead th {
  padding-bottom: .75em;
  vertical-align: bottom
}

.dcf-table tbody td, .dcf-table tbody th, .dcf-table tfoot td, .dcf-table tfoot th {
  padding-top: .75em;
  vertical-align: top
}

.dcf-table tbody td, .dcf-table tbody th {
  padding-bottom: .75em
}

.dcf-table-bordered thead th {
  padding-top: 1.33em
}

.dcf-wrapper-table-scroll {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  left: 50%;
  margin-left: -50vw;
  margin-right: -50vw;
  padding-bottom: 1em;
  position: relative;
  right: 50%;
  width: 100vw
}

@media only screen and (max-width:42.09em) {
	.dcf-table-responsive thead {
		clip: rect(0 0 0 0);
		-webkit-clip-path: inset(50%);
		clip-path: inset(50%);
		height: 1px;
		overflow: hidden;
		position: absolute;
		width: 1px;
		white-space: nowrap
	}
	.dcf-table-responsive tr {
		display: block
	}
	.dcf-table-responsive td {
		-webkit-column-gap: 3.16vw;
		-moz-column-gap: 3.16vw;
		column-gap: 3.16vw;
		display: grid;
		grid-template-columns: 1fr 2fr;
		text-align: left!important
	}
	.dcf-table-responsive.dcf-table-bordered, .dcf-table-responsive.dcf-table-bordered thead th {
	border-width: 0
	}
	.dcf-table-responsive.dcf-table-bordered tbody td {
		border-top-width: 0
	}
	.dcf-table-responsive:not(.dcf-table-bordered) tbody tr {
		padding-bottom: .75em
	}
	.dcf-table-responsive:not(.dcf-table-bordered) tbody td {
		padding-bottom: 0
	}
	.dcf-table-responsive:not(.dcf-table-bordered):not(.dcf-table-striped) tbody td {
		padding-right: 0
	}
	.dcf-table-responsive.dcf-table-bordered tbody tr:last-child td:last-child {
		border-bottom-width: 0
	}
	.dcf-table-responsive tbody td:before {
		content: attr(data-label);
		float: left;
		font-weight: 700;
		padding-right: 1.78em
	}
}

.dcf-overflow-x-auto {
	overflow-x: auto!important;
	-webkit-overflow-scrolling: touch
}

.dcf-w-100\% {
	width: 100%!important;
}


.performance-schedule-table thead, .fixed-subscription-table thead, .flex-pass-table thead {
    background: #fbe8d5;
}

.performance-schedule-table thead th, .fixed-subscription-table thead th, .flex-pass-table thead th {
    color: #000;
    padding-top: 14px;
}

.performance-schedule-table tr td, .fixed-subscription-table tr td, .flex-pass-table tr td {
    padding-top: 12px;
    line-height: 1.3em;
}

.performance-schedule-table tbody tr:nth-child(even), .fixed-subscription-table tbody tr:nth-child(even), .flex-pass-table tbody tr:nth-child(even) {
    background: #f8f8f8;
}

body.page-id-1584 .owl-carousel .owl-item {
    padding: 0;
}

body.page-id-1584 .owl-theme .owl-dots .owl-dot.active span, body.page-id-1584 .owl-theme .owl-dots .owl-dot:hover span {
    background: #6b0303;
}

.red-button {
    color: #FFFFFF!important;
    border-width: 0px!important;
    border-color: #c99373;
    border-radius: 0px;
    font-size: 16px;
    font-family: 'Cinzel',Georgia,"Times New Roman",serif!important;
    text-transform: uppercase!important;
    background-color: #6b0303;
    padding-top: 15px!important;
    padding-right: 20px!important;
    padding-bottom: 12px!important;
    padding-left: 20px!important;
    transition: padding 300ms ease 0ms;
}

.artist-productions {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

.artist-productions .production {
    flex: 0 1 calc(33.33% - 20px);
    margin: 10px;
    text-align: center; 
}

.artist-productions .production a {
    display: block;
}

.artist-productions .production h5 {
    font-size: 22px;
}

.artist-productions .production img {
    max-width: 100%;
    height: auto;
}

.cast-tabs .et_pb_tabs_controls li a {
    padding: 15px 30px;
}

.cover-container, .production-team-container, .creative-team-container {
	display: flex;
	flex-direction: column;
	justify-content: space-between;	
}

.cover-member, .production-team-member, .creative-team-member {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: 1fr;
    grid-column-gap: 0px;
    grid-row-gap: 0px;
    column-gap: 20px;
	margin-bottom: 10px;
	padding: 5px 0;
}

.cover-title, .production-team-title, .creative-team-title {
    font-weight: 600;
}

#gallery h2 {
    margin-bottom: 2.75%;
    color: #000;
}

.empty-gallery {
	display: none !important;
}

footer .et_pb_menu__menu {
    margin: auto;
}
div#field_2_1 label {
    font-size: 20px;
}

.fixed-menu-container .fixed-only {
	display: none !important;
}

.fixed-menu-container.et_pb_sticky .fixed-only {
	display: inline-block !important;
}

.fixed-menu-container .primary-nav.et_pb_menu .et_mobile_menu ul.sub-menu {
    background: none !important;
}
body:not(.et-tb) #main-content .container {
    padding-top: 100px;
}
input#input_2_1 {
    height: 54px;
}
@media screen and (min-width: 1025px) and (max-width: 1600px) {
	.company_btn {
		padding-bottom: 0 !important;
		padding-top: 0 !important;
	}
} 

@media screen and (min-width: 981px) {

	.et-menu li li a {
    	width: 340px !important;
	}
	.nav li ul {
		width: 380px !important;
	}
	
	.et_pb_sticky .primary-nav .nav li:last-child {
		padding-right: 120px !important;
	}
}

@media screen and (max-width: 1200px) and (min-width: 981px) {
	
	.et_pb_text.explore-text {
		font-size: 40px;
	}
	
}

@media screen and (max-width: 980px) {
	header .primary-nav .et_pb_menu__logo-wrap {
		margin-bottom: 0 !important;
	}
	header .primary-nav .et_pb_menu__logo {
		width: 0;
	}
	header .et_pb_sticky .primary-nav .et_pb_menu__logo {
		width: 80px;
	}
	.header_top_section .right_side {
		justify-content: space-around;
	}
	.cast-members-container {
    	grid-template-columns: repeat(2, 1fr);
    }
	.artist img {
    	height: 50vh;
	}
	.swap-order {
		display: flex;
		flex-direction: column-reverse;
	}
	.explore-text {
		margin-top: 30px;
	}
	.explore-season .et_pb_column:first-child:after {
		display: none;
	}
	.mobile-only {
		display: block !important;
	}
}

@media screen and (max-width: 767px) {
	.header_top_section .right_side .et_pb_module {
		padding-top: 12px;
	}
	.footer_menu ul#mobile_menu2 {
		padding: 0;
		position: relative;
		display: block !important;
	}
	.footer_menu span.mobile_menu_bar{
		display:none !important;
	}
	.bgz-position {
		background-position:initial !important;
	}
	.artist-productions .production {
		flex: 0 1 100%;
		margin: 0px;
		margin-bottom: 20px;
	}
	.performance {
    	flex-wrap: wrap;
	}
	.performance a.et_pb_button {
		margin-top: 20px;
	}
}
@media screen and (min-width: 768px) and (max-width: 980px) {
	.boxes_designs {
		display: flex;
	}
	.copyrights {
		display: flex;
		flex-wrap: wrap;
	}
	.copyrights .et_pb_column:first-child {
		flex-basis: 40%;
	}
	.copyrights .et_pb_column:last-child {
		flex-basis: 60%;
	}
	.boxes_designs .et_pb_column {
		padding: 0 8px;
	}
	.footer_menu ul#mobile_menu2 {
		padding: 0;
		position: relative;
		display: flex!important;
	}
	.footer_menu ul li {
		padding: 0 20px!important;
		white-space: nowrap;
	}
	.footer_menu span.mobile_menu_bar{
		display:none !important;
	}
	.right_side{
		padding-top:20px;
	}
	footer.et-l.et-l--footer .et_pb_menu__wrap {
    	align-items: center;
    	justify-content: center;
	}
}

@media screen and (max-width: 480px) {
	.cast-members-container {
		grid-template-columns: 1fr;
	}
}

/**** This hides the sub menu items on mobile ****/
#page-container .mobile_nav li ul.hide {
    display: none !important;
}
/**** This adjusts the positioning and the background transparency of the parent menu item on mobile ****/
#page-container .mobile_nav .menu-item-has-children {
    position: relative;
}
#page-container .mobile_nav .menu-item-has-children > a {
    background: transparent;
}
/**** This styles the icon and moves it to the right ****/
#page-container .mobile_nav .menu-item-has-children > a + span {
    position: absolute;
    right: 0;
    top: 0;
    padding: 10px 20px;
    font-size: 20px;
    font-weight: 700;
    cursor: pointer;
    z-index: 3;
}
/**** Here you can swap out the actual icons ****/
#page-container span.menu-closed:before {
    content: "\4c";
    display: block;
    color: #fff;
    font-size: 16px;
    font-family: ETmodules;
}
#page-container span.menu-closed.menu-open:before {
    content: "\4d";
}
.speech-bubble-bottom-right {
	overflow: visible !important;
}

.speech-bubble-bottom-right .et_pb_text_inner:after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 85%;
    width: 0;
    height: 0;
    border: 30px solid transparent;
    border-top-color: #efefef;
    border-bottom: 0;
    border-right: 0;
    margin-left: -15px;
    margin-bottom: -40px;
}