@charset "UTF-8";
/*
値を1つ指定した場合： 指定した値が[上下左右]のパディングになります。
値を2つ指定した場合： 記述した順に[上下][左右]のパディングになります。
値を3つ指定した場合： 記述した順に[上][左右][下]のパディングになります。
値を4つ指定した場合： 記述した順に[上][右][下][左]のパディングになります。
*/

* {
    -webkit-box-sizing: border-box;
       -moz-box-sizing: border-box;
         -o-box-sizing: border-box;
        -ms-box-sizing: border-box;
            box-sizing: border-box;
}

a,
.ui-page-theme-a a,
 html .ui-bar-a a,
 html .ui-body-a a,
 html body .ui-group-theme-a a,
.ui-page-theme-a a:visited,
 html .ui-bar-a a:visited,
 html .ui-body-a a:visited,
 html body .ui-group-theme-a a:visited,
.ui-page-theme-a a:active,
 html .ui-bar-a a:active,
 html .ui-body-a a:active,
 html body .ui-group-theme-a a:active {
  color: #333;
  font-weight: normal;
}

html {
    overflow-y:scroll;
}

body {
   margin:0 auto; padding: 0;
   line-height:1.5;
   letter-spacing: 1px;
/*   font-size:14px; */
   color:#666666;
   overflow: auto;
   font-family: 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN', Meiryo, メイリオ, 'YuGothic', '游ゴシック', Helvetica, Arial, sans-serif;
}

/* 画面枠 */
.wrapper {
   margin:0 auto; padding: 0;
   width: 100%; height: 100%;
   background-color: #fff;
   overflow:hidden;
}

.menu_space {
  margin-top:13em;
}

.contents {
  float:none; clear:both;
  margin:0 auto; padding: 0;
  min-width:250px;
  max-width:1300px;
  height: 100%;
  background-color: #FFF;
}

/*  max-width:1052px;*/
/* styleで追加 (left:0px; right:0px;) */
/*static
特に配置方法を指定しません。この値のときには、top、bottom、left、rightは適用されず、初期値に配置します。（個人的に使わないです）
absolute
絶対位置への配置となります。親ボックスにpositionプロパティのstatic以外の値が指定されている場合には、親ボックスの左上が基準位置となります。親ボックスにpositionプロパティのstatic以外の値が指定されていない場合には、ウィンドウ全体の左上が基準位置となります。（個人的に単独で使う事はほぼないです）
relative
相対位置への配置となります。positionプロパティでstaticを指定した場合に表示される位置が基準位置となり、top、bottom、left、rightは適用されます。（個人的に単独では使わないです）
fixed
絶対位置への配置となるのはabsoluteと同じですが、スクロールしても位置が固定されたままとなります。（IE6は対応出来ていません...）
*/

.layer {
   float:none; clear:both;
   margin: 0 auto; padding: 0;
   z-index:11000;
   position:fixed;
/*   position: absolute; */
   visibility:hidden;
   width:100%;
   height:100%;
   overflow:hidden;
 }

.layer_top {
   position:absolute;
   visibility:visible;
   top:0;
   width:100%;
   min-height:114px;
   background-color: #FFF;
}
.menu_area {
  float:none; clear:both;
  margin:0 auto; padding: 0;
  min-width:250px;
  max-width:1300px;
/*  max-width:1024px;*/
}
.nav_area {
    float:none; clear:both;
    margin:0 auto; padding: 0;
    width:100%;
/*    background-color: #ffaaaa; */
    background-image: url(images/nav_area.png);
    background-repeat: repeat-x;
    background-position: bottom left;
}

.layer_left {
   position:absolute;
   visibility:visible;
   right:50%;
   margin-right: 512px;
   width:250px;
}

.layer_right {
   position:absolute;
   visibility:visible;
   left:50%;
   margin-left: 512px;
   width:250px;
}

.layer_center {
   position: absolute;
   visibility: visible;
   top:56px;
   width:100%;
 }

.layer_bottom {
   position:absolute;
   visibility: visible;
   bottom: 0;
   width:100%;
   height:25px;
   background-color: #FFF;
}
.copyright {
   margin: 0 auto; padding-top: 5px;
   color:#333;
   font-size:9px;
   text-align:center;
}

.layer_page {
   position:absolute;
   visibility: visible;
   right: 10px;
   bottom: 20px;
}

.layer_page_top {
   margin: 0 auto; padding: 0;
   visibility:visible;
}

.bxslider_area {
  margin: 0 auto; padding: 0;
  min-width:250px;
  max-width:1350px;
}

.footer_area {
  margin: 0 auto; padding: 0;
  width:100%;
  background-color: #ffaaaa;
}

.footer_center {
  float:none; clear:both;
  margin:0 auto; padding: 0;
  min-width:150px;
  max-width:1024px;
  color:#4d4d4d;
  font-weight: bold;
  text-shadow: none;
}

.footer_center a {
  color:#4d4d4d;
  font-weight: bold;
}

.cm_area {
   float:none; clear:both;
   margin: 0 auto; padding: 0;
   z-index:10000;
/*   position:relative; */
/*   position:absolute; */
   visibility:hidden;
   width:100%;
   height:100%;
   overflow:hidden;
 }

.cm_point {
   position:absolute;
   visibility: visible;
   top: 114px;
   left: 0;
}

.map_area {
   margin: 0 auto; padding: 5px;
   min-width:150px;
   max-width:600px;
}

.gmap_iframe {
	aspect-ratio:16/9;
	max-width:1000px;
	width:100%;
	height:auto;
}

.clear{
    float:none;
    clear:both;
}

.flexbox_wrapper {
  display: -webkit-flex;
  display: flex;
}
.flexbox_main {
  -webkit-flex: 1;
  flex: 1;
  width: 100%;
}
.flexbox_side {
  width: 300px;
}
.flexbox_top {
  height: 200px;
}

.canvas_box {
    border: 1px solid #ddd;
    color: #ccc;
    border-radius: 5px;        /* CSS3草案 */
    -webkit-border-radius: 5px;    /* Safari,Google Chrome用 */
    -moz-border-radius: 5px;   /* Firefox用 */
}

.border_on {
   margin: 0 auto;
   border-spacing: 0;
   border: 1px solid #ccc;
   border-radius: 5px;        /* CSS3草案 */
    -webkit-border-radius: 5px;    /* Safari,Google Chrome用 */
    -moz-border-radius: 5px;   /* Firefox用 */
   display:block;
}
.box_line {
    padding: .4em 1em;
    color: #333;
    border: 1px solid #ccc;
    border-radius: 5px;        /* CSS3草案 */
    -webkit-border-radius: 5px;    /* Safari,Google Chrome用 */
    -moz-border-radius: 5px;   /* Firefox用 */
}

.back_menu {
    font-size:18px;
    padding: 1.5em .5em 1.5em 5em;
    border: 1px solid #ccc;
    background-position: .5em .55em;
    background-repeat:no-repeat;
}

.border_img a img {
    border-width:1px;
}

a ,
a .box_line,
a .box_line_none,
.footer_area a {
  text-decoration: none;
  text-shadow: none;
}

a:hover ,
a:hover .box_line,
a:hover .box_line_none {
    filter:alpha(opacity=80);
    opacity: 0.80;
}

a:hover .ui-body {
   background-color: #f1f1f1;
}

.box_line_cheng a {
    position: relative;
    display: inline-block;
    padding: .4em 1em;
    width: 100%;
    color: #333;
    border: 1px solid #ccc;
    border-radius: 5px;        /* CSS3草案 */
    -webkit-border-radius: 5px;    /* Safari,Google Chrome用 */
    -moz-border-radius: 5px;   /* Firefox用 */
}
.box_line_cheng a span {
    width: 100%;
}

.box_line_cheng a::after {
  position: absolute;
  top: 0;
  left: 0;
  content: attr(data-adr) "\A" attr(data-tel);
  display: block;
  padding: .4em 1em;
  width: 100%;
  transition: .3s ease-in-out;
  opacity: 0;
  white-space: pre;
}

.box_line_cheng a span {
  display: inline-block;
  transition: .3s ease-in-out;
}

.box_line_cheng a:hover::after ,
.box_line_cheng a:focus::after {
  opacity: 1;
}

.box_line_cheng a:hover span ,
.box_line_cheng a:focus span {
  opacity: 0;
}

.font_color {
  color:#fb7482;
}


ul {
    margin:0 auto; position: 0;
}

dt {
    float: left;
}
dd {
    margin:0 auto;
}
dd::before {
    float:none;
    clear:both;
}

.text_indent {
  text-indent: 1em;
}

.text_headline ,
.text_headline_bold {
  position: relative;
}

.text_headline::after,
.text_headline_bold::after {
  position: absolute;
  top: 0;
  left: 0;
  content: attr(data-title);
  display: block;
}

.text_headline_bold::after {
  font-weight: bold;
}
.font_Awesome_red,
.font_Awesome_pink,
.font_Awesome_green,
.font_Awesome_orange,
.font_Awesome_blue {
  position: relative;
  word-wrap :break-word;
  overflow-wrap : break-word;
}

.font_Awesome_red::after,
.font_Awesome_pink::after,
.font_Awesome_green::after,
.font_Awesome_orange::after,
.font_Awesome_blue::after {
  position: absolute;
  top: 2%;
  left: .5em;
  z-index: 1;
  font-family: FontAwesome;
  font-weight: normal;
  content: attr(data-icon);
}
.font_Awesome_red::after {
  color: red;
}
.font_Awesome_pink::after {
  color: #fab6b5;
}
.font_Awesome_green::after {
  color: #00ae75;
}
.font_Awesome_orange::after {
  color: #fb8071;
}
.font_Awesome_blue::after {
  color: #3498db;
}

.font_Awesome_red::before,
.font_Awesome_pink::before,
.font_Awesome_green::before,
.font_Awesome_orange::before,
.font_Awesome_blue::before {
  position: absolute;
  top: 0;
  left: 2em;
  content: attr(data-title);
  display: block;
}

.text_make {
  position: relative;
}

.text_make::after {
  position: absolute;
  top: 0;
  left: 0;
  content: attr(data-title);
  display: block;
}

.text_make_1em {
  margin-left: 1em;
  text-indent: -1em;
}

.text_make_2em {
  margin-left: 2em;
  text-indent: -2.5em;
}

.text_make_5em {
  margin-left: 5em;
  text-indent: -5em;
}

.img_make_2em {
  padding-left: 2em;
  background: url("images/make_01.png") no-repeat left .3em;
}

.make_01 dt {
    padding-left: 2em;
  	position: relative;
}
.make_01 dt::after {
  position: absolute;
  top: 2%;
  left: .5em;
  z-index: 1;
  font-family: FontAwesome;
  font-weight: normal;
  content: attr(data-icon);
  color: red;
}

.make_01 dd {
  margin-left: 10em;
}

.make_02 dt {
    padding-left: 1.5em;
    padding-bottom: .5em;
    background: url("images/make_01.png") no-repeat left center;
}
.make_02 dd {
    margin-left: 10em;
    padding-bottom: .5em;
}

.make_03 ul {
  margin: 0;
  padding: 0;
  list-style: none;
}
.make_03 ul li {
  position: relative;
  padding-left: 2em;
}
.make_03 ul li::after,
.make_03 ul li::before {
  display: block;
  content: '';
  position: absolute;
}
.make_03 ul li::after {
  top: .2em;
  left: .5em;
  width: 14px;
  height: 14px;
  background-color: #fb7482;
  border-radius: 100%;
}
.make_03 ul li::before {
  z-index: 2;
  top: .5em;
  left: .8em;
  width: 4px;
  height: 4px;
  border-right: 1px solid #fff;
  border-bottom: 1px solid #fff;
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
}

.make_03 ul li a {
  display: block;
  text-decoration: none;
  color: #333;
}

.make_03 ul li a:hover  {
  color: #333;
}

.make_04 ul {
  margin: 0;
  padding: 0;
  list-style: none;
}
.make_04 ul li {
  position: relative;
  padding-left: 2em;
}
.make_04 ul li::after,
.make_04 ul li::before {
  display: block;
  content: '';
  position: absolute;
}
.make_04 ul li::after {
  top: .2em;
  left: .5em;
  width: 14px;
  height: 14px;
  background-color: #ffaaaa;
  border-radius: 100%;
}
.make_04 ul li::before {
  z-index: 2;
  top: .5em;
  left: .8em;
  width: 4px;
  height: 4px;
  border-right: 1px solid #fff;
  border-bottom: 1px solid #fff;
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
}

.make_04 ul li a {
  display: block;
  text-decoration: none;
  color: #333;
}

.make_04 ul li a:hover  {
  color: #333;
}

.link_h4 {
  margin-top:0;
  margin-bottom:0;
  font-size:18px;
}

.back_bar {
    font-size:18px;
    padding: .5em 1em;
    border: 1px solid #ccc;
    border-bottom: 3px solid #3498db;
    background: -webkit-linear-gradient(top, #fff 0%, #f0f0f0 100%);
    background: linear-gradient(to bottom, #fff 0%, #f0f0f0 100%);
    box-shadow: 0 -1px 0 rgba(255, 255, 255, 1) inset;
}

/*  バックのライン用 */
/*  <div class="back_line"><div><span>ABC</span></div></div> */
.back_line {
    position: relative;
    text-align: center;
    font-size:24px;
}

.back_line div::before {
    position: absolute;
    top: 50%;
    z-index: 1;
    content: '';
    display: block;
    width: 100%;
    height: 1px;
    background: #ccc;
    background: -webkit-linear-gradient(-45deg, transparent, #ccc 10%, #ccc 90%, transparent);
    background: linear-gradient(-45deg, transparent, #ccc 10%, #ccc 90%, transparent);
}

.back_line div span {
    position: relative;
    z-index: 2;
    display: inline-block;
    margin: 0 2.5em;
    padding: 0 1em;
    background-color: #fff;
    text-align: left;
    font-weight: bold;
}

div .back_box {
    position: relative;
    margin-top: 2.25em;
    padding: 2em 1em 1em;
    border: 1px solid #ddd;
    border-radius: 5px;        /* CSS3草案 */
    -webkit-border-radius: 5px;    /* Safari,Google Chrome用 */
    -moz-border-radius: 5px;   /* Firefox用 */
    background-color:#f9f9f9;
}

div .back_box::after {
    position: absolute;
    padding: .5em 0;
    top: -1.25em;
    left: 5%;
    z-index: 1;
    content: attr(data-title);
    display: block;
    background-color:#ffe6d5;
    width: 90%;
    font-size:18px;
    font-weight: bold;
    text-align:center;
    border: 2px solid #ffaaaa;
    border-radius: 5px;        /* CSS3草案 */
    -webkit-border-radius: 5px;    /* Safari,Google Chrome用 */
    -moz-border-radius: 5px;   /* Firefox用 */
}

.back_box2 {
    margin-top: 1em;
    position: relative;
    padding: 1em;
    border: 1px solid #ddd;
    border-radius: 5px;        /* CSS3草案 */
    -webkit-border-radius: 5px;    /* Safari,Google Chrome用 */
    -moz-border-radius: 5px;   /* Firefox用 */
}

.back_box2::after {
    position: absolute;
    padding: .5em 0;
    top: -1.25em;
    left: 5%;
    z-index: 1;
    background-color:#f9f9f9;
    content: attr(data-title);
    display: inline-block;
    font-size:14px;
    font-weight: bold;
}


.back_box_bar {
    position: relative;
    padding: .5em .5em .5em 2em;
    font-size:16px;
    font-weight: bold;
}

.back_box_bar::after {
    bottom: .25em;
    content: '';
    display: block;
    width: 100%;
    height: 1px;
    background: #fb8071;
    background: -webkit-linear-gradient(-45deg, transparent, #fb8071 10%, #fb8071 90%, transparent);
    background: linear-gradient(-45deg, transparent, #fb8071 10%, #fb8071 90%, transparent);
}

.back_box_bar::before {
    position: absolute;
    top: .5em;
    left: .5em;
    content: '';
    width: 6px;
    height: -webkit-calc(100% - 1em);
    height: calc(100% - 1em);
    background-color: #fb8071;
}

.back_line_bar {
    position: relative;
    padding: .5em .5em .5em 0em;
    font-size:16px;
    font-weight: bold;
}

.back_line_bar::after {
    bottom: .25em;
    content: '';
    display: block;
    width: 100%;
    height: 1px;
    background: #fb8071;
    background: -webkit-linear-gradient(-45deg, transparent, #fb8071 10%, #fb8071 90%, transparent);
    background: linear-gradient(-45deg, transparent, #fb8071 10%, #fb8071 90%, transparent);
}

.back_dog1 {
    position: relative;
    text-align: center;
    font-size:18px;
    background-color:#f6f6f6;
    height:2em;
}

.back_dog1 div::after {
    position: absolute;
    top: 0;
    right: 0;
    content: '';
    width: 0;
    border-width: 0 16px 16px 0;
    border-style: solid;
    border-color: #fff #fff #ddd #ddd;
    box-shadow: -1px 1px 2px rgba(0, 0, 0, .1);
}

.back_dog1 div span {
    position: relative;
    z-index: 2;
    display: inline-block;
    padding-top: 0.25em;
}

.back_dog2 {
    position: relative;
    text-align: center;
    font-size:18px;
    position: relative;
    padding: 1em 4em 1em 1em;
    -webkit-background: linear-gradient(-155deg, rgba(0, 0, 0, 0) 1.5em, #f6f6f6 0%);
    background: linear-gradient(-155deg, rgba(0, 0, 0, 0) 1.5em, #f6f6f6 0%);
    border-radius: 6px;
}

.back_dog2 div::after {
    position: absolute;
    top: 0;
    right: 0;
    content: '';
    width: 1.65507em;
    height: 3.5493em;
    background: -webkit-linear-gradient(to left bottom, rgba(0, 0, 0, 0) 50%, rgba(0, 0, 0, .1) 0%, rgba(0, 0, 0, .2));
    background: linear-gradient(to left bottom, rgba(0, 0, 0, 0) 50%, rgba(0, 0, 0, .1) 0%, rgba(0, 0, 0, .2));
    border-bottom-left-radius: 6px;
    box-shadow: -.2em .2em .3em -.1em rgba(0, 0, 0, .15);
    -webkit-transform: translateY(-1.89424em) rotate(-40deg);
    transform: translateY(-1.89424em) rotate(-40deg);
    -webkit-transform-origin: bottom right;
    transform-origin: bottom right;
}

.back_dog2 div span {
    position: relative;
    z-index: 2;
    display: inline-block;
}

.back_acc {
    position: relative;
    padding: .75em 1em .75em 1.5em;
    border: 1px solid #ccc;
    font-size:18px;
}

.back_acc2 {
    position: relative;
    padding: .75em 1em .75em 1.5em;
    border-bottom: 1px solid #ccc;
		text-shadow: none;
    color:  white;
    font-weight: bold;
    font-size:18px;
    border-radius: 5px;        /* CSS3草案 */
    -webkit-border-radius: 5px;    /* Safari,Google Chrome用 */
    -moz-border-radius: 5px;   /* Firefox用 */
}

.back_acc div::after,
.back_acc2 div::after {
    position: absolute;
    top: .5em;
    left: .5em;
    content: '';
    width: 6px;
    height: -webkit-calc(100% - 1em);
    height: calc(100% - 1em);
    background-color: #fff;
    border-radius: 4px;
}

.border_solid_line {
  padding-top: 1em;
  padding-bottom: 1em;
  border-bottom: 1px solid #ccc;
}

.border_dotted_line {
  padding-top: .5em;
  padding-bottom: .5em;
  border-bottom: 1px dotted #ccc;
}

.link_img_left ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

.link_img_left ul li {
  padding-top: .5em;
  padding-bottom: .5em;
  border-top: 1px dotted #ccc;
  border-bottom: 1px dotted #ccc;
}

.link_img_left ul li:not(:first-child) {
  border-top: none;
}

.link_img_left ul li img {
  margin-right: 1em
}

.line_on table {
   width:100%;
   border-spacing: 0;
   border-top: 1px solid #c7c7c7;
   border-left: 1px solid #c7c7c7;
}

.line_on tr, .line_on th, .line_on td {
   border-right: 1px solid #c7c7c7;
   border-bottom: 1px solid #c7c7c7;
}

.float_group_body::after {
  display: block;
  clear: both;
  content: '';
}
.float_group::after {
  display: block;
  clear: both;
  content: '';
}

.float_left{
    float: left;
}

.float_left > img {
  margin-right: 1em
}

.flexbox_left {
    display:-webkit-box;
    display:-moz-box;
    display:-ms-box;
    display:-webkit-flexbox;
    display:-moz-flexbox;
    display:-ms-flexbox;
    display:-webkit-flex;
    display:-moz-flex;
    display:-ms-flex;
    display:flex;
    -webkit-box-lines:multiple;
    -moz-box-lines:multiple;
    -webkit-flex-wrap:wrap;
    -moz-flex-wrap:wrap;
    -ms-flex-wrap:wrap;
    flex-wrap:wrap;
    -webkit-box-direction:row;
    -moz-box-direction:row;
    -webkit-flex-direction:row;
    -moz-flex-direction:row;
    flex-direction:row;
}


.block_left {
    display:inline-block;
    /display:inline;
    /zoom:1;
    letter-spacing: normal;
}
.block_spacing {
  letter-spacing: -1em; /* 文字間を詰めて隙間を削除する */
}

.float_right{
    float: right;
}

.top_1em {
    padding-top: 1em;
}

.top_5px {
    padding-top: 5px;
}

.top_10px {
    padding-top: 10px;
}

.top_15px {
    padding-top: 15px;
}

.top_20px {
    padding-top: 20px;
}

.top_40px {
    padding-top: 40px;
}
.top_60px {
    padding-top: 60px;
}

.left_1em {
    padding-left: 1em;
}

.left_2em {
    padding-left: 2em;
}

.left_5px {
    padding-left: 5px;
}

.left_10px {
    padding-left: 10px;
}

.left_20px {
    padding-left: 20px;
}

.right_1em {
    padding-right: 1em;
}

.right_5px {
    padding-right: 5px;
}

.right_10px {
    padding-right: 10px;
}

.right_20px {
    padding-right: 20px;
}

.text_left {
  text-align:left;
}

.text_center {
  text-align:center;
}

.text_right {
  text-align:right;
}

.text_baseline {
  vertical-align: baseline;
}

.text_top {
  vertical-align: top;
}

.text_middle {
  vertical-align: middle;
}

.text_bottom {
  vertical-align: bottom;
}

.text_nowrap {
  white-space: nowrap;
}
.text_bold {
  font-weight: bold;
}

.text_underline {
  text-decoration: underline;
}

.text_box {
  margin:0 auto; padding: 0;
  border: 1px solid #ccc;
  display: inline-block;
}

.font_8px {
  font-size:8px;
}
.font_9px {
  font-size:9px;
}
.font_10px {
  font-size:10px;
}
.font_11px {
  font-size:11px;
}
.font_12px {
  font-size:12px;
}
.font_14px {
  font-size:14px;
}
.font_16px {
  font-size:16px;
}
.font_18px {
  font-size:18px;
}
.font_20px {
  font-size:20px;
}
.font_22px {
  font-size:22px;
}
.font_24px {
  font-size:24px;
}

ul#fontSize {
  margin: 0 auto; padding: 0;
}

ul#fontSize li {
  margin-left: 2px;
  float: left;
  cursor: pointer;
  display: block;
}

ul#fontSize::after {
  display: block;
  clear: both;
  content: '';
}


@media print {
    /* 通常のプリントは見たままを印刷したい。 */
    /* 印刷ボタンを表示しているボックスだけ印刷時に非表示 */
  .layer
  {
     position:relative;
  }
  .print_no ,
  .layer_left,
  .layer_right,
  .layer_page {
    display:none;
  }
}