@charset "UTF-8";
/* ウェブフォント（ペン字：花鳥風月PB http://www.geocities.jp/s318shunkasyuto/ (c)TAKAYA）
---------------------------------------------------------*/
@font-face {
  font-family: "katyoufuugetupb";
  src: url("../fonts/katyoufuugetupb.eot?") format("eot"), url("../fonts/katyoufuugetupb.woff") format("woff");
}
/* 撮影スポット専用
-----------------------------------------
※上書きでスタイリング系の元は
　_module.scss が多いです。
-----------------------------------------*/
.page-tit .page-tit01 img {
  -webkit-transition: all 0.1s ease-in-out 0s;
  -o-transition: all 0.1s ease-in-out 0s;
  transition: all 0.1s ease-in-out 0s;
}
@media screen and (min-width: 768px) {
  .page-tit .page-tit01 img {
    /* タブレット：デバイス別表示設定
    --------------------------------------------*/
    width: auto;
    height: 49px;
  }
}
@media screen and (min-width: 1000px) {
  .page-tit .page-tit01 img {
    /* PC：デバイス別表示設定
    --------------------------------------------*/
    width: auto;
    height: 50px;
  }
}

main {
  margin-bottom: 100px;
}
@media screen and (min-width: 768px) {
  main {
    /* タブレット：デバイス別表示設定
    --------------------------------------------*/
    margin-bottom: 200px;
  }
}

.map header p {
  text-align: center;
  font-family: source-han-sans-japanese, sans-serif;
  font-style: normal;
  font-weight: 500;
  font-size: 14px;
  text-shadow: 0 2px 1px #FFF, 0 1px 1px #FFF, 1px 1px 1px #FFF, 1px 0 1px #FFF, 2px 0 1px #FFF, 1px -1px 1px #FFF, 1px -2px 1px #FFF, 0 -2px 1px #FFF, -1px -2px 1px #FFF, -2px -2px 1px #FFF, -2px -1px 1px #FFF, -2px 0 1px #FFF, -2px 1px 1px #FFF, -1px 1px 1px #FFF;
}
.map header .area-list li {
  font-size: 13px;
  padding: 0 0 3px;
}
.map header .area-list li a {
  text-decoration: none;
  color: #FFF;
  font-family: source-han-sans-japanese, sans-serif;
  font-style: normal;
  font-weight: 700;
  font-size: 13px;
  text-shadow: 0 2px 1px #000, 0 1px 1px #000, 1px 1px 1px #000, 1px 0 1px #000, 2px 0 1px #000, 1px -1px 1px #000, 1px -2px 1px #000, 0 -2px 1px #000, -1px -2px 1px #000, -2px -2px 1px #000, -2px -1px 1px #000, -2px 0 1px #000, -2px 1px 1px #000, -1px 1px 1px #000;
}
.map header .area-list li a:before {
  content: "\f0c8";
  font-family: FontAwesome;
  display: inline-block;
  font-size: 13px;
  line-height: 1;
  display: inline-block;
  margin-right: 5px;
}
.map header .area-list li a[href="#area01"] {
  text-shadow: 0 2px 1px #e168af, 0 1px 1px #e168af, 1px 1px 1px #e168af, 1px 0 1px #e168af, 2px 0 1px #e168af, 1px -1px 1px #e168af, 1px -2px 1px #e168af, 0 -2px 1px #e168af, -1px -2px 1px #e168af, -2px -2px 1px #e168af, -2px -1px 1px #e168af, -2px 0 1px #e168af, -2px 1px 1px #e168af, -1px 1px 1px #e168af;
}
.map header .area-list li a[href="#area01"]:hover {
  color: #e168af;
}
.map header .area-list li a[href="#area02"] {
  text-shadow: 0 2px 1px #3c6433, 0 1px 1px #3c6433, 1px 1px 1px #3c6433, 1px 0 1px #3c6433, 2px 0 1px #3c6433, 1px -1px 1px #3c6433, 1px -2px 1px #3c6433, 0 -2px 1px #3c6433, -1px -2px 1px #3c6433, -2px -2px 1px #3c6433, -2px -1px 1px #3c6433, -2px 0 1px #3c6433, -2px 1px 1px #3c6433, -1px 1px 1px #3c6433;
}
.map header .area-list li a[href="#area02"]:hover {
  color: #3c6433;
}
.map header .area-list li a[href="#area03"] {
  text-shadow: 0 2px 1px #0e608f, 0 1px 1px #0e608f, 1px 1px 1px #0e608f, 1px 0 1px #0e608f, 2px 0 1px #0e608f, 1px -1px 1px #0e608f, 1px -2px 1px #0e608f, 0 -2px 1px #0e608f, -1px -2px 1px #0e608f, -2px -2px 1px #0e608f, -2px -1px 1px #0e608f, -2px 0 1px #0e608f, -2px 1px 1px #0e608f, -1px 1px 1px #0e608f;
}
.map header .area-list li a[href="#area03"]:hover {
  color: #0e608f;
}
.map header .area-list li a[href="#area04"] {
  text-shadow: 0 2px 1px #a6790e, 0 1px 1px #a6790e, 1px 1px 1px #a6790e, 1px 0 1px #a6790e, 2px 0 1px #a6790e, 1px -1px 1px #a6790e, 1px -2px 1px #a6790e, 0 -2px 1px #a6790e, -1px -2px 1px #a6790e, -2px -2px 1px #a6790e, -2px -1px 1px #a6790e, -2px 0 1px #a6790e, -2px 1px 1px #a6790e, -1px 1px 1px #a6790e;
}
.map header .area-list li a[href="#area04"]:hover {
  color: #a6790e;
}
.map header .area-list li a[href="#area05"] {
  text-shadow: 0 2px 1px #514cc3, 0 1px 1px #514cc3, 1px 1px 1px #514cc3, 1px 0 1px #514cc3, 2px 0 1px #514cc3, 1px -1px 1px #514cc3, 1px -2px 1px #514cc3, 0 -2px 1px #514cc3, -1px -2px 1px #514cc3, -2px -2px 1px #514cc3, -2px -1px 1px #514cc3, -2px 0 1px #514cc3, -2px 1px 1px #514cc3, -1px 1px 1px #514cc3;
}
.map header .area-list li a[href="#area05"]:hover {
  color: #514cc3;
}
.map header .area-list li a:hover {
  text-shadow: 0 2px 1px #FFF, 0 1px 1px #FFF, 1px 1px 1px #FFF, 1px 0 1px #FFF, 2px 0 1px #FFF, 1px -1px 1px #FFF, 1px -2px 1px #FFF, 0 -2px 1px #FFF, -1px -2px 1px #FFF, -2px -2px 1px #FFF, -2px -1px 1px #FFF, -2px 0 1px #FFF, -2px 1px 1px #FFF, -1px 1px 1px #FFF;
}
.map .map-spot {
  background: url(../../spot/img/map-base.jpg) no-repeat center bottom;
  position: relative;
  margin: 0;
  padding: 0;
}
@media screen and (max-width: 767px) {
  .map {
    /* 例外サイズ
    --------------------------------------------*/
  }
  .map header {
    background: #dff7f9;
    padding: 30px 10px;
  }
  .map header h1 {
    margin: 0 auto 20px;
    max-width: 604px;
  }
  .map header p {
    margin: 0 0 20px 0;
  }
  .map header .area-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
  .map header .area-list li {
    white-space: nowrap;
  }
  .map header .area-list li:nth-of-type(2n) {
    width: 10.5em;
  }
  .map .map-spot {
    padding-bottom: 191%;
    background-size: 140%;
    height: 0;
  }
  .map .map-spot li {
    height: 0;
    padding: 0;
    margin: 0;
  }
  .map .map-spot a, .map .map-spot img[src*=map00] {
    position: absolute;
    display: block;
    -webkit-transition: all 0.35s ease-in-out 0s;
    -o-transition: all 0.35s ease-in-out 0s;
    transition: all 0.35s ease-in-out 0s;
  }
  .map .map-spot a {
    z-index: 1;
  }
  .map .map-spot a:before {
    content: "";
    display: block;
    position: absolute;
    z-index: -1;
    background-repeat: no-repeat;
    background-position: center top;
    background-size: contain;
    pointer-events: none;
  }
  .map .map-spot a[href="#area01a"] {
    top: 15%;
    left: 65%;
    width: 25.94%;
  }
  .map .map-spot a[href="#area01a"]:before {
    width: 71.69%;
    height: 75%;
    top: 49%;
    left: -50%;
    background-image: url(../../spot/img/map01a-sp-bar.png);
  }
  .map .map-spot a[href="#area01b"] {
    top: 34%;
    left: 74%;
    width: 24.38%;
  }
  .map .map-spot a[href="#area02a"] {
    top: 73.44%;
    left: 75%;
    width: 23.44%;
  }
  .map .map-spot a[href="#area02a"]:before {
    width: 17.33%;
    height: 150%;
    top: -120%;
    left: 15%;
    background-image: url(../../spot/img/map02a-sp-bar.png);
  }
  .map .map-spot a[href="#area02b"] {
    top: 68%;
    left: 28%;
    width: 22.5%;
  }
  .map .map-spot a[href="#area02c"] {
    top: 58%;
    left: 72%;
    width: 24.84%;
  }
  .map .map-spot a[href="#area03a"] {
    top: 10%;
    left: 1%;
    width: 26.56%;
  }
  .map .map-spot a[href="#area03f"] {
    /*pointer-events: none;//リンク先がまだないので無効化*/
    top: 8%;
    left: 30%;
    width: 25.94%;
  }
  .map .map-spot a[href="#area03b"] {
    top: 16%;
    left: 30%;
    width: 26.25%;
    z-index: 10;
  }
  .map .map-spot a[href="#area03c"] {
    top: 34.6%;
    left: 1%;
    width: 31.04%;
  }
  .map .map-spot a[href="#area03c"]:before {
    width: 7.67%;
    height: 110%;
    top: -105%;
    left: 35%;
    background-image: url(../../spot/img/map03c-sp-bar.png);
  }
  .map .map-spot a[href="#area03d"] {
    top: 22%;
    left: 32%;
    width: 41.88%;
    z-index: 10;
  }
  .map .map-spot a[href="#area03d"]:before {
    width: 37.8%;
    height: 120%;
    top: -20%;
    left: -7%;
    background-image: url(../../spot/img/map03d-sp-bar.png);
  }
  .map .map-spot a[href="#area04a"] {
    top: 52%;
    left: 78%;
    width: 20%;
  }
  .map .map-spot a[href="#area04a"]:before {
    width: 97.66%;
    height: 100%;
    top: 3%;
    left: -70%;
    background-image: url(../../spot/img/map04a-sp-bar.png);
  }
  .map .map-spot a[href="#area04b"] {
    top: 46%;
    left: 44%;
    width: 34.38%;
  }
  .map .map-spot a[href="#area04c"] {
    top: 21%;
    left: 2%;
    width: 26.25%;
  }
  .map .map-spot a[href="#area04c"]:before {
    width: 9.73%;
    height: 100%;
    bottom: -100%;
    right: 15%;
    background-image: url(../../spot/img/map04c-sp-bar.png);
  }
  .map .map-spot a[href="#area05a"] {
    top: 69%;
    left: 64%;
    width: 12.66%;
  }
  .map .map-spot a[href="#area05b"] {
    top: 76%;
    left: 60%;
    width: 9.38%;
  }
  .map .map-spot a[href="#area05c"] {
    top: 1%;
    left: 70%;
    width: 20.47%;
  }
  .map .map-spot a[href="#area03e"] {
    top: 41%;
    left: 22%;
    width: 20%;
  }
  .map .map-spot a[href="#area03e"]:before {
    width: 9.86%;
    height: 180%;
    top: -140%;
    left: 65%;
    background-image: url(../../spot/img/map03e-sp-bar.png);
  }
  .map .map-spot img[src*=map00a] {
    top: 89%;
    left: 65.5%;
    width: 7.03%;
  }
  .map .map-spot img[src*=map00b] {
    width: 10.94%;
  }
  .map .map-spot img[alt="PARKING 駐車場 北"] {
    top: 25%;
    left: 66%;
  }
  .map .map-spot img[alt="PARKING 駐車場 西"] {
    top: 33%;
    left: 33%;
    display: none;
  }
  .map .map-spot img[alt="PARKING 駐車場 南"] {
    top: 56%;
    left: 46%;
  }
  .map .map-spot img[src*=map00c] {
    top: 38%;
    left: 55%;
    width: 15%;
  }
  .map .map-spot img[src*=map00d] {
    top: 65%;
    left: 55%;
    width: 9%;
  }
  .map .map-spot img[src*="-pc."] {
    display: none;
  }
}
@media screen and (min-width: 550px) {
  .map {
    /* スマホ特大：デバイス別表示設定
    --------------------------------------------*/
  }
  .map header .area-list {
    max-width: 600px;
    margin: 0 auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
  .map header .area-list li {
    white-space: nowrap;
    width: 30%;
  }
  .map header .area-list li:nth-of-type(2n) {
    width: 30%;
  }
}
@media screen and (min-width: 768px) {
  .map {
    /* タブレット：デバイス別表示設定
    --------------------------------------------*/
  }
  .map header {
    background: #dff7f9;
    padding: 30px 10px 0;
    margin: 0;
    -webkit-transition: all 0.35s ease-in-out 0s;
    -o-transition: all 0.35s ease-in-out 0s;
    transition: all 0.35s ease-in-out 0s;
    position: relative;
    z-index: 1;
  }
  .map header h1 {
    margin: 0 auto;
    max-width: 604px;
  }
  .map header p {
    margin: 0;
    width: 600px;
    position: absolute;
    left: calc(50% - 300px);
    bottom: -5em;
  }
  .map header .area-list {
    width: 600px;
    position: absolute;
    left: calc(50% - 300px);
    bottom: -9.5em;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
  .map header .area-list li {
    white-space: nowrap;
    width: 30%;
  }
  .map .map-spot {
    padding-bottom: 191%;
    background-size: 140%;
    height: 0;
  }
  .map .map-spot li {
    height: 0;
    padding: 0;
    margin: 0;
  }
  .map .map-spot a, .map .map-spot img[src*=map00] {
    position: absolute;
    display: block;
    -webkit-transition: all 0.35s ease-in-out 0s;
    -o-transition: all 0.35s ease-in-out 0s;
    transition: all 0.35s ease-in-out 0s;
  }
  .map .map-spot a:before {
    content: "";
    display: block;
    position: absolute;
    background-repeat: no-repeat;
    background-position: center top;
    background-size: contain;
    pointer-events: none;
  }
  .map .map-spot a[href="#area01a"] {
    top: 21%;
    left: 53%;
    width: 29.9%;
  }
  .map .map-spot a[href="#area01b"] {
    top: 33%;
    left: 71%;
    width: 15.6%;
  }
  .map .map-spot a[href="#area02a"] {
    top: 67.44%;
    left: 72%;
    width: 21.9%;
  }
  .map .map-spot a[href="#area02a"]:before {
    width: 11.51%;
    height: 200%;
    top: -190%;
    left: 34%;
    background-image: url(../../spot/img/map02a-sp-bar.png);
  }
  .map .map-spot a[href="#area02b"] {
    top: 68%;
    left: 35%;
    width: 14.4%;
  }
  .map .map-spot a[href="#area02c"] {
    top: 55.5%;
    left: 75%;
    width: 15.9%;
  }
  .map .map-spot a[href="#area03a"] {
    top: 15%;
    left: 3%;
    width: 17%;
  }
  .map .map-spot a[href="#area03f"] {
    /*pointer-events: none;//リンク先がまだないので無効化*/
    top: 12%;
    left: 26%;
    width: 16.6%;
  }
  .map .map-spot a[href="#area03b"] {
    top: 17%;
    left: 39%;
    width: 16.8%;
  }
  .map .map-spot a[href="#area03c"] {
    top: 35%;
    left: 1%;
    width: 25.2%;
  }
  .map .map-spot a[href="#area03c"]:before {
    width: 7.67%;
    height: 210%;
    top: -200%;
    left: 40%;
    background-image: url(../../spot/img/map03c-sp-bar.png);
  }
  .map .map-spot a[href="#area03d"] {
    top: 23.5%;
    left: 37%;
    width: 26.8%;
  }
  .map .map-spot a[href="#area03d"]:before {
    width: 37.8%;
    height: 120%;
    top: -65%;
    left: -37%;
    background-image: url(../../spot/img/map03d-sp-bar.png);
    z-index: 1;
  }
  .map .map-spot a[href="#area04a"] {
    top: 50.5%;
    left: 68%;
    width: 12.8%;
  }
  .map .map-spot a[href="#area04b"] {
    top: 49%;
    left: 50%;
    width: 22%;
  }
  .map .map-spot a[href="#area04c"] {
    top: 25%;
    left: 7%;
    width: 16.8%;
  }
  .map .map-spot a[href="#area03e"] {
    top: 38.5%;
    left: 26%;
    width: 13%;
  }
  .map .map-spot a[href="#area03e"]:before {
    width: 12%;
    height: 182%;
    top: -160%;
    left: 65%;
    background-image: url(../../spot/img/map03e-sp-bar.png);
  }
  .map .map-spot a[href="#area05a"] {
    top: 71%;
    left: 69%;
    width: 8.1%;
  }
  .map .map-spot a[href="#area05b"] {
    top: 77%;
    left: 63%;
    width: 6%;
  }
  .map .map-spot a[href="#area05c"] {
    top: 10%;
    left: 80%;
    width: 13.1%;
  }
  .map .map-spot img[src*=map00a] {
    top: 89%;
    left: 67.5%;
    width: 4.5%;
  }
  .map .map-spot img[src*=map00b] {
    width: 7%;
  }
  .map .map-spot img[alt="PARKING 駐車場 南"] {
    top: 57%;
    left: 46%;
  }
  .map .map-spot img[src*=map00c] {
    top: 37%;
    left: 47%;
    width: 8.6%;
  }
  .map .map-spot img[src*=map00d] {
    top: 65%;
    left: 55%;
    width: 9%;
  }
  .map .map-spot img[src*="-sp."] {
    display: none;
  }
}
@media screen and (min-width: 1200px) {
  .map {
    /* PC大：デバイス別表示設定
    --------------------------------------------*/
  }
  .map header {
    padding: 60px 10px 0;
    margin: 0 auto -30px;
    -webkit-transition: all 0.35s ease-in-out 0s;
    -o-transition: all 0.35s ease-in-out 0s;
    transition: all 0.35s ease-in-out 0s;
  }
  .map header p {
    bottom: -6em;
    font-size: 16px;
  }
  .map header .area-list {
    width: auto;
    display: block;
    left: calc(50% + 300px);
    bottom: -18.5em;
  }
  .map header .area-list li {
    white-space: nowrap;
    width: auto;
  }
  .map header .area-list li a {
    font-size: 16px;
  }
  .map .map-spot {
    padding-bottom: 0;
    background-size: 1380px;
    height: 1895px;
    position: relative;
  }
  .map .map-spot:before, .map .map-spot:after {
    content: "";
    display: block;
    position: absolute;
    background-image: url(../../spot/img/map-base.jpg);
    background-repeat: no-repeat;
    background-size: 3000% 100%;
    width: 50%;
    height: 100%;
    top: 0;
    z-index: -1;
  }
  .map .map-spot:before {
    background-position: left top;
    left: 0;
  }
  .map .map-spot:after {
    background-position: right top;
    right: 0;
  }
  .map .map-spot li {
    height: 0;
    padding: 0;
    margin: 0;
  }
  .map .map-spot a, .map .map-spot img[src*=map00] {
    position: absolute;
    display: block;
    -webkit-transition: all 0.35s ease-in-out 0s;
    -o-transition: all 0.35s ease-in-out 0s;
    transition: all 0.35s ease-in-out 0s;
  }
  .map .map-spot a[href="#area01a"] {
    top: 21%;
    left: calc(50% + 20px);
    width: 210px;
  }
  .map .map-spot a[href="#area01b"] {
    top: 33%;
    left: calc(50% + 216px);
    width: 109px;
  }
  .map .map-spot a[href="#area02a"] {
    top: 62%;
    left: calc(50% + 305px);
    width: 153px;
  }
  .map .map-spot a[href="#area02a"]:before {
    display: none;
  }
  .map .map-spot a[href="#area02b"] {
    left: calc(50% - 100px);
    width: 101px;
  }
  .map .map-spot a[href="#area02c"] {
    top: 57%;
    left: calc(50% + 230px);
    width: 111px;
  }
  .map .map-spot a[href="#area03a"] {
    top: 18%;
    left: calc(50% - 420px);
    width: 119px;
  }
  .map .map-spot a[href="#area03f"] {
    top: 14%;
    left: calc(50% - 250px);
    width: 116px;
  }
  .map .map-spot a[href="#area03b"] {
    top: 17.5%;
    left: calc(50% - 130px);
    width: 118px;
  }
  .map .map-spot a[href="#area03c"] {
    top: 29%;
    left: calc(50% - 500px);
    width: 176px;
  }
  .map .map-spot a[href="#area03c"]:before {
    display: none;
  }
  .map .map-spot a[href="#area03d"] {
    top: 22.8%;
    left: calc(50% - 160px);
    width: 188px;
  }
  .map .map-spot a[href="#area04a"] {
    top: 51.5%;
    left: calc(50% + 160px);
    width: 90px;
  }
  .map .map-spot a[href="#area04b"] {
    top: 47%;
    left: calc(50% + 20px);
    width: 154px;
  }
  .map .map-spot a[href="#area04c"] {
    top: 23%;
    left: calc(50% - 324px);
    width: 118px;
  }
  .map .map-spot a[href="#area03e"] {
    top: 29%;
    left: calc(50% - 200px);
    width: 96px;
  }
  .map .map-spot a[href="#area03e"]:before {
    display: none;
  }
  .map .map-spot a[href="#area05a"] {
    top: 71%;
    left: calc(50% + 220px);
    width: 57px;
  }
  .map .map-spot a[href="#area05b"] {
    top: 77%;
    left: calc(50% + 150px);
    width: 42px;
  }
  .map .map-spot a[href="#area05c"] {
    top: 10%;
    left: calc(50% - 540px);
    width: 92px;
  }
  .map .map-spot img[src*=map00a] {
    top: 89%;
    left: calc(50% + 185px);
    width: 32px;
  }
  .map .map-spot img[src*=map00b] {
    width: 55px;
  }
  .map .map-spot img[alt="PARKING 駐車場 南"] {
    top: 58%;
    left: calc(50% + 0px);
  }
  .map .map-spot img[src*=map00c] {
    top: 41.5%;
    left: calc(50% + 5px);
    width: 80px;
  }
  .map .map-spot img[src*=map00d] {
    top: 65%;
    left: calc(50% + 5px);
    width: 74px;
  }
}

/* コンテンツ
--------------------------------- */
.area {
  margin: 0 auto 50px;
}
@media screen and (min-width: 1000px) {
  .area {
    /* PC：デバイス別表示設定
    --------------------------------------------*/
    max-width: 1200px;
    margin: 0 auto 70px;
  }
}
.area > header {
  margin: 0 0 10px;
  position: relative;
}
@media screen and (min-width: 1000px) {
  .area > header {
    /* PC：デバイス別表示設定
    --------------------------------------------*/
    margin: 0 0 50px;
  }
  .area > header:before {
    content: "";
    display: block;
    position: absolute;
    width: 100%;
    height: 0;
    left: 0;
    top: 50%;
    border-top: 1px dashed #000;
  }
}
.area > header h1 {
  text-align: center;
  background: #FFF;
  padding: 10px 0;
  position: relative;
}
@media screen and (min-width: 1000px) {
  .area > header h1 {
    /* PC：デバイス別表示設定
    --------------------------------------------*/
    padding: 25px 0;
    width: 630px;
    margin: 0 auto;
  }
}
.area > header h1:before, .area > header h1:after {
  content: "";
  display: block;
  position: absolute;
  width: 100%;
  height: 3px;
  left: 0;
  background-image: url(../img/back07.png);
  background-color: #e168af;
}
.area > header h1:before {
  top: 0;
}
.area > header h1:after {
  bottom: 0;
}
.area > header h1 img {
  width: auto;
  height: 30px;
}
@media screen and (min-width: 1000px) {
  .area > header h1 img {
    /* PC：デバイス別表示設定
    --------------------------------------------*/
    height: 49px;
  }
}
.area article {
  padding: 10px;
}
@media screen and (min-width: 1000px) {
  .area article {
    /* PC：デバイス別表示設定
    --------------------------------------------*/
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
}
.area article header {
  border-bottom: 1px dotted #000;
  padding: 0 0 3px;
  margin: 0 0 10px;
}
@media screen and (min-width: 1000px) {
  .area article header {
    /* PC：デバイス別表示設定
    --------------------------------------------*/
    margin: 0 0 20px;
    width: 100%;
  }
}
.area article header h2 {
  display: inline;
  font-family: source-han-sans-japanese, sans-serif;
  font-style: normal;
  font-weight: 500;
  font-size: 18px;
  color: #e168af;
}
@media screen and (min-width: 1000px) {
  .area article header h2 {
    /* PC：デバイス別表示設定
    --------------------------------------------*/
    font-size: 20px;
  }
}
.area article .col-lead {
  margin: 0 0 20px;
}
@media screen and (min-width: 1000px) {
  .area article .col-lead {
    /* PC：デバイス別表示設定
    --------------------------------------------*/
    width: calc(45% - 40px);
  }
}
.area article .col-lead img {
  border: 6px solid #FFF;
  -webkit-box-shadow: 0 0 1px #666;
          box-shadow: 0 0 1px #666;
  margin: 0 0 20px;
}
.area article .col-lead h3 {
  font-family: source-han-sans-japanese, sans-serif;
  font-style: normal;
  font-weight: 500;
  font-size: 16px;
  line-height: 1.2;
  margin: 0 0 10px;
}
@media screen and (min-width: 1000px) {
  .area article .col-lead h3 {
    /* PC：デバイス別表示設定
    --------------------------------------------*/
    font-size: 20px;
  }
}
.area article .col-lead .txt {
  font-size: 16px;
}
@media screen and (min-width: 1000px) {
  .area article .col-lead .txt {
    /* PC：デバイス別表示設定
    --------------------------------------------*/
    font-size: 14px;
    line-height: 2;
  }
}
@media screen and (min-width: 1000px) {
  .area article .col-point {
    /* PC：デバイス別表示設定
    --------------------------------------------*/
    width: 55%;
  }
}
.area article .col-point .point {
  border: 1px dotted #000;
  background: #fffeec;
  padding: 10px;
  margin: 0 0 20px;
  position: relative;
}
.area article .col-point .point h4 {
  width: 150px;
  margin: -15px 0 10px -15px;
}
@media screen and (min-width: 1000px) {
  .area article .col-point .point h4 {
    /* PC：デバイス別表示設定
    --------------------------------------------*/
    width: 190px;
    margin: -15px 0 20px -15px;
  }
}
.area article .col-point .point .dot {
  margin-left: 10px;
}
.area article .col-point .point .dot li {
  padding: 0 0 5px;
  font-weight: bold;
  line-height: 1.2;
}
@media screen and (min-width: 1000px) {
  .area article .col-point .point .dot li {
    /* PC：デバイス別表示設定
    --------------------------------------------*/
    padding: 0 0 20px 10px;
  }
}
.area article .col-point .wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
}
.area article .col-point .wrapper img {
  border: 3px solid #FFF;
  -webkit-box-shadow: 0 0 1px #666;
          box-shadow: 0 0 1px #666;
  margin: 0 0 20px;
  width: 31%;
}
.area#area03 header h1:before, .area#area03 header h1:after {
  background-color: #0e608f;
}
.area#area03 article header h2 {
  color: #0e608f;
}
.area#area02 header h1:before, .area#area02 header h1:after {
  background-color: #3c6433;
}
.area#area02 article header h2 {
  color: #3c6433;
}
.area#area03 header h1:before, .area#area03 header h1:after {
  background-color: #0e608f;
}
.area#area03 article header h2 {
  color: #0e608f;
}
.area#area04 header h1:before, .area#area04 header h1:after {
  background-color: #a6790e;
}
.area#area04 article header h2 {
  color: #a6790e;
}
@media screen and (min-width: 1000px) {
  .area#area05 {
    /* PC：デバイス別表示設定
    --------------------------------------------*/
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
}
@media screen and (min-width: 1000px) {
  .area#area05 header {
    /* PC：デバイス別表示設定
    --------------------------------------------*/
    width: 100%;
  }
}
.area#area05 header h1:before, .area#area05 header h1:after {
  background-color: #514cc3;
}
@media screen and (min-width: 1000px) {
  .area#area05 article {
    /* PC：デバイス別表示設定
    --------------------------------------------*/
    width: calc(50% - 20px);
    margin: 0 auto;
  }
}
.area#area05 article header {
  text-align: center;
}
.area#area05 article header h2 {
  color: #514cc3;
}
.area#area05 article img {
  border: 6px solid #FFF;
  -webkit-box-shadow: 0 0 1px #666;
          box-shadow: 0 0 1px #666;
  margin-bottom: 10px;
  -webkit-align-self: flex-start;
  /* Safari */
  -ms-flex-item-align: start;
      align-self: flex-start;
}