@charset "utf-8";
/* CSS Document */
@import url(http://fonts.googleapis.com/earlyaccess/notosansjapanese.css);
html.ja body.top {
  font-family: "Noto Sans CJK JP", "Noto Sans Japanese", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, serif;
  font-weight: 300;
  color:#222;
  max-width: 100vw;
  overflow: hidden;
}
*, ::after, ::before {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
abbr, address, article, aside, audio, b, blockquote, body, canvas, caption, cite, code, dd, del, details, dfn, div, dl, dt, em, fieldset, figcaption, figure, footer, form, h1, h2, h3, h4, h5, h6, header, hgroup, html, i, iframe, img, ins, kbd, label, legend, li, mark, menu, nav, object, ol, p, pre, q, samp, section, small, span, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, time, tr, ul, var, video {
  font-size: 100%;
  margin: 0;
  padding: 0;
  vertical-align: baseline;
  border: 0;
  outline: 0;
  background: transparent;
  font-weight: 300;
}
button {
  padding: 0;
  cursor: pointer;
  border: none;
  background-color: transparent;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
img {
  display: inline-block;
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
  line-height: 1;
}
#hiThis{
  width: 100vw;
  height: 100vh;
  position: fixed;
  left:0;
  top:0;
  z-index: -999;
  visibility: hidden;
}
.winSizeTop{
position:fixed;
left:0;
top:0;
}
.winSizeBottom{
position:fixed;
left:0;
bottom:0;
}
.NotoSansCjkJp, .NotoSansCjkJp *{
  font-family: "Noto Sans CJK JP", "Noto Sans", sans-serif;
  font-weight: 300;
}
.NotoSansCjkJp.fwR, .NotoSansCjkJp.fwR *{
  font-weight: 500;
}
.NotoSansCjkJp.fwB, .NotoSansCjkJp.fwB *{
  font-weight: bold;
}
.main-visual {
  position: relative;
  width: 100%;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  background: #fff;
  overflow: hidden;
}
.main-visual .main-visual-box {
  position: relative;
  z-index: 2;
  width: 100%;
  height: 100%;
}
.main-visual-text {
  display: block;
  position: relative;
  margin: 0 auto;
  max-width: 1720px;
  width: 100%;
  height: 100%;
  z-index: 2;
}
.main-visual-text .scroll {
  position: absolute;
  bottom: 0;
  left: 12%;
  display: inline-block;
  height: calc(40vh - 8vw);
  color: #222;
  line-height: 1;
}
.main-visual-text .scroll a {
  font-family: "Myriad Pro", "Myriad Web", Tahoma, Verdana, sans-serif;
  font-weight: 300;
  letter-spacing: .2em;
  position: relative;
  display: inline-block;
  color: #222;
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
  -webkit-animation: scroll-text 3.5s cubic-bezier(.455,.03,.515,.955) infinite;
  animation: scroll-text 3.5s cubic-bezier(.455,.03,.515,.955) infinite;
}
.main-visual-text .scroll::before {
  position: absolute;
  left: .5em;
  top: 6em;
  display: block;
  width: 1px;
  content: "";
  cursor: default;
  pointer-events: none;
  background: #222;
  -webkit-animation: scroll cubic-bezier(.23, 1, .32, 1) 2.5s infinite;
  animation: scroll cubic-bezier(.23, 1, .32, 1) 2.5s infinite;
}
.main-visual .movie-box {
  position: absolute;
  z-index: 1;
  top: 0;
  height: 100%;
  overflow: hidden;
}
.main-visual .movie-box::before {
  position: absolute;
  z-index: 2;
  left: 50%;
  top: 50%;
  transform: translate(-50%,-50%);
  display: block;
  width: 100%;
  height: 100%;
  content: "";
}
.main-visual .movie-box .movie-wrap {
  position: relative;
  z-index: 1;
  overflow: hidden;
  width: 100%;
  height: 100%;
  opacity: 1;
}
.main-visual .movie-box .movie-wrap video{
  display: none;
}
.main-visual .movie-box .movie-wrap video.isPlay{
  display:block;
  line-height: 1;
  vertical-align: top;
  min-width: 100%;
}
.controlsArea{
  display: inline-block;
  position: absolute;
  bottom:0;
  right: 0;
  width: 100px;
  z-index: 4;
}
.controlsArea.conFix{
  position: fixed;
}
.controlsArea .mv-controls {
  line-height: 1;
  width: 100px;
  padding: 10px;
  -webkit-transform: 1s;
  -ms-transform: 1s;
  transform: 1s;
  text-align: center;
  opacity: 1;
  background: rgba(77,77,77,.8);
}
.controlsArea .mv-controls button {
  position: relative;
  display: inline-block;
  width: 20px;
  /* font-size: 20px; */
  font-size: 1.25rem;
  line-height: 1;
  cursor: pointer;
  vertical-align: middle;
}
.controlsArea .mv-controls button:focus{
  outline: none;
}
.controlsArea .mv-controls button + button {
  margin-left: 20px;
}
.controlsArea .mv-controls button.is-active {
  cursor: default;
  pointer-events: none;
  opacity: .6;
}
.controlsArea .mv-controls button + button::before {
  position: absolute;
  top: 0;
  left: -13px;
  display: block;
  width: 1px;
  height: 100%;
  content: "";
  -webkit-transform: skewX(-15deg);
  -ms-transform: skewX(-15deg);
  transform: skewX(-15deg);
  background: #fff;
}
.controlsArea .mv-controls button img{
  display: inline;
}
#contents{
  position: relative;
}
#contents #mapArea{
  display: none;
  position: relative;
  top: 8vh;
  background-color:#e6ebec;
  overflow: hidden;
  opacity: 0;
}
#contents #mapArea .mapBlock{
  position: relative;
  font-size: 0;
  max-width: 1920px;
  width: 100%;
  display: table;
}
#contents #mapArea .mapBlock > div{
  position: relative;
  display: table-cell;
  height: 875px;
  vertical-align: bottom;
  margin: 0 auto;
  background-repeat: no-repeat;
}
#contents #mapArea .mapBlock > div > img{
  position: relative;
  vertical-align: bottom;
  width:inherit;
  height: 120%;
}
#contents #mapArea .mapWest{
  background-image: url("/japan-travel-planner/tohoku-jre-ana/images/map_bg_japan_01.png");
  background-position:right bottom;
}
#contents #mapArea .mapEast{
  width: 832px;
  background-image: url("/japan-travel-planner/tohoku-jre-ana/images/map_bg_japan_02.png");
  background-position:center bottom;
}
#contents #mapArea .mapNorth{
  width: 27px;
  background-image: url("/japan-travel-planner/tohoku-jre-ana/images/map_bg_japan_03.png");
  background-position:left bottom;
}
#contents #mapArea .mapBlock .mapEast > p{
  display: inline-block;
  position:absolute;
}
#contents #mapArea .mapBlock .mapEast > .train_img {
  left: -29%;
  top: 1%;
  opacity: 0;
  transform: rotate(-5deg);
  width: 75%;
  height: 66%;
  border-radius: 50%;
  z-index: 1;
}
#contents #mapArea .mapBlock .mapEast > .train_img img {
  position: absolute;
  bottom: 33%;
  right: -10%;
  transform: rotate(-24deg);
  z-index: 3;
}
#contents #mapArea .mapBlock .mapEast > .airplane_img {
  left: 34%;
  top: 33%;
  transform: rotate(-45deg);
  width: 72%;
  height: 80%;
  box-sizing: border-box;
  border-radius: 50%;
  z-index: 1;
}
#contents #mapArea .mapBlock .mapEast > .airplane_img img{
  position: absolute;
  top: 20%;
  left: -4%;
  transform: rotate(-17deg);
  z-index: 3;
}
#mapArea .mapEast .prefecture{
  display: block;
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
  font-size: 1rem;
}
#mapArea .mapEast > .prefecture li{
  display: inline-block;
  position: absolute;
  opacity: 0;
  z-index: 3;
}
#mapArea .mapEast > .prefecture li .litexpoint{
  position: absolute;
  display: block;
  text-align: center;
  z-index: 250;
	top: 0;
}

#mapArea .mapEast > .prefecture .aomori .litexpoint{
  width: 60%;
  height: 100%;
  right: 0;
}
#mapArea .mapEast > .prefecture .akita .litexpoint{
  width: 64%;
  height: 67%;
  left: 0;
}
#mapArea .mapEast > .prefecture .iwate .litexpoint{
  right: 0;
  width: 38%;
  height: 100%;
}
#mapArea .mapEast > .prefecture .miyagi .litexpoint{
  width: 61%;
  height: 100%;
  right: 0;
}
#mapArea .mapEast > .prefecture .yamagata .litexpoint{
  width: 48%;
  height: 90%;
  left: 0;
}
#mapArea .mapEast > .prefecture .fukushima .litexpoint{
  width: 36%;
  height: 71%;
	top: 29%;
  right: 0;
}

#mapArea .mapEast > .prefecture li .litexpoint .litex{
  display: inline-block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateY(-50%) translateX(-50%);
  transform: translateY(-50%) translateX(-50%);
  /* font-size: 24px; */
  font-size: 1.5rem;
  color: #fff;
}
#mapArea .mapEast > .prefecture li img{
  position: relative;
}
#mapArea .mapEast > .prefecture li.akita,
#mapArea .mapEast > .prefecture li.yamagata,
#mapArea .mapEast > .prefecture li.miyagi{
  z-index: 4;
}

#mapArea .mapEast > .prefecture li.dispNoPcOnly{
  display: none;
  position: relative;
  visibility: hidden;
}

#mapArea .mapEast > .prefecture .aomori{
  right:145px;
  bottom: 462px;
  width: 29.9%;
}
#mapArea .mapEast > .prefecture .akita{
  right:451px;
  bottom: 433px;
  width: 28.3%;
}
#mapArea .mapEast > .prefecture .iwate{
  right:20px;
  bottom: 330px;
  width: 47.7%;
}
#mapArea .mapEast > .prefecture .miyagi{
  right:210px;
  bottom: 228px;
  width: 29.8%;
}
#mapArea .mapEast > .prefecture .yamagata{
  right:492px;
  bottom: 346px;
  width: 38.4%;
}
#mapArea .mapEast > .prefecture .fukushima{
  right:132px;
  bottom: 63px;
  width: 51%;
}
#contents #mapArea.animeOn{
  display: block;
  animation: show .3s linear .4s forwards, up .3s linear .5s forwards;
}
#mapArea.animeOn .mapEast > .prefecture .aomori{
  animation: show .25s linear 2.8s forwards;
}
#mapArea.animeOn .mapEast > .prefecture .akita{
  animation: show .25s linear 3.75s forwards;
}
#mapArea.animeOn .mapEast > .prefecture .iwate{
  animation: show .25s linear 4s forwards;
}
#mapArea.animeOn .mapEast > .prefecture .miyagi{
  animation: show .25s linear 4.25s forwards;
}
#mapArea.animeOn .mapEast > .prefecture .yamagata{
  animation: show .25s linear 4.5s forwards;
}
#mapArea.animeOn .mapEast > .prefecture .fukushima{
  animation: show .25s linear 5s forwards;
}

#contents #mapArea .txtBlock{
  /* font-size: 20px; */
  font-size: 1.25rem;
  letter-spacing: .05em;
  line-height: 3;
  position: absolute;
  left: 5.2%;
  left: calc(6.45vw - 24px);
  top: 85px;
	z-index: 3;
}
#contents #anchorNavArea{
  padding-top: 100px;
}
#contents #anchorNavArea h2{
  /* font-size: 42px; */
  font-size: 2.625rem;
  letter-spacing: .2em;
  line-height: 1;
  text-align: center;
  margin-bottom:60px;
  font-weight: 300;
}
#contents #anchorNavArea ul{
  display: table;
  width: 94.6%;
  max-width: 1240px;
  margin:0 auto;
  font-size: 0;
}
#contents #anchorNavArea > ul > li{
  display: table-cell;
  vertical-align: middle;
  text-align: center;
  letter-spacing: .2em;
	width: 16.65%;
}
#contents #anchorNavArea > ul > li a{
  display:block;
  line-height: 1;
  padding-top: 1em;
  transition:opacity .3s linear;
}
#contents #anchorNavArea > ul > li a:hover,
#contents #anchorNavArea > ul > li a:focus{
  opacity:.8;
}
#contents #anchorNavArea > ul > li .navIcn{
  display: block;
  padding: 1em 0;
}
#contents #anchorNavArea > ul > li a .navIcn::after{
  content: "";
  position: relative;
  top: .5em;
  display: block;
  margin: 0 auto;
  width: .5em;
  height: .5em;
  border-left: solid 1px #222;
  border-bottom: solid 1px #222;
  transform: rotate(-45deg);
  transition:top .3s linear;
}
#contents .prefectureSec .ttlBlock{
  margin-bottom: 60px;
}
#contents .prefectureSec .ttlBlock > div{
  position: relative;
  height: 100%;
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
}
#contents .prefectureSec .ttlBlock > div > h3{
  position: relative;
  padding: .25em .15em;
  /* font-size: 60px; */
  font-size: 3.75rem;
  line-height: 1;
  letter-spacing: .2em;
	background: #fff;
	display: inline-block;
	margin-bottom: 1.8em;
}
#contents .prefectureSec .ttlBlock .ttlSubTxt{
  /* font-size:16px; */
  font-size:1.25rem;
  line-height: 2;
  letter-spacing: .05em;
  position: relative;
}
#contents .prefectureSec .ttlBlock .ttlSubTxt span{
  background-color:#fff;
  padding: 0.3em 0 0.3em 0.3em;
  margin-left: -0.3em;
}
#contents .prefectureSec .ttlBlock > .rightPic{
  right: 0;
  text-align: left;
  padding-left:20px;
}
#contents .prefectureSec .ttlBlock .rightPic::before{
  content:"";
  display: block;
  position: absolute;
  top: 0;
  width: 100%;
  height: 100%;
  background-color:#fff;
}

#contents .prefectureSec .ttlBlock > .rightPic > p:first-of-type{
  padding:108px 0 65px;
  line-height: 1;
  position: relative;
}
#contents .prefectureSec .ttlBlock > .leftPic{
  text-align: right;
  padding-right:20px;
}
#contents .prefectureSec .ttlBlock > .leftPic > h3{
  z-index: 2;
}
#contents .prefectureSec .ttlBlock .leftPic::before{
  content:"";
  display: block;
  position: absolute;
  right: 0;
  top: 0;
  width: 300px;
  height: 100%;
  background-color:#fff;
}
#contents .prefectureSec .ttlBlock > .leftPic > p:first-of-type{
  padding:108px 0 20px;
  line-height: 1;
  position: relative;
}
#contents .prefectureSec .ttlBlock.picR .ttlSubTxt{
  text-align: left;
  left:0;
  padding-bottom: 9.375em;
}
#contents .prefectureSec .ttlBlock.picL .ttlSubTxt{
  text-align: right;
  left:0;
  padding-bottom: 5.625em;
}
#contents .prefectureSec .ttlBlock > .leftPic + .ttlSubTxt{
  text-align: right;
}
#contents .prefectureSec > ul{
  display: block;
  font-size: 0;
  width: 97.91666666666667%;
  margin: 0 auto;
}
#contents .prefectureSec > ul > li{
  display: inline-block;
  width: 32.03125%;
}
#contents .prefectureSec > ul > li:nth-child(3n + 2){
  margin:auto 1.953125%;
}

#contents .prefectureSec > ul > li > a{
  display: block;
  position: relative;
  font-size:100%;
  height: 100%;
  vertical-align: middle;
  background-color:#00242e;
  overflow: hidden;
}
#contents .prefectureSec > ul > li > a .thumbImg img{
  transition:all .2s linear 0s;
  opacity: 1;
}
#contents .prefectureSec > ul > li > a:hover .thumbImg img,
#contents .prefectureSec > ul > li > a:focus .thumbImg img{
  opacity: .3;
  transform: scale(1.1,1.1);
}
#contents .prefectureSec > ul > li > a .thumbCap{
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  /* font-size:24px; */
  font-size:1.5rem;
  transform: translate(-50%,-50%);
  transition:opacity .2s linear 0s;
  color:#fff;
  opacity: 0;
  text-align: center;
  padding:1em;
  display: none;
}
#contents .prefectureSec > ul > li > a .viewMore{
  position: absolute;
  bottom: 1em;
  right: 0;
  display: inline-block;
  /* font-size:16px; */
  font-size: 1rem;
  font-weight: 500;
  line-height: 1;
  letter-spacing: .1em;
  color:#222;
  text-align: left;
  background-color:#fff;
  padding:.5em 2em .5em .5em;
  transition:color .2s linear 0s, background-color .2s linear 0s;
}
#contents .prefectureSec > ul > li > a .viewMore::before{
  content:"";
  display: block;
  position: absolute;
  right: .6em;
  top: .8em;
  width: 1em;
  height: .3em;
  border-right:solid 1px #222;
  border-bottom:solid 1px #222;
  transform: skewX(45deg);
  transition:border-color .2s linear 0s, right .2s linear 0s;
}
#contents .prefectureSec > ul > li > a:hover .thumbCap,
#contents .prefectureSec > ul > li > a:focus .thumbCap{
  opacity: 1;
  display: block;
}
#contents .prefectureSec > ul > li > a:hover .viewMore,
#contents .prefectureSec > ul > li > a:focus .viewMore{
  color: #fff;
  background-color: #008396;
}
#contents .prefectureSec > ul > li > a:hover .viewMore::before,
#contents .prefectureSec > ul > li > a:focus .viewMore::before{
  border-color: #fff;
  right: .4em;
}
#recommendArea{
  background-color:#e6ebec;
}
/*
#recommendArea a img{
  width: 100%;
}
*/
#recommendArea a {
  backface-visibility: hidden;
  transition: opacity .2s linear 0s;
}
#recommendArea a:hover,
#recommendArea a:focus{
  opacity: .8;
}
#recommendArea > div{
  max-width:1280px;
  width: 100%;
  margin: 0 auto;
}
#recommendArea h2{
  text-align: center;
  letter-spacing: .05em;
  line-height: 1;
  font-weight: 300;
}

#recommendArea .rcmBtn{
  margin: 0 auto;
  text-align: center;
  letter-spacing: .2em;
  line-height: 1;
}
#recommendArea .rcmBtn a{
  min-width: 45%;
  padding:.8em 2em .9em;
  font-weight: 300;
  position: relative;
  display: inline-block;
}
/*
#recommendArea .rcmBtn a::after{
  content: "";
  display: block;
  width: .5em;
  height: .5em;
  border-width: 1px;
  border-bottom-style: solid;
  border-right-style: solid;
  transform: rotate(-45deg) translateY(-50%);
  position: absolute;
  right: 1em;
  top: 48%;
  box-sizing: border-box;
  vertical-align: middle;
}
*/
#recommendArea .rcmBtn.orangeBtn a{
  background-color: #d74100;
  color: #fff;
}
#recommendArea .rcmBtn.orangeBtn a::after{
  content: "";
  display: block;
  width: .5em;
  height: .5em;
  border-width: 1px;
  border-bottom-style: solid;
  border-right-style: solid;
  transform: rotate(-45deg) translateY(-50%);
  position: absolute;
  right: 1em;
  top: 48%;
  box-sizing: border-box;
  vertical-align: middle;
  border-color: #fff;
}

.new-window-icon{
  margin-bottom: 2px;
  margin-left: 2px;
}

#recommendArea .rcmBtn.greenBtn a{
  border: solid 1px #006978;
  color: #006978;
}
#recommendArea .rcmBtn.greenBtn a::after{
  border-color: #006978;
}
#recommendArea .clm2Block{
  overflow: hidden;
  width: 100%;
  display: flex;
  justify-content: center;
}
#recommendArea .clm4Block{
  overflow: hidden;
  width: 100%;
}
#recommendArea .clm2Block::after{
  content:"";
  display: table;
  clear: both;
}
#recommendArea .clm4Block::after{
  content:"";
  display: table;
  clear: both;
}
#recommendArea .clm2Block > li{
  width:590px;
  max-width: 47.58%;
}

#recommendArea .clm2Block > li:nth-child(2n){
  margin-left: 4.84%; /* 追加 */
}

#recommendArea dt h3{
  line-height: 1;
  padding:1em 0 .5em;
  letter-spacing: .05em;
}
#recommendArea dd p{
  line-height: 1.5;
  letter-spacing: .05em;
}
.followingAnchor{
  position: fixed;
  left: 0;
  bottom: 0;
  width: 100%;
  z-index: 999;
  background-color:rgba(62,81,87,0.8);
}
.followingAnchor > div{
  display: table;
  width: 100%;
}
.followingAnchor > div > p{
  display: table-cell;
  vertical-align: middle;
  color: #fff;
  line-height: 1;
}
.followingAnchor > div > p:first-of-type{
  padding:.5em .5em .5em 1em;
  font-weight: 500;
  line-height: 1.3;
}
.followingAnchor > div > p:first-of-type b{
  font-weight: bold;
}
.followingAnchor .flwBtn{
  margin: 0 auto;
  text-align: center;
  letter-spacing: .2em;
  line-height: 1;
  width: 11em;
  background-color: #d74100;
  transition: all .2s linear 0s;
}
.followingAnchor .flwBtn a{
  padding:1.1em 2em 1.2em;
  font-weight: 300;
  position: relative;
  display: block;
  color: #fff;
}
.followingAnchor .flwBtn a::after{
  content: "";
  display: block;
  width: .5em;
  height: .5em;
  border-width: 1px;
  border-bottom-style: solid;
  border-right-style: solid;
  border-color: #fff;
  position: absolute;
  right: 1em;
  box-sizing: border-box;
  vertical-align: middle;
}
.followingAnchor .visibleAsw .flwBtn a::after{
  transform: rotate(-45deg) translateY(-50%);
  top: 48%;
  transition: right .2s linear 0s;
}
.followingAnchor .visibleWws .flwBtn a::after{
  transform: rotate(45deg) translateY(-50%);
  top: 42%;
  transition: top .2s linear 0s;
}

.footer .pagetTop{
  display: none;
}
.TxtView{
  position: absolute;
  top: 0;
  width: 100%;
  height: 100%;
}
.resizeHi .main_logoArea p.icnImg,
.main_logoArea.resizeHi p.icnImg{
  padding-top:2.83vh;
  font-size: 1.9vh;

}
.resizeHi .main_logoArea p.icnImg img,
.main_logoArea.resizeHi p.icnImg img{
  height:3.87vh;
  width: auto;
}
.resizeHi .main_logoArea .NotoSansCjkJp.fwB,
.main_logoArea.resizeHi .NotoSansCjkJp.fwB{
  font-size:2vh;
}
.resizeHi .main-visual-text h1{
  font-size: 6vh;
	display: inline-block;
}
.resizeHi .main-visual-text .ttlSub img{
  height: 12.1vh;
  width: auto;
}
.resizeHi .main-visual-text .scroll{
  bottom:calc(2vh + 2vw - 120px);
}
@media screen and (min-width:769px) {
  .dispNoPc:not(.mov){display: none !important;}
  .dispNoSp:not(.mov){display: block !important;}
  .dispNoSpIn{display: inline !important;}
  .dispNoPcIn{display: none !important;}
  nav.navigation {
    margin-bottom: 60px;
  }
  .main-visual .main-visual-box .movie-box{
    width: 74.52%;
    left: 25.5%;
  }
  .main-visual .movie-box .movie-wrap video.isPlay{
    margin-right:calc(100vw - 1920px);
    z-index: 1;
  }
  .main-visual-text {
    padding:0 20px;
  }
  .main_logoArea{
    padding: 0 20px;
  }
  .main_logoArea p.icnImg{
    text-align: left;
    padding: 30px 0 0;
    margin-top: 5vh;
    font-size: 1.041666666666667vw;
    width: 15em;
    background-color: #fff;
  }
  .main_logoArea p.icnImg img{
    width: 268px;
    padding-left: 5px;
  }
  .main_logoArea .NotoSansCjkJp.fwB{
    font-size: 20px;
    font-size: 1.041666666666667vw;
    line-height: 1;
    letter-spacing: .4em;
    text-align: left;
    padding: 1em 0 1.5em;
    margin-bottom:2vh;
    width: 15em;
    background-color: #fff;
  }
  .main_logoArea .NotoSansCjkJp.fwB span{
    color:#008396;
  }
  .main-visual-text h1{
    position: relative;
    font-size: 52px;
    font-size: 2.71vw;
    line-height: 1;
    letter-spacing: .12em;
    text-align: left;
    vertical-align: middle;
    padding: .78em .25em .68em .25em;
    background-color:#fff;
    margin-bottom:2vh;
		display: inline-block;
  }

  #contents .prefectureSec > ul > li:nth-child(n + 4){
    margin-top:1.953125%;
  }
  
  .main-visual-text .ttlSub{
    position: relative;
    width: 36.37%;
    margin-bottom:6vh;
  }
  .main-visual .movie-box .movie-wrap {
    background-size: auto 100%;
  }
  #contents #anchorNavArea{
    margin-bottom:122px;
  }
  #contents #anchorNavArea > ul > li{
    /* font-size: 20px; */
    font-size: 1.25rem;
  }
  #contents #anchorNavArea > ul > li:not(:first-child){
    border-left:solid 1px #ccc;
  }
  #contents #anchorNavArea > ul > li a:hover .navIcn::after,
  #contents #anchorNavArea > ul > li a:focus .navIcn::after{
    top:1em;
  }
  #contents .prefectureSec .ttlBlock .rightPic::before{
    right: 78.9%;
  }

  #contents .prefectureSec{
    margin-bottom:182px;
  }
  #contents .prefectureSec .ttlBlock {
    position: relative;
  }
  #contents .prefectureSec .ttlBlock::after{
    content:"";
    display: block;
    width:70.83333333333333%;
    height: 100%;
    position: absolute;
    top: 0;
    background-size: auto;
    background-repeat: no-repeat;
    z-index: -1;
  }
  #contents .prefectureSec .ttlBlock.picR::after{
    right: 0;
    background-position: left center;
  }
  #contents .prefectureSec .ttlBlock.picL::after{
    left: 0;
    background-position: right center;
  }
  #aomori .ttlBlock::after{
    background-image: url("/japan-travel-planner/tohoku-jre-ana/images/aomori_top.jpg");
  }
  #akita .ttlBlock::after{
    background-image: url("/japan-travel-planner/tohoku-jre-ana/images/akita_top.jpg");
  }
  #iwate .ttlBlock::after{
    background-image: url("/japan-travel-planner/tohoku-jre-ana/images/iwate_top.jpg");
  }
  #miyagi .ttlBlock::after{
    background-image: url("/japan-travel-planner/tohoku-jre-ana/images/miyagi_top.jpg");
  }
  #yamagata .ttlBlock::after{
    background-image: url("/japan-travel-planner/tohoku-jre-ana/images/yamagata_top.jpg");
  }
  #fukushima .ttlBlock::after{
    background-image: url("/japan-travel-planner/tohoku-jre-ana/images/fukushima_top.jpg");
  }

  #contents #mapArea{
    min-height: 875px;
  }
  #recommendArea{
    padding:100px 0;
  }
  #recommendArea > div{
    padding:0 20px;
  }
  #recommendArea .secondDiv{
    padding-top: 100px;
  }
  #recommendArea h2{
    margin-bottom: 80px;
    /* font-size: 42px; */
    font-size: 2.625rem;
  }s
  #recommendArea > .visibleAsw > ul{
  padding-right: 30px;
  }
  #recommendArea .clm4Block > li{
  max-width: 25%;
  float: left;
  padding-left: 30px;
  }
  #recommendArea .clm2Block > dt{
    float: left;
    display: block;
    width: 280px;
    max-width: 47.46%;
  }
  #recommendArea .clm4Block > dt{
    float: left;
    display: block;
  }
  #recommendArea .clm2Block > dd{
    float: right;
    display: block;
    width: 310px;
    max-width: 52.54%;
    padding-left:2em;
    /* font-size: 16px; */
    font-size: 1rem;
    line-height:1.5;
    letter-spacing: .05em;
  }

  #recommendArea .clm4Block > dd{
    float: right;
    display: block;
    max-width: 98%;
    /* font-size: 16px; */
    font-size: 1rem;
    line-height:1.5;
    letter-spacing: .05em;
    padding: 10px 0 10px 0;
  }

  #recommendArea dt h3{
    /* font-size: 24px; */
    font-size: 1.5rem;
  }
  #recommendArea dd p{
    /* font-size: 16px; */
    font-size: 1rem;
    margin-bottom:30px;
  }
  #recommendArea .rcmBtn a,
  #recommendArea .rcmBtn a::before{
    transition:all .2s linear 0s;
  }
  #recommendArea .rcmBtn.orangeBtn a:hover,
  #recommendArea .rcmBtn.orangeBtn a:focus{
    opacity:.8;
  }
  #recommendArea .rcmBtn.greenBtn a:hover,
  #recommendArea .rcmBtn.greenBtn a:focus{
    background-color: #006978;
    color: #fff;
  }
  #recommendArea .rcmBtn.greenBtn a:hover::after,
  #recommendArea .rcmBtn.greenBtn a:focus::after{
    border-color: #fff;
  }
  .followingAnchor > div > p{
    /* font-size:20px; */
    font-size:1.25rem;
  }
  .followingAnchor .flwBtn:hover,
  .followingAnchor .flwBtn:focus{
    background-color: #eb4f0c;
  }
  .followingAnchor .visibleAsw .flwBtn:hover a::after,
  .followingAnchor .visibleAsw .flwBtn:focus a::after{
    right: .7em;
  }
  .followingAnchor .visibleWws .flwBtn:hover a::after,
  .followingAnchor .visibleWws .flwBtn:focus a::after{
    transform: rotate(45deg) translateY(-50%);
    top: 48%;
  }


}
@media screen and (max-width:1280px){
  #contents #mapArea .mapBlock{
    width: 100%;
  }
  #contents #mapArea .mapBlock > .mapEast{
    width: 832px;
  }
  #contents #mapArea .mapBlock > .mapNorth{
    max-width: 27px;
  }
  #contents #mapArea .txtBlock{
    font-size: calc(1.25vw + 4px);
    top: calc(6.015625vw - 40px);
  }
  #contents .prefectureSec .ttlBlock > .rightPic > h3{
    padding-left:40px;
  }
  #contents .prefectureSec .ttlBlock .rightPic::before{
    right: inherit;
    left: 0;
    width: 272px;
  }
  #contents .prefectureSec .ttlBlock::after{
    width: 78.9%;
  }
  #contents .prefectureSec > ul > li > a .thumbCap {
    font-size: 1.875vw;
    font-size: calc(1.796875vw + 1px);
  }
  #contents .prefectureSec > ul > li > a .viewMore{
    font-size:1.25vw;
    font-size: calc(1.171875vw + 1px);
  }
}
@media screen and (max-width:860px) {

  #contents #mapArea .mapBlock > .mapWest{
    display: none;
  }
  #contents #mapArea .mapBlock > .mapNorth{
    display: none;
  }
  #contents #mapArea .mapBlock{
    display: block;
    width: 100%;
    transform:translateY(-18%);
    margin-bottom: -18%;
  }
  #contents #mapArea .mapBlock > .mapEast{
    display: block;
    height: 100%;
    width: 100%;
    background-size: 100%;
  }
  #contents #mapArea .txtBlock{
    font-size:2.67vw;
    position: relative;
    left: auto;
    top: auto;
    padding:3em 1em;
  }
  #mapArea .mapEast > .prefecture li.dispNoPcOnly{
    display: block;
    width: 100%;
  }
  #mapArea .mapEast > .prefecture .aomori{
    bottom: 46.5%;
    right:17.56%;
  }
  #mapArea .mapEast > .prefecture .akita{
    bottom:42.77%;
    right:54.26%;
  }
  #mapArea .mapEast > .prefecture .iwate{
    bottom:33.53%;
    right:2.86%;
  }
  #mapArea .mapEast > .prefecture .miyagi{
    bottom:22.52%;
    right:25.4%;
  }
  #mapArea .mapEast > .prefecture .yamagata{
    bottom:34.5%;
    right:59.26%;
  }
  #mapArea .mapEast > .prefecture .fukushima{
    bottom:6.24%;
    right:16.26%;
  }
  #contents #mapArea .mapBlock .mapEast > .train_img{
    bottom: 50.94%;
  }
  #contents #mapArea .mapBlock .mapEast > .airplane_img{
    bottom: 8.4%;
  }
  #contents #mapArea .mapBlock .mapEast > .train_img {
    left: -24%;
    top: 12%;
    z-index: 3;
    width: 75%;
    height: 62%;
  }
  #contents #mapArea .mapBlock .mapEast > .train_img img {
    bottom: 33%;
    right: -6%;
    transform: rotate(-13deg);
    width: 7.34vw;
  }
  #contents #mapArea .mapBlock .mapEast > .airplane_img {
    left: 34%;
    top: 40%;
    width: 68%;
    height: 68%;
  }
  #contents #mapArea .mapBlock .mapEast > .airplane_img img{
    width: 7.47vw;
  }
  #mapArea .mapEast .prefecture{
    display: block;
    position: relative;
    width: 100%;
    height: 100%;
    overflow: hidden;
    font-size: 1rem;
  }
}
@media screen and (max-width:768px) {
  .dispNoPc:not(.mov){display: block !important;}
  .dispNoSp:not(.mov){display: none !important;}
  .dispNoSpIn{display: none !important;}
  .dispNoPcIn{display: inline !important;}
  .main-visual {
    position: relative;
    height: auto;
  }

  #contents .prefectureSec > ul > li:nth-child(n + 4){
    margin-top:0;
  }

  .main-visual .main-visual-box{
    overflow-y: hidden;
  }
  .main-visual .main-visual-box .movie-box{
    width: 74.55%;
    left: 25.5%;
  }
  .main-visual-text {
    padding:0 2.66%;
  }
  .main_logoArea p.icnImg{
    position: relative;
    text-align: left;
    padding: 5% 0 0 2.7%;
    padding: 6.7vw 0 0 2.7vw;
    background-color:#fff;
  }
  .main_logoArea p.icnImg img{
    width: 48%;
  }
  .main_logoArea .NotoSansCjkJp.fwB{
    position: relative;
    font-size: 18px;
    font-size: 4.8vw;
    line-height: 1;
    letter-spacing: .4em;
    text-align: left;
    padding:1em 0 1.4em 2.7%;
    padding:1em 0 1.4em 2.7vw;
    background-color:#fff;
  }
  .main_logoArea .NotoSansCjkJp.fwB span{
    color:#008396;
  }
  .main-visual-text{
    margin-top: 5vh;
  }
  .main-visual-text h1{
    position: relative;
    display: inline-block;
    font-size: 30px;
    font-size: 8vw;
    line-height: 1;
    letter-spacing: .12em;
    text-align: left;
    vertical-align: middle;
    padding: .78em .68em .68em 0;
    margin-bottom:2vh;
    background-color:#fff;
  }
  .main-visual-text .ttlSub{
    position: relative;
    width: 54%;
    margin-bottom:7vh;
  }
  .main-visual .movie-box .movie-wrap {
    background-size: auto 100%;
  }
  .main-visual-text .scroll {
    font-size: 3.2vw;
    top: 60%;
  }
  .resizeHi .main-visual-text .scroll {
    font-size: 4vh;
    top: 50%;
  }
  .main-visual-text .scroll::before{
    top: 6em;
  }
  
  /* アニメ用 */
  #contents #anchorNavArea {
    padding-top:0;
    margin-bottom:11.46%; 
    margin-bottom:11.46vw; 
  }
  #contents #anchorNavArea h2{
    font-size: 24px;
    font-size: 6.4vw;
    margin:2.08em 0 2em;
  }
  #contents #anchorNavArea > ul{
    display:flex;
    flex-wrap:wrap;
    justify-content: top;
    align-items: center;
  }
  #contents #anchorNavArea > ul > li{
    width: 33%;
    width: calc(100%/3 -2px);
    font-size: 16px;
    font-size: 4.267vw;
  }
  #contents #anchorNavArea > ul > li .navIcn{
    height: 1px;
    padding: 0 0 1em;
  }
  #contents #anchorNavArea > ul > li .navIcn img{
    display: none;
  }
  #contents #anchorNavArea > ul > li .navIcn::after{
    top: 0;
  }
  #contents #anchorNavArea > ul > li:nth-child(3n + 2){
    border-left:solid 1px #ccc;
    border-right:solid 1px #ccc;
  }
  #contents #anchorNavArea > ul > li:nth-child(n + 4){
    border-top:solid 1px #ccc;
  }
  #contents #anchorNavArea > ul > li a{
    color: #008396;
    line-height: 1;
    padding:0 0 .5em;
  }
  #contents #anchorNavArea > ul > li:nth-child(n - 3) a{
    padding-bottom:.75em;
  }
  #contents #anchorNavArea > ul > li:nth-child(n + 4) a{
    padding-top:1em;
    padding-bottom:.25em;
  }
  #contents .prefectureSec{
    margin-bottom:16.26%;
    margin-bottom:16.26vw;
  }
  #contents .prefectureSec .ttlBlock {
    min-height: auto;
    margin-bottom:2em;
    position: relative;
  }
  #contents .prefectureSec .ttlBlock.picR > div::before{
    width:28%;
  }
  #contents .prefectureSec .ttlBlock > div::after{
    content:"";
    display: block;
    width: 72%;
    height: 100%;
    position: absolute;
    top: 0;
    background-size: auto 120%;
    background-repeat: no-repeat;
    z-index: -1;
  }
  #contents .prefectureSec .ttlBlock.picR > div::after{
    right: 0;
    background-position: center bottom;
  }
  #contents .prefectureSec .ttlBlock.picL > div::after{
    left: 0;
    background-position: center bottom;
  }
  #aomori .ttlBlock > div::after{
    background-image: url("/japan-travel-planner/tohoku-jre-ana/images/aomori_top.jpg");
  }
  #akita .ttlBlock > div::after{
    background-image: url("/japan-travel-planner/tohoku-jre-ana/images/akita_top.jpg");
  }
  #iwate .ttlBlock > div::after{
    background-image: url("/japan-travel-planner/tohoku-jre-ana/images/iwate_top.jpg");
  }
  #miyagi .ttlBlock > div::after{
    background-image: url("/japan-travel-planner/tohoku-jre-ana/images/miyagi_top.jpg");
  }
  #yamagata .ttlBlock > div::after{
    background-image: url("/japan-travel-planner/tohoku-jre-ana/images/yamagata_top.jpg");
  }
  #fukushima .ttlBlock > div::after{
    background-image: url("/japan-travel-planner/tohoku-jre-ana/images/fukushima_top.jpg");
  }

  #mapArea .mapEast > .prefecture li .litexpoint .litex{
  width: 96%;
  font-size: 90%;
  line-height: 1;
  padding: 0px 2%;
  }


  #contents .prefectureSec .ttlBlock > .rightPic{
    position:relative;
    right: auto;
    top: auto;
    text-align: left;
    background-position: left -460% center;
    background-size: cover;
    padding: 0;
  }
  #contents .prefectureSec .ttlBlock > .rightPic > p:first-of-type{
    width: 38.26%;
    width: 38.26vw;
    position: relative;
    margin-left:2.67%;
    padding:18vw 0 5.86%;
  }
  #contents .prefectureSec .ttlBlock > .rightPic > h3{
    padding: .15em;
    margin: 0 0 26.13vw 5.6vw;
    font-size: 30px;
    font-size: 8vw;
  }
  #contents .prefectureSec .ttlBlock > .rightPic + .ttlSubTxt{
    position: static;
    font-size: 14px;
    font-size: 3.7vw;
    padding: .5em 2.67% 0;
  }
  #contents .prefectureSec .ttlBlock > .leftPic{
    position:relative;
    left: auto;
    top: auto;
    text-align: right;
    background-position: right -460% center;
    background-size: cover;
  }
  #contents .prefectureSec .ttlBlock > .leftPic > p:first-of-type {
    position: relative;
    margin-right:2.67%;
    padding:18vw 0 5.86%;
  }
  #contents .prefectureSec .ttlBlock > .leftPic > p:first-of-type img{
    width: 38.26%;
    width: 38.26vw;
  }
  #contents .prefectureSec .ttlBlock > .leftPic > h3{
    padding: .15em;
    margin: 0 0 26.13vw 5.33vw;
    font-size:30px;
    font-size:8vw;
  }
  #contents .prefectureSec .ttlBlock.picL .ttlSubTxt{
    font-size: 14px;
    font-size: 3.7vw;
    padding: .5em 2.67% 0;
    text-align: left;
  }
  #contents .prefectureSec .ttlBlock .leftPic::before{
    width:28%;
    width:28vw;
  }
  #contents .prefectureSec > ul {
    display: block;
    font-size: 1rem;
    width:100%;
    margin: 0 auto;
  }
  #contents .prefectureSec > ul > li{
    display: block;
    width:100%;
    border-bottom:solid 2px #fff;
  }
  #contents .prefectureSec > ul > li > a .thumbCap{
    font-size: 16px;
    font-size:4.26vw;
    text-align: left;
    line-height: 1;
    opacity: 1;
    background-color:rgba(0,20,25,.55);
    top: inherit;
    bottom:0;
    left: 0;
    height: auto;
    padding: .5em;
    transform: none;
    display: block !important; 
  }


  #contents .prefectureSec > ul > li:nth-child(3n + 2) {
    margin:0;
  }
  #contents .prefectureSec > ul > li > a .viewMore{
    display: none;
  }
  #contents .prefectureSec > ul > li > a .thumbImg{
    height:150px;
    height:40.26vw;
    overflow: hidden;
  }
  #contents .prefectureSec > ul > li > a .thumbImg img {
    opacity: 1;
    transform:translateY(-20%);
    transition: none;
  }
  #contents .prefectureSec > ul > li > a:hover .thumbImg img ,
  #contents .prefectureSec > ul > li > a:focus .thumbImg img {
    opacity: 1;
    transform:translateY(-20%);
    transition: none;
  }
  #recommendArea{
    padding:13.33% 0;
    padding:13.33vw 0;
  }
  #recommendArea > div{
    padding:0 2.66%;
    padding:0 2.66vw;
  }
  #recommendArea .secondDiv{
    padding-top:13.33%;
    padding-top:13.33vw;
  }
  #recommendArea h2{
    font-size: 24px;
    font-size: 6.4vw;
    margin-bottom:.9em;
    padding: 0 1.25em;
    line-height: 1.3;
  }
  #recommendArea .clm4Block > li{
  max-width: 50%;
  float: left;
  padding-left: 5px;
  padding-right: 5px;
  margin-bottom:8.45%;
  margin-bottom:8vw;
  }
  #recommendArea .clm4Block > li:nth-child(2n-1){
  padding-left: 0px;
  }
  #recommendArea .clm4Block > li:nth-child(2n){
  padding-right: 0px;
  }
  #recommendArea .clm2Block > dd{
    font-size: 14px;
    font-size: 3.3vw;
    padding: .5em 0;
  }

  #recommendArea .clm4Block > dd{
    font-size: 14px;
    font-size: 3.3vw;
    padding: .5em 0;
  }

  #recommendArea .visibleWws .clm2Block,
  #recommendArea .countryVisible .clm2Block {
    display: block; /* 追加 */
  }

    #recommendArea .visibleWws .clm2Block > li,
  #recommendArea .countryVisible .clm2Block > li{
    width: 100%;
    max-width: 100%;
    margin-bottom:8.45%;
    margin-bottom:8vw;
    margin-left: 0;
  }

  #recommendArea dt h3{
    font-size:16px;
    font-size:4.26vw;
  }
  #recommendArea dl,
  #recommendArea dt,
  #recommendArea dd{
    height: auto;
  }
  #recommendArea dd p{
    font-size: 14px;
    font-size: 3.73vw;
  }
  #recommendArea .visibleWws dd p,
  #recommendArea .countryVisible dd p{
    margin-bottom:.8em;
  }
  .followingAnchor > div > p{
    font-size:14px;
    font-size:3.2vw;
  }
}

/* アニメ用 */
#contents #mapArea.animeOn .mapBlock .mapEast > .train_img{
  animation: RunNew 2.2s linear 3s forwards, show .2s linear 2.8s forwards;
}
#contents #mapArea.animeOn .mapBlock .mapEast > .airplane_img{
  animation: FlyNew 2s linear .8s forwards;
}
@-webkit-keyframes scroll-text{
  0%{-webkit-transform:translateY(0);transform:translateY(0)}
  40%,50%{-webkit-transform:translateY(10px);transform:translateY(10px)}
  100%{-webkit-transform:translateY(0);transform:translateY(0)}
}
@keyframes scroll-text{0%{-webkit-transform:translateY(0);transform:translateY(0)}
  40%,50%{-webkit-transform:translateY(10px);transform:translateY(10px)}
  100%{-webkit-transform:translateY(0);transform:translateY(0)}
}
@-webkit-keyframes scroll {
0% {
top:6em;
height:0;
opacity:1
}
50% {
top:6em;
height:27vh;
}
90% {
opacity:1
}
to {
height:27vh;
opacity:0
}
}
@keyframes scroll {
0% {
top:6em;
height:0;
opacity:1
}
50% {
top:6em;
height:27vh;
}
90% {
opacity:1
}
to {
height:27vh;
opacity:0
}
}
@-webkit-keyframes scroll2 {
0% {
top:6em;
height:0;
opacity:1
}
50% {
top:6em;
height:18vh;
}
90% {
opacity:1;
}
to {
height:18vh;
opacity:0;
}
}
@keyframes scroll2 {
0% {
top:6em;
height:0;
opacity:1
}
50% {
top:6em;
height:18vh;
}
90% {
opacity:1;
}
to {
height:18vh;
opacity:0;
}
}
@keyframes show {
  0%{opacity: 0;}
  100%{opacity: 1;}
}
@keyframes up {
  0%{top: 8vh;}
  100%{top: 0;}
}

@keyframes FlyNew{
  0%{transform: rotate(-45deg);}
  100%{transform: rotate(20deg);}
}
@keyframes RunNew{
  0%{transform: rotate(-5deg);}
  100%{transform: rotate(40deg);}
}

/* ロード完了まで隠す */
.hideAll > *:not(#hiThis){
  visibility: hidden;
}
.hideAll #hiThis{
  visibility:visible;
  background:#173999;
  color: #fff;
  font-size: 1rem;
  z-index: 99999999;
}

.loadingNow{
  display: none;
}
.hideAll #hiThis .centerLoadTxt{
  position:absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%,-50%);
}
.hideAll #hiThis .loadingNow {
  display: block;
  color: #ffffff;
  font-size: .5rem;
  margin: 5em auto;
  width: 1vw;
  height: 1vw;
  border-radius: 50%;
  position: relative;
  text-indent: -9999em;
  -webkit-animation: load4 1.3s infinite linear;
  animation: load4 1.3s infinite linear;
  -webkit-transform: translateZ(15%);
  -ms-transform: translateZ(15%);
  transform: translateZ(15%);
}
@-webkit-keyframes load4 {
  0%,
  100% {
    box-shadow: 0 -3em 0 0.2em, 2em -2em 0 0em, 3em 0 0 -1em, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 -1em, -3em 0 0 -1em, -2em -2em 0 0;
  }
  12.5% {
    box-shadow: 0 -3em 0 0, 2em -2em 0 0.2em, 3em 0 0 0, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 -1em, -3em 0 0 -1em, -2em -2em 0 -1em;
  }
  25% {
    box-shadow: 0 -3em 0 -0.5em, 2em -2em 0 0, 3em 0 0 0.2em, 2em 2em 0 0, 0 3em 0 -1em, -2em 2em 0 -1em, -3em 0 0 -1em, -2em -2em 0 -1em;
  }
  37.5% {
    box-shadow: 0 -3em 0 -1em, 2em -2em 0 -1em, 3em 0em 0 0, 2em 2em 0 0.2em, 0 3em 0 0em, -2em 2em 0 -1em, -3em 0em 0 -1em, -2em -2em 0 -1em;
  }
  50% {
    box-shadow: 0 -3em 0 -1em, 2em -2em 0 -1em, 3em 0 0 -1em, 2em 2em 0 0em, 0 3em 0 0.2em, -2em 2em 0 0, -3em 0em 0 -1em, -2em -2em 0 -1em;
  }
  62.5% {
    box-shadow: 0 -3em 0 -1em, 2em -2em 0 -1em, 3em 0 0 -1em, 2em 2em 0 -1em, 0 3em 0 0, -2em 2em 0 0.2em, -3em 0 0 0, -2em -2em 0 -1em;
  }
  75% {
    box-shadow: 0em -3em 0 -1em, 2em -2em 0 -1em, 3em 0em 0 -1em, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 0, -3em 0em 0 0.2em, -2em -2em 0 0;
  }
  87.5% {
    box-shadow: 0em -3em 0 0, 2em -2em 0 -1em, 3em 0 0 -1em, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 0, -3em 0em 0 0, -2em -2em 0 0.2em;
  }
}
@keyframes load4 {
  0%,
  100% {
    box-shadow: 0 -3em 0 0.2em, 2em -2em 0 0em, 3em 0 0 -1em, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 -1em, -3em 0 0 -1em, -2em -2em 0 0;
  }
  12.5% {
    box-shadow: 0 -3em 0 0, 2em -2em 0 0.2em, 3em 0 0 0, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 -1em, -3em 0 0 -1em, -2em -2em 0 -1em;
  }
  25% {
    box-shadow: 0 -3em 0 -0.5em, 2em -2em 0 0, 3em 0 0 0.2em, 2em 2em 0 0, 0 3em 0 -1em, -2em 2em 0 -1em, -3em 0 0 -1em, -2em -2em 0 -1em;
  }
  37.5% {
    box-shadow: 0 -3em 0 -1em, 2em -2em 0 -1em, 3em 0em 0 0, 2em 2em 0 0.2em, 0 3em 0 0em, -2em 2em 0 -1em, -3em 0em 0 -1em, -2em -2em 0 -1em;
  }
  50% {
    box-shadow: 0 -3em 0 -1em, 2em -2em 0 -1em, 3em 0 0 -1em, 2em 2em 0 0em, 0 3em 0 0.2em, -2em 2em 0 0, -3em 0em 0 -1em, -2em -2em 0 -1em;
  }
  62.5% {
    box-shadow: 0 -3em 0 -1em, 2em -2em 0 -1em, 3em 0 0 -1em, 2em 2em 0 -1em, 0 3em 0 0, -2em 2em 0 0.2em, -3em 0 0 0, -2em -2em 0 -1em;
  }
  75% {
    box-shadow: 0em -3em 0 -1em, 2em -2em 0 -1em, 3em 0em 0 -1em, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 0, -3em 0em 0 0.2em, -2em -2em 0 0;
  }
  87.5% {
    box-shadow: 0em -3em 0 0, 2em -2em 0 -1em, 3em 0 0 -1em, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 0, -3em 0em 0 0, -2em -2em 0 0.2em;
  }
}

/* 出し分け用 */
#recommendArea .js-hidden, .followingAnchor .js-hidden{
  display: none;
}

/* mwbp対応 */
.main-visual-text .scroll .mwbp-u_animate-once,
.main-visual-text .scroll.mwbp-u_animate-once::before {
  -webkit-animation-iteration-count: 1;
  animation-iteration-count: 1;
}
.main-visual-text .scroll.mwbp-u_animate-once::before {
  height: 27vh;
}
.mwbp-u_bgclr_blk {
  -moz-text-shadow: #000 2px 0px 10px, #000 -2px 0px 10px, #000 0px -2px 10px, #000 0px 2px 10px, #000 2px 2px 10px, #000 -2px 2px 10px, #000 2px -2px 10px, #000 -2px -2px 10px, #000 1px 2px 10px, #000 -1px 2px 10px, #000 1px -2px 10px, #000 -1px -2px 10px, #000 2px 1px 10px, #000 -2px 1px 10px, #000 2px -1px 10px, #000 -2px -1px 10px;
  -webkit-text-shadow: #000 2px 0px 10px, #000 -2px 0px 10px, #000 0px -2px 10px, #000 0px 2px 10px, #000 2px 2px 10px, #000 -2px 2px 10px, #000 2px -2px 10px, #000 -2px -2px 10px, #000 1px 2px 10px, #000 -1px 2px 10px, #000 1px -2px 10px, #000 -1px -2px 10px, #000 2px 1px 10px, #000 -2px 1px 10px, #000 2px -1px 10px, #000 -2px -1px 10px;
  text-shadow: #000 2px 0px 10px, #000 -2px 0px 10px, #000 0px -2px 10px, #000 0px 2px 10px, #000 2px 2px 10px, #000 -2px 2px 10px, #000 2px -2px 10px, #000 -2px -2px 10px, #000 1px 2px 10px, #000 -1px 2px 10px, #000 1px -2px 10px, #000 -1px -2px 10px, #000 2px 1px 10px, #000 -2px 1px 10px, #000 2px -1px 10px, #000 -2px -1px 10px;
}
#contents #mapArea.animeOn .mapBlock .mapEast > .train_img.mwbp-u_animate-none{
  animation-name:none;
  transform: rotate(40deg);
  opacity: 1;
}
#contents #mapArea.animeOn .mapBlock .mapEast > .airplane_img.mwbp-u_animate-none{
  animation-name:none;
  transform: rotate(20deg);
}
#contents #mapArea.animeOn.mwbp-u_animate-none,
#mapArea.animeOn .mapEast > .prefecture .aomori.mwbp-u_animate-none,
#mapArea.animeOn .mapEast > .prefecture .akita.mwbp-u_animate-none,
#mapArea.animeOn .mapEast > .prefecture .iwate.mwbp-u_animate-none,
#mapArea.animeOn .mapEast > .prefecture .miyagi.mwbp-u_animate-none,
#mapArea.animeOn .mapEast > .prefecture .yamagata.mwbp-u_animate-none,
#mapArea.animeOn .mapEast > .prefecture .fukushima.mwbp-u_animate-none {
  animation-name: none;
  opacity :1;
}
.mwbp-u_underline {
  text-decoration: underline;
}
.mwbp-u_fontweight_bold {
  font-weight: bold!important;
}
.prefectureSec .mwbp-u_open_in_a_new_window {
  background-color: #fff;
  padding: 5px;
  position: absolute;
  top:0;
  right: 0;
}

#recommendArea .mwbp-u_open_in_a_new_window {
  width: auto;
  background-color: #fff;
  padding: 5px;
  position: absolute;
  top:0;
  right: 0;
}

.mwbp-u_a_block {
  display: block;
  position: relative;
}


/* ==========================================================
  北米対応
========================================================== */
/* h1調整 */
.main-visual-text h1 {
  margin-top: 200px;
}
.main_logoArea {
  position: absolute;
  top: 0;
  left: 20px;
}
@media screen and (max-width: 768px) {
  .main-visual-text h1 {
    margin-top: 0;
  }
  .main_logoArea {
    position: static;
  }
}

/* MV再生ボタン */
.controlsArea,
.controlsArea .mv-controls {
  width: 60px;
}
.controlsArea .mv-controls button.is-active {
  display: none;
}
.controlsArea .mv-controls button + button {
  margin-left: 0;
}
.controlsArea .mv-controls button + button:before {
  content: none;
}

/* マップ */
#contents #mapArea .mapBlock.mwbp-u_mapimage:before {
  content: '';
  display: table-cell;
  background: url(/japan-travel-planner/tohoku-jre-ana/images/map_bg_japan_01.png) right bottom no-repeat;
}
#contents #mapArea .mapBlock.mwbp-u_mapimage:after {
  content: '';
  display: table-cell;
  width: 27px;
  max-width: 27px;
  background: url(/japan-travel-planner/tohoku-jre-ana/images/map_bg_japan_03.png) left bottom no-repeat;
}
#contents #mapArea .mapBlock .mapEast > .airplane_img,
#contents #mapArea .mapBlock .mapEast > .train_img {
  display: inline-block;
  position: absolute;
}

/* 各東北見出し */
#contents .prefectureSec .ttlBlock > .rightPic > h3,
#contents .prefectureSec .ttlBlock > .leftPic > h3 {
  margin-top: 272px;
}
#contents .prefectureSec .ttlBlock > .rightPic > p:first-of-type {
  position: absolute;
  top: 0;
  left: 20px;
}
#contents .prefectureSec .ttlBlock > .leftPic > p:first-of-type {
  position: absolute;
  top: 0;
  right: 20px;
}
@media screen and (max-width: 768px) {
  #contents .prefectureSec .ttlBlock > .rightPic > h3,
  #contents .prefectureSec .ttlBlock > .leftPic > h3 {
    margin-top: 34vw;
  }
  #contents .prefectureSec .ttlBlock > .rightPic > p:first-of-type {
    left: 0;
  }
  #contents .prefectureSec .ttlBlock > .leftPic > p:first-of-type {
    right: 0;
  }

}

/* おトクな運賃のご紹介 */
.mwbp_u_imgdesbox {
  padding-top: 34%;
  position: relative;
}
.mwbp_u_imgdesbox .mwbp_u_imgdesbox_img {
  position: absolute;
  top: 0;
  left: 0;
}









