.x-scroll,.xy-scroll {
    overflow-x: auto;
}
.y-scroll,.xy-scroll {
    overflow-y: auto;
}
.x-scroll {
    overflow-y:hidden;
}
.y-scroll {
    overflow-x:hidden;
}
.x-scroll,.y-scroll,.xy-scroll {
    cursor: grab;
}
.x-scroll:not(.with-scrollbar),.y-scroll:not(.with-scrollbar),.xy-scroll:not(.with-scrollbar) {
    scrollbar-width: none; 
}
.x-scroll:not(.with-scrollbar)::-webkit-scrollbar,.y-scroll:not(.with-scrollbar)::-webkit-scrollbar,.xy-scroll:not(.with-scrollbar)::-webkit-scrollbar { 
    display: none; /* For Chrome, Safari and Opera */
}
.ArnContainer {
  width: 100%;
}
.keystoneCarousel-container {
  position:relative;
  display:flex;
  /* overflow: auto; */
  height: 100%;
  width: 100% !important;
}

#thePropertyImages, fieldset#theHotel, fieldset.ArnProperty{
    min-inline-size: auto;
    width: 100%;
}
.keystoneCarousel-container .keystoneCarousel {
  z-index:20;
  white-space: nowrap;
  height: 100%;
  /* display: flex; */
}
.keystoneCarousel-container > :not(.keystoneCarousel) {
  position:absolute;
}
.keystoneCarousel-container > :not(.keystoneCarousel, .slide-loading-content) {
  border-radius:20px;
  background-color:#fff;
}
.keystoneCarousel-container i {
  z-index:30;
  top:calc(50% - 11px);
  right:5%;
  width:22px;
  height:22px;
  transition: opacity 1s;
  display: flex;
  justify-content: center;
  align-items: center; 
}
.keystoneCarousel-container i svg {
  height: 50%;
  width: 50%;
  margin:0 !important;
}
.keystoneCarousel-container.hideOverlayUntilHover i.hidden, .keystoneCarousel-container i.hidden {
  opacity: 0 !important;
}
.keystoneCarousel-container i.left {
  z-index:30;
  left: 5%;
}
.touchEnabled, .touchEnabled * {
  cursor: pointer;
}
.keystoneCarousel-container > .slide-loading-content {
  z-index:10;
  height:100%;
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center; 
}
.keystoneCarousel-container > .slideStatusBar {
  z-index:30;
  bottom:5%;
  left:5%;
  gap: 4px;
} 
.keystoneCarousel-container  .slideCount, .keystoneCarousel-container  .toggleFullscreen {
  display: inline-block;
  border-radius: 5rem;
  font-size: 16px;
  padding: 0 0.5em;
  font-weight: 700;
  color: #36382E;
}
.keystoneCarousel .slideCount {
  position: absolute;
    z-index: 30;
    bottom: 5%;
    left: 5%;
  border-radius:20px;
  background-color:#fff;
}
.keystoneCarousel .slide .slide-loading-content {
  display:none;
}
.keystoneCarousel .slideCount svg, .keystoneCarousel-container > .slideCount svg, .keystoneCarousel-container > .slideStatusBar svg, .keystoneCarousel-container > .toggleFullscreen svg {
  height: 1em;
  vertical-align: middle;
}
.keystoneCarousel-container > .slide-loading-content .throbber {
  height:75px !important;
  width: 75px !important;
}
.keystoneCarousel-container .slide > div {
  display:flex;
  height: 100%;
  width: 100%;
}
.keystoneCarousel-container .slide  img {
  opacity:1;
  transition: opacity 1s;
}
.keystoneCarousel-container .slide .lazy img {
  opacity:0;
}
.keystoneCarousel-container .slide {
  /* overflow: hidden; */
  display: inline-block;
  width:100%;
  /* object-fit: cover; */
  height: 100%;
  /* max-height: 400px; */
  /* align-items: stretch; */
  /* flex-direction: column; */
  /* flex-grow: 1; */
  flex: 1;
  /* align-items: stretch; */
}
.keystoneCarousel-container:fullscreen .slide a {
  display:flex !important;
  justify-content: center;
  align-items: center; 
  width:100%;
}
.keystoneCarousel-container:fullscreen .slide img {
  border-radius:0px !important;
  display: block;
  width: 100%;
  height: auto;
  /* padding: 1em; */
  object-fit: contain !important;
  padding: 1em;
}
.keystoneCarousel-container .imageCarousel .slide > div >  img, .keystoneCarousel-container .imageCarousel .slide > div > a > img {
  object-fit:cover;
  object-position: 50% 50%;
  height: 100%;
  width: 100%;
}
.keystoneCarousel-container .imageCarousel .slide > div > a {
  width:100%;
  height:100;
}
.SearchMode-WBHotelListKeystone .ArnPropThumb {
  max-height:250px;
}
.keystoneCarousel-container.hideOnDesktop {
    display: none;
}

.keystoneCarousel-container:fullscreen .slide {
  height: 100% !important;
}
@media screen and (max-width: 800px) {
  .keystoneCarousel-container {
    width:100% !important;
  }
  .keystoneCarousel-container.hideOnDesktop {
    display:flex; 
  }
  .keystoneCarousel-container .keystoneCarousel{
    border-radius: 0px;
    overflow: scroll;
  }
}
.ArnContainer:fullscreen {
  flex: 1;
  flex-direction: column-reverse;
  align-items: center;
  padding: 1em;
}
.ArnContainer:fullscreen .ArnPropThumb {
  max-height: 100% !important;
  width: 100% !important;
  flex-grow: 1;
  border-radius: 8px !important;
  background-color:transparent !important;
}
.ArnContainer:fullscreen .keystoneCarousel.imageCarousel .slide {
  height: 100% !important;
}
.ArnContainer:fullscreen .ArnPropSummary {
  background-color: #fff;
  border-radius: 8px !important;
}

.ArnContainer:fullscreen .ArnBottomContainer {
  position:relative;
}
.ArnContainer:fullscreen .keystoneCarousel-container .imageCarousel .slide > div > img, .ArnContainer:fullscreen .keystoneCarousel-container .imageCarousel .slide > div > a > img {
  object-fit: contain;
  border-radius: 8px !important;
}
.ArnContainer:fullscreen .slide-loading-content {
  display:none;
}
.arnPropFullscreenActions {
  display:none;
  text-align:center;
}
.ArnContainer:fullscreen .arnPropFullscreenActions {
  margin-top:1em;
  margin-bottom:1em;
  display:block;
  color: #fff;
}
.ArnContainer:fullscreen .arnPropFullscreenActions button {
  margin:0 1em;
}
.ArnContainer:fullscreen .slideStatusBar .toggleFullscreen {
  display:none;
}


/* OLD
#thePropertyImages, fieldset#theHotel {
    min-inline-size: auto;
}
.keystoneCarousel-container{
  display: flex;
  position: relative;
  width: 100%;
}
.keystoneCarousel-container.hideOnDesktop {
  display:none;
}
.keystoneCarousel-container.hideOverlayUntilHover i, .keystoneCarousel-container.hideOverlayUntilHover .slideCount {
  opacity: 0;
  visibility: 0;
}
.keystoneCarousel-container.hideOverlayUntilHover:hover i, .keystoneCarousel-container.hideOverlayUntilHover:hover .slideCount {
  opacity: 1;
  visibility: 1;
}
.keystoneCarousel-container .keystoneCarousel i {
  opacity: 0;
  visibility: 0;
}
.keystoneCarousel-container .keystoneCarousel.loaded i {
  opacity: 1;
  visibility: 1;
}
.keystoneCarousel-container i{
  top: 50%;
  height: 44px;
  width: 44px;
  color: #36382E;
  cursor: pointer;
  font-size: 1.15rem;
  position: absolute;
  text-align: center;
  line-height: 44px;
  background: rgba(255, 255, 255, 0.90);
  border-radius: 50%;
  transform: translateY(-50%);
  transition: transform 0.1s linear, visibility 0.5s, opacity 0.5s linear;
}
.keystoneCarousel-container i {
  z-index: 200;
}
.keystoneCarousel-container i:hover {
  opacity:1;
}
.keystoneCarousel-container i:active{
  transform: translateY(-50%) scale(0.8);
  background: #f2f2f2;
}
.keystoneCarousel-container i.hidden {
  visibility: hidden;
  opacity: 0;
}
.keystoneCarousel-container i:first-child{
  left: 15px;
}
.keystoneCarousel-container i:last-child{
  right: 15px;
}
.keystoneCarousel-container .keystoneCarousel{
  -webkit-overflow-scrolling: touch;
  width: 100%;
  cursor: grab;
  white-space: nowrap;
  overflow: hidden;
  border-radius: 8px;
}
.keystoneCarousel-container .keystoneCarousel:not(.isTouchSafari) {
  -webkit-overflow-scrolling: touch;
  scroll-behavior: smooth;
  scroll-snap-type: x mandatory;
}
.keystoneCarousel:not(.isTouchSafari):active, .keystoneCarousel.dragging {
  scroll-snap-type: none !important;
  scroll-behavior: auto !important;
}
.keystoneCarousel:active{
  cursor: grabbing;
}
.keystoneCarousel.dragging .slide{
  pointer-events: none;
  width: 100%;
  height: 100%;
}
.keystoneCarousel.imageCarousel .slide img {
  object-fit: cover;
  object-position: center;
  width: 100%;
  height: 100%;
  pointer-events: none;
}
.keystoneCarousel .slide .throbber {
  width: 44px;
  height: 44px;
}
.keystoneCarousel .slide .slide-loading-content {
  display:none;
}
.keystoneCarousel .slide > div {
  height:100%;
  width: 100%;
  vertical-align: top;
}
.keystoneCarousel .slide > div.lazy img {
  display:none;
}
.keystoneCarousel .slide > div.lazy .slide-loading-content {
  height:100%;
  display: flex;
  justify-content: center;
  align-items: center;
}
.keystoneCarousel .slide {
  user-select: none;
  margin-right: 12px;
  scroll-snap-align: start;
  width: 100%;
  display: inline-block;
  vertical-align: top;
}
.keystoneCarousel.imageCarousel .slide {
  height:400px;
}

.keystoneCarousel .slideCount {
  position: absolute;
    left: 15px;
    bottom: 15px;
    background-color: rgba(255, 255, 255, 0.90);
    padding: 4px 16px;
    font-weight: 700;
    z-index: 1;
    color: #36382E;
    gap: 4px;
    font-size: 16px;
    border-radius: 5rem;
    display: flex;
    align-items: center;
    transition: all .3s ease-in-out;
    box-shadow: 1px 2px 3px 4px rgba(0, 0, 0, .0);
}
@media screen and (max-width: 800px) {
  .keystoneCarousel-container.hideOnDesktop {
    display:flex; 
  }
  .keystoneCarousel-container .keystoneCarousel{
    border-radius: 0px;
    overflow: scroll;
  }
}
*/