/* ==============================
  Base Settings
============================== */
@media screen and (min-width: 751px), print {
  html {
    font-size: 0.625em;
  }
}
@media screen and (max-width: 750px) {
  html {
    font-size: 2.2vw;
  }
}

body {
  font-family: sans-serif;
  font-size: 1.8rem;
  color: #111;
}

img {
  vertical-align: bottom;
  max-width: 100%;
}

/* Display
------------------------------ */
@media screen and (min-width: 751px), print {
  .forsp {
    display: none !important;
  }
  br.fortb {
    display: none;
  }
}
@media screen and (max-width: 1189px) {
  br.fortb {
    display: inline;
  }
}
@media screen and (max-width: 750px) {
  .forpc {
    display: none !important;
  }
}
.detail_wrapper {
  width: min(100%, 1100px);
  margin: 0 auto;
}
.detail_inner {
  position: relative;
  width: 90%;
  margin: 0 auto;
  padding: 5% 0 5rem;
  text-align: center;
}
.detail_inner > p {
  margin-bottom: 0.25em;
  line-height: 1.6;
}
@media screen and (max-width: 750px) {
  .detail_inner {
    padding: 8% 0;
    line-height: 1.5;
  }
}
.detail_title {
  font-size: 4.6rem;
  font-weight: 700;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 750px) {
  .detail_title {
    font-size: 3.8rem;
  }
}
#okigaru .detail_title {
  color: #0062b1;
}
#lifeup .detail_title {
  color: #E8537D;
}
.detail_place {
  margin: 0.75em 0 0.5em;
  font-size: 3.4rem;
  font-weight: 700;
  letter-spacing: 0.05em;
}
.detail_place > span {
  display: inline-block;
  margin: 0 0.25em;
}
@media screen and (max-width: 750px) {
  .detail_place {
    margin-top: 0.5em;
    line-height: 1.3 !important;
    font-size: 2.8rem;
    letter-spacing: 0;
  }
}
#okigaru .detail_place {
  color: #f00;
}
#lifeup .detail_place {
  color: #0062b1;
}
.detail_address > span {
  display: inline-block;
  margin: 0 0.25em;
}
.detail_access > span {
  display: inline-block;
  margin: 0 0.25em;
}
#okigaru .detail_access {
  color: #0062b1;
}
#lifeup .detail_access {
  color: #E8537D;
}
.detail_parking {
  margin-top: 0.5em;
  font-size: 2.5rem;
}
.detail_mapbtn {
  margin-top: 1em;
  font-size: 2rem;
}
.detail_mapbtn a {
  width: 11em;
  margin: 0 auto;
  padding: 0.5rem 0.75rem;
  border-radius: 0.8em;
  display: flex;
  align-items: center;
  color: #fff;
  transition: opacity 0.3s;
}
#okigaru .detail_mapbtn a {
  background-color: #0062b1;
  box-shadow: 0 2px 0 rgba(0, 98, 177, 0.5);
}
#lifeup .detail_mapbtn a {
  background-color: #E8537D;
  box-shadow: 0 2px 0 rgba(232, 83, 125, 0.5);
}
.detail_mapbtn a::after {
  content: "";
  width: 1.2em;
  height: 1.2em;
  background: url(/assets/images/common/map_arw.svg) center center/contain no-repeat;
}
.detail_mapbtn a span {
  flex: 1;
  text-align: center;
}
.detail_mapbtn a:hover {
  opacity: 0.8;
}
.detail_mark {
  position: absolute;
  top: 3rem;
  right: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 2rem;
}
.detail_mark img {
  width: 9rem;
}
@media screen and (max-width: 750px) {
  .detail_mark {
    position: static;
    margin: 3rem 0;
  }
}
.detail_date {
  width: min(90%, 720px);
  margin: 3rem auto 0;
  display: flex;
  justify-content: center;
  gap: 20px;
}
.detail_date > dl {
  width: min((100% - 20px) / 2, 350px);
  background-color: #FFFEE5;
}
.detail_date > dl dt {
  padding: 1rem 1.25rem;
  line-height: 1;
  text-align: center;
  font-size: 2rem;
  font-weight: 500;
  color: #fff;
}
#okigaru .detail_date > dl dt {
  background-color: #0062b1;
}
#lifeup .detail_date > dl dt {
  background-color: #E8537D;
}
.detail_date > dl dd {
  height: calc(100% - 4.5rem);
  padding: 1rem 2rem;
  display: flex;
  justify-content: center;
  align-items: center;
  line-height: 1.4;
}
@media screen and (max-width: 750px) {
  .detail_date {
    display: block;
  }
  .detail_date > dl {
    width: 100%;
  }
}
.detail_day ul li {
  text-align: right;
  font-size: 2.4rem;
  font-feature-settings: "palt";
}
.detail_time ul {
  display: flex;
  flex-wrap: wrap;
}
.detail_time ul li {
  width: 50%;
  text-align: left;
}
.detail_time ul li:nth-child(odd) {
  padding: 0 0.5em 0 0;
}
.detail_time ul li:nth-child(even) {
  padding: 0 0 0 0.5em;
}
#lifeup .detail_time ul {
  display: block;
}
#lifeup .detail_time ul li {
  width: 100%;
  font-size: 2.4rem;
  padding: 0 !important;
}
.detail_button {
  padding: 3rem 5%;
}
#okigaru .detail_button {
  background-color: #C8E1FF;
}
#lifeup .detail_button {
  background-color: #FADCE9;
}
.detail_button > * {
  width: min(100%, 860px);
  margin: 0 auto;
  line-height: 1.4;
}
.detail_close {
  padding: 1.5rem;
  border-radius: 5rem;
  background-color: #767677;
  text-align: center;
  font-size: 2rem;
  font-weight: 700;
  color: #fff;
}
@media screen and (max-width: 750px) {
  .detail_close {
    font-size: 2rem;
  }
  #lifeup .detail_close::first-line {
    font-size: 1.6rem;
  }
}
.detail_open a {
  display: flex;
  align-items: center;
  padding: 1.5rem;
  border-radius: 5rem;
  font-size: 2.4rem;
  font-weight: 700;
  color: #fff;
  transition: opacity 0.3s;
}
#okigaru .detail_open a {
  background-color: #0062b1;
}
#lifeup .detail_open a {
  background-color: #E8537D;
}
.detail_open a::after {
  content: "";
  width: 1em;
  height: 1em;
  background: url(/assets/images/common/btn_arrow.svg) center center/contain no-repeat;
}
.detail_open a > span {
  flex: 1;
  text-align: center;
}
.detail_open a > span span {
  display: inline-block;
  vertical-align: middle;
  padding: 0.25em 0.5em;
  background-color: #fff;
  font-size: 1.6rem;
  font-weight: 400;
  color: #111;
}
.detail_open a > span em {
  font-style: normal;
}
.detail_open a:hover {
  opacity: 0.8;
}
@media screen and (max-width: 750px) {
  .detail_open a > span {
    display: block;
    padding: 0 0.5em;
  }
  .detail_open a > span span {
    margin-top: -1rem;
    font-size: 1.4rem;
  }
  #lifeup .detail_open a {
    font-size: 1.8rem;
  }
}/*# sourceMappingURL=soudan_detail.css.map */