@charset "UTF-8";
/* ----------------------------------- */
html {
  line-height: 1.5;
  font-size: 6.25%;
  position: relative;
}

body {
  background: black;
  position: relative;
  font-size: 21rem;
  font-family: 'M PLUS Rounded 1c', sans-serif;
  /* IE表示用のCSS　*/
}

body:-ms-input-placeholder {
  font-family: Meiryo, sans-serif;
}

* {
  margin: 0;
  padding: 0;
}

::-moz-selection {
  background: #ba2d7a;
  color: #e9f076;
}

::selection {
  background: #ba2d7a;
  color: #e9f076;
}

a {
  outline: none;
  text-decoration: underline;
  cursor: pointer;
}

a:link {
  color: #f60a96;
}

a:visited {
  color: #f60a96;
}

button {
  padding: 0;
  border: none;
  outline: none;
  background-color: transparent;
  cursor: pointer;
}

li {
  list-style: none;
}

.text {
  text-shadow: 1px 1px 1px gray;
}

.text__bold {
  color: #f60a96;
  font-weight: normal;
}

.text__center-box {
  text-align: center;
  color: #fd3485;
  margin: 30px auto;
  border-top: 2px dashed #fd3485;
  border-bottom: 2px dashed #fd3485;
}

.text-with-image {
  width: 100%;
}

.text-with-image__image {
  display: block;
  width: 25%;
  height: 25%;
  margin: 0 auto;
}

.text-with-image__text {
  width: 100%;
  padding-top: 2%;
  margin-bottom: 5%;
}

.image {
  display: block;
  width: 100%;
  margin-bottom: 6%;
  border-radius: 5px;
}

/* ----------------------------------- */
.wrapper {
  width: 100%;
  margin: 0;
  padding: 0;
  overflow: hidden;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  position: relative;
}

.second-main {
  background: url(../img/bg_higan.png) 0 calc(100% + 200px) no-repeat, url(../img/bg_cloud.png) 0 calc(100% + 300px) no-repeat, url(../img/bg_star.png) 0 0% no-repeat, -webkit-gradient(linear, left top, left bottom, from(#fd3485), to(#ff8d81));
  background: url(../img/bg_higan.png) 0 calc(100% + 200px) no-repeat, url(../img/bg_cloud.png) 0 calc(100% + 300px) no-repeat, url(../img/bg_star.png) 0 0% no-repeat, linear-gradient(to bottom, #fd3485, #ff8d81);
  background-size: contain, contain, contain, auto;
  width: 100%;
  padding: 80px 0 150px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

/* ----------------------------------- */
.window-wrap {
  padding: 0 50px 0;
  margin: 0 auto;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

.manual-window {
  background: url(../img/img_box_decoration.png) 110% 110% no-repeat, rgba(255, 255, 255, 0.6);
  max-width: 960px;
  border-radius: 5px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -webkit-box-shadow: 5px 5px 0 7px white, 10px 10px 0 13px black;
          box-shadow: 5px 5px 0 7px white, 10px 10px 0 13px black;
  margin: 0 auto;
  padding: 0 0 60px;
  -webkit-transform: skewY(-4deg);
          transform: skewY(-4deg);
  position: relative;
}

.manual-window__contents {
  width: 96%;
  height: 100%;
  -webkit-transform: skewY(4deg);
          transform: skewY(4deg);
  position: relative;
  margin: 0 auto;
}

.manual-window__thorn01, .manual-window__thorn05 {
  display: block;
  position: absolute;
}

.manual-window__thorn01 {
  width: 18%;
  top: 0%;
  right: -19%;
}

.manual-window__thorn05 {
  width: 18%;
  bottom: -1%;
  left: -18%;
}

.manual-wrap {
  width: 100%;
  height: 100%;
}

.glNav {
  width: 100%;
  margin: 0 auto;
  position: relative;
}

.glNav-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  width: 90%;
  position: relative;
  margin: 0 auto;
}

.glNav-list__item {
  display: block;
  width: 32.66667%;
  height: 0;
  padding-bottom: 9%;
  position: relative;
}

.glNav-list__item:not(:nth-of-type(3n+1)) {
  margin-left: 1%;
}

.glNav-list__item:nth-of-type(n+4) {
  margin-top: 1%;
}

.glNav-button, .glNav-button-long {
  display: block;
  background: url(../img/bg_text.png) 0 0 repeat;
  width: 100%;
  height: 100%;
  text-align: center;
  font-size: 1.5em;
  position: absolute;
  border-radius: 10000px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  padding-top: 4.5%;
  font-weight: bold;
  text-decoration: none;
  -webkit-box-shadow: 5px 5px 0 0 black;
          box-shadow: 5px 5px 0 0 black;
}

.glNav-button:link, .glNav-button-long:link {
  color: white;
}

.glNav-button:visited, .glNav-button-long:visited {
  color: white;
}

.glNav-button-long {
  font-size: 1.1em;
  padding-top: 7%;
}

.glNav-button:hover, .glNav-button-long:hover, .glNav-button-long:hover {
  background: url(../img/bg_text_on.png) 0 0 repeat;
}

.manual-caption-wrap {
  background: url(../img/bg_text_black.png);
  width: 100%;
  height: 0;
  padding-bottom: 18%;
  margin-bottom: 8%;
  border-radius: 0.5vw 0 10vw 10vw;
  -webkit-box-shadow: 10px 10px white, 10px 10px 0 0 #3871ce50 inset;
          box-shadow: 10px 10px white, 10px 10px 0 0 #3871ce50 inset;
  position: relative;
}

.manual-caption-flower {
  width: 35.16667%;
  position: absolute;
  top: -65%;
  left: -7%;
}

.manual-caption, .manual-caption-2rows {
  width: 100%;
  height: 40%;
  position: absolute;
  top: 50%;
  -webkit-transform: translate(0, -50%);
          transform: translate(0, -50%);
}

.manual-caption__caption {
  height: 100%;
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}

.manual-caption-2rows {
  height: 80%;
  top: 52%;
}

.manual-subcaption {
  background: url(../img/img_box_decoration_ring.png) 100% 40% no-repeat, url(../img/bg_text.png);
  width: 100%;
  font-size: 2em;
  font-weight: bold;
  text-shadow: 2px 2px black;
  border-radius: 1000px;
  -webkit-box-shadow: 5px 5px 0 0 black;
          box-shadow: 5px 5px 0 0 black;
  color: white;
  text-align: center;
  margin-bottom: 40px;
}

.manual-minicaption {
  background: url(../img/img_box_decoration_ring.png) 100% 40% no-repeat, url(../img/bg_text_black.png);
  width: 70%;
  font-size: 1.2em;
  font-weight: bold;
  border-radius: 1000px;
  color: white;
  text-align: left;
  padding-left: 3%;
  margin-bottom: 2%;
}

.manual-textbox {
  background: url(../img/bg_text_white.png);
  width: 89%;
  margin: 0 auto;
  color: black;
  padding: 4%;
  border-radius: 20px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

.manual-info {
  width: 80%;
  margin: 0 auto;
}

.manual-right {
  font-size: 0.8em;
}

.manual-textbox + .manual-textbox {
  margin-top: 3%;
}

.text + .manual-subcaption {
  margin-top: 10%;
}

.text + .manual-minicaption {
  margin-top: 5%;
}

.glNav + .manual-textbox {
  margin-top: 5%;
}

.manual-textbox + .glNav {
  margin-top: 8%;
}

footer {
  font-size: 0.8em;
  font-family: Arial, Helvetica, sans-serif;
  position: relative;
  bottom: -3em;
  width: 100%;
  text-align: center;
}
