:root {
  --card-border: #d6c35a;
  --price-main: #4c4fd6;
}

.event-product-section {
  margin: 0 auto;
  padding: 0;
}

.event-product-section:last-of-type {
  margin-bottom: 0;
}

.event-text-display {
  margin: 0px auto 90px auto;
}

.event-section-title {
  margin: 20px auto 16px auto;
}

.event-product-item {
  margin: 0 auto 4px auto;
}

.event-product-item:last-child {
  margin-bottom: 12px;
}

.event-product-checkbox {
  width: 20px;
  height: 20px;
  min-width: 20px;
  cursor: pointer;
  accent-color: #EBD05D;
  flex-shrink: 0;
  margin: 6px 8px 6px 6px;
  align-self: flex-start;
  border-radius: 5px;
}

.event-page {
  width: 100%;
  max-width: 1080px;
  margin: 0 auto;
  position: relative;
}

.event-page .event-bg-image {
  position: absolute;
  top: 0;
  left: 50%;
  width: 100%;
  max-width: 1080px;
  height: 100%;
  transform: translateX(-50%);
  z-index: 0;
  display: block;
}

.event-image-stack {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-top: 147%;
  padding-bottom: 25%;
  gap: clamp(5px, 1.3vw, 12px);
  position: relative;
  z-index: 1;
}

.event-card {
  position: relative;
  width: 88.2%;
  max-width: 952px;
  background: transparent;
  border: 0;
  box-shadow: none;
  padding: 0;
  margin: 0;
  cursor: pointer;
}

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

.event-image-checkbox {
  position: absolute;
  accent-color: #ff3b9b;
  cursor: pointer;
  z-index: 2;
}

.checkbox-pos-a .event-image-checkbox {
  left: 39%;
  top: 11%;
  width: 5.3%;
  height: 12.3%;
  aspect-ratio: 1 / 1;
}

.checkbox-pos-b .event-image-checkbox {
  left: 6%;
  top: 12.9%;
  width: 5.3%;
  height: 12.3%;
  aspect-ratio: 1 / 1;
}

.event-product-meta {
  display: none;
}

.event-section-title-img {
  display: block;
  height: auto;
  margin: 22px auto -15px;
}

.event-section-title-img--contour {
  width: 86.5%;
}

.event-section-title-img--bright {
  width: 64.4%;
}

.event-section-title-img--moisture {
  width: 77.9%;
}

.event-section-title-img--hair {
  width: 42.7%;
}

.event-note-group {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: clamp(30px, 3.4vw, 35px);
  gap: clamp(8px, 1.6vw, 14px);
}

.event-note {
  display: block;
  height: auto;
}

.event-note--short {
  width: 44.4%;
}

.event-note--wide {
  width: 74.4%;
}

.event-bottom-box {
  display: block;
  width: 100%;
  height: auto;
  margin-top: clamp(16px, 3.2vw, 26px);
}

.event-page .event-reservation-button-container {
  position: fixed;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  max-width: 1080px;
  padding: 0;
  box-sizing: border-box;
  background-color: transparent;
  box-shadow: none;
  z-index: 20;
  display: none;
}

.event-page .event-reservation-button-container.active {
  display: block;
}

.event-page .event-reservation-button {
  background-color: transparent;
  padding: 0;
  border: none;
  width: 100%;
  max-width: 1080px;
  display: block;
}

.event-reservation-button-img {
  display: block;
  width: 100%;
  height: auto;
  max-width: 100%;
}

.floating-event-menu {
  position: fixed;
  bottom: 100px;
  right: calc(50% - min(46vw, 270px) + 10px);
  z-index: 999;
  cursor: pointer;
  transition: transform 0.3s ease;
}

.floating-event-menu img {
  width: auto;
  height: auto;
  max-width: 70px;
  display: block;
  border-radius: 0;
}

.floating-event-menu:hover {
  transform: scale(1.05);
}

@media screen and (min-width: 1080px) {
  .event-text-display {
    margin-bottom: 130px;
  }

  .event-product-checkbox {
    width: 28px;
    height: 28px;
    min-width: 28px;
    margin: 9px 12px 8px 10px;
    border-radius: 5px;
  }

  .floating-event-menu {
    bottom: 130px;
    right: calc(50% - 450px + 20px);
  }

  .floating-event-menu img {
    width: auto;
    height: auto;
    max-width: 120px;
  }

  .event-page .event-reservation-button {
    max-width: 1080px;
    margin: 0 auto;
  }

  .checkbox-pos-a .event-image-checkbox {
    left: 38%;
    top: 8.3%;
    width: 4.5%;
    height: 17%;
    aspect-ratio: 1 / 1;
  }

  .checkbox-pos-b .event-image-checkbox {
    left: 5%;
    top: 11%;
    width: 4.5%;
    height: 17%;
    aspect-ratio: 1 / 1;
  }
}

@media (max-width: 480px) {
  .checkbox-pos-a .event-image-checkbox {
    left: 37%;
    top: 7.5%;
    width: 1.3%;
    height: 14.3%;
    aspect-ratio: 1 / 1;
  }

  .checkbox-pos-b .event-image-checkbox {
    left: 3.5%;
    top: 10.3%;
    width: 3.3%;
    height: 14.3%;
    aspect-ratio: 1 / 1;
  }
}
