/*---------------------------------------------------------------

 SP COMMON STYLE

---------------------------------------------------------------*/
body {
  font-size: 13px;
  letter-spacing: -0.04rem;
  line-height: 1.6;
}

.gNavTtl {
  padding: 1.5rem 3% .5rem;
}

#topMainContent h1 {
  margin-top: 0;
  padding: 1rem 5%;
}
#topMainContent p.date {
  padding: 0 5% .7rem;
}

.footerInfo {
  padding: 0 5% 1rem;
}

.sp_topStory {
  background-color: #FEF4D5;
}

@media screen and (min-width: 641px) {
  #header {
    height: 6rem;
  }
}
@media screen and (max-width: 641px) {
  #header {
    height: 49px;
  }
}

.headerAreaInner {
  position: relative;
}
@media screen and (min-width: 641px) {
  .headerAreaInner {
    width: 980px;
    max-width: 980px;
    margin-right: auto;
    margin-left: auto;
  }
}
.headerAreaInner .headerSubMenu {
  position: absolute;
}
.headerAreaInner .headerSubMenu ul li {
  display: inline-block;
}

@media screen and (min-width: 641px) {
  .headerNav ul {
    box-sizing: border-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-lines: multiple;
    -moz-box-lines: multiple;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-justify-content: space-between;
    -moz-justify-content: space-between;
    -ms-flex-pack: justify;
    -ms-justify-content: space-between;
    justify-content: space-between;
  }
}
@media screen and (max-width: 641px) {
  .headerNav {
    height: 0;
    background: rgba(63, 125, 197, 0.8);
    position: fixed;
    padding: 0;
    width: 100%;
    top: 0;
    left: 0;
  }
  .headerNav ul {
    display: none;
    padding: 2rem 5%;
  }
  .headerNav li a {
    padding: 0.5rem;
    display: block;
    color: #fff;
  }
}

.menuTrigger,
.menuTrigger span {
  display: inline-block;
  transition: all .4s;
  box-sizing: border-box;
}

.menuTrigger {
  position: relative;
  width: 25px;
  height: 20px;
  z-index: 999;
}

.menuTrigger span {
  position: absolute;
  left: 0;
  width: 100%;
  height: 3px;
  background-color: #fff;
  border-radius: 0px;
}

.menuTrigger span:nth-of-type(1) {
  top: 3px;
}

.menuTrigger span:nth-of-type(2) {
  top: 10px;
}

.menuTrigger span:nth-of-type(3) {
  bottom: 0px;
}

.menuTrigger {
  position: absolute;
  top: 1.3em;
  right: 3%;
  left: inherit;
}

.menuTrigger.is-active span {
  background-color: #fff;
}

.menuTrigger.is-active span:nth-of-type(1) {
  top: -1px;
}

.menuTrigger.is-active span:nth-of-type(3) {
  bottom: -2px;
}

@media screen and (min-width: 641px) {
  .menuTrigger {
    display: none;
  }
}
.headerNav.is-onanimation {
  height: 100%;
}
.headerNav.is-onanimation ul {
  display: block;
}

#ticketPage .link img {
  margin: .5rem 0;
}

#ticketPage .sectionBlock p a {
  text-decoration: none;
  color: inherit;
}

#ticketPage .sectionBlock {
  padding-bottom: .5rem;
  margin-bottom: .5rem;
}

#kouenSapporo,
#kouenSyoutai {
  margin-bottom: 1rem;
}

.gMap {
  margin: 1rem 0;
}

#pageTitle {
  padding-bottom: .2rem;
  margin-bottom: .5rem;
}
#pageTitle strong {
  line-height: 1;
}

#header {
  height: auto;
}

#topPage .sectionBlock {
  padding-right: 3%;
  padding-left: 3%;
}

#intro {
  padding-top: 1rem;
  margin-bottom: 1rem;
}

.sectionBlock {
  text-align: justify;
}

.caption {
  font-size: 75%;
}

.blockTitle {
  margin-bottom: .7rem;
}

#monogatari p {
  padding-right: 45%;
  text-align: justify;
}

#toha p strong {
  display: block;
  margin-bottom: .4rem;
}

#toha .blockFloatElement {
  margin: .4rem 0;
}

#monogatari {
  overflow: hidden;
  margin-bottom: .9rem;
  position: relative;
}
#monogatari p {
  position: relative;
  z-index: 2;
}
#monogatari .blockFloatElement {
  position: absolute;
  right: -3%;
  bottom: .5rem;
  width: 55%;
  z-index: 0;
}
#monogatari .blockFloatElement img {
  width: 100%;
  height: auto;
}

#toha {
  border: 1px solid #333;
  padding: .5rem 3%;
  width: 96%;
  margin: auto;
}
#toha figure {
  text-align: right;
}

#pageTitle {
  letter-spacing: -0.15rem;
  font-size: 100%;
  position: relative;
  line-height: 1.6;
}
#pageTitle strong {
  padding-right: 0.8rem;
  font-family: 'Georgia','Athelas',serif;
  font-size: 240%;
  letter-spacing: -0.03rem;
  font-weight: normal;
}
#pageTitle:after {
  content: '';
  display: none;
  position: absolute;
  left: 0;
  bottom: 15px;
  width: 100%;
  height: 1px;
  background: #333;
}

body {
  padding-top: 49px;
}

body.is-openNav #sp_gNav ul {
  display: block;
  background: #4F141A;
  background: -moz-linear-gradient(left, #4F141A 0%, #702129 100%);
  background: -webkit-gradient(linear, left top, right top, color-stop(0%, #4F141A), color-stop(100%, #702129));
  background: -webkit-linear-gradient(left, #4F141A 0%, #702129 100%);
  background: -o-linear-gradient(left, #4F141A 0%, #702129 100%);
  background: -ms-linear-gradient(left, #4F141A 0%, #702129 100%);
  background: linear-gradient(to right, #4F141A 0%, #702129 100%);
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='$start-color', endColorstr='$end-color',GradientType=1 );
}

.sp_BnrWrapp {
  position: absolute;
  left: 3%;
  top: 20px;
  width: 35%;
}

.annivIcon {
  box-sizing: border-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-lines: multiple;
  -moz-box-lines: multiple;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.annivIcon a {
  display: block;
  width: 48.5%;
}
.annivIcon a.irancarapute {
  margin-left: 3%;
}

.gNavTtl {
  font-size: 83%;
  background: #732D30;
  background: -moz-linear-gradient(left, #732D30 0%, #511D1F 100%);
  background: -webkit-gradient(linear, left top, right top, color-stop(0%, #732D30), color-stop(100%, #511D1F));
  background: -webkit-linear-gradient(left, #732D30 0%, #511D1F 100%);
  background: -o-linear-gradient(left, #732D30 0%, #511D1F 100%);
  background: -ms-linear-gradient(left, #732D30 0%, #511D1F 100%);
  background: linear-gradient(to right, #732D30 0%, #511D1F 100%);
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='$start-color', endColorstr='$end-color',GradientType=1 );
}

#sp_gNav {
  height: 49px;
  position: relative;
  z-index: 999;
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
}
#sp_gNav ul {
  z-index: 999;
  display: none;
  height: 100%;
  width: 100%;
  position: fixed;
  left: 0;
  top: 48px;
  padding-top: 1rem;
  background-color: rgba(0, 0, 0, 0.8);
}
#sp_gNav ul a {
  padding: .5rem 3%;
  display: block;
  text-align: right;
  color: #fff;
  text-decoration: none;
}

#bgDiscover {
  height: 70%;
  background-position-x: right;
  top: 40px;
  background-size: 121%;
}

.sp_topStory {
  padding-bottom: 1rem;
}

#topMainContent h1 {
  padding-bottom: .5rem;
}

.mainContentInner {
  padding: 1.5rem 3%;
}

#footer:before {
  display: none;
}

.lede {
  width: 60%;
  font-weight: normal;
  display: block;
  font-size: 110%;
  margin-bottom: 1rem;
  letter-spacing: -0.08rem;
}

#shuen {
  overflow: hidden;
  margin-bottom: .7rem;
  padding-bottom: .7rem;
}

#shuen .blockFloatElement {
  right: -5%;
  left: inherit;
  top: 0;
  bottom: inherit;
  width: 44%;
  overflow: hidden;
}
#shuen .blockFloatElement img {
  margin-bottom: -3rem;
  margin-right: -2rem;
}

#kyakuhon {
  margin-bottom: .7rem;
}
#kyakuhon .ledewrapp,
#kyakuhon .blockTitle {
  padding-left: 35%;
}
#kyakuhon .lede {
  padding-right: 0;
  width: 100%;
}
#kyakuhon .blockFloatElement {
  width: 30%;
  left: 0;
  top: 0;
}
#kyakuhon .kyakuhonBottom {
  padding-bottom: .7rem;
}

#inviHero {
  height: 460px;
}
#inviHero #inviTitle {
  width: 100%;
}
#inviHero #inviOtoko {
  width: 90%;
  left: 5%;
}
#inviHero #inviTag {
  width: 110px;
}

body#inviPage .headerInner p img {
  display: none;
}

.moeBnr {
  margin-left: 0;
}

.menuTrigger {
  text-decoration: none;
  position: fixed;
}

.menuTrigger div {
  color: #fff;
  position: absolute;
  right: 128%;
  top: 0;
}

.menuTrigger span:nth-of-type(1) {
  -webkit-animation: menu-bar01 .75s forwards;
  animation: menu-bar01 .75s forwards;
}

@-webkit-keyframes menu-bar01 {
  0% {
    -webkit-transform: translateY(10px) rotate(45deg);
  }
  50% {
    -webkit-transform: translateY(10px) rotate(0);
  }
  100% {
    -webkit-transform: translateY(0) rotate(0);
  }
}
@keyframes menu-bar01 {
  0% {
    transform: translateY(10px) rotate(45deg);
  }
  50% {
    transform: translateY(10px) rotate(0);
  }
  100% {
    transform: translateY(0) rotate(0);
  }
}
.menuTrigger span:nth-of-type(2) {
  transition: all .25s .25s;
  opacity: 1;
}

.menuTrigger span:nth-of-type(3) {
  -webkit-animation: menu-bar02 .75s forwards;
  animation: menu-bar02 .75s forwards;
}

@-webkit-keyframes menu-bar02 {
  0% {
    -webkit-transform: translateY(-10px) rotate(-45deg);
  }
  50% {
    -webkit-transform: translateY(-10px) rotate(0);
  }
  100% {
    -webkit-transform: translateY(0) rotate(0);
  }
}
@keyframes menu-bar02 {
  0% {
    transform: translateY(-10px) rotate(-45deg);
  }
  50% {
    transform: translateY(-10px) rotate(0);
  }
  100% {
    transform: translateY(0) rotate(0);
  }
}
.menuTrigger.is-active span:nth-of-type(1) {
  -webkit-animation: active-menu-bar01 .75s forwards;
  animation: active-menu-bar01 .75s forwards;
}

@-webkit-keyframes active-menu-bar01 {
  0% {
    -webkit-transform: translateY(0) rotate(0);
  }
  50% {
    -webkit-transform: translateY(10px) rotate(0);
  }
  100% {
    -webkit-transform: translateY(10px) rotate(45deg);
  }
}
@keyframes active-menu-bar01 {
  0% {
    transform: translateY(0) rotate(0);
  }
  50% {
    transform: translateY(10px) rotate(0);
  }
  100% {
    transform: translateY(10px) rotate(45deg);
  }
}
.menuTrigger.is-active span:nth-of-type(2) {
  opacity: 0;
}

.menuTrigger.is-active span:nth-of-type(3) {
  -webkit-animation: active-menu-bar03 .75s forwards;
  animation: active-menu-bar03 .75s forwards;
}

@-webkit-keyframes active-menu-bar03 {
  0% {
    -webkit-transform: translateY(0) rotate(0);
  }
  50% {
    -webkit-transform: translateY(-10px) rotate(0);
  }
  100% {
    -webkit-transform: translateY(-10px) rotate(-45deg);
  }
}
@keyframes active-menu-bar03 {
  0% {
    transform: translateY(0) rotate(0);
  }
  50% {
    transform: translateY(-10px) rotate(0);
  }
  100% {
    transform: translateY(-10px) rotate(-45deg);
  }
}
