@charset "UTF-8";
/*
   * Mixin for placeholder
   * @include placeholderColor(#00ff00);
   */
/*
html5doctor.com Reset Stylesheet v1.6.1
Last Updated: 2010-09-17
*/
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;
}

article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

ol, 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;
}

/* change colours to suit your needs */
ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}

/* change colours to suit your needs */
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;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

/* change border colour to suit your needs */
hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #cccccc;
  margin: 1em 0;
  padding: 0;
}

input, select {
  vertical-align: middle;
}

img {
  vertical-align: top;
  font-size: 0;
  line-height: 0;
  max-width: 100%;
  height: auto;
}

img[src$=".svg"] {
  width: 100%;
}

body {
  font-size: 62.5%;
  color: #3C3A39;
  background: #ffffff;
  min-width: 1000px;
  font-family: "Meiryo UI", Meiryo, "YuGothic", "Yu Gothic", "游ゴシック", "游ゴシック体", "Hiragino Kaku Gothic ProN", sans-serif;
}

/* ==========================================================================
   Base styles: opinionated defaults
   ========================================================================== */
button,
input,
select,
textarea {
  color: #3C3A39;
  outline: none;
}

button {
  cursor: pointer;
}

/*
 * Remove text-shadow in selection highlight: h5bp.com/i
 * These selection rule sets have to be separate.
 * Customize the background color to match your design.
 */
::-moz-selection {
  background: #b3d4fc;
  text-shadow: none;
}

::selection {
  background: #b3d4fc;
  text-shadow: none;
}

/*
 * Remove the gap between images, videos, audio and canvas and the bottom of
 * their containers: h5bp.com/i/440
 */
audio,
canvas,
img,
video {
  vertical-align: middle;
}

/*
 * Remove default fieldset styles.
 */
fieldset {
  border: 0;
  margin: 0;
  padding: 0;
}

/*
 * Allow only vertical resizing of textareas.
 */
textarea {
  resize: vertical;
}

a {
  color: #3C3A39;
  text-decoration: none;
}

a:hover {
  text-decoration: underline;
}

@media only screen and (max-device-width: 805px) {
  a:hover {
    text-decoration: none;
  }
}

a.rev {
  text-decoration: underline;
}

a.rev:hover {
  text-decoration: none;
}

p {
  margin: 0 0 1em;
}

label,
select,
input[type=submit] {
  cursor: pointer;
}

*, *:before, *:after {
  box-sizing: border-box;
}

a:hover img.over {
  opacity: 0.8;
  filter: alpha(opacity=80);
  cursor: pointer;
}

@media only screen and (max-device-width: 805px) {
  a:hover img.over {
    opacity: 1;
    filter: alpha(opacity=100);
  }
}

@media only screen and (min-device-width: 806px) and (max-device-width: 1024px) {
  a:hover img.over {
    opacity: 1;
    filter: alpha(opacity=100);
  }
}

img {
  max-width: 100%;
  height: auto;
}

img[src$=".svg"] {
  width: 100%;
}

address {
  font-style: normal;
}

.spPic {
  display: none;
}

.spPic {
  display: none;
}

figcaption {
  font-size: 15.2px;
  line-height: 1.2;
  margin-top: 10px;
  margin-bottom: 10px;
}

#special {
  font-size: 14px;
  width: 800px;
  margin: auto;
}

#special h1 {
  font-size: 24px;
  position: relative;
  line-height: 37px;
}

#special h2 {
  font-size: 20px;
  margin-bottom: 10px;
}

#special h2.line-1 {
  min-height: 50px;
  height: 50px;
  line-height: 50px;
}

#special h2.line-1:not(:target) {
  line-height: 50px\9;
}

:root #special h2.line-1 {
  line-height: 50px\9;
}

#special p {
  font-size: 14px;
  line-height: 33px;
  margin: 0;
}

#special .top-image {
  text-align: center;
}

#special .top-image img {
  max-width: 100%;
  margin-bottom: 0px;
}

#special .main {
  font-family: "Meiryo UI", Meiryo, "YuGothic", "Yu Gothic", "游ゴシック", "游ゴシック体", "Hiragino Kaku Gothic ProN", sans-serif;
}

#special .main-text {
  text-align: left;
  margin-bottom: 60px;
}

#special .main-text .sub-title {
  font-size: 18px;
}

#special .main-text p {
  line-height: 33px;
  margin: 0;
}

#special .main-text img {
  margin: 15px 0 20px 0;
}

#special .main-cont .item {
  margin-bottom: 60px;
}

#special .main-cont .item p {
  text-indent: 1em;
}

#special .main-cont .item .one-column {
  margin-top: 30px;
}

#special .main-cont .item .one-column img {
  max-width: 100%;
}

#special .main-cont .item .half-block {
  margin-top: 30px;
}

#special .main-cont .item .half-block_right {
  float: right;
  width: 49%;
}

#special .main-cont .item .half-block_left {
  float: left;
  width: 49%;
}

#special .main-cont .item .half-block img {
  max-width: 100%;
}

#special .main-cont .item .half-block:after {
  content: "";
  display: table;
  clear: both;
}

#special .main-cont .pic-left_text {
  width: 490px;
  float: right;
}

#special .main-cont .pic-left img {
  float: left;
  max-width: 260px;
}

#special .main-cont .pic-left h2 img {
  float: none;
}

#special .main-cont .pic-left:after {
  content: "";
  display: table;
  clear: both;
}

#special .main-cont .pic-right {
  margin-bottom: 30px;
}

#special .main-cont .pic-right_text {
  width: 490px;
  float: left;
}

#special .main-cont .pic-right .pic {
  float: right;
  max-width: 280px;
  margin-bottom: 10px;
}

#special .main-cont .pic-right h2 img {
  float: none;
}

#special .main-cont .pic-right:after {
  content: "";
  display: table;
  clear: both;
}

#special .main-cont .headline {
  text-align: left;
  font-size: 24px;
  font-weight: bold;
  background-repeat: no-repeat;
  background-position: center;
  margin-bottom: 30px;
  margin-top: 70px;
  line-height: 36px;
}

#special .main-cont .headline:first-child {
  margin-top: 30px;
}

#special .main .contact table {
  width: 100%;
  border-collapse: collapse;
  table-layout: fixed;
  margin-bottom: 30px;
}

#special .main .contact table caption {
  text-align: left;
  font-size: 16px;
  line-height: 26px;
  margin-bottom: 10px;
}

#special .main .contact table caption:before {
  content: "●";
  position: relative;
  width: 1em;
  text-indent: 0;
  margin-right: 5px;
}

#special .main .contact table tbody tr {
  border: 1px solid #656464;
}

#special .main .contact table tbody tr th {
  background: #656464;
  color: #fff;
  padding: 14px;
  width: 120px;
  border-bottom: 1px solid #fff;
  vertical-align: top;
  font-size: 13px;
  text-align: left;
}

#special .main .contact table tbody tr td {
  border: 1px solid #656464;
  padding: 10px;
}

#special .main .contact table tbody tr:last-child th {
  border-bottom: 1px solid #656464;
}

#special .main .profile {
  margin-top: 20px;
  padding: 20px;
  margin-bottom: 30px;
}

#special .main .profile p {
  line-height: 25px;
  margin: 0;
}

#special .main .profile img {
  max-width: 110px;
  float: left;
}

#special .main .profile_text {
  float: right;
  width: 640px;
}

#special .main .profile:after {
  content: "";
  display: table;
  clear: both;
}

#special .main .page-top a {
  display: block;
  position: fixed;
  width: 80px;
  height: 80px;
  background: url("../img/page-top.png");
  bottom: 100px;
  right: 50px;
  z-index: 100;
  transition: opacity .2s ease-in-out;
  cursor: pointer;
  opacity: 1;
  filter: alpha(opacity=100);
}

@media only screen and (max-device-width: 805px) {
  #special .main .page-top a {
    opacity: 1;
    filter: alpha(opacity=100);
  }
}

@media only screen and (min-device-width: 806px) and (max-device-width: 1024px) {
  #special .main .page-top a {
    opacity: 1;
    filter: alpha(opacity=100);
  }
}

#special .main .page-top a:hover {
  text-decoration: none;
  opacity: 0.7;
  filter: alpha(opacity=70);
}

@media only screen and (max-device-width: 805px) {
  #special .main .page-top a:hover {
    opacity: 1;
    filter: alpha(opacity=100);
  }
}

@media only screen and (min-device-width: 806px) and (max-device-width: 1024px) {
  #special .main .page-top a:hover {
    opacity: 1;
    filter: alpha(opacity=100);
  }
}

#special .main .page-top a:hover {
  opacity: 0.7;
}

#special #google-map {
  margin-top: 10px;
}

#special .panel {
  transition: all 0.2s ease-in-out;
  opacity: 1;
}

#special .panel:hover {
  opacity: 0.7;
  filter: alpha(opacity=70);
  cursor: pointer;
}

#special.jamping h1 {
  color: #000000;
}

#special.jamping h1:before {
  border-color: #000000;
}

#special.jamping h1:after {
  border-color: #8c8c8c;
}

#special.jamping h2 {
  border-color: #000000;
  margin-bottom: 40px;
}

#special.jamping h3 {
  margin-bottom: 20px;
}

#special.jamping .item {
  width: 800px;
  overflow: hidden;
  margin-bottom: 40px;
}

#special.jamping .main-cont h2 {
  color: #000000;
}

#special.jamping .sub-title {
  color: #000000;
  font-size: 18px;
  position: relative;
  line-height: 37px;
  font-weight: bold;
}

#special.jamping .title-box {
  color: #000000;
  font-size: 160%;
  font-weight: bold;
  position: relative;
  padding-left: 20px;
  margin-bottom: 15px;
  margin-top: 20px;
  border-left: 9px solid #000000;
}

#special.jamping .contact img {
  margin-top: 30px;
}

#special.jamping .contact table tbody tr td .address {
  margin-bottom: 20px;
}

#special.jamping .block_center {
  width: 411px;
  margin: 0 auto;
}

#special.jamping .main-cont .pic-right {
  margin-bottom: 30px;
}

#special.jamping .main-cont .pic-right_text {
  width: 550px;
  float: left;
}

#special.jamping .main-cont .pic-right .pic {
  max-width: 230px;
  margin-bottom: 10px;
}

#special.jamping .main-cont .pic-right .main-cont .pic {
  float: right;
  max-width: 230px;
  margin-bottom: 10px;
}

#special.jamping .main-cont .pic-right h2 img {
  float: none;
}

#special.jamping .main-cont .pic-right:after {
  content: "";
  display: table;
  clear: both;
}

#special.jamping .top-image {
  margin-bottom: 20px;
  text-align: center;
}

#special.jamping .top-image .title {
  width: 179px;
  height: 77px;
  margin-bottom: 40px;
}

#special.jamping .top-image img {
  margin-bottom: 0px;
}

#special.jamping .contact_img {
  width: 143px;
}

#special.jamping .icon-title {
  padding-top: 60px;
}

#special.jamping .w500-block {
  width: 501px;
  margin-top: 10px;
  margin-bottom: 20px;
}

#special.jamping .w800-block {
  width: 800px;
  margin-top: 20px;
}

#special.jamping .text-left {
  width: 455px;
  float: left;
  margin-bottom: 50px;
}

#special.jamping .left2 {
  width: 333px;
  float: left;
  margin-bottom: 30px;
}

#special.jamping .text-right {
  width: 320px;
  float: right;
  text-align: unset;
}

#special.jamping .half-block {
  width: 800px;
  margin-bottom: 20px;
}

#special.jamping .half-block.column3 {
  width: 822px;
}

#special.jamping .half-block:after {
  content: "";
  display: table;
  clear: both;
}

#special.jamping .half-block .half-block_2column_left {
  float: left;
  width: 380px;
}

#special.jamping .half-block .half-block_2column_right {
  float: right;
  width: 380px;
}

#special.jamping .half-block:after {
  content: "";
  display: table;
  clear: both;
}

#special.jamping .half-block .half-block_3column {
  float: left;
  width: 252px;
  margin-right: 22px;
}

#special.jamping .half-block .w393 {
  width: 393px;
}

#special.jamping .half-block .w381 {
  width: 381px;
}

#special.jamping .half-block .w333 {
  width: 333px;
}

#special.jamping .half-block .w433 {
  width: 433px;
}

#special.hitokoto h1 {
  color: #6A3906;
}

#special.hitokoto h1:before {
  border-color: #6A3906;
}

#special.hitokoto h1:after {
  border-color: #d0c4b9;
}

#special.hitokoto h2 {
  border-color: #007f78;
}

#special.hitokoto .main-cont h2 {
  color: #007f78;
}

#special.hitokoto .main-cont .h2-rigth {
  display: inline-block;
  width: 300px;
}

#special.hitokoto .main-cont .h2-left {
  display: inline-block;
  width: 300px;
}

#special.hitokoto .main-cont .pic-right {
  margin-bottom: 30px;
}

#special.hitokoto .main-cont .pic-right_text1 {
  width: 541px;
  float: left;
}

#special.hitokoto .main-cont .pic-right_text2 {
  width: 558px;
  float: left;
}

#special.hitokoto .center {
  text-align: center;
  margin: 50px 0;
}

#special.hitokoto .center .pic2 {
  width: 50%;
}

#special.hitokoto .main-text .mb60 {
  margin-bottom: 60px;
}

#special.hitokoto .title {
  color: #007F78;
  font-size: 20px;
  font-weight: bold;
  line-height: 33px;
}

#special.hitokoto .sub-title {
  color: #6A3906;
}

#special.hitokoto .headline {
  color: #6A3906;
  margin-bottom: 50px;
  margin-top: 80px;
}

#special.hitokoto .headline2 {
  color: #6A3906;
  margin-bottom: 50px;
  margin-top: 150px;
}

#special.hitokoto .profile {
  background-image: url("../img/hitokoto/person_bk.png");
}

#special.hitokoto .top-image {
  text-align: center;
}

#special.hitokoto .top-image .title {
  width: 100%;
  margin-bottom: 100px;
}

#special.hitokoto .top-image img {
  max-width: 100%;
}

#special.report figcaption {
  font-size: 15.2px;
  line-height: 1.2;
  margin-top: 10px;
  margin-bottom: 10px;
}

#special.report caption {
  text-align: left;
  font-size: 16px;
  line-height: 26px;
  margin-bottom: 10px;
}

#special.report h1 {
  color: #00608B;
}

#special.report h1:before {
  border-color: #00608B;
}

#special.report h1:after {
  border-color: #c6d6dd;
}

#special.report h2 {
  color: #00608B;
}

#special.report .main-text img {
  margin: 15px 0 15px 0;
}

#special.report .topMainV {
  width: 100%;
}

#special.report .topMainV .pc {
  display: block;
  margin: 0 auto;
}

#special.report .topMainV .sp {
  display: none;
}

#special.report .pic {
  max-width: 656px;
  max-height: 360px;
  margin: 0 auto;
}

#special.report .main-cont .item {
  margin-bottom: 40px;
}

#special.report .main-left {
  width: 475px;
  float: left;
  margin-bottom: 40px;
}

#special.report .main-left:after {
  content: "";
  display: table;
  clear: both;
}

#special.report .main-left img {
  width: 100%;
  height: 100%;
}

#special.report .main-left h1 {
  color: #00608B;
}

#special.report .main-left h2 {
  color: #00608B;
}

#special.report .main-left h3 {
  font-size: 120%;
}

#special.report .main-right {
  width: 301px;
  float: left;
  margin-left: 20px;
  margin-bottom: 60px;
}

#special.report .main-right:after {
  content: "";
  display: table;
  clear: both;
}

#special.report .main-right img {
  width: 100%;
  height: 100%;
}

#special.report .top-image {
  margin-bottom: 58px;
}

#special.report .top-image .title {
  width: auto;
  height: 76px;
  margin-bottom: 40px;
}

#special.report .top-image img {
  margin-bottom: 0px;
}

#special.report .center {
  margin: auto;
  width: 582px;
}

#special.report .main-image {
  text-align: left;
}

#special.report .main-image .title {
  width: auto;
  margin-top: 20px;
  margin-bottom: 10px;
}

#special.report .main-image img {
  margin-left: 0px;
  margin-bottom: 0px;
}

#special.promenade .movieBox {
  border: 2px solid #009FE8;
  padding: 30px;
  text-align: center;
  margin-bottom: 60px;
}

#special.promenade .movieBox .pic {
  width: 380px;
}

#special.promenade .movieBox .movieBox_text {
  vertical-align: middle;
  display: inline-block;
  text-align: left;
  line-height: 25px;
}

#special.promenade .movieBox .movieBox_text img {
  margin-left: 6px;
}

#special.promenade .movieBox .movieBox_text .link {
  vertical-align: middle;
}

#special.promenade .movieBox .left {
  text-align: left;
}

#special.promenade .movieBox .movieBox_icon {
  display: inline;
  vertical-align: middle;
}

#special.promenade .top-image {
  margin-bottom: 50px;
}

#special.promenade .top-image .title {
  margin-bottom: 40px;
}

#special.promenade .top-image .title img {
  width: auto;
  height: 76px;
}

#special.promenade .top-image .pic02 {
  width: 652px;
}

#special.promenade .top-image .pic01 {
  width: 672px;
}

#special.promenade .top-image .text {
  text-align: left;
  margin-top: 50px;
  margin-bottom: 50px;
}

#special.promenade .top-image .text sup {
  color: #EE8593;
}

#special.promenade .top-image .left {
  text-align: left;
  margin-top: 47px;
  margin-bottom: 24px;
}

#special.promenade .top-image .content img {
  margin-top: 5px;
}

#special.promenade .top-image .content .content {
  margin-top: 5px;
}

#special.promenade .top-image .content .content_01 {
  background-color: #FAE5EE;
  border-radius: 20px;
  margin-top: 5px;
}

#special.promenade .top-image .content .content_01 img {
  margin-bottom: 30px;
}

#special.promenade .top-image .content .content_01 .pic {
  width: 356px;
}

#special.promenade .top-image .content .content_01 .icon {
  vertical-align: middle;
  margin: 0;
}

#special.promenade .top-image .content .content_01 p {
  padding-bottom: 13px;
}

#special.promenade .top-image .content .content_02 {
  background-color: #DEF1FB;
  border-radius: 20px;
  margin-top: 5px;
}

#special.promenade .top-image .content .content_02 img {
  margin-top: 30px;
  margin-bottom: 24px;
}

#special.promenade .top-image .content .content_02 .pic {
  width: 446px;
}

#special.promenade .top-image .content .content_02 .icon {
  vertical-align: middle;
  margin: 0;
}

#special.promenade .top-image .content .content_02 p {
  padding-bottom: 13px;
}

#special.promenade:after {
  content: "";
  display: table;
  clear: both;
}

#special.promenade .half-block_2column {
  float: left;
  width: 400px;
  margin-right: 0px;
}

#special.promenade .last {
  margin-right: 0px;
}

#special.promenade .main-text {
  font-size: 14px;
  line-height: 210%;
  margin-bottom: 0;
}

#special.promenade .main-text img {
  margin: 0;
}

#special.promenade .section01 {
  margin-bottom: 0px;
}

#special.promenade .section01 .section01_text01 {
  margin-bottom: 50px;
}

#special.promenade .section01 .section01_img01 {
  margin-bottom: 30px;
}

#special.promenade .section01 .half-block_2column_right {
  float: right;
  width: 380px;
}

#special.promenade .section01:after {
  content: "";
  display: table;
  clear: both;
}

#special.promenade .section01 .half-block_3column {
  float: left;
  width: 252px;
  margin-right: 22px;
}

#special.promenade .section01 .last {
  margin-right: 0px;
}

#special.promenade h2 {
  margin-bottom: 15px;
}

#special.promenade .section02 {
  margin-bottom: 55px;
}

#special.promenade .section02 .section02_title01 {
  margin-bottom: 22px;
}

#special.promenade .section02 .section02_text01 {
  margin-bottom: 55px;
}

#special.promenade .section02 .section02_img01 {
  text-align: center;
}

#special.promenade .section03 {
  margin-bottom: 60px;
}

#special.promenade .section03:after {
  content: "";
  display: table;
  clear: both;
}

#special.promenade .section03 .section03_title01 {
  margin-bottom: 22px;
}

#special.promenade .section03 .section03_text01 {
  width: 390px;
  float: left;
}

#special.promenade .section03 .section03_img01 {
  float: right;
}

#special.promenade .section04 {
  margin-bottom: 165px;
}

#special.promenade .section04 .section04_title01 {
  margin-bottom: 22px;
}

#special.promenade .section04 .section04_wrap01:after {
  content: "";
  display: table;
  clear: both;
}

#special.promenade .section04 .section04_wrap01 .section04_text01 {
  width: 494px;
  float: left;
}

#special.promenade .section04 .section04_wrap01 .section04_img01 {
  width: 270px;
  float: right;
}

#special.promenade .section04 .section04_line01 {
  margin: 25px 0px;
}

#special.promenade .section04 .section04_text02 {
  margin-bottom: 55px;
}

#special.promenade .main-cont {
  margin-left: 10px;
  margin-top: 20px;
  margin-bottom: 20px;
}

#special span.bold {
  font-weight: bold;
}

#special span.normal {
  font-weight: normal;
}

#special span.red {
  color: brown;
}

#special .text-center {
  text-align: center;
}

#special .text-left {
  text-align: left;
}

#special .text-right {
  text-align: right;
}

#special .sp {
  display: none;
}

#special .mt0 {
  margin-top: 0px;
}

#special .ml0 {
  margin-left: 0px;
}

#special .mr0 {
  margin-right: 0px;
}

#special .mb0 {
  margin-bottom: 0px;
}

#special .pt0 {
  padding-top: 0px;
}

#special .pl0 {
  padding-left: 0px;
}

#special .pr0 {
  padding-right: 0px;
}

#special .pb0 {
  padding-bottom: 0px;
}

#special .mt10 {
  margin-top: 10px;
}

#special .ml10 {
  margin-left: 10px;
}

#special .mr10 {
  margin-right: 10px;
}

#special .mb10 {
  margin-bottom: 10px;
}

#special .pt10 {
  padding-top: 10px;
}

#special .pl10 {
  padding-left: 10px;
}

#special .pr10 {
  padding-right: 10px;
}

#special .pb10 {
  padding-bottom: 10px;
}

#special .mt20 {
  margin-top: 20px;
}

#special .ml20 {
  margin-left: 20px;
}

#special .mr20 {
  margin-right: 20px;
}

#special .mb20 {
  margin-bottom: 20px;
}

#special .pt20 {
  padding-top: 20px;
}

#special .pl20 {
  padding-left: 20px;
}

#special .pr20 {
  padding-right: 20px;
}

#special .pb20 {
  padding-bottom: 20px;
}

#special .mt30 {
  margin-top: 30px;
}

#special .ml30 {
  margin-left: 30px;
}

#special .mr30 {
  margin-right: 30px;
}

#special .mb30 {
  margin-bottom: 30px;
}

#special .pt30 {
  padding-top: 30px;
}

#special .pl30 {
  padding-left: 30px;
}

#special .pr30 {
  padding-right: 30px;
}

#special .pb30 {
  padding-bottom: 30px;
}

#special .mt40 {
  margin-top: 40px;
}

#special .ml40 {
  margin-left: 40px;
}

#special .mr40 {
  margin-right: 40px;
}

#special .mb40 {
  margin-bottom: 40px;
}

#special .pt40 {
  padding-top: 40px;
}

#special .pl40 {
  padding-left: 40px;
}

#special .pr40 {
  padding-right: 40px;
}

#special .pb40 {
  padding-bottom: 40px;
}

#special .mt50 {
  margin-top: 50px;
}

#special .ml50 {
  margin-left: 50px;
}

#special .mr50 {
  margin-right: 50px;
}

#special .mb50 {
  margin-bottom: 50px;
}

#special .pt50 {
  padding-top: 50px;
}

#special .pl50 {
  padding-left: 50px;
}

#special .pr50 {
  padding-right: 50px;
}

#special .pb50 {
  padding-bottom: 50px;
}

#promenade {
  font-size: 14px;
  width: 800px;
  margin: auto;
}

#promenade p {
  font-size: 16px;
  line-height: 33px;
  margin: 0 0 1.5em;
}

#promenade .top-image {
  text-align: center;
}

#promenade .top-image .title {
  width: auto;
  height: 76px;
  margin-bottom: 40px;
}

#promenade .top-image img {
  max-width: 100%;
  margin-bottom: 40px;
}

#promenade .main {
  font-family: "Meiryo UI", Meiryo, "YuGothic", "Yu Gothic", "游ゴシック", "游ゴシック体", "Hiragino Kaku Gothic ProN", sans-serif;
}

#promenade .main-text {
  text-align: left;
  margin-bottom: 60px;
}

#promenade .main-text .sub-title {
  font-size: 18px;
}

#promenade .main-text p {
  line-height: 33px;
  margin: 0;
}

#promenade .main-text .text {
  margin-top: 30px;
}

#promenade .main-text img {
  margin: 15px 0 20px 0;
}

#promenade .main_pic {
  text-align: center;
  margin-bottom: 40px;
}

.mainitemList {
  font-family: "Meiryo UI", Meiryo, "YuGothic", "Yu Gothic", "游ゴシック", "游ゴシック体", "Hiragino Kaku Gothic ProN", sans-serif;
  margin-bottom: 50px;
}

.mainitemList dt {
  color: #1f2677;
  font-size: 20px;
  line-height: 29px;
  font-weight: bold;
  letter-spacing: 0.05em;
  background-image: url("../img/promenade/icon_q.png");
  background-position: left;
  background-repeat: no-repeat;
  background-size: 50px auto;
  padding: 13px 0 13px 64px;
  position: relative;
  margin-bottom: 25px;
}

.mainitemList dd {
  font-size: 16px;
  line-height: 33px;
  margin: 0 0 1.5em;
  background-image: url("../img/promenade/icon_a.png");
  background-position: left 0;
  background-repeat: no-repeat;
  background-size: 50px auto;
  padding: 0 0 0 64px;
}

.mainitemList_illust {
  display: inline-block;
  margin-left: 10px;
}

.mainitemList_illust-01 {
  margin-top: -14px;
  width: 42px;
  height: auto;
}

.mainitemList_illust-02 {
  margin-top: -17px;
  width: 34px;
  height: auto;
}

.mainitemList_pic {
  text-align: center;
}

.mainitemList_caption {
  margin-bottom: 80px;
}

.subTwoBox {
  overflow: hidden;
  margin-bottom: 10px;
}

.subTwoBox_left {
  float: left;
  width: 390px;
}

.subTwoBox_right {
  float: right;
  width: 394px;
}

#eshikokutanbou {
  width: 800px;
  margin: 0 auto 200px;
}

#eshikokutanbou .eshikoku_sec_top {
  margin-bottom: 70px;
}

#eshikokutanbou .eshikoku_sec_top_title {
  text-align: center;
  margin-bottom: 50px;
}

#eshikokutanbou .eshikoku_sec_top_main {
  margin-bottom: 30px;
}

#eshikokutanbou .eshikoku_sec_top_main:after {
  content: "";
  display: table;
  clear: both;
}

#eshikokutanbou .eshikoku_sec_top_main_text {
  width: 405px;
  float: left;
  font-size: 15px;
  line-height: 170%;
}

#eshikokutanbou .eshikoku_sec_top_main_pic {
  float: right;
  padding-right: 50px;
}

#eshikokutanbou .eshikoku_sec_top figure figcaption {
  font-size: 14px;
  line-height: 170%;
}

#eshikokutanbou .eshikoku_sec_wrap .eshikoku_h2 {
  padding-left: 12px;
  border-left: 10px solid #c24e00;
  color: #c24e00;
  font-size: 20px;
  line-height: 150%;
  margin-bottom: 30px;
}

#eshikokutanbou .eshikoku_sec_wrap .eshikoku_h3 {
  font-size: 20px;
  padding-left: 12px;
  border-left: 9px solid #c24e00;
  margin-bottom: 25px;
}

#eshikokutanbou .eshikoku_sec_wrap .half-block {
  margin-bottom: 30px;
}

#eshikokutanbou .eshikoku_sec_wrap .half-block:after {
  content: "";
  display: table;
  clear: both;
}

#eshikokutanbou .eshikoku_sec_wrap .half-block .half-block_left {
  width: 390px;
  float: left;
}

#eshikokutanbou .eshikoku_sec_wrap .half-block .half-block_right {
  width: 390px;
  float: right;
}

#eshikokutanbou .eshikoku_sec_00 {
  margin-bottom: 55px;
}

#eshikokutanbou .eshikoku_sec_00 h1 {
  font-size: 24px;
  color: #c24e00;
  margin-bottom: 15px;
}

#eshikokutanbou .eshikoku_sec_00 .line {
  margin-bottom: 15px;
}

#eshikokutanbou .eshikoku_sec_00 .sub-title {
  font-size: 18px;
  font-weight: bold;
}

#eshikokutanbou .eshikoku_sec_01 {
  margin-bottom: 55px;
}

#eshikokutanbou .eshikoku_sec_01_item_text {
  font-size: 14px;
  line-height: 220%;
}

#eshikokutanbou .eshikoku_sec_02 {
  margin-bottom: 55px;
}

#eshikokutanbou .eshikoku_sec_02_item_text {
  font-size: 14px;
  line-height: 220%;
}

#eshikokutanbou .eshikoku_sec_03 {
  margin-bottom: 55px;
}

#eshikokutanbou .eshikoku_sec_03_item_text {
  font-size: 14px;
  line-height: 220%;
  margin-bottom: 30px;
}

#eshikokutanbou .eshikoku_sec_03 figure {
  margin-bottom: 30px;
}

#eshikokutanbou .eshikoku_sec_03 figure figcaption {
  font-size: 14px;
  line-height: 180%;
}

#eshikokutanbou .eshikoku_sec_03 .half-block {
  margin-bottom: 15px;
}

#eshikokutanbou .eshikoku_sec_03 .captionTitle {
  font-size: 14px;
}

#eshikokutanbou .eshikoku_sec_contact_name {
  font-size: 14px;
  margin-bottom: 10px;
}

#eshikokutanbou .eshikoku_sec_contact table {
  border: 1px solid #000;
  background: #fff;
  width: 100%;
}

#eshikokutanbou .eshikoku_sec_contact th {
  width: 140px;
  text-align: left;
  background: #656464;
  color: #fff;
}

#eshikokutanbou .eshikoku_sec_contact th,
#eshikokutanbou .eshikoku_sec_contact td {
  border: 1px solid #000;
  padding: 15px;
  font-size: 14px;
}

@media only screen and (max-device-width: 805px) {
  figcaption {
    margin-top: 20px;
    text-indent: 0;
    line-height: 1.6em;
    font-size: 1.4em;
  }
  #special {
    font-size: 0.65em;
    width: 100%;
  }
  #special h1 {
    font-size: 2.3em;
    line-height: 1.5;
  }
  #special h2 {
    font-size: 2.7em;
    line-height: 1.4;
  }
  #special h2.line-1 {
    min-height: 98px;
    height: 98px;
    line-height: 98px;
  }
  #special h2.line-1:not(:target) {
    line-height: 98px\9;
  }
  :root #special h2.line-1 {
    line-height: 98px\9;
  }
  #special p {
    font-size: 1.5em;
    line-height: 1.8;
  }
  #special .top-image {
    padding-top: 0;
  }
  #special .top-image .title {
    max-width: 100%;
  }
  #special .top-image .caption {
    margin-left: 20px;
  }
  #special .main {
    padding: 0 20px 20px;
  }
  #special .main-text .sub-title {
    font-size: 1.6em;
    line-height: 1.8;
  }
  #special .main-text p {
    line-height: 2em;
    text-align: left;
    margin-bottom: 0;
  }
  #special .main-text p br {
    display: none;
  }
  #special .main-text img {
    margin: 10px 0;
    width: 100%;
  }
  #special .main-cont .item p {
    margin-bottom: 15px;
  }
  #special .main-cont .item figcaption {
    margin-top: 20px;
    text-indent: 0;
    line-height: 1.6em;
    font-size: 1.4em;
  }
  #special .main-cont .item .half-block_right {
    float: none;
    width: 100%;
    margin-bottom: 40px;
  }
  #special .main-cont .item .half-block_left {
    float: none;
    width: 100%;
    margin-bottom: 40px;
  }
  #special .main-cont .item .half-block img {
    max-width: 100%;
    display: block;
    margin: 20px auto;
  }
  #special .main-cont .item .half-block h2 img {
    margin: 0;
    display: inline;
  }
  #special .main-cont .item .half-block figcaption {
    margin-top: 20px;
    text-indent: 0;
    line-height: 1.6em;
    font-size: 1.4em;
  }
  #special .main-cont .item .half-block:after {
    content: "";
    display: table;
    clear: both;
  }
  #special .main-cont .pic-right_text {
    width: 100%;
    float: none;
  }
  #special .main-cont .pic-right .pic {
    float: none;
    max-width: 100%;
    display: block;
    margin: 20px auto;
    text-align: left;
  }
  #special .main-cont .pic-right img {
    width: 100%;
    display: block;
    margin: 20px auto;
  }
  #special .main-cont .pic-right h2 img {
    margin: 0;
    display: inline;
  }
  #special .main-cont .pic-right figcaption {
    margin-top: 8px;
    text-indent: 0;
    line-height: 130% !important;
  }
  #special .main-cont .pic-left_text {
    width: 100%;
    float: none;
  }
  #special .main-cont .pic-left img {
    float: none;
    max-width: 100%;
    display: block;
    margin: 20px auto;
  }
  #special .main-cont .pic-left h2 img {
    margin: 0;
    display: inline;
  }
  #special .main-cont .headline {
    font-size: 2.2em;
    line-height: 1.5em;
    background-size: 85%;
    margin-top: 70px;
    margin-bottom: 55px;
  }
  #special .main .contact {
    word-break: break-all;
  }
  #special .main .contact table {
    font-size: 1.3em;
    line-height: 1.5;
  }
  #special .main .contact table caption {
    font-size: 1.2em;
    line-height: 130%;
  }
  #special .main .contact table tbody tr th {
    width: 90px;
  }
  #special .main .contact table p {
    font-size: 1.2em;
  }
  #special .main .contact iframe {
    width: 100%;
    height: 200px;
  }
  #special .main .profile {
    background-size: cover;
    text-align: center;
    padding: 25px;
    background-repeat: repeat;
    background-size: contain;
  }
  #special .main .profile p {
    font-size: 1.5em;
    line-height: 1.7;
    margin-bottom: 0;
  }
  #special .main .profile img {
    max-width: unset;
    float: unset;
    margin-bottom: 15px;
  }
  #special .main .profile_text {
    float: unset;
    width: unset;
    text-align: left;
  }
  #special .main .page-top a {
    width: 95px;
    height: 95px;
    background-size: cover;
    right: 20px;
    bottom: 120px;
  }
  #special #google-map {
    max-width: 100%;
  }
  #special .sp-br {
    display: block;
  }
  #special .pc {
    display: none;
  }
  #special .sp {
    display: block;
  }
  #special.hitokoto h1 {
    color: #6A3906;
  }
  #special.hitokoto h1:before {
    border-color: #6A3906;
  }
  #special.hitokoto h1:after {
    border-color: #d0c4b9;
  }
  #special.hitokoto h2 {
    border-color: #007f78;
  }
  #special.hitokoto .main-cont h2 {
    color: #007f78;
  }
  #special.hitokoto .main-cont .pic-right {
    margin-bottom: 30px;
  }
  #special.hitokoto .main-cont .pic-right_text1 {
    width: 100%;
    float: left;
  }
  #special.hitokoto .main-cont .pic-right_text2 {
    width: 100%;
    float: left;
  }
  #special.hitokoto .sub-title {
    color: #6A3906;
  }
  #special.hitokoto .headline {
    color: #6A3906;
  }
  #special.hitokoto .profile {
    background-image: url("../img/hitokoto/person_bk.png");
  }
  #special.hitokoto .top-image {
    text-align: center;
  }
  #special.hitokoto .top-image .title {
    width: 100%;
    margin-bottom: 40px;
  }
  #special.hitokoto .top-image img {
    max-width: 100%;
    margin-bottom: 0px;
  }
  #special.hitokoto .item .pic-right .sp_resize {
    max-width: 85%;
  }
  #special.hitokoto .headline2 {
    margin-top: 50px;
  }
  #special.promenade {
    word-wrap: break-word;
  }
  #special.promenade .movieBox {
    border: 2px solid #009FE8;
    text-align: center;
    margin-bottom: 0;
    font-size: 0;
  }
  #special.promenade .movieBox .movieBox_text {
    vertical-align: middle;
    text-align: center;
    display: block;
    font-size: 14px;
    word-wrap: break-word;
  }
  #special.promenade .movieBox .movieBox_text img {
    margin-left: 6px;
  }
  #special.promenade .movieBox .movieBox_icon img {
    vertical-align: middle;
    margin: 6px;
  }
  #special.promenade .top-image {
    padding: 20px;
    margin-bottom: 20px;
  }
  #special.promenade .top-image .title {
    margin-bottom: 40px;
  }
  #special.promenade .top-image .title img {
    width: auto;
    height: 76px;
  }
  #special.promenade .main-text {
    font-size: 1.5em;
    line-height: 33px;
    margin-bottom: 0;
  }
  #special.promenade .main-text img {
    margin: 0;
  }
  #special.promenade .section01 {
    margin-bottom: 10px;
  }
  #special.promenade .section01 .section01_text01 {
    margin-bottom: 0;
  }
  #special.promenade .section01 .section01_img01 {
    margin-bottom: 30px;
  }
  #special.promenade .section01 .half-block_2column_right {
    float: right;
    width: 100%;
  }
  #special.promenade .section01:after {
    content: "";
    display: table;
    clear: both;
  }
  #special.promenade .section01 .half-block_3column {
    float: left;
    width: 100%;
    margin-right: 0px;
  }
  #special.promenade .section01 .half-block_3column img {
    width: 100%;
  }
  #special.promenade .section01 .last {
    margin-right: 0px;
  }
  #special.promenade h2 {
    margin-bottom: 15px;
  }
  #special.promenade .section02 {
    margin-bottom: 30px;
  }
  #special.promenade .section02 .section02_title01 {
    margin-bottom: 22px;
  }
  #special.promenade .section02 .section02_title01 img {
    max-width: 100%;
    width: auto;
    height: auto;
  }
  #special.promenade .section02 .section02_text01 {
    margin-bottom: 30px;
  }
  #special.promenade .section02 .section02_img01 {
    text-align: center;
  }
  #special.promenade .section03 {
    margin-bottom: 30px;
  }
  #special.promenade .section03:after {
    content: "";
    display: table;
    clear: both;
  }
  #special.promenade .section03 .section03_title01 {
    margin-bottom: 22px;
  }
  #special.promenade .section03 .section03_title01 img {
    max-width: 100%;
    width: auto;
    height: auto;
  }
  #special.promenade .section03 .section03_text01 {
    margin-bottom: 30px;
    width: 100%;
    float: none;
  }
  #special.promenade .section03 .section03_img01 {
    float: none;
  }
  #special.promenade .section04 {
    margin-bottom: 20px;
  }
  #special.promenade .section04 .section04_title01 {
    margin-bottom: 22px;
  }
  #special.promenade .section04 .section04_title01 img {
    max-width: 100%;
    width: auto;
    height: auto;
  }
  #special.promenade .section04 .section04_wrap01:after {
    content: "";
    display: table;
    clear: both;
  }
  #special.promenade .section04 .section04_wrap01 .section04_text01 {
    width: 100%;
    float: none;
    margin-bottom: 20px;
  }
  #special.promenade .section04 .section04_wrap01 .section04_img01 {
    width: 100%;
    float: none;
    text-align: center;
  }
  #special.promenade .section04 .section04_wrap01 .section04_img01 img {
    max-width: 100%;
    width: auto;
    height: auto;
  }
  #special.promenade .section04 .section04_line01 {
    margin: 15px 0px;
  }
  #special.promenade .section04 .section04_text02 {
    margin-bottom: 40px;
  }
  #special.promenade .main-cont {
    margin-left: 10px;
    margin-top: 20px;
    margin-bottom: 20px;
  }
  .subTwoBox {
    overflow: hidden;
    margin-bottom: 10px;
  }
  .subTwoBox_left {
    float: none;
    width: auto;
    margin-bottom: 10px;
  }
  .subTwoBox_right {
    float: none;
    width: auto;
  }
  #special.report h1 {
    color: #00608B;
  }
  #special.report h1:before {
    border-color: #00608B;
  }
  #special.report h1:after {
    border-color: #c6d6dd;
  }
  #special.report h2 {
    border-color: #00608B;
  }
  #special.report .topMainV {
    width: 100%;
  }
  #special.report .topMainV img {
    width: 100%;
  }
  #special.report .topMainV .pc {
    display: none;
  }
  #special.report .topMainV .sp {
    display: block;
  }
  #special.report .main-left {
    width: 100%;
    float: none;
    margin-bottom: 40px;
  }
  #special.report .main-left:after {
    content: "";
    display: table;
    clear: both;
  }
  #special.report .main-left img {
    width: 100%;
    height: 100%;
  }
  #special.report .main-left h1 {
    color: #00608B;
  }
  #special.report .main-left h2 {
    color: #00608B;
  }
  #special.report .main-left h3 {
    font-size: 120%;
  }
  #special.report .main-right {
    width: 100%;
    float: none;
    margin-left: 0px;
    margin-bottom: 0px;
  }
  #special.report .main-right:after {
    content: "";
    display: table;
    clear: both;
  }
  #special.report .main-right img {
    width: 100%;
    height: 100%;
  }
  #special.report .top-image {
    text-align: center;
  }
  #special.report .top-image .title {
    width: auto;
    height: 76px;
    margin-bottom: 10px;
  }
  #special.report .top-image img {
    max-width: 100%;
    width: 100%;
    margin-bottom: 0px;
  }
  #special.report .main-image {
    text-align: left;
  }
  #special.report .main-image .title {
    width: auto;
    margin-top: 20px;
    margin-bottom: 10px;
    font-size: 120%;
    line-height: 130%;
  }
  #special.report .main-image img {
    margin-left: 0px;
    margin-bottom: 0px;
  }
  #special.report .center {
    margin-left: 0px;
    width: 100%;
  }
  #special.jamping .title-box {
    color: #000000;
    font-size: 160%;
    font-weight: bold;
    position: relative;
    padding-left: 20px;
    margin-bottom: 15px;
    margin-top: 20px;
    border-left: 9px solid #000000;
  }
  #special.jamping .item {
    width: 100%;
  }
  #special.jamping .contact img {
    margin-top: 30px;
  }
  #special.jamping .contact table tbody tr td .address {
    margin-bottom: 20px;
  }
  #special.jamping .main-cont .pic-right {
    margin-bottom: 30px;
  }
  #special.jamping .main-cont .pic-right_text {
    width: 100%;
    float: left;
  }
  #special.jamping .main-cont .pic-right .pic {
    float: right;
    max-width: 100%;
    margin-bottom: 10px;
  }
  #special.jamping .main-cont .pic-right .main-cont .pic {
    float: right;
    max-width: 100%;
    margin-bottom: 10px;
  }
  #special.jamping .main-cont .pic-right h2 img {
    float: none;
  }
  #special.jamping .main-cont .pic-right:after {
    content: "";
    display: table;
    clear: both;
  }
  #special.jamping .block_center {
    width: 100%;
    margin: 0 auto;
  }
  #special.jamping .top-image {
    text-align: center;
    margin-bottom: 0px;
  }
  #special.jamping .top-image .title {
    margin-bottom: 40px;
  }
  #special.jamping .top-image img {
    margin-bottom: 0px;
  }
  #special.jamping .icon-title {
    padding-top: 20px;
  }
  #special.jamping .w500-block {
    width: 100%;
    margin-top: 10px;
    margin-bottom: 30px;
  }
  #special.jamping .w800-block {
    width: 100%;
    margin-top: 30px;
  }
  #special.jamping .text-left {
    width: 100%;
    float: left;
    margin-bottom: 0px;
  }
  #special.jamping .text-right {
    width: 100%;
    float: right;
    text-align: unset;
  }
  #special.jamping .half-block {
    width: 100%;
    margin-bottom: 0px;
  }
  #special.jamping .half-block:after {
    content: "";
    display: table;
    clear: both;
  }
  #special.jamping .half-block .half-block_2column_left {
    float: left;
    width: 100%;
  }
  #special.jamping .half-block .half-block_2column_right {
    float: right;
    width: 100%;
  }
  #special.jamping .half-block.column3 {
    width: 100%;
  }
  #special.jamping .half-block:after {
    content: "";
    display: table;
    clear: both;
  }
  #special.jamping .half-block .half-block_3column {
    float: none;
    width: 100%;
    margin-right: 22px;
  }
  #special.jamping .half-block .half-block_3column img {
    width: 100%;
    height: auto;
  }
  #special.jamping .half-block .w393 {
    width: 100%;
  }
  #special.jamping .half-block .w381 {
    width: 100%;
  }
  #special.jamping .half-block .w342 {
    width: 100%;
  }
  #special.jamping .half-block .w433 {
    width: 100%;
  }
  #eshikokutanbou {
    width: 100%;
    padding: 0 20px;
    margin: 0 auto 30px;
  }
  #eshikokutanbou .eshikoku_sec_top {
    margin-bottom: 40px;
  }
  #eshikokutanbou .eshikoku_sec_top_title {
    text-align: center;
    margin-bottom: 40px;
  }
  #eshikokutanbou .eshikoku_sec_top_main {
    margin-bottom: 30px;
  }
  #eshikokutanbou .eshikoku_sec_top_main:after {
    content: "";
    display: table;
    clear: both;
  }
  #eshikokutanbou .eshikoku_sec_top_main_text {
    width: 100%;
    float: left;
    font-size: 1.5rem;
    line-height: 170%;
  }
  #eshikokutanbou .eshikoku_sec_top_main_pic {
    float: right;
    padding-right: 50px;
  }
  #eshikokutanbou .eshikoku_sec_top figure figcaption {
    font-size: 1.5rem;
    line-height: 170%;
  }
  #eshikokutanbou .eshikoku_sec_wrap .eshikoku_h2 {
    padding-left: 12px;
    border-left: 10px solid #c24e00;
    color: #c24e00;
    font-size: 2.0rem;
    line-height: 150%;
    margin-bottom: 20px;
  }
  #eshikokutanbou .eshikoku_sec_wrap .eshikoku_h3 {
    font-size: 2.0rem;
    padding-left: 12px;
    border-left: 9px solid #c24e00;
    margin-bottom: 20px;
  }
  #eshikokutanbou .eshikoku_sec_wrap .half-block {
    margin-bottom: 0px;
  }
  #eshikokutanbou .eshikoku_sec_wrap .half-block:after {
    content: "";
    display: table;
    clear: both;
  }
  #eshikokutanbou .eshikoku_sec_wrap .half-block .half-block_left {
    width: 100%;
    float: none;
  }
  #eshikokutanbou .eshikoku_sec_wrap .half-block .half-block_right {
    width: 100%;
    float: none;
  }
  #eshikokutanbou .eshikoku_sec_wrap .half-block figcaption {
    font-size: 1.5rem;
    margin: 5px 0px 10px;
  }
  #eshikokutanbou .eshikoku_sec_00 {
    margin-bottom: 30px;
  }
  #eshikokutanbou .eshikoku_sec_00 h1 {
    font-size: 24px;
    color: #c24e00;
    margin-bottom: 15px;
  }
  #eshikokutanbou .eshikoku_sec_00 .line {
    margin-bottom: 15px;
  }
  #eshikokutanbou .eshikoku_sec_00 .sub-title {
    font-size: 18px;
    font-weight: bold;
  }
  #eshikokutanbou .eshikoku_sec_01 {
    margin-bottom: 30px;
  }
  #eshikokutanbou .eshikoku_sec_01_item_text {
    font-size: 1.5rem;
    line-height: 220%;
  }
  #eshikokutanbou .eshikoku_sec_02 {
    margin-bottom: 30px;
  }
  #eshikokutanbou .eshikoku_sec_02_item_text {
    font-size: 1.5rem;
    line-height: 220%;
  }
  #eshikokutanbou .eshikoku_sec_03 {
    margin-bottom: 30px;
  }
  #eshikokutanbou .eshikoku_sec_03_item_text {
    font-size: 1.5rem;
    line-height: 220%;
    margin-bottom: 30px;
  }
  #eshikokutanbou .eshikoku_sec_03 figure {
    margin-bottom: 30px;
  }
  #eshikokutanbou .eshikoku_sec_03 figure figcaption {
    font-size: 1.5rem;
    line-height: 180%;
  }
  #eshikokutanbou .eshikoku_sec_03 .half-block {
    margin-bottom: 15px;
  }
  #eshikokutanbou .eshikoku_sec_03 .half-block .half-block_left {
    margin-bottom: 10px;
  }
  #eshikokutanbou .eshikoku_sec_03 .captionTitle {
    font-size: 1.5rem;
    line-height: 150%;
  }
  #eshikokutanbou .eshikoku_sec_contact_name {
    font-size: 1.5rem;
    margin-bottom: 10px;
  }
  #eshikokutanbou .eshikoku_sec_contact table {
    border: 1px solid #000;
    background: #fff;
    width: 100%;
  }
  #eshikokutanbou .eshikoku_sec_contact th {
    width: 140px;
    text-align: left;
    background: #656464;
    color: #fff;
  }
  #eshikokutanbou .eshikoku_sec_contact th,
  #eshikokutanbou .eshikoku_sec_contact td {
    border: 1px solid #000;
    padding: 15px;
    font-size: 1.5rem;
  }
  #eshikokutanbou .eshikoku_sec_contact th iframe,
  #eshikokutanbou .eshikoku_sec_contact td iframe {
    width: 100%;
    height: 100px;
  }
}

/*
 Container
----------------------------------------------------------- */
.container {
  width: 800px;
  margin: 0 auto;
  position: relative;
  font-size: 140%;
  line-height: 1.8;
}

.container:after {
  content: "";
  display: table;
  clear: both;
}

/*
 Header
----------------------------------------------------------- */
.header_logo-01 {
  position: absolute;
  top: 17px;
  left: 0;
}

.header_logo-01 img {
  width: auto;
  height: 42px;
}

.header_logo-02 {
  text-align: center;
  line-height: 85px;
}

.header_logo-02 img {
  width: auto;
  height: 28px;
}

.header_logo-03 {
  position: absolute;
  top: 15px;
  right: 0;
}

.header_logo-03 img {
  width: auto;
  height: 54px;
}

.pageTopBtn {
  position: fixed;
  bottom: 100px;
  right: 50px;
  width: 80px;
  height: 80px;
  display: none;
  z-index: 29;
}

.pageTopBtn a {
  display: block;
  transition: opacity .2s ease-in-out;
  cursor: pointer;
  opacity: 1;
  filter: alpha(opacity=100);
}

@media only screen and (max-device-width: 805px) {
  .pageTopBtn a {
    opacity: 1;
    filter: alpha(opacity=100);
  }
}

@media only screen and (min-device-width: 806px) and (max-device-width: 1024px) {
  .pageTopBtn a {
    opacity: 1;
    filter: alpha(opacity=100);
  }
}

.pageTopBtn a:hover {
  text-decoration: none;
  opacity: 0.7;
  filter: alpha(opacity=70);
}

@media only screen and (max-device-width: 805px) {
  .pageTopBtn a:hover {
    opacity: 1;
    filter: alpha(opacity=100);
  }
}

@media only screen and (min-device-width: 806px) and (max-device-width: 1024px) {
  .pageTopBtn a:hover {
    opacity: 1;
    filter: alpha(opacity=100);
  }
}

#footerContainer {
  background-image: url("../img/special/foot_bg.gif");
  background-repeat: repeat-x;
  height: 87px;
  position: relative;
  background-position: 0px 20px;
  margin-top: -30px;
}

#footerFrame {
  background-image: url("../img/special/foot_bg.gif");
  background-repeat: repeat-x;
  height: 87px;
  position: relative;
  background-position: 0px 20px;
}

#footerContainer #footLink {
  margin-left: auto;
  color: #FFFFFF;
  text-align: left;
  height: 32px;
  width: 786px;
  background-color: #FFFFFF;
  margin-right: auto;
  background-image: url("../img/special/foot_bg.gif");
  background-repeat: repeat-x;
  background-position: 0px 20px;
  padding-top: 55px;
  padding-left: 15px;
}

.clearfix:after {
  content: "";
  display: table;
  clear: both;
}

#headerInner #subNavi ul,
#headerInner #gnavi ul,
#footerContainer #footLink ul {
  margin: 0px;
  padding: 0px;
  position: relative;
  z-index: 100;
}

#headerInner #subNavi li,
#headerInner #gnavi li,
#footerContainer #footLink li {
  list-style-type: none;
  display: inline;
  margin: 0px;
  padding: 0px;
  float: left;
}

#headerInner #gnavi {
  position: absolute;
  left: 0px;
  top: 86px;
}

#footerContainer #footLink a {
  color: #FFFFFF;
}

#footerContainer #footLink a.current {
  color: #FFFF00;
}

#footerContainer #footLink a:hover {
  color: #FFFF00;
}

#footerContainer #footCopy {
  font-size: 85%;
  color: #999999;
  position: absolute;
  top: 68px;
  width: 801px;
  margin-left: -400px;
  left: 50%;
  text-align: right;
}

* html #mainContainer {
  width: 801px;
}

* html #footerContainer #footLink {
  height: 87px;
  width: 801px;
}

/*
 Container
----------------------------------------------------------- */
@media only screen and (max-device-width: 805px) {
  html {
    font-size: 62.5%;
  }
  body {
    font-size: 1.4rem;
    width: 100%;
    min-width: 320px !important;
    min-height: initial;
    -webkit-text-size-adjust: 100%;
  }
  .bodyNoScloll {
    position: fixed;
    z-index: 0;
    overflow: hidden;
  }
  .container {
    width: auto;
    max-width: initial;
    font-size: 1.4rem;
  }
  .container:after {
    content: "";
    display: table;
    clear: both;
  }
  .header_logo-01 {
    top: 17px;
    left: 10px;
  }
  .header_logo-01 img {
    width: auto;
    height: 22px;
  }
  .header_logo-02 {
    text-align: center;
    line-height: 60px;
  }
  .header_logo-02 img {
    width: auto;
    height: 18px;
  }
  .header_logo-03 {
    position: absolute;
    top: 12px;
    right: 10px;
  }
  .header_logo-03 img {
    height: 34px;
  }
  .pageTopBtn {
    position: fixed;
    bottom: 50px;
    right: 10px;
    width: 40px;
    height: 40px;
    display: none;
    z-index: 29;
  }
  .pageTopBtn a {
    display: block;
    transition: opacity .2s ease-in-out;
    cursor: pointer;
    opacity: 1;
    filter: alpha(opacity=100);
  }
}

@media only screen and (max-device-width: 805px) and (max-device-width: 805px) {
  .pageTopBtn a {
    opacity: 1;
    filter: alpha(opacity=100);
  }
}

@media only screen and (max-device-width: 805px) and (min-device-width: 806px) and (max-device-width: 1024px) {
  .pageTopBtn a {
    opacity: 1;
    filter: alpha(opacity=100);
  }
}

@media only screen and (max-device-width: 805px) {
  .pageTopBtn a:hover {
    text-decoration: none;
    opacity: 0.7;
    filter: alpha(opacity=70);
  }
}

@media only screen and (max-device-width: 805px) and (max-device-width: 805px) {
  .pageTopBtn a:hover {
    opacity: 1;
    filter: alpha(opacity=100);
  }
}

@media only screen and (max-device-width: 805px) and (min-device-width: 806px) and (max-device-width: 1024px) {
  .pageTopBtn a:hover {
    opacity: 1;
    filter: alpha(opacity=100);
  }
}

@media only screen and (max-device-width: 805px) {
  #footerContainer {
    background-image: url("../img/special/foot_bg.gif");
    background-repeat: repeat-x;
    height: 87px;
    position: relative;
    background-position: 0px 20px;
    margin-top: -30px;
  }
  #footerFrame {
    background-image: url("../img/special/foot_bg.gif");
    background-repeat: repeat-x;
    height: 87px;
    position: relative;
    background-position: 0px 20px;
  }
  #footerContainer #footLink {
    padding-top: 45px;
    padding-left: 0;
    text-align: center;
    width: 100%;
  }
  #headerInner #subNavi ul,
  #headerInner #gnavi ul,
  #footerContainer #footLink ul {
    margin: 0px;
    padding: 0px;
    position: relative;
    z-index: 100;
    text-align: center;
  }
  #headerInner #subNavi li,
  #headerInner #gnavi li,
  #footerContainer #footLink li {
    float: none;
    font-size: 1.2rem;
  }
  #headerInner #subNavi li a,
  #headerInner #gnavi li a,
  #footerContainer #footLink li a {
    font-size: 10px;
  }
  #headerInner #gnavi {
    position: absolute;
    left: 0px;
    top: 86px;
  }
  #footerContainer #footCopy {
    font-size: 1.3rem;
    margin: 0;
    top: initial;
    bottom: 10px;
    color: #fff;
    z-index: 100;
    width: 100%;
    left: 0;
    font-size: 0.8rem;
    text-align: center;
  }
}
