video {
  object-fit: cover;
  width: 100vw;
  height: 100vh;
  position: fixed;
  top: 0;
  left: 0;
}

html, body {
  height: 100%;
  background-color: #000;
}

html {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
  font-size: 24px;
  line-height: 1.4;
}

body {
  margin: 0;
}

a,
a:visited,
a:hover,
a:active {
  color: #c40000;      /* Inherits the color from parent element */
  text-decoration: underline; /* Optional, keep if you want underline */
}

table {
  width: 100%;
  height: 100%;
}

#main-content {
  position: relative;
  width: 85vw;
  height: auto;
  opacity: 0.88;           /* Standard for modern browsers */
  transition: opacity 1.5s ease-in-out;
  filter: alpha(opacity=70); /* For old IE (<= IE8) */
  display: flex;
  flex-direction: column;
  align-items: flex-end;   /* aligns items to the right */
  justify-content: flex-start; /* starts from the top */
  text-align: right;       /* aligns text to the right */
  padding-top: 4vw;
  padding-right: 6vw;
  padding-left: 6vw;
  margin-top: 25px;
}

.div-radius-1 {
  border-radius: 15% 10px 15% 10%;
}

.div-radius-2 {
  border-radius: 5% 10px 5% 10px;
}

#head-td {
  font-size: 1.0rem;
}

#main-td {
  width: 100%;
  height: 100%;
}

#footer {
  width: 100%;
  height: 100%;
  text-transform: none;
  font-size: 0.6rem;
  letter-spacing: normal;
  margin: 0;
  margin-bottom: 30px;
  padding-top: 30px;
  color: #FFF;
  font-family: sans-serif;
  font-weight: normal;
}

.footer-powered {
  width: 100%;
  display: block;
  align-items: center;
  gap: 10px; /* Optional: adds space between text and image */
  font-weight: normal;
  text-transform: none;
  font-size: 0.4rem;
  letter-spacing: normal;
  text-align: center;
  margin: 0 auto;
}

.footer-powered img {
  height: 24px; /* Adjust as needed */
}

.footer-powered a {
    color: #FFF;
}

.event-title {
  font-size: 1.3rem;
  font-weight: 600;
  margin-bottom: 1rem;
  margin-top: 1rem;
  letter-spacing: normal;
}

.event-detail {
  font-family: 'Playfair Display', serif;  /* Custom serif font */
  font-size: 0.7rem;
  margin: 0;
  line-height: 1.4;
  letter-spacing: normal;
  text-align: right;
  text-transform: none;  /* Ensures no all-caps */
}

#event-map {
    width: 100%;
}

.event-detail-map {
  margin: 0;
  line-height: 1.4;
  letter-spacing: normal;
  text-align: right;
  text-transform: none;  /* Ensures no all-caps */
}

.event-detail-map iframe {
  border: 1px solid #000 !important;
}

.gen-spacer {
  margin: 0;
  height: 5vw;
  width: 100%;
}

.gen-title {
  font-size: 1.0rem;
  font-weight: 600;
  margin-bottom: 1rem;
  letter-spacing: normal;
  text-align: center;
  padding-bottom: 10px;
  border-bottom: 1px solid #CDCDCD;
  text-transform: none;
}

.gen-title-l {
  font-size: 1.3rem;
  font-weight: 600;
  margin-bottom: 1rem;
  margin-top: 1rem;
  letter-spacing: normal;
  width: 100%;
  text-align: left;
}

.gen-subtitle {
  font-size: 0.8rem;
  font-weight: 400;
  margin-bottom: 1rem;
  letter-spacing: normal;
  text-align: right;
  padding-bottom: 10px;
  border-bottom: 1px solid #CDCDCD;
  text-transform: none;
}

.gen-subtitle-l {
  font-size: 0.8rem;
  font-weight: 400;
  margin-bottom: 1rem;
  letter-spacing: normal;
  text-align: left;
  padding-bottom: 10px;
  border-bottom: 1px solid #CDCDCD;
  text-transform: none;
}

.gen-detail {
  font-family: 'Playfair Display', serif;  /* Custom serif font */
  font-size: 0.75rem;
  margin: 0;
  margin-bottom: 0.8rem;
  width: 100%;
  line-height: 1.4;
  letter-spacing: normal;
  text-align: left;
  text-transform: none;  /* Ensures no all-caps */
}

.gen-detail-centered {
  font-family: 'Playfair Display', serif;  /* Custom serif font */
  font-size: 0.75rem;
  margin: 0;
  margin-bottom: 0.8rem;
  width: 100%;
  line-height: 1.4;
  letter-spacing: normal;
  text-align: center;
  text-transform: none;  /* Ensures no all-caps */
}

.gen-detail-2 {
  font-family: 'Playfair Display', serif;  /* Custom serif font */
  font-size: 0.8rem;
  margin: 0;
  padding-bottom: 50px;
  width: 100%;
  line-height: 1.4;
  letter-spacing: normal;
  text-align: left;
  text-transform: none;  /* Ensures no all-caps */
}

@import url('https://fonts.googleapis.com/css2?family=Great+Vibes&display=swap');

.gen-detail-2::first-letter {
    font-size: 3.2rem; /* Enlarges the first letter */
    font-family: 'Great Vibes', cursive; /* Elegant script font */
    font-weight: normal;
    float: left; /* Ensures it wraps nicely */
    margin-right: 0.5rem; /* Adds spacing */
    line-height: 1.4rem; /* Aligns the letter properly */
}

.gen-title-2 {
  font-size: 1.7rem;
  font-weight: 600;
  margin-bottom: 1rem;
  letter-spacing: normal;
  text-align: center;
  width: 100%;
}

h1 {
  font-family: "Bodoni Moda", serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: normal !important;
  color: #4a3a27;
  text-transform: uppercase;
  letter-spacing: 3vw;
  line-height: 1.2;
  font-size: 3.5vw;
  text-align: center;
  span {
    display: block;
    font-size: 14vw;
    letter-spacing: 0.5vw;
  }
}

.viewport-header-center {
  position: relative;
  text-align: center;
  display: flex;
  align-items: top;
  justify-content: center;
}

@media (min-width: 480px) { /* Small tablets */
}
@media (min-width: 768px) { /* Tablets & small desktops */
}
@media (min-width: 1024px) { /* Desktops */
  table {
    width: 100%;
  }
}
@media (min-width: 1280px) { /* Large desktops */
    h1 {
      font-family: 'Syncopate', sans-serif;
      color: #4a3a27;
      text-transform: uppercase;
      letter-spacing: 3vw;
      line-height: 1.2;
      font-size: 3vw;
      text-align: center;
      span {
        display: block;
        font-size: 10vw;
        letter-spacing: -1.3vw;
      }
    }

    .viewport-header-center {
     display: flex;
      align-items: center;
    }

    #main-content {
        padding-top: 2vw;
    }

    .event-title {
        font-size: 2.5rem;
        width: 100%;
        margin-bottom: 1rem;
    }

    .gen-title {
        font-size: 2.5rem;
        padding-bottom: 1rem;
    }

    .gen-title-l {
        font-size: 2.5rem;
        margin-bottom: 1rem;
    }

    .gen-detail {
        font-size: 1rem;
    }

    .gen-detail-2 {
        font-size: 1rem;
        line-height: 2.8rem; /* Aligns the letter properly */
        margin-bottom: 3rem;
        padding-bottom: 0;
    }

    .gen-detail-2::first-letter {
        font-size: 5.2rem; /* Enlarges the first letter */
        line-height: 1.8rem; /* Aligns the letter properly */
    }

    .gen-detail-centered {
        font-size: 1.8rem;
    }

    .event-detail {
        font-size: 1rem;
    }

    .gen-separator {
        margin: 0 auto 1em !important;
    }

    #event-map {
        width: 100%;
        height: 100%;
    }

    .event-detail-map {
        width: 100%;
        height: 15rem;
    }

    .product-card {
        width: 50% !important;
        margin-bottom: 2rem !important;
        margin-top: 2rem !important;
    }

    .product-card-image {
        width: 30% !important;
    }

    .product-card-so {
        width: 30% !important;
    }

    .product-card-body {
        width: 70% !important;
        padding-left: 2vw !important;
        padding-right: 2vw !important;
    }

    .product-card-title {
        font-size: 1.2rem !important;
        margin-top: 1rem !important;
    }

    .product-card-price {
        font-size: 1rem !important;
    }

    .product-card-stock-so {
        font-size: 1rem !important;
    }

    .product-card-cart button {
        width: 50% !important;
    }

    .cart-product-card {
        height: auto !important;
    }

    .cart-product-card-image {
        width: 15% !important;
    }

    .cart-product-details {
        width: 85% !important;
        padding-left: 3vw !important;
        padding-top: 3vw;
    }

    .cart-product-details button {
        font-size: 0.5rem !important;
        width: 67px !important;
        height: 1.2rem !important;
    }

    .cart-product-name {
        font-size: 1rem;
    }

    .cart-product-stock {
        font-size: 0.6rem !important;
        margin-bottom: 1.5vw !important;
    }

    .cart-product-price {
        margin-bottom: 1.5vw !important;
        font-size: 0.8rem !important;
        padding-right: 100px !important;
    }

    .cart-product-total {
        font-size: 0.85rem !important;
    }

    .cart-total-price {
        font-size: 1rem !important;
        padding-left: 1rem;
    }

    .cart-total {
        font-size: 1rem !important;
        text-align: right;
        padding-right: 50px !important;
    }

    .cart-check-out {
        text-align: right !important;
        margin-bottom: 3vw !important;
        padding-right: 50px !important;
    }

    .cart-check-out button {
        font-size: 1.3rem !important;
    }

    .field-label {
        font-size: 0.6rem !important;
    }

    .field-input {
        font-size: 0.8rem !important;
    }

    .field-input-suggestions {
        font-size: 0.6rem !important;
    }

    .checkout button {
        font-size: 1.3rem !important;
        height: 2.1rem !important;
        margin-top: 2rem !important;
        margin-bottom: 2rem !important;
    }

    .payment-details {
        margin-bottom: 3vw;
    }

    .order-details {
        width: 60% !important;
        position: relative;
        float: left;
        font-size: 1rem !important;
    }

    .gen-subtitle {
        font-size: 1.2rem !important;
    }

    .gen-subtitle-l {
        font-size: 1.2rem !important;
    }

    .payment-summary {
        padding-right: 1rem !important;
        padding-left: 1rem !important;
    }
}

.center {
  margin: auto;
  width: 50%;
  border: 3px solid green;
  padding: 10px;
}


.refresh-button {
  align-items: center;
  appearance: none;
  background-color: #fff;
  border-radius: 24px;
  border-style: none;
  box-shadow: rgba(0, 0, 0, .2) 0 3px 5px -1px,rgba(0, 0, 0, .14) 0 6px 10px 0,rgba(0, 0, 0, .12) 0 1px 18px 0;
  box-sizing: border-box;
  color: #3c4043;
  cursor: pointer;
  display: inline-flex;
  fill: currentcolor;
  font-family: "Google Sans",Roboto,Arial,sans-serif;
  font-size: 14px;
  font-weight: 500;
  height: 48px;
  justify-content: center;
  letter-spacing: .25px;
  line-height: normal;
  max-width: 100%;
  overflow: visible;
  padding: 2px 24px;
  position: relative;
  text-align: center;
  text-transform: none;
  transition: box-shadow 280ms cubic-bezier(.4, 0, .2, 1),opacity 15ms linear 30ms,transform 270ms cubic-bezier(0, 0, .2, 1) 0ms;
  user-select: none;
  -webkit-user-select: none;
  touch-action: manipulation;
  width: auto;
  will-change: transform,opacity;
  z-index: 0;
}

.refresh-button:hover {
  background: #F6F9FE;
  color: #174ea6;
}

.refresh-button:active {
  box-shadow: 0 4px 4px 0 rgb(60 64 67 / 30%), 0 8px 12px 6px rgb(60 64 67 / 15%);
  outline: none;
}

.refresh-button:focus {
  outline: none;
  border: 2px solid #4285f4;
}

.refresh-button:not(:disabled) {
  box-shadow: rgba(60, 64, 67, .3) 0 1px 3px 0, rgba(60, 64, 67, .15) 0 4px 8px 3px;
}

.refresh-button:not(:disabled):hover {
  box-shadow: rgba(60, 64, 67, .3) 0 2px 3px 0, rgba(60, 64, 67, .15) 0 6px 10px 4px;
}

.refresh-button:not(:disabled):focus {
  box-shadow: rgba(60, 64, 67, .3) 0 1px 3px 0, rgba(60, 64, 67, .15) 0 4px 8px 3px;
}

.refresh-button:not(:disabled):active {
  box-shadow: rgba(60, 64, 67, .3) 0 4px 4px 0, rgba(60, 64, 67, .15) 0 8px 12px 6px;
}

.refresh-button:disabled {
  box-shadow: rgba(60, 64, 67, .3) 0 1px 3px 0, rgba(60, 64, 67, .15) 0 4px 8px 3px;
}

.button-top {
  padding-top:50px;
}

.product {
  margin-bottom: 10vw;
  width: 100%;
  height: 100%;
}

.product-image {
  position: relative;
  float: left;
  width: 100%;
  height: 52vh;
  text-align: center;
}

.product-image img {
  max-width: 100%;
  max-height: 100%;
  border: 1px solid #000;
  border-radius: 5% 10px 5% 10px;
}

.product-details {
  position: relative;
  float: left;
  width: 100%;
  text-align: left;
}

.product-details button {
  height: 60px;
  width: 95%;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .75rem;
  font-weight: 700;
  color: hsl(0, 0%, 100%);
  background: hsl(158, 36%, 37%);
  border: hsl(158, 36%, 37%);
  border-radius: 6px;
}

.product-details button:hover{
  background-color: hsl(212, 21%, 14%);
}

.product-details a {
  font-size: .75rem;
  text-transform: none;
  letter-spacing: normal;
}

.product-name {
  font-size: 1rem;
  text-transform: none;
  letter-spacing: normal;
  font-weight: bold;
  text-align: center;
}

.product-description {
  font-size: .75rem;
  line-height: 160%;
  text-transform: none;
  letter-spacing: normal;
}

.product-price {
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  font-size: 1.6rem;
  color: hsl(158, 36%, 37%);
  text-transform: none;
  letter-spacing: normal;
  text-align: center;
}

.product-quantity {
  font-weight: bold;
  font-size: 0.8rem;
  color: #d9534f; /* Bootstrap's 'danger' red; change to green if you want 'in stock' feel */
  background-color: #f9d6d5;
  padding: 4px 8px;
  border-radius: 5px;
  display: inline-block;
  text-transform: none;
  letter-spacing: normal;
}

.product-quantity-so {
  font-weight: bold;
  font-size: 0.8rem;
  color: #333;
  background-color: #CDCDCD;
  padding: 4px 8px;
  border-radius: 5px;
  text-align: center;
}

.product-list {
  width: 100%;
  height: 100%;
  text-align: left;
  text-transform: none;
  letter-spacing: normal;
}

.product-card {
  position: relative;
  float: left;
  width: 100%;
  margin-bottom: 10vw;
}

.product-card-image {
  position: relative;
  float: left;
  width: 50%;
  text-align: center;
}

.product-card-image img {
  width: 100%;
  border-radius: 30% 10px 15% 30%;
  border: 5px solid #000;
}

.product-card-so img {
  filter: grayscale(100%);
  -webkit-filter: grayscale(100%); /* Safari 6.0 - 9.0 */
  -moz-filter: grayscale(100%);    /* Older Firefox */
  -ms-filter: grayscale(100%);     /* IE (limited support) */
  -o-filter: grayscale(100%);
  filter: gray;                    /* Older IE (non-standard) */
  color: gray;
}

.product-card-add {
    position: absolute;
    right: 0;
    bottom: 0;
}

.product-card-body {
  position: relative;
  float: left;
  width: 50%;
  padding-left: 5vw;
}

.product-card-title {
  font-size: 1rem;
  padding: 0;
}

.product-card-title a {
  color: #000;
  text-decoration: none;
}

.product-card-price {
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  font-size: 0.7rem;
  font-weight: bold;
  color: hsl(158, 36%, 37%);
}

.product-card-text {
  font-size: 0.8rem;
}

.product-card-stock {
  font-weight: bold;
  font-size: 0.5rem;
  color: #d9534f; /* Bootstrap's 'danger' red; change to green if you want 'in stock' feel */
  background-color: #f9d6d5;
  padding: 4px 8px;
  border-radius: 5px;
  display: inline-block;
}

.product-card-stock-so {
  font-weight: bold;
  font-size: 0.5rem;
  color: #333;
  background-color: #CDCDCD;
  padding: 4px 8px;
  border-radius: 5px;
  display: inline-block;
  text-transform: uppercase;
  letter-spacing: 0.2rem;
  text-align: center;
}

.product-card-cart button:hover{
  background-color: hsl(212, 21%, 14%);
}

.product-card-cart a {
  font-size: .75rem;
  text-transform: none;
  letter-spacing: normal;
}

.product-card-cart button {
  height: 1.5rem;
  width: 90%;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .75rem;
  font-weight: 700;
  color: hsl(0, 0%, 100%);
  background: hsl(158, 36%, 37%);
  border: hsl(158, 36%, 37%);
  border-radius: 6px;
}

.cart {
  text-transform: none;
  letter-spacing: normal;
  text-align: left;
  width: 100%;
}

.cart-table {
  width: 100%;
}

.cart-product-card {
  position: relative;
  float: left;
  width: 100%;
  height: 30vw;
  padding-bottom: 10px;
  margin-bottom: 15px;
  border-bottom: 1px dotted #CDCDCD;
}

.cart-product-card-image {
  position: relative;
  float: left;
  width: 25%;
  max-height: 100%;
  text-align: center;
}

.cart-product-card-image img {
  width: 100%;
  border-radius: 30% 10px 15% 30%;
}

.cart-product-details {
  position: relative;
  display: flex;
  flex-direction: column; /* Optional: vertical stacking of child elements */
  justify-content: center; /* Vertically centers content */
  height: 100%;
  width: 75%;
  padding-left: 15px;
  margin: 0;
}

.cart-product-name {
  position: relative;
  float: left;
  width: 100%;
  font-weight: bold;
  margin-bottom: 5px;
}

.cart-product-stock {
  font-weight: bold;
  font-size: 0.5rem;
  color: #d9534f; /* Bootstrap's 'danger' red; change to green if you want 'in stock' feel */
  padding: 2px 2px;
  border-radius: 5px;
  display: inline-block;
  margin-bottom: 5px;
}

.cart-product-price {
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  font-size: 0.5rem;
  text-transform: none;
  letter-spacing: normal;
  margin-bottom: 5px;
  padding-left: 2px;
}

.cart-product-total {
  position: relative;
  float: right;
  font-size: 0.6rem;
}

.cart-product-details button {
  height: 1rem;
  width: 60px;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.4rem;
  font-weight: 700;
  color: hsl(0, 0%, 100%);
  background-color: #f7941d;
  border: hsl(158, 36%, 37%);
  border-radius: 6px;
}

.cart-product-details button:hover{
  background-color: hsl(212, 21%, 14%);
}

.cart-total {
  position: relative;
  float: left;
  width: 100%;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  font-size: 0.9rem;
  padding-left: 10px;
  margin-top: 15px;
  color: hsl(158, 36%, 37%);
}

.cart-total-price {
  position: relative;
  float: right;
  text-align: right;
  font-weight: bold;
  text-transform: none;
  letter-spacing: normal;
  font-size: 0.7rem;
}

.cart-check-out {
  position: relative;
  float: left;
  width: 100%;
  text-align: center;
  margin-top: 20px;
  margin-bottom: 20px;
}

.cart-check-out button {
  font-size: 0.8rem;
  padding: 10px 20px;
  background: hsl(158, 36%, 37%);
  color: white;
  border: none;
  border-radius: 5px;
  cursor: pointer;
  text-transform: uppercase;
}

.checkout {
  position: relative;
  width: 100%;
  float: left;
  text-decoration: none;
  letter-spacing: normal;
  text-transform: none;
}

.checkout button {
  font-size: 0.8rem;
  padding: 10px 20px;
  background: hsl(158, 36%, 37%);
  color: white;
  border: none;
  border-radius: 5px;
  cursor: pointer;
  text-transform: uppercase;
  margin-top: 1rem;
  margin-bottom: 1rem;
  height: 2rem;
}

.center-content {
    position: relative;
    float: left;
    width: 100%;
    text-align: center;
}

:root {
  --color-gray: #737888;
  --color-lighter-gray: #e3e5ed;
  --color-light-gray: #f7f7fa;
}

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

.form {
  display: grid;
  grid-gap: 1rem;
}

.field {
  position: relative;
  width: 100%;
  display: flex;
  flex-direction: column;
  border: 1px solid var(--color-lighter-gray);
  padding: .5rem;
  border-radius: .25rem;
}

.field-label {
  color: var(--color-gray);
  font-size: 0.4rem;
  font-weight: 300;
  text-transform: uppercase;
  margin-bottom: 0.25rem;
  letter-spacing: normal;
}

.field-input {
  padding: 0;
  margin: 0;
  border: 0;
  outline: 0;
  font-size: 0.6rem;
  width: 100%;
  -webkit-appearance: none;
  appearance: none;
  background-color: transparent;
}

.field-input-suggestions {
  display: none;
  position: absolute;
  top: 90%;
  left: 0;
  right: 0;
  z-index: 999;
  background-color: #fff;
  list-style: none;
  padding: 10px;
  max-height: 200px;
  overflow-y: auto;
  text-align: left;
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
  border-left: 1px solid #CDCDCD;
  border-right: 1px solid #CDCDCD;
  border-bottom: 1px solid #CDCDCD;
  border-top: 4px dashed rgba(0, 123, 255, 0.2);
  box-shadow: 0 2px 0 2px rgba(0, 123, 255, 0.2); /* subtle focus effect */
  border-radius: 0 0 .25rem 0.25rem;
  width: 100%;
  margin-top: 0;
  line-height: 1rem;
}

.field-input-suggestions a {
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  color: #000;
  font-size; 0.4rem;
}

.field:focus-within {
  border-color: #CDCDCD;
  box-shadow: 0 0 0 2px rgba(0, 123, 255, 0.2); /* subtle focus effect */
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
}

.fields {
  display: grid;
  grid-gap: 1rem;
}
.fields-2 {
  grid-template-columns: 1fr 1fr;
}
.fields-3 {
  grid-template-columns: 1fr 1fr 1fr;
}

.order-details {
  width: 100%;
}

.payment-details {
  position: relative;
  width: 100%;
  text-decoration: none;
  letter-spacing: normal;
  text-transform: none;
  text-align: center;
}

.payment-summary {
  position: relative;
  width: 100%;
  box-shadow: 0 30px 50px -20px rgb(50 50 93 / 25%), 0 30px 60px -30px rgb(0 0 0 / 30%);
  padding: 10px;
  border-radius: 15% 10px 15% 10%;
}

.payment-summary table {
  width: 100%;
  margin-bottom: 1rem;
}

.payment-summary td {
  padding-right: 5px;
}

.payment-shipping-details {
  position: relative;
  width: 100%;
  text-align: center;
  padding-left: 15px;
  box-shadow: 0 30px 50px -20px rgb(50 50 93 / 25%), 0 30px 60px -30px rgb(0 0 0 / 30%);
  padding: 10px;
  border-radius: 15% 10px 15% 10%;
}
