@charset "utf-8";
@import url("https://fonts.googleapis.com/css?family=Montserrat:600i");
@font-face {
  font-family: 'Noto Sans Japanese';
  font-style: normal;
  font-weight: 400;
  src: url("./font/NotoSansCJKjp-Regular.eot");
  src: url("./font/NotoSansCJKjp-Regular.eot?#iefix") format("embedded-opentype"), url("./font/NotoSansCJKjp-Regular.woff") format("woff"), url("./font/NotoSansCJKjp-Regular.ttf") format("truetype");
}

/*                reset
======================================================= */
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

body {
  line-height: 1;
  -webkit-text-size-adjust: 100%;
}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section, main {
  display: block;
}

nav ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
  content: '';
  content: none;
}

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}

mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold;
}

del {
  text-decoration: line-through;
}

abbr[title], dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #cccccc;
  margin: 1em 0;
  padding: 0;
}

input, select {
  vertical-align: middle;
}

main {
  display: block;
}

/*
====================================================================
Set Default Style
====================================================================
*/
h1, h2, h3, h4, h5, h6, strong {
  font-weight: normal;
}

em {
  font-style: oblique;
}

img {
  vertical-align: top;
  width: 100%;
  height: auto;
}

a img {
  border: none;
}

ul li {
  list-style: none;
}

/*
--------------------------------------------------------------------
Font Setting
--------------------------------------------------------------------
*/
body {
  color: #000000;
  font-family: "Noto Sans Japanese","ヒラギノ角ゴ ProN W3","Hiragino Kaku Gothic ProN","メイリオ",Meiryo,Osaka,"MS Pゴシック","MS PGothic",sans-serif;
  font-size: 14px;
  line-height: 1.4;
  font-weight: 400;
}

table {
  font-size: inherit;
  font: 100%;
}

pre, code, kbd, samp, tt {
  font-family: monospace;
  *font-size: 14px;
  line-height: 1;
}

a {
  color: #333333;
  text-decoration: none;
}

a:hover {
  color: #333333;
  text-decoration: underline;
  opacity: 0.7;
}

a img {
  border: none;
}

a.current {
  color: #5a5a5a;
  text-decoration: none;
}

button, area, input, a:active, a:focus {
  outline: none;
}

/*
--------------------------------------------------------------------
Structure
--------------------------------------------------------------------
*/
html {
  background-color: #ffffff;
  height: 100%;
  overflow-y: scroll;
}

body {
  height: 100%;
}

img {
  width: 100%;
}

/*                leyout
======================================================= */
#wrapper {
  overflow: hidden;
}

#main_area {
  background-color: #ffffff;
  position: relative;
  top: 62px;
  z-index: 10;
  margin-top: 632px;
}
@media only screen and (max-width: 1300px) {
  #main_area {
    margin-top: 49.3%;
  }
}
@media only screen and (max-width: 768px) {
  #main_area {
    margin-top: 99.3%;
  }
}
@media only screen and (max-width: 640px) {
  #main_area {
    margin-top: 97.5%;
  }
}
@media only screen and (max-width: 480px) {
  #main_area {
    margin-top: 94.5%;
  }
}
#main_area:before, #main_area:after {
  background-repeat: no-repeat;
  background-size: 100% 100%;
  content: '';
  height: 82px;
  width: 50%;
  position: absolute;
  top: -82px;
  z-index: 10;
}
@media only screen and (max-width: 768px) {
  #main_area:before, #main_area:after {
    display: none;
  }
}
#main_area:before {
  background-image: url(../img/kv_bg01.png);
  background-position: left bottom;
  left: 0;
}
#main_area:after {
  background-image: url(../img/kv_bg02.png);
  background-position: right bottom;
  right: 0;
}

.main_width {
  display: block;
  width: 1000px;
  margin: 0 auto;
}
@media only screen and (max-width: 768px) {
  .main_width {
    width: auto;
    padding: 0 4%;
  }
}

/*                header
======================================================= */
#header {
  background-color: #ffffff;
  height: 62px;
  left: 0;
  position: fixed;
  top: 0;
  width: 100%;
  z-index: 1000;
}
@media only screen and (max-width: 768px) {
  #header {
    height: 43px;
  }
}
#header p#hd_logo {
  width: 168px;
  padding: 15px 0;
  margin: 0 auto;
}
@media only screen and (max-width: 768px) {
  #header p#hd_logo {
    padding: 10px 0;
    width: 120px;
  }
}
#header p#hd_logo a {
  display: block;
}
#header p#hd_logo a:hover {
  opacity: 1 !important;
}

/*                main_kv
======================================================= */
.kv {
  height: 632px;
  left: 0;
  overflow: hidden;
  position: fixed;
  top: 62px;
  width: 100%;
}
@media only screen and (max-width: 1220px) {
  .kv {
    height: auto;
  }
}
@media only screen and (max-width: 768px) {
  .kv {
    top: 7%;
  }
}
@media only screen and (max-width: 640px) {
  .kv {
    top: 6%;
  }
}
@media only screen and (max-width: 480px) {
  .kv {
    top: 5%;
  }
}
.kv .social-icons {
  position: absolute;
  right: 18px;
  top: 22px;
  z-index: 10;
}
@media only screen and (max-width: 768px) {
  .kv .social-icons {
    right: 0;
    text-align: center;
    top: 18px;
    width: 100%;
  }
}
.kv .social-icons a {
  background-color: transparent;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
  border-radius: 0;
  cursor: pointer;
  float: left;
  height: 37px;
  width: 37px;
  margin-right: 10px;
}
@media only screen and (max-width: 768px) {
  .kv .social-icons a {
    display: inline-block;
    float: none;
  }
}
.kv .social-icons a.facebook {
  background-image: url(../img/icon_facebook.png);
}
.kv .social-icons a.twitter {
  background-image: url(../img/icon_twitter.png);
}
.kv .social-icons a.google-plus {
  background-image: url(../img/icon_google.png);
}
.kv .social-icons a.hatena {
  background-image: url(../img/icon_hatena.png);
}
.kv .social-icons a.pinterest {
  background-image: url(../img/icon_pinterest.png);
}
.kv .bg_slider ul.slides {
  overflow: hidden;
}
.kv .bg_slider ul.slides li img {
  -moz-transition: -moz-transform 9s linear;
  -webkit-transition: -webkit-transform 9s linear;
  -o-transition: -o-transform 9s linear;
  -ms-transition: -ms-transform 9s linear;
  transition: transform 9s linear;
  -webkit-transform: scale(1.2);
  -moz-transform: scale(1.2);
  -o-transform: scale(1.2);
  -ms-transform: scale(1.2);
  transform: scale(1.2);
}
.kv .bg_slider ul.slides li span {
  background-color: #ffffff;
  display: block;
  font-size: 92.9%;
  position: absolute;
  right: 100px;
  padding: 6px 16px;
}
@media only screen and (min-width: 1221px) {
  .kv .bg_slider ul.slides li span {
    top: 518px;
  }
}
@media only screen and (max-width: 1220px) {
  .kv .bg_slider ul.slides li span {
    right: 7.8%;
    top: 81.96%;
  }
}
@media only screen and (max-width: 1024px) {
  .kv .bg_slider ul.slides li span {
    top: 75%;
  }
}
@media only screen and (max-width: 900px) {
  .kv .bg_slider ul.slides li span {
    right: 5%;
    top: 70%;
  }
}
@media only screen and (max-width: 768px) {
  .kv .bg_slider ul.slides li span {
    font-size: 71.4%;
    right: 1.46%;
    top: 78%;
  }
}
.kv .bg_slider ul.slides li.flex-active-slide img {
  -webkit-transform: scale(1);
  -moz-transform: scale(1);
  -o-transform: scale(1);
  -ms-transform: scale(1);
  transform: scale(1);
}

/*                main_title_area
======================================================= */
.main_title_area {
  position: relative;
  top: -177px;
  width: 907px;
  z-index: 15;
  margin: 0 auto;
}
@media only screen and (max-width: 1220px) {
  .main_title_area {
    top: -160px;
  }
}
@media only screen and (max-width: 1024px) {
  .main_title_area {
    top: -140px;
  }
}
@media only screen and (max-width: 850px) {
  .main_title_area {
    top: -120px;
  }
}
@media only screen and (max-width: 768px) {
  .main_title_area {
    top: -120px;
    width: 100%;
  }
}
@media only screen and (max-width: 640px) {
  .main_title_area {
    top: -60px;
  }
}
@media only screen and (max-width: 480px) {
  .main_title_area {
    top: -55px;
  }
}
.main_title_area h1 {
  margin-bottom: 5px;
}
@media only screen and (max-width: 768px) {
  .main_title_area h1 {
    margin-bottom: 35px;
  }
}
.main_title_area p {
  width: 682px;
  margin: 0 auto;
}
@media only screen and (max-width: 1220px) {
  .main_title_area p {
  }
}
@media only screen and (max-width: 768px) {
  .main_title_area p {
    width: 74.9%;
  }
}

.main_title_area p.btn a {
	width: 340px;
	margin: 40px auto 0 auto;
	background-color: #000000;
	border-radius: 5px;
	color: #ffffff;
	display: block;
	font-size: 24px;
	position: relative;
	padding: 12px;
	text-align: center; 
	line-height: 1.2;
	font-family: 'Montserrat', sans-serif;
}
.main_title_area p.btn a:hover { text-decoration: none; }
.main_title_area p.btn a:after {
	background: url(../img/btn_arrow.png) no-repeat right top;
	background-size: 7px 12px;
	content: '';
	display: inline-block;
	height: 12px;
	position: absolute;
	right: 12px;
	top: 50%;
	width: 7px;
	margin-top: -6px;
}
.main_title_area p.btn a small { font-size: 14px; line-height: 1; }
@media only screen and (max-width: 768px) {
	.main_title_area p.btn { display: none; }
}

/*                map_area
======================================================= */
.map_area {
  max-width: 1144px;
	width: 1144px;
  margin-top: -260px;
	margin-bottom: 70px;
}
@media only screen and (max-width: 1220px) {
  .map_area {
		margin-top: -260px;
  }
}
@media only screen and (max-width: 1024px) {
  .map_area {
    margin-top: -200px;
		width: 1024px;
  }
}
@media only screen and (max-width: 850px) {
  .map_area {
    margin-top: -200px;
		width: 850px;
  }
}
@media only screen and (max-width: 768px) {
  .map_area {
    width: 100%;
    padding: 0;
    margin-top: -75px;
  }
}
@media only screen and (max-width: 640px) {
  .map_area {
    margin-top: -60px;
  }
}
@media only screen and (max-width: 480px) {
  .map_area {
    margin-top: -45px;
  }
}

/*                plans
======================================================= */
.plans {
  padding-bottom: 50px;
}
@media only screen and (min-width: 769px) {
  .plans {
    min-width: 1280px;
  }
}
.plans h2 {
  width: 640px;
  margin: -14px auto 26px;
}
@media only screen and (max-width: 768px) {
  .plans h2 {
    width: 85.33%;
    margin: 0 auto 5%;
  }
}
.plans .plan {
  position: relative;
}
@media only screen and (max-width: 768px) {
  .plans .plan {
    clear: both;
  }
}
@media only screen and (min-width: 769px) {
  .plans .plan:after {
    content: "";
    clear: both;
    display: block;
  }
}
.plans .plan .bg {
  background-repeat: repeat;
  height: 598px;
  right: 0;
  opacity: 1;
  position: absolute;
  top: 95px;
  width: 0;
}
@media only screen and (max-width: 768px) {
  .plans .plan .bg {
    height: 100%;
    opacity: 1 !important;
    top: 0;
    width: 100%;
    padding-bottom: 22%;
  }
}
.plans .plan .img {
  height: 598px;
  overflow: hidden;
  opacity: 1;
  position: absolute;
  top: 95px;
  width: 0;
}
.plans .plan05 .img { top: 30px; }
.plans .plan05 .bg  { top: 30px; }
@media only screen and (max-width: 768px) {
  .plans .plan .img {
    height: 0;
    opacity: 1 !important;
    top: 0;
    width: 100%;
    padding-top: 80%;
  }
}
.plans .plan .img img {
  height: auto;
  position: absolute;
  left: -50px;
  top: 50%;
  -ms-transform: translate3d(0, -50%, 0);
  -moz-transform: translate3d(0, -50%, 0);
  -webkit-transform: translate3d(0, -50%, 0);
  transform: translate3d(0, -50%, 0);
}
@media only screen and (max-width: 1740px) {
  .plans .plan .img img {
    height: 100%;
    left: 0%;
    top: 0;
    -ms-transform: translate3d(-50%, 0, 0);
    -moz-transform: translate3d(-50%, 0, 0);
    -webkit-transform: translate3d(-50%, 0, 0);
    transform: translate3d(-50% 0, 0);
    width: auto;
  }
}
@media only screen and (max-width: 768px) {
  .plans .plan .img img {
    left: 0;
    width: 100%;
    -ms-transform: none;
    -moz-transform: none;
    -webkit-transform: none;
    transform: none;
  }
}
.plans .plan .icon_title {
  opacity: 0;
  position: relative;
  top: 60px;
  width: 1020px;
  margin: 0 auto 60px;
}
@media only screen and (max-width: 768px) {
  .plans .plan .icon_title {
    opacity: 1 !important;
    position: absolute;
    top: -10%;
    width: 97.3%;
    margin: 0 auto;
  }
}
@media only screen and (max-width: 480px) {
  .plans .plan .icon_title {
    top: -8%;
  }
}
.plans .plan .icon_title p.title {
  width: 462px;
  margin: 0 auto;
}
.plans .plan01 .icon_title p.title { width: 512px; }
.plans .plan02 .icon_title p.title { width: 514px; }
.plans .plan03 .icon_title p.title { width: 330px; }
.plans .plan04 .icon_title p.title { width: 514px; }
.plans .plan05 .icon_title p.title { width: 347px; margin-top: 50px; }
@media only screen and (max-width: 768px) {
  .plans .plan .icon_title p.title {
    width: 61.6%;
	}
		.plans .plan03 .icon_title p.title {
			width: 40.6%;
  }
	.plans .plan05 .icon_title p.title {
		width: 50.6%;
		margin-top: 0px;
		padding: 30px 0;
	}
}
.plans .plan .icon_title p.icon {
  bottom: auto;
  position: absolute;
  width: 135px;
	top:50%; -webkit-transform: translateY(-50%); -ms-transform: translateY(-50%); transform: translateY(-50%); 
}
@media only screen and (max-width: 768px) {
  .plans .plan .icon_title p.icon {
    width: 14.24%;
  }
}
.plans .plan .text {
  opacity: 0;
  position: relative;
  width: 435px;
  padding-left: 65px;
  margin-bottom: 38px;
}
@media only screen and (min-width: 769px) {
  .plans .plan .text {
    top: 60px;
  }
}
@media only screen and (max-width: 768px) {
  .plans .plan .text {
    opacity: 1 !important;
    width: auto;
    padding: 86.6% 6.6% 0;
    margin: 0 0 10px;
  }
}
.plans .plan .text h3 {
  margin-bottom: 23px;
}
.plans .plan01 .text h3 img { height: 40px; width: auto; }
.plans .plan02 .text h3 img { height: 80px; width: auto; }
.plans .plan03 .text h3 img { height: 40px; width: auto; }
.plans .plan04 .text h3 img { height: 44px; width: auto; }
.plans .plan05 .text h3 img { height: 44px; width: auto; }

@media only screen and (max-width: 768px) {
	.plans .plan01 .text h3 img { height: 30px; width: auto; }
	.plans .plan02 .text h3 img { height: 60px; width: auto; }
	.plans .plan03 .text h3 img { height: 30px; width: auto; }
	.plans .plan04 .text h3 img { height: 33px; width: auto; }
	.plans .plan05 .text h3 img { height: 33px; width: auto; }
}
@media only screen and (max-width: 768px) {
  .plans .plan .text h3 {
    margin-bottom: 15px;
  }
}
.plans .plan .text p {
  line-height: 1.85;
}
@media only screen and (max-width: 768px) {
  .plans .plan .text p {
    font-size: 85.7%;
    line-height: 1.66;
  }
}
.plans .plan .text p.btn {
  width: 200px;
  margin-top: 23px;
	font-family: 'Montserrat', sans-serif;
}
@media only screen and (max-width: 768px) {
  .plans .plan .text p.btn {
    max-width: 400px;
    width: 61.53%;
    margin: 10px auto 0;
  }
}
.plans .plan .text p.btn a {
  background-color: #000000;
  border-radius: 5px;
  color: #ffffff;
  display: block;
  font-size: 92.9%;
  position: relative;
  padding: 6px 12px 7px 16px;
}
@media only screen and (max-width: 768px) {
  .plans .plan .text p.btn a {
    border-radius: 3px;
    text-align: center;
    padding: 15px 0;
  }
}
.plans .plan .text p.btn a:after {
  background: url(../img/btn_arrow.png) no-repeat right top;
  background-size: 7px 12px;
  content: '';
  display: inline-block;
  height: 12px;
  position: absolute;
  right: 12px;
  top: 50%;
  width: 7px;
  margin-top: -6px;
}
@media only screen and (max-width: 768px) {
  .plans .plan .text p.btn a:after {
    background-size: 6px 11px;
    height: 11px;
    width: 6px;
    margin-top: -5px;
  }
}
.plans .plan .text p.btn a:hover {
  text-decoration: none;
}
.plans .plan .subimg {
  opacity: 0;
  position: relative;
}
@media only screen and (min-width: 769px) {
  .plans .plan .subimg {
    top: 60px;
  }
}
@media only screen and (max-width: 768px) {
  .plans .plan .subimg {
    opacity: 1 !important;
    width: auto;
    padding: 0 6.6%;
    margin-left: 0;
  }
}
.plans .plan .subimg img {
  display: block;
}
.plans .plan.plan01 .bg, .plans .plan.plan03 .bg, .plans .plan.plan05 .bg {
  background-position: right top;
}
.plans .plan.plan01 .icon_title p.icon, .plans .plan.plan03 .icon_title p.icon, .plans .plan.plan05 .icon_title p.icon {
  right: 0;
}
.plans .plan.plan01 .text, .plans .plan.plan03 .text, .plans .plan.plan05 .text {
  margin-left: 50%;
}
@media only screen and (max-width: 768px) {
	.plans .plan.plan01 .text, .plans .plan.plan03 .text, .plans .plan.plan05 .text {
    margin-left: 0;
  }
}
.plans .plan.plan01 .subimg, .plans .plan.plan03 .subimg, .plans .plan.plan05 .subimg {
  margin-left: 50%;
}
@media only screen and (max-width: 768px) {
	.plans .plan.plan01 .subimg, .plans .plan.plan03 .subimg, .plans .plan.plan05 .subimg {
    float: left;
    margin-left: 0;
  }
}
.plans .plan.plan01 .subimg img, .plans .plan.plan03 .subimg img, .plans .plan.plan05 .subimg img {
  width: 630px;
  margin-left: -130px;
}
@media only screen and (max-width: 768px) {
	.plans .plan.plan01 .subimg img, .plans .plan.plan03 .subimg img, .plans .plan.plan05 .subimg img {
    width: 100%;
    margin-left: 0;
  }
}
.plans .plan.plan02 .bg, .plans .plan.plan04 .bg {
  background-position: left top;
}
.plans .plan.plan02 .img, .plans .plan.plan04 .img {
  right: 0;
}
.plans .plan.plan02 .icon_title p.icon, .plans .plan.plan04 .icon_title p.icon {
  left: 0;
}
@media only screen and (max-width: 768px) {
	.plans .plan.plan02 .icon_title p.icon, .plans .plan.plan04 .icon_title p.icon { right: 0px; left: auto;}
}
.plans .plan.plan02 .text, .plans .plan.plan04 .text {
  margin-right: 50%;
}
@media only screen and (min-width: 769px) {
  .plans .plan.plan02 .text, .plans .plan.plan04 .text {
    float: right;
    padding-right: 65px;
  }
}
@media only screen and (max-width: 768px) {
  .plans .plan.plan02 .text, .plans .plan.plan04 .text {
    margin-right: 0;
  }
}
.plans .plan.plan02 .subimg, .plans .plan.plan04 .subimg {
  float: right;
  margin-right: 50%;
}
@media only screen and (max-width: 768px) {
  .plans .plan.plan02 .subimg, .plans .plan.plan04 .subimg {
    margin-right: 0;
  }
}
.plans .plan.plan02 .subimg img, .plans .plan.plan04 .subimg img {
  width: 636px;
  margin-right: -136px;
}
@media only screen and (max-width: 768px) {
  .plans .plan.plan02 .subimg img, .plans .plan.plan04 .subimg img {
    width: 100%;
    margin-right: 0;
  }
}
.plans .plan.plan01 .bg {
  background-image: url(../img/bg_repeat1_pc.png);
}
@media only screen and (max-width: 768px) {
  .plans .plan.plan01 .bg {
    background-image: url(../img/bg_repeat1_sp.png);
  }
}
.plans .plan.plan02 {
  margin-top: 80px;
}
@media only screen and (max-width: 768px) {
  .plans .plan.plan02 {
    margin-top: 60%;
  }
}
.plans .plan.plan02 .bg {
  background-image: url(../img/bg_repeat2_pc.png);
}
@media only screen and (max-width: 768px) {
  .plans .plan.plan02 .bg {
    background-image: url(../img/bg_repeat2_sp.png);
  }
}
@media only screen and (max-width: 768px) {
  .plans .plan.plan02 .subimg {
    bottom: -34%;
  }
}
@media only screen and (max-width: 480px) {
  .plans .plan.plan02 .subimg {
    bottom: -30%;
  }
}
.plans .plan.plan03 {
  margin-top: 50px;
}
@media only screen and (max-width: 768px) {
  .plans .plan.plan03 {
    margin-top: 60%;
  }
}
.plans .plan.plan03 .bg {
  background-image: url(../img/bg_repeat3_pc.png);
}
@media only screen and (max-width: 768px) {
  .plans .plan.plan03 .bg {
    background-image: url(../img/bg_repeat3_sp.png);
  }
}
.plans .plan.plan03 .text .btn_area {
  overflow: hidden;
  margin-top: 23px;
}
@media only screen and (max-width: 768px) {
  .plans .plan.plan03 .text .btn_area {
    margin-top: 10px;
  }
}
.plans .plan.plan03 .text .btn_area .select_wrap {
  background-color: #ffffff;
  border: 2px #2ec583 solid;
  border-radius: 5px;
  float: left;
  font-size: 13px;
  overflow: hidden;
  position: relative;
  width: 166px;
}
@media only screen and (max-width: 768px) {
  .plans .plan.plan03 .text .btn_area .select_wrap {
    font-size: 12px;
    width: 69%;
  }
}
.plans .plan.plan03 .text .btn_area .select_wrap:before {
  color: #2ec583;
  content: "▼";
  font-size: 50%;
  position: absolute;
  right: 9px;
  top: 8px;
}
@media only screen and (max-width: 768px) {
  .plans .plan.plan03 .text .btn_area .select_wrap:before {
    top: 14px;
  }
}
.plans .plan.plan03 .text .btn_area .select_wrap select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: none;
  padding: 6px 42px 5px 10px;
  width: 137%;
}
@media only screen and (max-width: 768px) {
  .plans .plan.plan03 .text .btn_area .select_wrap select {
    padding: 12px 42px 11px 10px;
  }
}
.plans .plan.plan03 .text .btn_area p.btn {
  float: left;
  margin-top: 0;
  margin-left: 5px;
}
@media only screen and (max-width: 768px) {
  .plans .plan.plan03 .text .btn_area p.btn {
    float: right;
    width: 27.7%;
    margin-left: 0;
  }
}
@media only screen and (max-width: 768px) {
  .plans .plan.plan03 .text .btn_area p.btn a {
    font-size: 85.7%;
  }
}
@media only screen and (max-width: 768px) {
  .plans .plan.plan03 .text .btn_area p.btn a:after {
    display: none;
  }
}
.plans .plan.plan04 {
  margin-top: 55px;
}
@media only screen and (max-width: 768px) {
  .plans .plan.plan04 {
    margin-top: 65%;
  }
}
.plans .plan.plan04 .bg {
  background-image: url(../img/bg_repeat4_pc.png);
}
@media only screen and (max-width: 768px) {
  .plans .plan.plan04 .bg {
    background-image: url(../img/bg_repeat4_sp.png);
  }
}
@media only screen and (max-width: 768px) {
	.plans .plan.plan05 {
		margin-top: 60%;
	}
}
.plans .plan.plan05 .bg {
	background-image: url(../img/bg_repeat5_pc.png);
}
@media only screen and (max-width: 768px) {
	.plans .plan.plan05 .bg {
		background-image: url(../img/bg_repeat5_sp.png);
	}
}
.plans p.more {
  clear: both;
  text-align: center;
  width: 376px;
  margin: 65px auto 0;
}
@media only screen and (max-width: 768px) {
  .plans p.more {
    display: none;
  }
}
.plans p.more a {
  background-color: #000000;
  border-radius: 10px;
  color: #ffffff;
  display: block;
  font-size: 142.9%;
  position: relative;
  padding: 30px 0 32px;
}
.plans p.more a:after {
  background: url(../img/btn_arrow.png) no-repeat right top;
  background-size: 9px 17px;
  content: '';
  display: inline-block;
  height: 17px;
  position: absolute;
  right: 15px;
  top: 50%;
  width: 9px;
  margin-top: -9px;
}
.plans p.more a:hover {
  text-decoration: none;
}

/*                search_area
======================================================= */
.search_area {
  background-color: #f3f4ec;
  clear: both;
  padding-bottom: 56px;
}
@media only screen and (max-width: 768px) {
  .search_area {
    padding-bottom: 34px;
  }
}
@media only screen and (min-width: 769px) {
  .search_area .search_area_icon {
    position: relative;
    top: -99px;
    width: 258px;
    margin: 0 auto;
  }
}
.search_area .main_width {
  margin-top: -40px;
}
@media only screen and (max-width: 768px) {
  .search_area .main_width {
    padding-top: 30px;
    margin-top: 0;
  }
}
.search_area .main_width .area_search h2, .search_area .main_width .season_search h2 {
  width: 412px;
  margin: 0 auto 12px;
}
@media only screen and (max-width: 768px) {
  .search_area .main_width .area_search h2, .search_area .main_width .season_search h2 {
    width: 71.46%;
    margin: 0 auto 24px;
  }
}
.search_area .main_width .area_search {
  padding-bottom: 72px;
}
@media only screen and (max-width: 768px) {
  .search_area .main_width .area_search {
    padding-bottom: 45px;
  }
}
.search_area .main_width .area_search .area_map {
  background: url(../img/area_map_pc.jpg) no-repeat center top;
  height: 478px;
  position: relative;
  width: 1000px;
}
@media only screen and (max-width: 768px) {
  .search_area .main_width .area_search .area_map {
    background: url(../img/area_map_sp.jpg) no-repeat center top;
    background-size: 100% auto;
    height: 0;
    position: relative;
    width: 100%;
    padding-top: 123.47%;
  }
}
.search_area .main_width .area_search .area_map .area {
  position: absolute;
}
.search_area .main_width .area_search .area_map .area .inner {
  position: relative;
}
@media only screen and (max-width: 768px) {
  .search_area .main_width .area_search .area_map .area .inner {
    height: 100%;
  }
}
.search_area .main_width .area_search .area_map .area .inner a {
  display: block;
  height: 100%;
}
@media only screen and (min-width: 769px) {
  .search_area .main_width .area_search .area_map .area .inner a {
    position: absolute;
  }
}
@media only screen and (max-width: 768px) {
  .search_area .main_width .area_search .area_map .area .inner a img {
    display: none;
  }
}
.search_area .main_width .area_search .area_map .area .inner a:hover img {
  opacity: 0.8;
}
.search_area .main_width .area_search .area_map .area .inner span {
  position: absolute;
  display: none;
}
@media only screen and (max-width: 768px) {
  .search_area .main_width .area_search .area_map .area .inner span {
    display: none !important;
  }
}
.search_area .main_width .area_search .area_map .area.area01 {
  height: 330px;
  left: 0;
  top: 0;
  width: 523px;
}
@media only screen and (max-width: 768px) {
  .search_area .main_width .area_search .area_map .area.area01 {
    height: 48%;
    left: -4%;
    top: -24px;
    width: 46%;
  }
}
@media only screen and (min-width: 769px) {
  .search_area .main_width .area_search .area_map .area.area01 .inner a {
    height: 244px;
    left: 0;
    top: 0;
    width: 242px;
  }
}
.search_area .main_width .area_search .area_map .area.area01 .inner span {
  left: 304px;
  top: 106px;
}
.search_area .main_width .area_search .area_map .area.area02 {
  height: 313px;
  right: 0;
  top: 0;
  width: 613px;
}
@media only screen and (max-width: 768px) {
  .search_area .main_width .area_search .area_map .area.area02 {
    height: 48%;
    right: -4%;
    top: -24px;
    width: 46%;
  }
}
@media only screen and (min-width: 769px) {
  .search_area .main_width .area_search .area_map .area.area02 .inner a {
    height: 244px;
    right: 0;
    top: 0;
    width: 242px;
  }
}
.search_area .main_width .area_search .area_map .area.area02 .inner span {
  right: 288px;
  top: 35px;
}
.search_area .main_width .area_search .area_map .area.area03 {
  height: 234px;
  bottom: 0;
  left: 0;
  width: 525px;
}
@media only screen and (max-width: 768px) {
  .search_area .main_width .area_search .area_map .area.area03 {
    height: 48%;
    bottom: -24px;
    left: -4%;
    width: 46%;
  }
}
@media only screen and (min-width: 769px) {
  .search_area .main_width .area_search .area_map .area.area03 .inner a {
    height: 234px;
    left: 0;
    top: 0px;
    width: 242px;
  }
}
.search_area .main_width .area_search .area_map .area.area03 .inner span {
  left: 336px;
  top: 42px;
}
.search_area .main_width .area_search .area_map .area.area04 {
  height: 234px;
  bottom: 0;
  right: 0;
  width: 528px;
}
@media only screen and (max-width: 768px) {
  .search_area .main_width .area_search .area_map .area.area04 {
    height: 48%;
    bottom: -24px;
    right: -4%;
    width: 46%;
  }
}
@media only screen and (min-width: 769px) {
  .search_area .main_width .area_search .area_map .area.area04 .inner a {
    height: 234px;
    right: 0;
    top: 0;
    width: 242px;
  }
}
.search_area .main_width .area_search .area_map .area.area04 .inner span {
  right: 310px;
  top: -32px;
}
.search_area .main_width .season_search h2 {
  margin-bottom: 44px;
}
@media only screen and (max-width: 768px) {
  .search_area .main_width .season_search h2 {
    margin-bottom: 24px;
  }
}
.search_area .main_width .season_search .season_plan_area ul.tab {
  overflow: hidden;
  margin: 0 -2px 20px;
}
@media only screen and (max-width: 768px) {
  .search_area .main_width .season_search .season_plan_area ul.tab {
    margin: 0 -2px 15px;
  }
}
.search_area .main_width .season_search .season_plan_area ul.tab li {
  box-sizing: border-box;
  cursor: pointer;
  float: left;
  font-size: 171.4%;
  text-align: center;
  width: 25%;
  padding: 0 2px;
}
@media only screen and (max-width: 768px) {
  .search_area .main_width .season_search .season_plan_area ul.tab li {
    font-size: 100%;
  }
}
.search_area .main_width .season_search .season_plan_area ul.tab li .inner {
  background-color: #ffffff;
  display: block;
  padding: 12px 0 18px;
}
@media only screen and (max-width: 768px) {
  .search_area .main_width .season_search .season_plan_area ul.tab li .inner {
    padding: 19px 0 21px;
  }
}
.search_area .main_width .season_search .season_plan_area ul.tab li .inner .text {
  display: block;
  line-height: 1;
  width: 62px;
  margin: 1px auto 0;
}
@media only screen and (max-width: 768px) {
  .search_area .main_width .season_search .season_plan_area ul.tab li .inner .text {
    width: 36px;
  }
}
.search_area .main_width .season_search .season_plan_area ul.tab li .inner .text .on {
  display: none;
}
.search_area .main_width .season_search .season_plan_area ul.tab li .inner .text .off {
  display: block;
}
.search_area .main_width .season_search .season_plan_area ul.tab li.spring {
  color: #f68080;
}
.search_area .main_width .season_search .season_plan_area ul.tab li.spring .inner {
  border: 3px #f68080 solid;
}
@media only screen and (max-width: 768px) {
  .search_area .main_width .season_search .season_plan_area ul.tab li.spring .inner {
    border: 2px #f68080 solid;
  }
}
.search_area .main_width .season_search .season_plan_area ul.tab li.summer {
  color: #3f7ccb;
}
.search_area .main_width .season_search .season_plan_area ul.tab li.summer .inner {
  border: 3px #3f7ccb solid;
}
@media only screen and (max-width: 768px) {
  .search_area .main_width .season_search .season_plan_area ul.tab li.summer .inner {
    border: 2px #3f7ccb solid;
  }
}
.search_area .main_width .season_search .season_plan_area ul.tab li.autumn {
  color: #ed9523;
}
.search_area .main_width .season_search .season_plan_area ul.tab li.autumn .inner {
  border: 3px #ed9523 solid;
}
@media only screen and (max-width: 768px) {
  .search_area .main_width .season_search .season_plan_area ul.tab li.autumn .inner {
    border: 2px #ed9523 solid;
  }
}
.search_area .main_width .season_search .season_plan_area ul.tab li.winter {
  color: #af6ddd;
}
.search_area .main_width .season_search .season_plan_area ul.tab li.winter .inner {
  border: 3px #af6ddd solid;
}
@media only screen and (max-width: 768px) {
  .search_area .main_width .season_search .season_plan_area ul.tab li.winter .inner {
    border: 2px #af6ddd solid;
  }
}
.search_area .main_width .season_search .season_plan_area ul.tab li.select {
  color: #ffffff !important;
}
.search_area .main_width .season_search .season_plan_area ul.tab li.select .inner .text .on {
  display: block;
}
.search_area .main_width .season_search .season_plan_area ul.tab li.select .inner .text .off {
  display: none;
}
.search_area .main_width .season_search .season_plan_area ul.tab li.select.spring .inner {
  background-color: #f68080;
}
.search_area .main_width .season_search .season_plan_area ul.tab li.select.summer .inner {
  background-color: #3f7ccb;
}
.search_area .main_width .season_search .season_plan_area ul.tab li.select.autumn .inner {
  background-color: #ed9523;
}
.search_area .main_width .season_search .season_plan_area ul.tab li.select.winter .inner {
  background-color: #af6ddd;
}
.search_area .main_width .season_search .season_plan_area .tab_content {
  overflow: hidden;
  margin: 0 -7px -14px;
}
@media only screen and (max-width: 768px) {
  .search_area .main_width .season_search .season_plan_area .tab_content {
    margin: 0 -7px -10px;
  }
}
.search_area .main_width .season_search .season_plan_area .tab_content .plan_set {
  box-sizing: border-box;
  float: left;
  width: 33.33333%;
  padding: 0 7px;
  margin-bottom: 14px;
}
@media only screen and (max-width: 768px) {
  .search_area .main_width .season_search .season_plan_area .tab_content .plan_set {
    float: none;
    width: 100%;
    margin-bottom: 10px;
  }
}
.search_area .main_width .season_search .season_plan_area .tab_content .plan_set a {
  background-color: #ffffff;
  display: block;
}
.search_area .main_width .season_search .season_plan_area .tab_content .plan_set a:hover {
  text-decoration: none;
}
.search_area .main_width .season_search .season_plan_area .tab_content .plan_set a .photo {
  display: block;
  width: 100%;
}
.search_area .main_width .season_search .season_plan_area .tab_content .plan_set a .text {
  display: block;
  padding: 15px 25px 18px;
}
@media only screen and (max-width: 768px) {
  .search_area .main_width .season_search .season_plan_area .tab_content .plan_set a .text {
    padding: 15px 15px 13px;
  }
}
.search_area .main_width .season_search .season_plan_area .tab_content .plan_set a .text .name {
  display: block;
  font-size: 114.3%;
  line-height: 1.625;
  padding-bottom: 9px;
}
@media only screen and (max-width: 768px) {
  .search_area .main_width .season_search .season_plan_area .tab_content .plan_set a .text .name {
    font-size: 107.1%;
    line-height: 1.46;
  }
}
.search_area .main_width .season_search .season_plan_area .tab_content .plan_set a .text .price {
  border-top: 1px #ecf2f4 solid;
  display: block;
  padding-top: 9px;
}
@media only screen and (max-width: 768px) {
  .search_area .main_width .season_search .season_plan_area .tab_content .plan_set a .text .price {
    padding-top: 7px;
  }
}
.search_area .main_width .season_search .season_plan_area .tab_content .plan_set a .text .price .font_L {
  font-size: 171.4%;
}
@media only screen and (max-width: 768px) {
  .search_area .main_width .season_search .season_plan_area .tab_content .plan_set a .text .price .font_L {
    font-size: 178.6%;
  }
}
.search_area .main_width .season_search .season_plan_area .tab_content.spring .price .font_L {
  color: #f68080;
}
.search_area .main_width .season_search .season_plan_area .tab_content.summer {
  display: none;
}
.search_area .main_width .season_search .season_plan_area .tab_content.summer .price .font_L {
  color: #3f7ccb;
}
.search_area .main_width .season_search .season_plan_area .tab_content.autumn {
  display: none;
}
.search_area .main_width .season_search .season_plan_area .tab_content.autumn .price .font_L {
  color: #ed9523;
}
.search_area .main_width .season_search .season_plan_area .tab_content.winter {
  display: none;
}
.search_area .main_width .season_search .season_plan_area .tab_content.winter .price .font_L {
  color: #af6ddd;
}
.search_area .main_width .season_search p.more {
  text-align: center;
  width: 268px;
  margin: 40px auto 0;
}
@media only screen and (max-width: 768px) {
  .search_area .main_width .season_search p.more {
    max-width: 530px;
    width: 76.8%;
    margin: 30px auto 0;
  }
}
.search_area .main_width .season_search p.more a {
  background-color: #000000;
  border-radius: 8px;
  color: #ffffff;
  display: block;
  font-size: 114.3%;
  position: relative;
  padding: 21px 0;
}
@media only screen and (max-width: 768px) {
  .search_area .main_width .season_search p.more a {
    border-radius: 5px;
    font-size: 107.1%;
    padding: 16px 0 14px;
  }
}
.search_area .main_width .season_search p.more a:after {
  background: url(../img/btn_arrow.png) no-repeat right top;
  background-size: 7px 12px;
  content: '';
  display: inline-block;
  height: 12px;
  position: absolute;
  right: 20px;
  top: 50%;
  width: 7px;
  margin-top: -6px;
}
@media only screen and (max-width: 768px) {
  .search_area .main_width .season_search p.more a:after {
    background-size: 8px 15px;
    height: 15px;
    right: 15px;
    width: 8px;
    margin-top: -7px;
  }
}
.search_area .main_width .season_search p.more a:hover {
  text-decoration: none;
}

/*                cont_btm_bnr
======================================================= */
.cont_btm_bnr {
  padding-top: 25px;
  padding-bottom: 60px;
}
@media only screen and (max-width: 768px) {
  .cont_btm_bnr {
    padding-top: 6px;
    padding-bottom: 30px;
    margin-top: -5%;
  }
}
.cont_btm_bnr a {
  display: block;
}

/*                footer
======================================================= */
#footer {
  background-color: #f7412d;
  position: relative;
  text-align: center;
  z-index: 10;
  padding: 6px 0 5px;
  margin-top: 62px;
}
#footer p#copyright {
  color: #ffffff;
}


.spots { margin-bottom: 60px; }
.spots h2 { text-align: center; margin-bottom: 40px; }
.spots h2 img { max-width: 640px;}
.spots ul { font-size: 0; text-align: left; max-width: 1200px; margin: 0 auto;}
.spots ul li { width: 33.3%; display: inline-block; margin: 0 0.05% 0.05% 0; position: relative; text-align: center; color: #fff;font-family: 'Montserrat', sans-serif; overflow: hidden; background: #000;  }
.spots ul li:nth-of-type(3n) { margin-right: 0;}
.spots ul li img { -webkit-transition: all 0.5s; transition: all 0.5s; }
.spots ul li span { letter-spacing: 0.16em;  display: block; font-size: 28px; font-weight: bold; position:absolute; top:50%; left: 50%; -webkit-transform: translate(-50%,-50%); -ms-transform: translate(-50%,-50%); transform: translate(-50%,-50%);text-transform: uppercase; opacity: 0; -webkit-transition: all 0.5s; transition: all 0.5s; }
.spots ul li:hover img {transform: scale(1.1,1.1); -webkit-filter: blur(5px); filter: blur(5px); opacity: 0.7; }
.spots ul li:hover span { opacity: 1; }
.spots ul li a { color: #fff; }
.share { width: 580px; margin: 0 auto; margin-bottom: 50px; }
.share p.btn { margin-bottom: 25px;}
.share p.btn a {
	margin: 0px auto;
	background-color: #000000;
	border-radius: 6px;
	color: #ffffff;
	display: block;
	font-size: 20px;
	position: relative;
	padding: 25px 12px;
	text-align: center; 
	line-height: 1.2;
	font-family: 'Montserrat', sans-serif;
}
.share p.btn a:hover { text-decoration: none; }
.share p.btn a:after {
	background: url(../img/btn_arrow.png) no-repeat right top;
	background-size: 7px 12px;
	content: '';
	display: inline-block;
	height: 12px;
	position: absolute;
	right: 22px;
	top: 50%;
	width: 7px;
	margin-top: -6px;
}
.share p.btn a small { font-size: 14px; line-height: 1; }
.share ul { font-size: 0; }
.share ul li { width: 48.2%; display: inline-block; margin: 0 3.6% 0 0; font-size: 18px; text-align: center; text-transform: uppercase;font-family: 'Montserrat', sans-serif;}
.share ul li:nth-of-type(2n) { margin-right: 0;}
.share ul li a { display: block; border-radius: 6px; border: 2px solid #ccc; text-decoration: none;  padding: 20px; text-indent: 30px;}
.share .fb a { color: #3b5a9a; border-color: #3b5a9a; background: url(../img/share_icn_fb.png) 20px 50% no-repeat; background-size: 32px 32px; }
.share .tw a { color: #55acee; border-color: #55acee; background: url(../img/share_icn_tw.png) 20px 50% no-repeat; background-size: 31px 24px; }
.about { background: url(../img/link_bg_pc.jpg) 50% 0 no-repeat; background-size: cover; padding: 65px 20px 50px 20px; color: #fff; text-align: center;font-family: 'Montserrat', sans-serif; }
.about p.lead { font-size: 28px; line-height: 1.6; margin-bottom: 35px; }
.about p.btn { width: 340px; margin: 0 auto; text-align: center;  }
.about p.btn a { border-radius: 6px; color: #fff;display: block;font-size: 18px; position: relative; padding: 20px 12px; text-decoration: none; border: 1px solid #fff; }
.about p.btn a:after {
	background: url(../img/btn_arrow.png) no-repeat right top;
	background-size: 7px 12px;
	content: '';
	display: inline-block;
	height: 12px;
	position: absolute;
	right: 12px;
	top: 50%;
	width: 7px;
	margin-top: -6px;
}

@media only screen and (max-width: 768px) {
	.spots { margin-top: 120px; margin-bottom: 45px;}
	.spots h2 { margin-bottom: 25px; padding: 0 25px; }
	.spots h2 img { }
	.spots ul { }
	.spots ul li { width: 49.8%; display: inline-block; margin: 0 0.4% 0.4% 0; background: #fff;  }
	.spots ul li:nth-of-type(3n) { margin-right: 0.4%;}
	.spots ul li:nth-of-type(2n) { margin-right: 0;}
	.spots ul li img {  }
	.spots ul li span { font-size: 20px; opacity: 1;  }
	.spots ul li:hover img { }
	.spots ul li:hover span {  }
	.share { width: 100%; margin: 0 auto; margin-bottom: 45px; }
	.share p.btn { margin:0 auto 20px auto; max-width: 275px;}
	.share p.btn a { font-size: 15px; padding: 16px 12px; }
	.share p.btn a:hover { text-decoration: none; }
	.share p.btn a:after { }
	.share p.btn a small { font-size: 10px; line-height: 1; }
	.share ul { max-width: 275px; margin: 0 auto;}
	.share ul li { width: 100%; display: block; margin: 0 0 8px 0; font-size: 14px; }
	.share ul li a { padding: 10px; text-indent: 15px;}
	.share .fb a { background-size: 22px 22px; }
	.share .tw a { background-size: 23px 18px; }
	.about { background: url(../img/link_bg_sp.jpg) 50% 0 no-repeat; background-size: cover; padding: 60px 10px;  }
	.about p.lead { font-size: 14px; line-height: 1.6; margin-bottom: 18px; }
	.about p.btn { max-width: 275px;   }
	.about p.btn a { font-size: 13px;  padding: 10px 12px;}
	.about p.btn a:after { }
}
