@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: 660px;
  z-index: 15;
  margin: 0 auto;
}
@media only screen and (max-width: 1220px) {
  .main_title_area {
    top: -160px;
    width: 51.56%;
  }
}
@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: -75px;
    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: -45px;
  }
}
.main_title_area h1 {
  margin-bottom: 59px;
}
@media only screen and (max-width: 768px) {
  .main_title_area h1 {
    margin-bottom: 35px;
  }
}
.main_title_area p {
  width: 594px;
  margin: 0 auto;
}
@media only screen and (max-width: 1220px) {
  .main_title_area p {
    width: 90%;
  }
}
@media only screen and (max-width: 768px) {
  .main_title_area p {
    width: 74.9%;
  }
}

/*                map_area
======================================================= */
.map_area {
  width: 996px;
  margin-top: -177px;
}
@media only screen and (max-width: 1220px) {
  .map_area {
    margin-top: -160px;
  }
}
@media only screen and (max-width: 1024px) {
  .map_area {
    margin-top: -140px;
  }
}
@media only screen and (max-width: 850px) {
  .map_area {
    margin-top: -120px;
  }
}
@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: 173px;
}
@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;
}
@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 32px;
}
@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;
}
@media only screen and (max-width: 768px) {
  .plans .plan .icon_title p.title {
    width: 61.6%;
  }
}
.plans .plan .icon_title p.icon {
  bottom: 0;
  position: absolute;
  width: 135px;
}
@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;
}
@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: 150px;
  margin-top: 23px;
}
@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 5px 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.gif) 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 {
  background-position: right top;
}
.plans .plan.plan01 .icon_title p.icon, .plans .plan.plan03 .icon_title p.icon {
  right: 0;
}
.plans .plan.plan01 .text, .plans .plan.plan03 .text {
  margin-left: 50%;
}
@media only screen and (max-width: 768px) {
  .plans .plan.plan01 .text, .plans .plan.plan03 .text {
    margin-left: 0;
  }
}
.plans .plan.plan01 .subimg, .plans .plan.plan03 .subimg {
  margin-left: 50%;
}
@media only screen and (max-width: 768px) {
  .plans .plan.plan01 .subimg, .plans .plan.plan03 .subimg {
    float: left;
    margin-left: 0;
  }
}
.plans .plan.plan01 .subimg img, .plans .plan.plan03 .subimg img {
  width: 630px;
  margin-left: -130px;
}
@media only screen and (max-width: 768px) {
  .plans .plan.plan01 .subimg img, .plans .plan.plan03 .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;
}
.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%;
  }
}
/*                plan02_area add
======================================================= */
.plans .plan.plan02 .text .btn_area {
  overflow: hidden;
  margin-top: 23px;
}
@media only screen and (max-width: 768px) {
  .plans .plan.plan02 .text .btn_area {
    margin-top: 10px;
  }
}
.plans .plan.plan02 .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.plan02 .text .btn_area .select_wrap {
    font-size: 12px;
    width: 69%;
  }
}
.plans .plan.plan02 .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.plan02 .text .btn_area .select_wrap:before {
    top: 14px;
  }
}
.plans .plan.plan02 .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.plan02 .text .btn_area .select_wrap select {
    padding: 12px 42px 11px 10px;
  }
}
.plans .plan.plan02 .text .btn_area p.btn {
  float: left;
  margin-top: 0;
  margin-left: 5px;
}
@media only screen and (max-width: 768px) {
  .plans .plan.plan02 .text .btn_area p.btn {
    float: right;
    width: 27.7%;
    margin-left: 0;
  }
}
@media only screen and (max-width: 768px) {
  .plans .plan.plan02 .text .btn_area p.btn a {
    font-size: 85.7%;
  }
}
@media only screen and (max-width: 768px) {
  .plans .plan.plan02 .text .btn_area p.btn a:after {
    display: none;
  }
}
/*                plan03_area
======================================================= */
.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: 55%;
  }
}
.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);
  }
}
.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.gif) 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;
}
/*                button_area_add start 2018.02.21
======================================================= */
.button_area p.more {
  clear: both;
  text-align: center;
  width: 376px;
  margin: 65px auto 0;
}
@media only screen and (max-width: 768px) {
  .button_area p.more {
    display: none;
  }
}
.button_area p.more a {
  background-color: #000000;
  border-radius: 10px;
  color: #ffffff;
  display: block;
  font-size: 142.9%;
  position: relative;
  padding: 30px 0 32px;
}
.button_area p.more a:after {
  background: url(../img/btn_arrow.gif) no-repeat right top;
  background-size: 9px 17px;
  content: '';
  display: inline-block;
  height: 14px;
  position: absolute;
  right: 15px;
  top: 50%;
  width: 9px;
  margin-top: -9px;
}
.button_area p.more a:hover {
  text-decoration: none;
}
/*                button_area_add end 2018.02.21
======================================================= */

/*                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.gif) 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;
}
