@charset "utf-8";
/* CSS Document */
/**/
#header, #footer {
  display: none;
}
#main {
  margin: 0 !important;
  padding: 0 !important;
}
body {
  background: #F8F2F0;
}
#rosem {
  box-sizing: border-box;
  margin: 0 auto;
  padding: 0;
  box-shadow: none !important;
  position: relative;
  line-height: 1.5;
  max-width: 800px;
  margin: 0 auto;
}
@media (min-width: 800px) {
  #rosem {
    box-shadow: 0px 0px 10px 0px rgba(170, 170, 170, 0.5) !important;
  }
}
#rosem a, #rosem a:hover {
  text-decoration: none;
  display: block;
}
#rosem img {
  width: 100%;
  vertical-align: bottom;
  margin: 0;
  border: none;
}
#rosem h3 {
  text-align: center;
  color: #7c3a44;
  font-family: "Noto Serif JP", serif;
  font-size: 18px;
  line-height: 1.3;
  margin: 16px 0;
}
/*------------------------------------------*/
.rosem-hd {
  height: 60px;
  max-width: 800px;
  box-shadow: 0px 5px 10px 0px rgba(124, 58, 68, 0.1) !important;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  padding: 0 3%;
  position: fixed;
  background: #F8F2F0;
  width: 100%;
  box-sizing: border-box;
  z-index: 9;
}
.rosem-hd .hd-left, .rosem-hd .hd-right {
  width: 80px;
  display: flex;
}
.rosem-hd .hd-right {
  justify-content: right;
}
.rosem-hd .hd-center {
  width: calc(100% - 160px);
}
.rosem-hd .rosem-logo {
  width: 100%;
  height: 60px;
  margin: 0;
  padding: 0;
}
.rosem-hd .rosem-logo img {
  height: 28px !important;
  width: auto !important;
  margin-top: 8px !important;
}
.rosem-hd .rosem-logo p {
  display: flex;
  max-width: 300px;
  align-items: center;
  text-align: center;
  margin: 4px auto 0;
  font-size: 10px;
  font-weight: normal;
  width: 100%;
  color: #7c3a44;
  font-family: "Noto Serif JP", serif;
}
.rosem-hd .rosem-logo p::before, .rosem-hd .rosem-logo p::after {
  content: "";
  flex: 1;
  height: 1px;
  background-color: #7c3a44;
  margin: 0 3px;
}
.rosem-hd .rosem-logo span {
  white-space: nowrap;
}
#rosem .rosem-hd .icon, #rosem #rosem-menu .close .icon {
  width: 24px;
  height: auto;
  max-height: 24px;
  fill: currentColor;
  display: inline-block;
  vertical-align: middle;
  color: #7c3a44;
}
#rosem .rosem-hd .icon path, #rosem #rosem-menu .close .icon path {
  fill: currentColor;
}
.rosem-hd .hd-right a {
  width: 40px;
  height: 40px;
  display: flex !important;
  justify-content: center;
  align-items: center;
  margin: 0 !important;
  padding: 0;
}
#rosem .rosem-trigger {
  width: 40px;
  height: 40px;
  box-sizing: border-box;
  padding: 0;
  z-index: 99;
  display: flex;
  justify-content: center;
  align-items: center;
}
/*------------------------------------------*/
#rosem .nav-hd {
  height: 60px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  padding: 0 3%;
  justify-content: flex-start;
}
#rosem #rosem-menu .close {
  width: 40px;
  text-align: center;
}
/*------------------------------------------*/
#rosem .nav-cate {
  width: 100%;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  background: #F8F2F0;
}
#rosem .nav-cate ul {
  width: 100%;
  border-bottom: solid 1px #7c3a44;
}
#rosem .nav-cate li {
  width: 100%;
  position: relative;
  border-top: solid 1px #7c3a44;
}
#rosem .nav-cate li:after {
  display: block;
  content: "";
  position: absolute;
  top: 50%;
  right: 16px;
  width: 8px;
  height: 8px;
  margin: -4px 0 0 0;
  border-top: solid 1px #7c3a44;
  border-right: solid 1px #7c3a44;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
#rosem .nav-cate li a {
  padding: 12px 16px;
  color: #7c3a44;
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  font-size: 16px;
}
/*------------------------------------------*/
#rosem .nav-user {
  width: 100%;
  margin: 0 auto;
  background: #7c3a44;
  padding: 16px;
  box-sizing: border-box;
  margin-top: auto;
}
#rosem .nav-user .user-icon {
  margin-right: 8px;
}
#rosem .nav-user ul {
  display: flex;
  justify-content: space-between;
}
#rosem .nav-user li {
  width: 48%;
  border: 1px solid #7c3a44;
  background: #fff;
  border-radius: 8px;
  position: relative;
}
#rosem .nav-user li a {
  padding: 8px;
  color: #7c3a44;
  text-align: center;
}
#rosem .nav-user li:after {
  display: block;
  content: "";
  position: absolute;
  top: 50%;
  right: 15px;
  width: 8px;
  height: 8px;
  margin: -4px 0 0 0;
  border-top: solid 1px #7c3a44;
  border-right: solid 1px #7c3a44;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
/*------------------------------------------*/
#rosem .nav-info {
  width: 100%;
  margin: 0 auto;
  margin-top: auto;
  padding: 16px;
  box-sizing: border-box;
  background: rgba(124, 58, 68, .2);
}
#rosem .nav-info ul {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
#rosem .nav-info ul li a {
  padding: 3px 8px;
  color: #7c3a44;
  font-size: 10px;
}
/*------------------------------------------*/
#rosem .video {
  margin: 0;
}
#rosem .video video {
  max-width: 800px;
  width: 100%;
  height: auto;
  display: block;
  margin: 0 auto;
  aspect-ratio: 9 / 16;
  padding-top: 60px;
}
#rosem .video.video-yoko video {
  aspect-ratio: 16 / 9;
}
/*------------------------------------------*/
#rosem .bg-box {
  position: relative;
  width: calc(100% - 48px);
  margin: 16px auto 64px;
  padding: 16px;
  box-sizing: border-box;
  background: none;
  color: #7c3a44;
  text-align: center;
  border-radius: 8px;
  box-shadow: 0px 5px 10px 0px rgba(124, 58, 68, 0.4) !important;
  font-family: "Noto Serif JP", serif;
}
#rosem .bg-box::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-image: url('https://d-rw.com/Contents/Rosem/teaser/teaser_bg_image.png');
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  opacity: 0.5;
  z-index: -1;
  border-radius: inherit;
}
#rosem .bg-box h2 {
  font-family: "Mea Culpa", cursive;
  font-weight: normal;
  font-size: 40px;
  margin: 8px auto;
}
#rosem .bg-box p.text {
  font-size: 11px;
  margin: 8px auto;
}
#rosem .bg-box p.title-img {
  width: 70%;
  max-width: 280px;
  margin: 0 auto;
  margin: 16px auto;
}
#rosem .bg-box .sns-flex {
  display: flex;
  background: rgba(255, 255, 255, .5);
  border-radius: 8px;
  padding: 16px;
  justify-content: center;
  align-items: center;
}
#rosem .bg-box .sns-flex li {
  width: 40px;
  margin: 0 4px;
}
/*------------------------------------------*/
#rosem .rosem-ft {
  background: rgba(124, 58, 68, .2);
  padding: 32px 16px 64px;
  margin: 0;
}
#rosem .rosem-ft .ft-info ul {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
#rosem .rosem-ft .ft-info ul li a {
  padding: 3px 8px;
  color: #7c3a44;
  font-size: 10px;
}
#rosem .rosem-ft h1 {
  width: 120px;
  margin: 0 auto 16px;
}
#rosem .rosem-ft .copy {
  text-align: center;
  color: #7c3a44;
  font-size: 10px;
  margin: 24px auto 0;
}
/**/
#rosem .img-wrap {
  width: 100%;
  margin: 0 auto;
  padding: 0;
}
#rosem .img-wrap .flex {
  display: flex;
}
#rosem .img-wrap .flex div {
  flex: 1;
}
/**/
#rosem .fade-box {
  margin: 0 auto;
  position: relative;
}
#rosem .fade {
  position: relative;
  top: 0;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}
#rosem .fade.visible {
  opacity: 1;
  transform: translateY(0);
}