@charset "utf-8";

/* =========================================================
   STVegas2016.css
   ShowtimeVegas.com General Site CSS
   Corrected replacement file

   Notes:
   - Current Ajatix menu class standardized as:
     .AJXCSSMenuadRSYWA and .AJXCSSMenuadRSYWA_n
   - Removed old Ajatix menu override blocks that targeted the prior menu class.
   - Removed invalid HTML-style comments inside CSS.
   - Corrected malformed .box1 / .box3 block.
   - Added safe menu overflow and mobile detection support.
========================================================= */


/* =========================================================
   GLOBAL / FLUID MEDIA
========================================================= */

*, *::before, *::after {
  box-sizing: border-box;
}

html,
body {
  max-width: 100%;
  overflow-x: hidden;
  margin: 0;
  padding: 0;
}

img,
object,
embed,
video {
  max-width: 100%;
}

img {
  height: auto;
  display: block;
  margin-left: auto;
  margin-right: auto;
}

/* IE 6 fallback */
.ie6 img {
  width: 100%;
}

@media (prefers-color-scheme: dark) {
  /* Intentionally left blank. */
}


/* =========================================================
   DREAMWEAVER FLUID GRID PROPERTIES
   dw-num-cols-mobile: 6;
   dw-num-cols-tablet: 9;
   dw-num-cols-desktop: 12;
   dw-gutter-percentage: 25;
========================================================= */


/* Mobile Layout: 480px and below */
@media (max-width: 480px) {

  .gridContainer {
    margin-left: auto;
    margin-right: auto;
    width: 94.9666%;
    padding-left: 1.5166%;
    padding-right: 1.5166%;
  }

  #LayoutDiv1,
  #LayoutDiv2,
  #LayoutDiv3,
  #LayoutDiv4,
  #LayoutDiv5,
  #LayoutDiv6 {
    clear: both;
    float: left;
    margin-left: 0;
    width: 100%;
    display: block;
  }

  #LayoutDiv1,
  #LayoutDiv6 {
    background-color: #000000;
  }

  #LayoutDiv2,
  #LayoutDiv3,
  #LayoutDiv4,
  #LayoutDiv5 {
    background-color: #333333;
  }

  #LayoutDiv2 {
    height: 55px;
  }
}


/* Tablet Layout: 481px to 768px */
@media screen and (min-width: 481px) and (max-width: 768px) {

  .gridContainer {
    width: 90.9333%;
    padding-left: 1.0333%;
    padding-right: 1.0333%;
    margin-left: auto;
    margin-right: auto;
  }

  #LayoutDiv1,
  #LayoutDiv2,
  #LayoutDiv3,
  #LayoutDiv4,
  #LayoutDiv5,
  #LayoutDiv6 {
    clear: both;
    float: left;
    margin-left: 0;
    width: 100%;
    display: block;
  }

  #LayoutDiv1,
  #LayoutDiv6 {
    background-color: #000000;
  }

  #LayoutDiv2,
  #LayoutDiv3,
  #LayoutDiv4,
  #LayoutDiv5 {
    background-color: #333333;
  }
}


/* Desktop Layout: 769px and up */
@media screen and (min-width: 769px) {

  .gridContainer {
    width: 100%;
    max-width: 1920px;
    padding-left: 0.4891%;
    padding-right: 0.4891%;
    margin: auto;
  }

  #LayoutDiv1,
  #LayoutDiv2,
  #LayoutDiv3,
  #LayoutDiv4,
  #LayoutDiv5,
  #LayoutDiv6 {
    clear: both;
    float: left;
    margin-left: 0;
    width: 100%;
    display: block;
  }

  #LayoutDiv1,
  #LayoutDiv6 {
    background-color: #000000;
  }

  #LayoutDiv2,
  #LayoutDiv3,
  #LayoutDiv4,
  #LayoutDiv5 {
    background-color: #333333;
  }
}


/* =========================================================
   LEGACY CONTAINERS
========================================================= */

.wrapperTN {
  max-width: 80%;
  margin: 0 auto;
  background: #ffffff;
  padding: 0;
  overflow: auto;
}

.container {
  width: 300px;
  max-width: 100%;
}

.container1 {
  width: 100%;
  height: 100%;
}

.container2 {
  max-width: 100%;
}

.responsive {
  display: inline-block;
  position: relative;
  width: 100%;
  max-width: 100%;
  height: auto;
}

.responsive1 {
  display: inline-block;
  position: relative;
  max-width: 100%;
  height: 100%;
  overflow: auto;
}

.JS-container {
  position: relative;
  padding-bottom: 83%;
  max-width: 100%;
}

.JS-container script {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.Amazon-container {
  position: relative;
  padding-bottom: 83%;
  height: 0;
  overflow: hidden;
}

.Amazon-container iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

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


/* =========================================================
   TEST / BOX SECTION - CLEANED
========================================================= */

.about-section {
  max-width: 1920px;
  overflow: hidden;
  padding-bottom: 90px;
  margin: 0 auto;
}

.about-section h3 {
  color: #333333;
  margin: 90px 0 60px;
}

.box {
  box-sizing: border-box;
  width: 20%;
  max-width: 100%;
  float: left;
  border: 0 solid #000000;
  margin-left: 3%;
  background-color: #333333;
}

.box1 {
  box-sizing: border-box;
  width: 28%;
  max-width: 100%;
  float: left;
  border: 0 solid #000000;
  margin-left: 4%;
}

.box2 {
  box-sizing: border-box;
  width: 44%;
  max-width: 100%;
  float: left;
  border: 0 solid #000000;
  margin-left: 4%;
}

.box3 {
  box-sizing: border-box;
  width: 28%;
  max-width: 100%;
  float: left;
  border: 0 solid #000000;
  margin-left: 4%;
}

.box4 {
  box-sizing: border-box;
  width: 50%;
  max-width: 100%;
  float: left;
  border: 0 solid #333333;
  margin-left: 25%;
  background-color: #333333;
}

#firstBox {
  margin-left: 0;
}

#firstBoxc {
  margin-left: 36%;
}

.boxc {
  box-sizing: border-box;
  width: 28%;
  max-width: 100%;
  float: left;
  border: 0 solid #000000;
  margin-left: 36%;
}


/* =========================================================
   FLUID RATIO RESIZE
========================================================= */

.fluid-ratio-resize {
  max-width: 960px;
  background-image: url(students.jpg);
  background-size: cover;
  background-position: center;
}

.fluid-ratio-resize::after {
  content: " ";
  display: block;
  width: 100%;
  padding-top: 4.918%;
  height: 102.786px;
}


/* =========================================================
   BLUE DROP DOWN LIST CSS
========================================================= */

#related_links {
  width: 12em;
  border-right: 1px solid #000000;
  padding: 0 0 1em;
  margin-bottom: 1em;
  font-family: "Trebuchet MS", "Lucida Grande", Verdana, Lucida, Geneva, Helvetica, Arial, sans-serif;
  background-color: #90bade;
  color: #333333;
}

#related_links ul {
  list-style: none;
  margin: 0;
  padding: 0;
  border: none;
}

#related_links li {
  border-bottom: 1px solid #90bade;
  margin: 0;
}

#related_links li a {
  display: block;
  padding: 5px 5px 5px 0.5em;
  border-left: 10px solid #1958b7;
  border-right: 10px solid #508fc4;
  background-color: #2175bc;
  color: #ffffff;
  text-decoration: none;
  width: 100%;
}

html > body #related_links li a {
  width: auto;
}

#related_links li a:hover {
  border-left: 10px solid #1c64d1;
  border-right: 10px solid #5ba3e0;
  background-color: #2586d7;
  color: #ffffff;
}


/* =========================================================
   LEGACY TEXT STYLES
========================================================= */

.Style2 {
  color: #ffffff;
  font-size: 12pt;
  font-family: Arial, Helvetica, sans-serif;
  font-weight: 500;
}

.style3 {
  color: #ffffff;
  font-size: 10px;
  font-family: Arial, Helvetica, sans-serif;
  font-weight: 500;
}

.Style4 {
  color: #9999cc;
  font-size: 10px;
  font-family: Arial, Helvetica, sans-serif;
  font-weight: 500;
}

.style11 {
  color: #6633cc;
  font-size: 16px;
  font-family: Arial, Helvetica, sans-serif;
  font-weight: bold;
}

.Style12 {
  color: #9999cc;
  font-size: 12px;
  font-family: Arial, Helvetica, sans-serif;
  font-weight: 400;
}

.Style13 {
  color: #ff99cc;
  font-size: 12px;
  font-family: Arial, Helvetica, sans-serif;
  font-weight: 300;
}

.Style14 {
  color: #000000;
  font-size: 12px;
  font-family: Arial, Helvetica, sans-serif;
  font-weight: 300;
}

.Style15 {
  color: #0066cc;
  font-size: 20px;
  font-family: Arial, Helvetica, sans-serif;
  font-weight: 300;
}

.style16 {
  color: #000000;
  font-size: 15px;
  font-family: Arial, Helvetica, sans-serif;
  font-weight: bold;
}

.style17 {
  color: #ff6600;
  font-size: 20px;
  font-family: Arial, Helvetica, sans-serif;
  font-weight: bold;
}

.style18 {
  color: #0099cc;
  font-size: 20px;
  font-family: Arial, Helvetica, sans-serif;
  font-weight: bold;
}

.style19 {
  color: #0033ff;
  font-size: 22px;
  font-family: Arial, Helvetica, sans-serif;
  font-weight: 700;
}

.style20 {
  color: #0099ff;
  font-size: 14px;
  font-family: Arial, Helvetica, sans-serif;
  font-weight: 300;
}

.style25 {
  color: #ffffff;
  font-size: 12px;
  font-family: Arial, Helvetica, sans-serif;
  font-weight: 200;
}

.Style30 {
  color: #ffcc00;
  font-size: 15px;
  font-family: Arial, Helvetica, sans-serif;
  font-weight: 200;
}

.Style35 {
  color: #ffcc00;
  font-size: 15px;
  font-family: Arial, Helvetica, sans-serif;
  font-weight: bold;
}

.Style40 {
  color: #ffcc00;
  font-size: 16px;
  font-family: Arial, Helvetica, sans-serif;
  font-weight: bold;
}

.Style42 {
  color: #ffcc00;
  font-size: 12px;
  font-family: Arial, Helvetica, sans-serif;
  font-weight: 500;
}


/* =========================================================
   LEGACY HEADING CLASSES
========================================================= */

.h1,
.h1-white,
.h2,
.h3,
.h4,
.h5,
h6 {
  display: block;
  margin: 0;
  font-family: Arial, Helvetica, sans-serif;
}

.h1 {
  font-size: 18px;
  color: #000000;
  font-weight: 800;
}

.h1-white {
  font-size: 18px;
  color: #ffffff;
  font-weight: 800;
}

.h1-hero-black {
  color: #000000;
  font-size: 20px;
  font-family: Arial, Helvetica, sans-serif;
  font-weight: bold;
}

.h1-hero-white {
  color: #ffffff;
  font-size: 20px;
  font-family: Arial, Helvetica, sans-serif;
  font-weight: bold;
}

.h1-huge-black {
  color: #000000;
  font-size: 16px;
  font-family: Arial, Helvetica, sans-serif;
  font-weight: bold;
}

.h1-huge-white {
  color: #ffffff;
  font-size: 16px;
  font-family: Arial, Helvetica, sans-serif;
  font-weight: bold;
}

.h2 {
  font-size: 15px;
  color: #9999cc;
  font-weight: 800;
}

.h2-hero-black {
  color: #000000;
  font-size: 18px;
  font-family: Arial, Helvetica, sans-serif;
  font-weight: bold;
}

.h2-hero-white {
  color: #ffffff;
  font-size: 18px;
  font-family: Arial, Helvetica, sans-serif;
  font-weight: bold;
}

.h2-huge-black {
  color: #000000;
  font-size: 14px;
  font-family: Arial, Helvetica, sans-serif;
  font-weight: bold;
}

.h2-huge-white {
  color: #ffffff;
  font-size: 14px;
  font-family: Arial, Helvetica, sans-serif;
  font-weight: bold;
}

.h3,
.h4,
.h5,
h6 {
  font-size: 12px;
  color: #9999cc;
  font-weight: 800;
}

.h3-hero-black {
  color: #000000;
  font-size: 18px;
  font-family: Arial, Helvetica, sans-serif;
  font-weight: bold;
}

.h3-hero-white {
  color: #ffffff;
  font-size: 18px;
  font-family: Arial, Helvetica, sans-serif;
  font-weight: bold;
}

.h3-huge-black {
  color: #000000;
  font-size: 14px;
  font-family: Arial, Helvetica, sans-serif;
  font-weight: bold;
}

.h3-huge-white {
  color: #ffffff;
  font-size: 14px;
  font-family: Arial, Helvetica, sans-serif;
  font-weight: bold;
}


/* =========================================================
   SHOWTIMEVEGAS GENERAL PAGE / SECTION CSS
========================================================= */

.stv-page {
  width: 100%;
  margin: 0;
  padding: 0;
  font-family: Arial, Helvetica, sans-serif;
  text-align: center;
}

.stv-section {
  width: 100vw;
  max-width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  padding: 36px 16px;
  box-sizing: border-box;
  overflow-x: hidden;
  text-align: center;
}

.stv-container {
  width: min(1180px, 100%);
  margin: 0 auto;
  text-align: center;
}

.stv-center {
  text-align: center;
}

.stv-section-black {
  background: #000000;
  color: #ffffff;
}

.stv-section-gold {
  background: #f99903;
  color: #111111;
}

.stv-section-red {
  background: #b40000;
  color: #ffffff;
}

.stv-section-purple {
  background: #3b0066;
  color: #ffffff;
}

.stv-section-blue {
  background: #062b6f;
  color: #ffffff;
}

.stv-section-light {
  background: #f3f3f3;
  color: #111111;
}

.stv-section-white {
  background: #ffffff;
  color: #111111;
}

.stv-logo {
  max-width: 200px;
  height: auto;
}

.stv-hero-img {
  max-width: 100%;
  height: auto;
  border: 4px solid #f99903;
}

.stv-section h1 {
  margin: 0 0 12px;
  font-size: clamp(2rem, 5vw, 4rem);
  line-height: 1.1;
}

.stv-section h1 span {
  font-size: clamp(1.25rem, 3vw, 2rem);
}

.stv-section h2 {
  margin: 0;
  font-size: clamp(1.3rem, 3vw, 2.3rem);
}

.stv-hero-title {
  font-size: 16px;
  font-weight: 700;
}

.stv-hero-subtitle {
  font-size: 14px;
}


/* =========================================================
   FULL-WIDTH SECTIONS / HERO
========================================================= */

.stv-section.stv-section-black.full-width {
  width: 100vw !important;
  max-width: 100vw !important;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
  padding: 0 !important;
  background: #000000 !important;
  overflow: visible !important;
}

.stv-section.stv-section-black.full-width .stv-container,
.stv-menu-section .stv-container {
  width: 100% !important;
  max-width: none !important;
  margin: 0 auto !important;
  padding: 0 !important;
  overflow: visible !important;
}

.stv-menu-section {
  overflow: visible !important;
}

.stv-hero-full {
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  padding: 0;
}

.stv-hero-full .stv-hero-img {
  width: 100%;
  height: auto;
  display: block;
  border: 0;
  box-shadow: 0 8px 5px #999999;
}


/* =========================================================
   SHOWTIMEVEGAS CARD GRID / TICKET BOXES
========================================================= */

.stv-card-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 24px;
  justify-content: center;
  align-items: stretch;
}

.stv-card {
  flex: 1 1 260px;
  max-width: 320px;
  background: #ffffff;
  border: 3px solid #f99903;
  border-radius: 14px;
  box-shadow: 0 6px 18px rgba(0,0,0,.18);
  overflow: hidden;
  text-align: center;
  display: flex;
  flex-direction: column;
  height: 100%;
}

.stv-card img {
  width: 100%;
  height: auto;
  display: block;
}

.stv-card h3 {
  margin: 14px 14px 8px;
  font-size: 1.2rem;
  text-transform: uppercase;
  text-align: center;
  color: #b40000;
}

.stv-card h3 a {
  color: #b40000;
  text-decoration: none;
}

.stv-card h3 a:hover {
  text-decoration: underline;
}

.stv-card p {
  padding: 0 18px;
  margin: 0 0 auto;
  font-size: 0.875rem;
  line-height: 1.5;
  text-align: left;
  flex-grow: 1;
}

.stv-info-box {
  box-sizing: border-box;
  width: 100%;
  max-width: 950px;
  margin-left: auto;
  margin-right: auto;
  background: #f7f7f7;
  border: 3px solid #f99903;
  border-radius: 14px;
  padding: 28px;
  box-shadow: 0 6px 18px rgba(0,0,0,.15);
}

.stv-info-box h2 {
  text-align: center;
  color: #b40000;
  margin-bottom: 18px;
}

.stv-info-box p {
  font-size: 1.05rem;
  line-height: 1.65;
}

.stv-top-link {
  color: #ffffff;
  font-weight: bold;
}

.stv-btn {
  display: inline-block;
  margin: 20px auto;
  padding: 10px 18px;
  background: #0284c7;
  color: #ffffff !important;
  font-weight: 600;
  text-decoration: none;
  border-radius: 8px;
  text-align: center;
  transition: all 0.25s ease;
}

.stv-btn:link,
.stv-btn:visited,
.stv-btn:hover,
.stv-btn:active {
  color: #ffffff !important;
  text-decoration: none;
}

.stv-btn:hover {
  background: #0369a1;
  transform: translateY(-2px);
  box-shadow:
    0 0 8px rgba(56,189,248,0.7),
    0 0 18px rgba(56,189,248,0.6),
    0 0 28px rgba(56,189,248,0.5);
}

.ticket-box {
  background: linear-gradient(180deg, #ffffff 0%, #fff7e6 100%);
  border: 3px solid #f99903;
  box-shadow:
    0 0 10px rgba(249,153,3,0.45),
    0 8px 22px rgba(0,0,0,0.18);
  transition:
    transform 0.25s ease,
    box-shadow 0.25s ease,
    border-color 0.25s ease;
}

.ticket-box:hover {
  transform: translateY(-4px);
  border-color: #ffb22e;
  box-shadow:
    0 0 14px rgba(249,153,3,0.65),
    0 0 28px rgba(249,153,3,0.35),
    0 12px 28px rgba(0,0,0,0.24);
}

.ticket-box .text-small {
  padding-left: 14px;
  padding-right: 14px;
}

@media (hover: none) {
  .ticket-box:hover {
    transform: none;
  }
}

@media (max-width: 768px) {
  .stv-section {
    padding: 28px 12px;
  }

  .stv-card {
    flex-basis: 100%;
    max-width: 420px;
  }
}

@media (max-width: 640px) {
  .stv-info-box {
    padding: 20px 16px;
  }
}


/* =========================================================
   SHOWTIMEVEGAS FOOTER
========================================================= */

.stv-footer {
  padding-bottom: 50px;
}

.stv-footer-grid {
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: stretch;
  gap: 24px;
}

.stv-footer-box {
  flex: 1 1 0;
  max-width: 360px;
  min-width: 0;
  background: #111111;
  border: 2px solid #f99903;
  border-radius: 14px;
  padding: 22px;
  color: #ffffff;
}

.stv-footer-box h3 {
  color: #f99903;
  margin-top: 0;
}

.stv-footer-box a {
  display: block;
  color: #ffffff;
  text-decoration: none;
  margin: 8px 0;
}

.stv-footer-box a:hover {
  color: #f99903;
  text-decoration: underline;
}

.stv-footer-box img {
  max-width: 180px;
  height: auto;
  margin-bottom: 14px;
}

/* iPhone portrait only */
@media (max-width: 480px) {
  .stv-footer-grid {
    flex-direction: column;
    flex-wrap: nowrap;
    align-items: center;
  }

  .stv-footer-box {
    width: 100%;
    max-width: 360px;
  }
}

/* iPhone landscape and larger */
@media (min-width: 481px) {
  .stv-footer-grid {
    flex-direction: row;
    flex-wrap: nowrap;
  }

  .stv-footer-box {
    width: auto;
  }
}


/* =========================================================
   ALIGNMENT HELPERS
========================================================= */

.justify-center,
.stv-center,
.center-content {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  text-align: center;
}

.justify-left {
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  flex-direction: column;
  text-align: left;
}

.justify-right {
  display: flex;
  justify-content: flex-end;
  align-items: flex-end;
  flex-direction: column;
  text-align: right;
}

.flex-row {
  justify-content: center;
}

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


/* =========================================================
   SHOWTIMEVEGAS svU CAROUSEL CSS
========================================================= */

.svU {
  width: 100%;
  max-width: 1290px;
  margin: 0 auto;
  padding: 12px;
  font-family: system-ui, Arial, Helvetica, sans-serif;
  color: #000000;
}

.svU * {
  box-sizing: border-box;
}

.svU-header,
.svU-controls {
  text-align: center;
  justify-content: center;
}

.svU-title {
  margin: 0 0 6px;
  font-size: 20px;
  font-weight: 700;
  text-align: center;
}

.svU-controls {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 10px 0;
}

.svU-arrow {
  display: none !important;
}

.svU-dots {
  flex: 1;
  display: flex;
  justify-content: center;
  gap: 8px;
}

.svU-dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  border: 1px solid #cccccc;
  background: #ffffff;
  cursor: pointer;
}

.svU-dot[aria-selected="true"] {
  background: #f99903;
  border-color: #f99903;
}

.svU-viewport {
  width: 100%;
  overflow-x: auto !important;
  overflow-y: visible !important;
  -webkit-overflow-scrolling: touch;
  scroll-behavior: smooth;
  padding: 4px;
}

.svU-track {
  display: flex;
  flex-direction: row;
  gap: 14px;
  align-items: stretch;
  width: max-content;
  min-width: 100%;
}

.svU-card {
  flex: 0 0 260px;
  background: #ffffff;
  border: 3px solid #f99903;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 6px 18px rgba(0,0,0,.18);
  display: flex;
  flex-direction: column;
}

.svU-media {
  height: 170px;
  overflow: hidden;
}

.svU-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  border: 0;
}

.svU-body {
  padding: 12px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex: 1;
}

.svU-cardTitle {
  margin: 0;
  font-size: 16px;
  color: #b40000;
  text-align: center;
  text-transform: uppercase;
}

.svU-desc {
  margin: 0;
  font-size: 14px;
  line-height: 1.45;
  color: #111111;
}

.svU-btn {
  margin-top: auto;
  display: inline-block;
  text-align: center;
  font-weight: 700;
  font-size: 13px;
  padding: 9px 12px;
  border-radius: 50px;
  background: #0284c7;
  color: #ffffff !important;
  text-decoration: none;
}

.svU-btn:hover {
  background: #0369a1;
  color: #ffffff !important;
}

@media (min-width: 768px) {
  .svU-card {
    flex-basis: 300px;
  }

  .svU-media {
    height: 190px;
  }
}

@media (max-width: 420px) {
  .svU-card {
    flex-basis: 240px;
  }
}


/* =========================================================
   SHOWTIMEVEGAS VIATOR GRID
========================================================= */

.stv-viator-grid {
  width: 100%;
  max-width: 1290px;
  margin: 0 auto;
  padding: 12px;
  box-sizing: border-box;
  font-family: Arial, Helvetica, sans-serif;
}

.stv-viator-grid [class*="viator"] ul,
.stv-viator-grid [class*="viator"] .products,
.stv-viator-grid [class*="viator"] .product-grid,
.stv-viator-grid [class*="viator"] [class*="grid"] {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 18px !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 auto !important;
  padding: 0 !important;
  list-style: none !important;
  align-items: stretch !important;
}

.stv-viator-grid [class*="viator"] li,
.stv-viator-grid [class*="viator"] .product,
.stv-viator-grid [class*="viator"] [class*="card"],
.stv-viator-grid [class*="viator"] [class*="item"] {
  width: 100% !important;
  max-width: 100% !important;
  float: none !important;
  display: flex !important;
  flex-direction: column !important;
  height: 100% !important;
  min-height: 100% !important;
  box-sizing: border-box !important;
  border: 1px solid #d8d8d8 !important;
  border-radius: 14px !important;
  overflow: hidden !important;
  background: #ffffff !important;
  box-shadow: 0 4px 14px rgba(0,0,0,.16) !important;
}

.stv-viator-grid img {
  width: 100% !important;
  height: 190px !important;
  object-fit: cover !important;
  display: block !important;
}

.stv-viator-grid [class*="title"],
.stv-viator-grid h3,
.stv-viator-grid h4 {
  font-family: Arial, Helvetica, sans-serif !important;
  font-size: 17px !important;
  font-weight: 700 !important;
  line-height: 1.25 !important;
  text-align: center !important;
  color: #111111 !important;
  margin: 12px 10px 8px !important;
}

.stv-viator-grid p,
.stv-viator-grid [class*="description"],
.stv-viator-grid [class*="content"] {
  font-family: Arial, Helvetica, sans-serif !important;
  font-size: 14px !important;
  line-height: 1.45 !important;
  color: #333333 !important;
  text-align: left !important;
}

.stv-viator-grid [class*="content"],
.stv-viator-grid [class*="body"],
.stv-viator-grid [class*="details"] {
  display: flex !important;
  flex-direction: column !important;
  flex: 1 1 auto !important;
}

.stv-viator-grid a[href*="viator.com"] {
  color: #ffffff !important;
  text-decoration: none !important;
}

/* Button-like Viator links.
   If your Viator widget wraps images in links, add a custom class to text links
   if this rule ever styles image links unexpectedly. */
.stv-viator-grid a[href*="viator.com"] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: 12px auto 14px;
  padding: 10px 18px;
  min-height: 42px;
  border-radius: 999px;
  background: #1679b8;
  color: #ffffff !important;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.2;
  text-align: center;
  text-decoration: none;
  box-shadow: 0 3px 8px rgba(0,0,0,.18);
}

.stv-viator-grid a[href*="viator.com"]:hover,
.stv-viator-grid a[href*="viator.com"]:visited {
  color: #ffffff !important;
  background: #0f679f;
  text-decoration: none;
}

/* iPad + iPhone landscape */
@media (max-width: 900px) {
  .stv-viator-grid [class*="viator"] ul,
  .stv-viator-grid [class*="viator"] .products,
  .stv-viator-grid [class*="viator"] .product-grid,
  .stv-viator-grid [class*="viator"] [class*="grid"] {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

/* iPhone portrait */
@media (max-width: 600px) {
  .stv-viator-grid {
    padding: 10px;
  }

  .stv-viator-grid [class*="viator"] ul,
  .stv-viator-grid [class*="viator"] .products,
  .stv-viator-grid [class*="viator"] .product-grid,
  .stv-viator-grid [class*="viator"] [class*="grid"] {
    grid-template-columns: 1fr !important;
  }

  .stv-viator-grid img {
    height: 210px !important;
  }
}

/* =========================================
   ShowtimeVegas Ticket Box Black Text
   Centered Headings
========================================= */

.stv-ticket-text-black,
.stv-ticket-text-black p,
.stv-ticket-text-black h1,
.stv-ticket-text-black h2,
.stv-ticket-text-black h3,
.stv-ticket-text-black h4,
.stv-ticket-text-black span,
.stv-ticket-text-black strong,
.stv-ticket-text-black em,
.stv-ticket-text-black a {
  color: #000000 !important;
}

.stv-ticket-text-black p {
  text-align: left !important;
}

.stv-ticket-centered-headings h1,
.stv-ticket-centered-headings h2,
.stv-ticket-centered-headings h3,
.stv-ticket-centered-headings h4 {
  width: 100%;
  text-align: center !important;
  align-self: center;
}

/* =========================================================
   SHOWTIMEVEGAS FULL-SCREEN SECTION WIDTH
   Keeps every .stv-section full viewport width,
   while .stv-container remains centered for readable content.
========================================================= */

.stv-section {
  width: 100vw !important;
  max-width: 100vw !important;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
  box-sizing: border-box !important;
}

.stv-container {
  width: min(1180px, 100%) !important;
  max-width: 1180px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  box-sizing: border-box !important;
}

/* Use this class when content should also stretch edge-to-edge */
.stv-container-full {
  width: 100% !important;
  max-width: none !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* Prevent Dreamweaver wrapper/grid constraints from shrinking ShowtimeVegas sections */
.gridContainer .stv-section,
#LayoutDiv1 .stv-section,
#LayoutDiv2 .stv-section,
#LayoutDiv3 .stv-section,
#LayoutDiv4 .stv-section,
#LayoutDiv5 .stv-section,
#LayoutDiv6 .stv-section {
  width: 100vw !important;
  max-width: 100vw !important;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
}

/* Keep horizontal scrollbars from appearing after viewport breakout */
html,
body {
  overflow-x: hidden !important;
}

