@charset "utf-8";

/* ==========================================
 Layout
============================================*/

/* デザイン幅に対する比率計算用 */
[style*="--w"] {
  width: calc(100% * var(--w) / 1100);
}

/* ==========================================
 Layer
============================================*/

.layer--1 {
  top: 88%;
  left: 17.5%;
}

.layer--2 {
  top: 37%;
}

.layer--3 {
  top: 17%;
}

.layer--4 {
  top: 37%;
}

.layer--5 {
  top: 84%;
  left: 17.5%;
}

.layer--6 {
  top: 3%;
  left: 73%;
}

.layer--7 {
  top: 37%;
}

.layer--8 {
  top: 0%;
}

.layer--9 {
  top: 46%;
}

.layer--10 {
  top: 80%;
  left: 17.5%;
}

.layer--11 {
  top: 48%;
  left: 73%;
}

.layer--12 {
  top: 37%;
}

.layer--13 {
  top: 37%;
}

.layer--14 {
  top: 6%;
}

.layer--popup {
  width: 92.5%;
  top: unset;
  bottom: 1.5%;
}

/* ==========================================
 Contents
============================================*/

/* text */
.txt-today {
  color: var(--bs-white);
  position: absolute;
  top: 8%;
  left: 50%;
  transform: translateX(-50%);
  font-size: var(--sz-40);
  font-weight: 500;
  white-space: nowrap;
  line-height: 1;
}

/* form */
.form-control {
  font-size: var(--sz-27);
  text-align: center;
  padding: 1em 1em;
  margin-bottom: 1em;
  --bs-border-width: 0;
  --bs-border-radius: 0;
}

/* caution */
.caution {
  font-size: var(--sz-28);
  text-align: center;
  --color-red: #901d16;
}

.caution__head {
  color: var(--bs-white);
  height: var(--sz-160);
  padding-top: 12%;
  line-height: 2;
}

.caution__body {
  padding: 1em;
  font-size: 110%;
  line-height: 1.9;
  --mb-p: 1em;
  @media (max-width: 360px) {
    font-size: 100%;
  }
}

/* slider */
.slider1 {
  & .slick-slide {
    padding: 0 var(--sz-10);
  }
}

.slider2 {
  & .slick-slide {
    height: var(--sz-300);

    & * {
      height: 100%;
    }

    & img {
      object-fit: cover;
    }
  }
}

/* ==========================================
 Follow
============================================*/
.follow {
  position: fixed;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  display: none;
  z-index: 100;
  max-width: 750px;
  width: 100%;
}

/* ==========================================
 Countdown
============================================*/
.countdown {
  position: absolute;
  top: var(--sz-32);
  right: 3.5%;
  color: #e2b90f;
  font-size: var(--sz-34);
  font-weight: bold;
  line-height: 1;
  letter-spacing: 0.33em;

  &.over {
    letter-spacing: normal;
    right: 2%;
  }
}

/* ==========================================
 Page Top
============================================*/
.pagetop {
  bottom: calc(100vw * 235 / 1100);
}

@media (min-width: 750px) {
  .pagetop {
    bottom: 5%;
  }
}

/* ==========================================
 Modal
============================================*/

.modal {
}

.modal-dialog {
  margin: 0 auto;
}

.modal-content {
  border: none;
  border-radius: 0;
  background-color: transparent;
}

.modal-header {
  border-bottom: none;
  padding: 0.5em 0;

  & .btn-close {
    --bs-btn-close-color: var(--bs-white);
    --bs-btn-close-bg: none;
    --bs-btn-close-opacity: 1;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 2em;

    &:focus {
      box-shadow: none;
    }
  }
}

.modal-body {
  padding: 0;
}

.modal__today {
  position: absolute;
  top: 2.5%;
  left: 50%;
  transform: translateX(-50%);
  font-family: var(--font-serif);
  font-size: var(--sz-65);
  font-weight: 500;
  color: var(--bs-white);
  line-height: 1;
  white-space: nowrap;
}

@media (min-width: 576px) {
  .modal__today {
    font-size: 42px;
  }
}

@media (min-width: 750px) {
  .modal-dialog {
    max-width: 650px;
  }

  .modal__today {
    font-size: 53px;
  }
}
