.heroTxt {
    line-height: 1.5rem !important;
    margin-bottom: 2rem !important;
}

.home-video {
    max-height: 600px;
    overflow: hidden;
}

@media(max-width:1199px) {
    .home-video {
        max-height: 400px;
        overflow: hidden;
    }
}

.home-video iframe {
    width: 100%;
}

.home-video .ratio-16x9 {
    margin-top: -10px;
}

#logo-home {
    max-height: 125px;
    filter: drop-shadow(0px 0px 0px white) brightness(2);
}

#logo-footer {
    max-height: 200px;
    filter: drop-shadow(0px 0px 0px white) brightness(2);
}

.footer-wrapper {
    background-color: transparent;
}

#heroCarousel .hero-content.heroBtnWrap {
    margin: 0px;
}

#promotiles .btn {
    width: 100% !important;
}

.dropdown-menu li:hover a {
    color: var(--color-3);
}

.navbar-toggler {
    filter: invert(1);
}

.page-header {
    background-image: url('https://media-library-activestorage-production.s3.us-east-2.amazonaws.com/qb1p2qchjppw0v6n8p6xhos6ha0g');
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    border-bottom: 2px solid var(--color-1);
}

.page-header h1 {
    text-wrap: balance;
    display: inline-block;
    background: var(--color-3);
    color: var(--color-1);
    border: 2px solid var(--color-1);
    padding: 5px 12px;
    box-shadow: 0px 0px 10px var(--color-1-opacity);
}

.player-card {
    padding: 2rem 1.5rem;
    background-color: var(--color-1);
    border-radius: 1rem;
}

.player-card p,
.player-card h2 {
    color: var(--color-3);
}

.player-image-wrapper {
    width: 250px;
    height: 250px;
    max-width: 100%;
    max-height: 100%;
    overflow: hidden;
}

.player-image-wrapper img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.player-name {
    font-weight: 600;
}

.player-bio {
    font-size: 0.95rem;
    line-height: 1.6;
    max-height: 8.5rem;
    overflow: hidden;
    position: relative;
    text-align: left;
    opacity: 1;
}

.player-bio::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 3rem;
    background: linear-gradient(to bottom, rgba(20, 20, 20, 0), var(--color-1));
}

.player-bio.expanded::after {
    display: none;
}

@media (prefers-reduced-motion: no-preference) {
    .player-bio {
        transition: max-height 0.35s ease, opacity 0.35s ease;
    }
}

@media (prefers-reduced-motion: reduce) {
    .player-bio {
        transition: none;
    }
}

.player-toggle {
    margin-top: 1rem;
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding-inline: 1.5rem;
}

.player-toggle:focus-visible {
    outline: 3px solid #ffc107;
    outline-offset: 3px;
}


#top-dueling-piano-songs h2,
#top-dueling-piano-songs h3 {
    color: var(--color-1);
}

.top-songs-list {
    counter-reset: song-counter;
    margin: 0;
    padding-left: 0;
}

.top-songs-list>li {
    position: relative;
    padding: 1rem 1.25rem 1rem 3.25rem;
    border-radius: 0.75rem;
    background-color: var(--color-1);
    box-shadow: 0px 0px 10px var(--color-1-opacity);
}

.top-songs-list>li::before {
    counter-increment: song-counter;
    content: counter(song-counter);
    position: absolute;
    left: 27px;
    top: 50%;
    transform: translate(-50%, -50%);
    font-weight: 700;
    font-size: 1.25rem;
    line-height: 1;
    color: var(--color-3);
}

.top-songs-list>li * {
    color: var(--color-3) !important;
}


.top-songs-list>li:nth-child(2n) {
    background-color: var(--color-3);
    border: 2px solid var(--color-1);
}

.top-songs-list>li:nth-child(2n) *,
.top-songs-list>li:nth-child(2n)::before {
    color: var(--color-1) !important;
}

.song-artist {
    display: inline-block;
    margin-left: 0.25rem;
    font-weight: 500;
}

.song-description {
    font-size: 0.95rem;
}

#top-dueling-piano-songs a:focus-visible,
#top-dueling-piano-songs button:focus-visible {
    outline: 3px solid #ffc107;
    outline-offset: 3px;
}

#history-dueling-pianos p,
#history-dueling-pianos li,
#history-dueling-pianos a {
    color: var(--color-1);
    line-height: 1.65;
}

.history-content p {
    margin-bottom: 1.25rem;
    font-size: 1.05rem;
}

.history-sources li {
    margin-bottom: 0.75rem;
}

.history-sources a {
    text-decoration: underline;
}

#history-dueling-pianos a:focus-visible {
    outline: 3px solid #ffc107;
    outline-offset: 3px;
}



#weekly-events h1,
#weekly-events h2,
#weekly-events h3 {
    color: var(--color-1);
}

#weekly-events p {
    color: var(--color-1);
}

#weekly-events img {
    width: 100%;
    height: auto;
    display: block;
    box-shadow: 0px 0px 10px var(--color-1-opacity);
}

#weekly-events a:focus-visible,
#weekly-events button:focus-visible {
    outline: 3px solid #ffc107;
    outline-offset: 3px;
}



.gift-card-hero img {
    display: block;
}

.gift-card-content h2 {
    color: var(--color-1);
}

.gift-card-content p {
    color: var(--color-1);
    font-size: 1.05rem;
}

.gift-card-btn:focus-visible {
    outline: 3px solid #000000;
    outline-offset: 3px;
}


#reservations p {
    color: var(--color-1);
}

#reservations a:focus-visible,
#reservations button:focus-visible {
    outline: 3px solid #ffc107;
    outline-offset: 3px;
}

.reservation-widget {
    max-width: 100%;
    min-height: 260px;
}

#reservation-widgets {
    min-height: 460px;
    padding-top: 9rem !important;
    padding-bottom: 9rem !important;
}

#reservation-widgets iframe {
    position: absolute;
}

#ot-reservation-widget:focus-visible {
    outline: 3px solid #ffc107;
    outline-offset: 3px;
}

@media(max-width:1199px) {
    #reservation-widgets {
        min-height: 400px;
        padding-top: 3rem !important;
        padding-bottom: 3rem !important;
    }
}

.ot-dtp-picker.wide .ot-title {
    color: var(--color-3) !important;
}

.blog-tag {
    color: var(--color-3) !important;
}

[data-gjs-type="content-section"] .player-bio {
    max-height: 100% !important;
}

.calendarTags label {
    text-transform: capitalize;
}

.calendar-events .card-img-top {
    height: 230px;
    object-position: top;
}



/* menu css */

.divider {
	color: var(--color-1);
	width: 100%;
	margin: 20px auto;
	overflow: hidden;
	text-align: center;
	line-height: 2;
}

.divider:before,
.divider:after {
	content: "";
	vertical-align: middle;
	display: inline-block;
	width: 50%;
	border-bottom: 2px dotted var(--color-1);
	margin: 0 2% 0 -55%;
}

.divider:after {
	margin: 0 -55% 0 2%;
}

h3:nth-child(2) {
	font-size: 3em;
}

h3.divider {
	font-family: var(--big-headers-font);
	text-transform: capitalize;
	font-size: 3rem;
}


.menu-header {
	max-height: 300px;
    border-radius: 25px;
    box-shadow: 0px 0px 10px var(--color-1-opacity);
    object-fit: cover;
}
.menu-header .popup-image{
    width: 100%;
}
.menu-header img {
	object-fit: cover;
}

.menu-main {
    background-color: var(--color-3);
    border: 2px solid var(--color-1);
    border-radius: 15px;
    padding: 20px;
    margin-bottom: 25px;
}

.menu-main .nav-link {
	color: var(--color-1);
}

.menu-main .nav-link.active {
	background-color: var(--color-1);
	color: #fff;
}

.menu-main .menu-item h5 {
	font-weight: 700;
	color: var(--color-1);
	margin-bottom: 0;
	justify-content: space-between;
	display: flex;
}

.menu-main .ingredients {
    font-size: .8rem;
    padding-right:2px;
    padding-left: 2px;
}

.item-title {
	margin-bottom: 30px;
	position: relative;
}

.item-title h5 {
	display: flex;
	justify-content: space-between;
	position: relative;
	z-index: 0;
}

.item-title h5::before {
	content: "";
	position: absolute;
	top: 11px;
	left: 0;
	right: 0;
	z-index: -1;
	border-bottom: 2px dotted var(--color-1);
}

.item-title h5 > span {
	background-color: white;
	margin-bottom: -2px;
	font-size: 1.2rem;
	line-height: 1.5;
    padding-right:2px;
    padding-left: 2px;
}

@media (max-width: 1200px) {
	.item-title h5 > span {
		font-size: 14px;
	}
}

@media (max-width: 1200px) {
	.item-title h5 > span {
		font-size: 12px;
	}

	h3.divider {
		font-size: 2rem;
	}
}

.price {
	background-color: white;
	color: var(--color-1) !important;
	font-size: 14px;
	line-height: 1.5;
	padding-left: 3px;
}

.col-lg-12:has(.divider):has(p) h3.divider {
  margin-bottom: 0 !important;
}
.col-lg-12:has(.divider) p {
  margin-bottom: 20px;
}

.menu-main .fade:not(.show) {
	display: none;
}

.accordion-button:not(.collapsed) {
	color: var(--color-1);
	background-color: var(--color-1-opacity);
	box-shadow: inset 0 calc(-1 * var(--bs-accordion-border-width)) 0 var(--bs-accordion-border-color);
}

.accordion-button:focus {
	z-index: 3;
	border-color: var(--color-1-opacity);
	outline: 0;
	box-shadow: var(--color-1-opacity);
}

.accordion {
	--bs-accordion-btn-active-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23ce3f3f'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");

	--bs-accordion-btn-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23ce3f3f'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
}

.item-title h5 span > span:last-child {
	margin-right: 5px;
}

.calendar-events .fa-solid.fa-calendar-plus {
    -webkit-filter: drop-shadow(0px 0px 3px var(--color-3-opacity));
    filter: drop-shadow(0px 0px 3px var(--color-3-opacity));
}