:root {
  --base-color: #ff7f0b;
}

.main {
  overflow: hidden;
  color: #5c1a1a;
}

.moriHd {
  background-color: #fff;
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  left: 0;
  z-index: 1000;
}
.moriHd.js-move {
  background-color: rgb(255, 255, 255,0.9);
}
.moriHd .moriHd__inr {
  padding: 10rem 0;
  max-width: 1320rem;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.moriHd .moriHd__logo {
  width: 50rem;
}
.moriHd .moriHd__list {
  display: flex;
  align-items: center;
}
.moriHd .moriHd__item + .moriHd__item {
  padding-left: 30rem;
}
.moriHd .moriHd__item a {
  color: var(--c-hover);
  font-size: 16rem;
  font-weight: bold;
  line-height: 1;
  text-decoration: none;
}
.moriHd .moriHd__item a:hover {
  text-decoration: underline;
}
.moriHd .moriHd__menu {
  display: none;
}
/* PC
----------------------------------*/
@media screen and (min-width: 769px) {
  .moriHd .moriHd__list {
    display: flex !important;
    opacity: 1 !important;
  }
}
/* SP
----------------------------------*/
@media screen and (max-width: 768px) {
  .moriHd {
  }
  .moriHd.js-move {
  }
  .moriHd.js-open {
    background-color: #fff;
  }
  .moriHd .moriHd__inr {
    padding: 0;
    max-width: 100%;
    height: 80rem;
  }
  .moriHd .moriHd__logo {
    width: 45rem;
  }
  .moriHd .moriHd__list {
    display: none;
    position: absolute;
    top: 80rem;
    left: 0;
    width: 100%;
    background-color: #fff;
    border-bottom: 1px solid #e0e0e0;
  }
  .moriHd .moriHd__item + .moriHd__item {
    padding-left: 0;
  }
  .moriHd .moriHd__item a {
    border-top: 1px solid #e0e0e0;
    padding: 20rem;
    position: relative;
  }
  .moriHd .moriHd__item a::before {
    content: " ";
    width: 8rem;
    height: 12rem;
    background: url(/common/images/icn_arw_link_rd.svg) no-repeat center / contain;
    position: absolute;
    top: 50%;
    right: 20rem;
    transform: translateY(-50%);
  }
  .moriHd .moriHd__item a:hover {
    text-decoration: none;
  }
  .moriHd .moriHd__menu {
    display: block;
    text-align: center;
  }
  .moriHd .moriHd__menuBar {
    order: 2;
    width: 40rem;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20rem 0;
    cursor: pointer;
    z-index: 50;
    transition: all 0.2s ease-in-out;
    background-color: transparent;
  }
  .moriHd .moriHd__bar,
  .moriHd .moriHd__menuBar::before,
  .moriHd .moriHd__menuBar::after {
    width: 100%;
    height: 2px;
    background-color: #e70012;
    transition: all 0.2s ease-in-out;
  }
  .moriHd .moriHd__menuBar::before,
  .moriHd .moriHd__menuBar::after {
    content: " ";
    position: absolute;
  }
  .moriHd .moriHd__menuBar::before {
    top: 12rem;
    right: 0;
  }
  .moriHd .moriHd__menuBar::after {
    bottom: 12rem;
    left: 0;
  }
  .moriHd .moriHd__menuTtl {
    color: #e70012;
    font-size: 10rem;
    font-weight: bold;
    line-height: 1.5;
    margin-top: -5rem;
    transition: all 0.2s ease-in-out;
  }
  /* ↓ナビオープン時↓ */
  .moriHd.js-open .moriHd__menuBar {
    border-radius: 50%;
    background-color: #fff;
  }
  .moriHd.js-open .moriHd__bar {
    opacity: 0;
  }
  .moriHd.js-open .moriHd__menuBar::before {
    transform: rotate(-45deg);
    top: 20rem;
  }
  .moriHd.js-open .moriHd__menuBar::after {
    transform: rotate(45deg);
    bottom: 20rem;
  }
  .moriHd.js-open .moriHd__menuTtl {
    opacity: 0;
  }
  /* ↑ナビオープン時↑ */
  .wrapOl {
    background-color: rgba(255, 129, 10,0.8);
  }
}


.moriFt {
  background-color: var(--c-hover);
  position: relative;
}
.moriFt .moriFt__inr {
  padding: 20rem;
}
.moriFt .moriFt__returnBtn {
  position: fixed;
  bottom: 75rem;
  right: 20rem;
  width: 50rem;
  height: 60rem;
}
.moriFt .moriFt__copyright {
  text-align: center;
  font-size: 14rem;
  font-weight: 500;
  line-height: 1.5;
  color: #fff;
}
/* SP
----------------------------------*/
@media screen and (max-width: 768px) {
  .moriFt .moriFt__inr {
    padding: 20rem 0;
  }
  .moriFt .moriFt__copyright {
    font-size: 12rem;
  }
}


/*====================================
↓コンテンツ部分↓
====================================*/
.secKv {
  overflow: hidden;
}
.secKv .secKv__inr {
  position: relative;
  display: flex;
}
.secKv .secKv__info {
  width: 442rem;
  padding: 35rem 0 40rem;
}
.secKv .secKv__infoLogo {
  width: 280rem;
  margin: 0 auto;
}
.secKv .secKv__infoTtl {
  text-align: center;
  margin-top: 15rem;
}
.secKv .secKv__infoTtl span {
  display: inline-block;
  background-color: #fff;
  padding: 10rem 20rem;
  margin: 5rem 0;
  border-radius: 10rem;
  font-size: 36rem;
  font-weight: bold;
  line-height: 1;
}
.secKv .secKv__infoImg {
  margin: 40rem auto 0;
  width: 425rem;
}
.secKv .secKv__img {
  margin-right: -100rem;
  flex: 1;
  display: flex;
  overflow: hidden;
}
.secKv .secKv__img picture {
  width: calc(100% / 3);
}
.secKv .secKv__img img {
  -o-object-fit: cover;
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.secKv .secKv__cta {
  position: absolute;
  bottom: 40rem;
  right: -60rem;
}
.secKv .secKv__ctaInr {
  width: 340rem;
  padding: 20rem;
  border-radius: 10rem;
  background-color: #fff;
  text-align: center;
}
.secKv .secKv__ctaTtl {
  font-size: 15rem;
  font-weight: bold;
  line-height: 1.5;
}
.secKv .secKv__ctaImg {
  margin-top: 20rem;
}
.secKv .secKv__ctaBtn {
  margin: 20rem auto 0;
  width: 300rem;
}
/* SP
----------------------------------*/
@media screen and (max-width: 768px) {
  .secKv {
    overflow: unset;
  }
  .secKv .secKv__inr {
    display: block;
  }
  .secKv .secKv__info {
    width: 100%;
    padding: 25rem 0;
    display: flex;
  }
  .secKv .secKv__infoTop {
    width: 160rem;
  }
  .secKv .secKv__infoLogo {
    width: 100%;
    margin-left: 0;
  }
  .secKv .secKv__infoBottom {
    flex: 1;
  }
  .secKv .secKv__infoTtl {
    flex: 1;
    margin-top: 0;
  }
  .secKv .secKv__infoTtl span {
    padding: 5rem 10rem;
    margin: 2rem 0;
    font-size: 22rem;
  }
  .secKv .secKv__infoImg {
    margin: 10rem auto 0;
    width: 190rem;
  }
  .secKv .secKv__img {
    margin-right: 0;
    margin: 0 -20rem;
    flex: 1;
    display: flex;
  }
  .secKv .secKv__img picture {
    width: calc(100% / 3);
  }
  .secKv .secKv__img img {
    -o-object-fit: cover;
    object-fit: cover;
    width: 100%;
    height: 100%;
  }
  .secKv .secKv__cta {
    position: absolute;
    bottom: -20rem;
    right: auto;
    left: 50%;
    transform: translate(-50%,100%);
  }
  .secKv .secKv__ctaInr {
    width: 350rem;
  }
}



.secAbout {
  background-color: var(--base-color);
}
.secAbout .sec__inr {
  padding: 80rem 0 60rem;
  text-align: center;
  color: #fff;
}
.secAbout .sec__ttl {
  font-size: 40rem;
  font-weight: bold;
  line-height: 1.5;
  padding-bottom: 30rem;
  position: relative;
}
.secAbout .sec__ttl::before {
  content: " ";
  width: 160rem;
  height: 6rem;
  background: url(/lineup/moritama/images/about_bar.svg) no-repeat center / contain;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
}
.secAbout .sec__txt {
  margin-top: 30rem;
  line-height: 1.8;
}
.secAbout .sec__img {
  margin: 30rem -50rem 0;
  width: 1300rem;
}
.secAbout .caption {
  text-align:right;
  margin-top: 20px;
}
/* SP
----------------------------------*/
@media screen and (max-width: 768px) {
  .secAbout {
  }
  .secAbout .sec__inr {
    /* padding: 280rem 0 60rem; */
    padding: 60rem 0 60rem;
  }
  .secAbout .sec__ttl {
    font-size: 32rem;
    padding-bottom: 30rem;
  }
  .secAbout .sec__ttl::before {
    content: " ";
    width: 120rem;
  }
  .secAbout .sec__txt {
    margin-top: 30rem;
  }
  .secAbout .sec__img {
    margin: 30rem 0 0 -10rem;
    width: 360rem;
  }
  .secAbout .caption {
    font-size: 10rem;
  }
}


.secPoint {
  background: url(/lineup/moritama/images/moritama_block_bg.png) repeat top left / 100%;
  padding-bottom: 120rem;
}
.secPoint .sec__block {
  padding-top: 100rem;
  padding-bottom: 20rem;
  position: relative;
  z-index: 0;
  overflow: hidden;
}
.secPoint .sec__block::before {
  content: " ";
  width: 100vw;
  height: 400rem;
  background-color: var(--base-color);
  position: absolute;
  top: 140rem;
  z-index: -1;
}
.secPoint .sec__blockInr {
  position: relative;
  z-index: 1;
  display: flex;
}
.secPoint .sec__img {
  width: 520rem;
}
.secPoint .sec__info {
  margin-top: 80rem;
  background-color: #fff;
  padding: 40rem;
  border-radius: 20rem;
  flex: 1;
  box-shadow: 0 3rem 10rem rgba(0, 0, 0,0.16);
}
.secPoint .sec__infoHead {
  display: flex;
  align-items: center;
}
.secPoint .sec__num {
  width: 100rem;
}
.secPoint .sec__ttl {
  flex: 1;
  padding-left: 20rem;
  font-size: 32rem;
  font-weight: bold;
  line-height: 1.5;
}
.secPoint .sec__ttl em,
.secPoint .sec__txt em {
  color: var(--base-color);
}
.secPoint .sec__txt {
  margin-top: 35rem;
  font-weight: bold;
  line-height: 1.8;
  letter-spacing: 0.05em;
}
.secPoint .sec__txt + .sec__txt {
  margin-top: 25rem;
}
.secPoint .sec__block._type-imgR::before {
  left: 600rem;
  transform: translateX(-50%);
  border-radius: 0 200rem 200rem 0;
}
.secPoint .sec__block._type-imgR .sec__info {
  margin-left: 40rem;
}
.secPoint .sec__block._type-imgL::before {
  left: -600rem;
  transform: translateX(50%);
  border-radius: 200rem 0 0 200rem;
}
.secPoint .sec__block._type-imgL .sec__info {
  margin-right: 40rem;
  order: -1;
}
/* SP
----------------------------------*/
@media screen and (max-width: 768px) {
  .secPoint {
    background: url(/lineup/moritama/images/moritama_block_bg.png) repeat top left / 300%;
    padding-bottom: 60rem;
  }
  .secPoint .sec__block {
    padding-top: 80rem;
    padding-bottom: 20rem;
  }
  .secPoint .sec__block::before {
    width: 100vw;
    height: 400rem;
    top: 40rem;
  }
  .secPoint .sec__blockInr {
    display: block;
  }
  .secPoint .sec__img {
    width: 100%;
  }
  .secPoint .sec__info {
    margin-top: 20rem;
    padding: 30rem 20rem;
  }
  .secPoint .sec__infoHead {
    display: block;
    text-align: center;
  }
  .secPoint .sec__num {
    width: 80rem;
    margin: 0 auto;
  }
  .secPoint .sec__ttl {
    padding-left: 0;
    font-size: 24rem;
    margin: 20rem -10rem 0;
  }
  .secPoint .sec__ttl em,
  .secPoint .sec__txt em {
    color: var(--base-color);
  }
  .secPoint .sec__txt {
    margin-top: 25rem;
  }
  .secPoint .sec__txt + .sec__txt {
    margin-top: 15rem;
  }
  .secPoint .sec__block._type-imgR::before {
    left: 0;
    transform: translateX(0);
    border-radius: 0 200rem 200rem 0;
  }
  .secPoint .sec__block._type-imgR .sec__info {
    margin-left: 0;
  }
  .secPoint .sec__block._type-imgL::before {
    left: auto;
    right: 0;
    transform: translateX(0);
    border-radius: 200rem 0 0 200rem;
  }
  .secPoint .sec__block._type-imgL .sec__info {
    margin-right: 0;
    order: -1;
  }
}


.secAttempt {
  background-color: #fefaed;
}
.secAttempt .sec__inr {
  padding: 100rem 0;
  overflow: hidden;
  text-align: center;
}
.secAttempt .sec__ttl {
  font-size: 32rem;
  font-weight: bold;
  line-height: 1.6;
  position: relative;
  display: inline-block;
}
.secAttempt .sec__ttl::before,
.secAttempt .sec__ttl::after {
  content: " ";
  width: 50vw;
  height: 2px;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background-color: #5c1a1a;
}
.secAttempt .sec__ttl::before {
  left: -30rem;
  transform: translateX(-100%);
}
.secAttempt .sec__ttl::after {
  right: -30rem;
  transform: translateX(100%);
}
.secAttempt .sec__cts {
  text-align: left;
  margin-top: 45rem;
  display: flex;
  justify-content: space-between;
}
.secAttempt .sec__item {
  width: calc((100% / 3) - 30rem);
}
.secAttempt .sec__itemInr {
  height: 100%;
  display: flex;
  flex-direction: column;
  background-color: var(--base-color);
  border-radius: 20rem;
  padding: 40rem;
  color: #fff;
}
.secAttempt .sec__itemTtl {
  text-align: center;
  font-size: 20rem;
  font-weight: bold;
  line-height: 1.5;
}
.secAttempt .sec__itemTxt {
  margin-top: 25rem;
  line-height: 1.8;
}
.secAttempt .md-linkBtn {
  margin-top: auto;
  padding-top: 20rem;
  width: 100%;
}
.secAttempt .md-linkBtn a {
  border: 0;
  font-weight: bold;
  color: #5c1a1a;
}
.secAttempt .md-linkBtn a::before {
  background: url(/lineup/moritama/images/icn_circle_arw_or.svg) no-repeat center center / contain;
}
/* SP
----------------------------------*/
@media screen and (max-width: 768px) {
  .secAttempt .sec__inr {
    padding: 50rem 0;
  }
  .secAttempt .sec__ttl {
    font-size: 20rem;
  }
  .secAttempt .sec__ttl::before,
  .secAttempt .sec__ttl::after {
    height: 2px;
  }
  .secAttempt .sec__ttl::before {
    left: -20rem;
  }
  .secAttempt .sec__ttl::after {
    right: -20rem;
  }
  .secAttempt .sec__cts {
    margin-top: 40rem;
    display: block;
  }
  .secAttempt .sec__item {
    width: 100%;
  }
  .secAttempt .sec__item + .sec__item {
    margin-top: 30rem;
  }
  .secAttempt .sec__itemInr {
    border-radius: 10rem;
    padding: 30rem 20rem;
  }
  .secAttempt .sec__itemTtl {
    font-size: 20rem;
  }
  .secAttempt .sec__itemTxt {
    margin-top: 15rem;
  }
  .secAttempt .md-linkBtn {
    padding-top: 30rem;
  }
  .secAttempt .md-linkBtn a {
  }
  .secAttempt .md-linkBtn a::before {
    background: url(/lineup/moritama/images/icn_circle_arw_or.svg) no-repeat center center / contain;
  }
}


.secLineUp {
  background-color: #fff;
}
.secLineUp .sec__inr {
  padding: 80rem 0;
  text-align: center;
}
.secLineUp .sec__ttl {
  font-size: 38rem;
  font-weight: bold;
  line-height: 1.5;
  position: relative;
  padding-bottom: 30rem;
}
.secLineUp .sec__ttl::before {
  content: " ";
  width: 160rem;
  height: 6rem;
  background: url(/lineup/moritama/images/about_bar_or.svg) no-repeat center / contain;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
}
.secLineUp .sec__cts {
  margin-top: 60rem;
}
.secLineUp .sec__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0 -50rem;
}
.secLineUp .sec__item {
  width: calc((100% / 3));
  padding: 40rem 50rem;
  text-align: center;
}
.secLineUp .sec__itemTtl {
  margin-top: 20rem;
  font-size: 18rem;
  font-weight: bold;
  line-height: 1.5;
}
.secLineUp .md-linkBtn {
  margin-top: 30rem;
  width: 100%;
}
.secLineUp .md-linkBtn a {
  border: 0;
  background-color: var(--base-color);
  color: #fff;
  font-size: 16rem;
  font-weight: bold;
}
.secLineUp .md-linkBtn a::before {
  background: url(/common/images/icn_circle_arw_or.svg) no-repeat center center / contain;
}
.secLineUp .md-linkBtn span {
  position: relative;
  padding-left: 28rem;
}
.secLineUp .md-linkBtn span::before {
  content: " ";
  width: 18rem;
  height: 18rem;
  background: url(/common/images/icn_shop_wt.svg) no-repeat center / contain;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
}
.secLineUp .sec__ftTtl {
  margin-top: 80rem;
  font-size: 38rem;
  font-weight: bold;
  line-height: 1.5;
}
/* SP
----------------------------------*/
@media screen and (max-width: 768px) {
  .secLineUp .sec__inr {
    padding: 50rem 0;
  }
  .secLineUp .sec__ttl {
    font-size: 32rem;
    padding-bottom: 30rem;
  }
  .secLineUp .sec__ttl::before {
    width: 120rem;
    height: 6rem;
  }
  .secLineUp .sec__cts {
    margin-top: 20rem;
  }
  .secLineUp .sec__list {
    display: block;
    margin: 0;
  }
  .secLineUp .sec__item {
    width: 100%;
    padding: 20rem 20rem;
    text-align: center;
  }
  .secLineUp .sec__itemTtl {
    margin-top: 10rem;
  }
  .secLineUp .md-linkBtn {
    margin-top: 20rem;
  }
  .secLineUp .md-linkBtn a {
    font-size: 16rem;
  }
  .secLineUp .sec__ftTtl {
    margin-top: 40rem;
    font-size: 22rem;
  }
}


.secOther {
}
.secOther .sec__inr {
  padding: 120rem 0;
}
.secOther .sec__gift {
  border-radius: 20rem;
  background: url(/lineup/moritama/images/moritama_gift_bg.png) no-repeat center / cover;
  padding: 40rem 60rem;
  display: flex;
  align-items: center;
  margin: 0 auto;
  width: 980rem;
}
.secOther .sec__giftImg {
  order: 2;
  width: 374rem;
}
.secOther .sec__giftInfo {
  flex: 1;
  padding-right: 60rem;
}
.secOther .sec__giftTtl {
  font-size: 36rem;
  font-weight: bold;
  line-height: 1.5;
}
.secOther .sec__giftTxt {
  margin-top: 20rem;
  line-height: 1.8;
}
.secOther .sec__gift .md-linkBtn {
  margin-left: 0;
  margin-top: 30rem;
  width: 300rem;
}
.secOther .sec__gift .md-linkBtn a {
  border: 0;
  font-weight: bold;
  color: #5c1a1a;
}
.secOther .sec__gift .md-linkBtn a::before {
  background: url(/lineup/moritama/images/icn_circle_arw_or.svg) no-repeat center center / contain;
}
.secOther .sec__info {
  /*margin-top: 120rem;*/
  overflow: hidden;
  text-align: center;
}
.secOther .sec__ttl {
  color: var(--c-hover);
  font-size: 32rem;
  font-weight: bold;
  line-height: 1.5;
  position: relative;
  display: inline-block;
}
.secOther .sec__ttl::before,
.secOther .sec__ttl::after {
  content: " ";
  width: 50vw;
  height: 2px;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background-color: var(--c-hover);
}
.secOther .sec__ttl::before {
  left: -30rem;
  transform: translateX(-100%);
}
.secOther .sec__ttl::after {
  right: -30rem;
  transform: translateX(100%);
}
.secOther .sec__list {
  margin-top: 45rem;
  display: flex;
  justify-content: space-between;
  color: #fff;
}
.secOther .sec__item {
  width: calc((100% / 2) - 20rem);
}
.secOther .sec__itemInr {
  background-color: var(--c-hover);
  border-radius: 20rem;
  padding: 40rem;
}
.secOther .sec__itemTtl {
  font-size: 32rem;
  font-weight: bold;
  line-height: 1.5;
}
.secOther .sec__itemTxt {
  margin-top: 15rem;
  font-weight: bold;
  line-height: 1.8;
}
.secOther .md-linkBtn {
  margin-top: 40rem;
  width: 300rem;
}
.secOther .md-linkBtn a {
  border: 0;
  color: var(--c-hover);
  font-weight: bold;
}
/* SP
----------------------------------*/
@media screen and (max-width: 768px) {
  .secOther {
  }
  .secOther .sec__inr {
    padding: 60rem 0;
  }
  .secOther .sec__gift {
    border-radius: 10rem;
    background: url(/lineup/moritama/images/moritama_gift_bg.png) no-repeat center / cover;
    padding: 40rem 20rem;
    display: block;
    width: 100%;
  }
  .secOther .sec__giftImg {
    width: 100%;
  }
  .secOther .sec__giftInfo {
    padding-right: 0;
    margin-top: 40rem;
    text-align: center;
  }
  .secOther .sec__giftTtl {
    font-size: 28rem;
  }
  .secOther .sec__giftTxt {
    margin-top: 20rem;
    line-height: 1.8;
  }
  .secOther .sec__gift .md-linkBtn {
    margin-top: 30rem;
    width: 100%;
  }
  .secOther .sec__info {
    margin-top: 80rem;
  }
  .secOther .sec__ttl {
    font-size: 20rem;
  }
  .secOther .sec__ttl::before {
    left: -10rem;
  }
  .secOther .sec__ttl::after {
    right: -10rem;
  }
  .secOther .sec__list {
    margin-top: 35rem;
    display: block;
  }
  .secOther .sec__item {
    width: 100%;
  }
  .secOther .sec__item + .sec__item {
    margin-top: 20rem;
  }
  .secOther .sec__itemInr {
    border-radius: 10rem;
    padding: 30rem 20rem;
  }
  .secOther .sec__itemTtl {
    font-size: 24rem;
  }
  .secOther .sec__itemTxt {
    margin-top: 15rem;
  }
  .secOther .md-linkBtn {
    margin-top: 30rem;
    width: 100%;
  }
  .secOther .md-linkBtn a {
    border: 0;
    color: var(--c-hover);
    font-weight: bold;
  }
}
