
@charset "UTF-8";
/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝　初期設定　＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
*{
	margin: 0;
	padding: 0;
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
	font-family: 'Noto Sans JP', sans-serif;
}

body {
width:100%;
color:#000;
display:-webkit-box;
display:-ms-flexbox;
display:flex;
-webkit-box-orient: vertical;
-webkit-box-direction: normal;
-ms-flex-direction: column;
flex-direction: column;
min-height: 100vh;
font-family:"Yu Gothic", "游ゴシック", YuGothic, "游ゴシック体", 'Noto Serif JP', sans-serif;
}

.wrapper {
overflow:hidden;
}

footer {
background:#000;
text-align:center;
font-size:.8em;
margin-top:auto;
padding-top:0.8em;
color:#FFF;
}


.bg_white {
  padding:6%;
  background:#FFF;
}

/*画像メニュー */
.bn_hover {
background: #000;
}
.bn_hover img{
  width: 100%;
  cursor: pointer;
  transition-duration: 0.3s;
}
.bn_hover :hover {
	  opacity:0.6;
  transition-duration: 0.3s;
}


/* other
--------------------------- */
@media screen and (min-width: 579px) {
	.br-sp { display:none; }
}

@media screen and (max-width: 579px) {
	.br-sp2 { display:none; }
}


a:focus, *:focus {
	outline:none;
}


/* ＝＝＝＝＝＝＝＝＝＝＝＝＝　common　＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */

.maincontainer {
	max-width:1200px !important;
  margin: 0 auto;
  padding-left: 15px;
  padding-right: 15px;
}

.rl15-container {
  max-width: 1000px;
  position: relative;
  margin: 0 auto;
  padding-left: 15px;
  padding-right: 15px;
}

.rl90-container {
  max-width:900px;
  position: relative;
  margin: 0 auto;
  padding-left: 15px;
  padding-right: 15px;
}

.rl80-container {
  max-width: 800px;
  position: relative;
  margin: 0 auto;
  padding-left: 15px;
  padding-right: 15px;
}

.rl60-container {
  max-width: 600px;
  position: relative;
  margin: 0 auto;
  padding-left: 45px;
  padding-right: 45px;
}


p.lead {
margin:.5em 0 0.5em 1em;
font-size:1em;
}
p.lead2 {
margin:1.2em 0 1.2em 1em;
font-size:1em;
}

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝　ナビゲーション固定　＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
nav{
  position: fixed;
  z-index: 9999;
  top: 0;
  left: 0;
  width: 100%;
  height: auto;
}


/* ＝＝＝＝＝＝＝＝＝＝＝＝＝　footer navi　＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
.footer_nav ul {
text-align:center;
}

.footer_nav li {
display: inline-block;
}
.footer_nav li a {
color:#FFF;
}
.footer_nav li:after {
  content: '|';
color:#FFF;
margin-left:8px;
margin-right:8px;
}


@media screen and (max-width: 768px) {
	.footer_nav {
		display:none;	
	}
}

.sns_icon ul {
text-align:center;
font-size:0;
}

.sns_icon li {
display: inline-block;
  font-size: 0.9rem;
}
.sns_icon li a {
color:#FFF;
}



/* ＝＝＝＝ 地図 ＝＝＝＝＝ */
#gmap {
	float:left;
	width:100%;
	height:500px;
	margin:0px 0px 0px 0px;
}
.maph4 {
	color:#034a7f;
	font-weight: 900; 
	font-size:12px;
}
.popup {
	width:200px;
	height:50px;
	padding:5px;
	white-space: nowrap;
}

/* ＝＝＝＝ index access ＝＝＝＝＝ */
ul.ul_access {
border:solid 2px #6e4217;
border-radius :8px;
  box-shadow :0px 0px 3px #d96f32;
  padding: 0.5em 0.5em 0.5em 2em;
list-style-type: square;
margin-top:3em;
}
ul.ul_access li {
  line-height: 1.5;
  padding: 0.5em 0;
font-size:1.1rem;
}
:not(.square_nashi){
list-style-type: none;
}



/*============================
Title
============================*/
.main_title {
  position: relative;
  display: inline-block;
  padding: 0 90px;
color:#000;
font-family:font-family: "Sawarabi Mincho"; 

margin:0 auto;
}
.main_title:after {
  content: '';
  position: absolute;
  top: 50%;
  display: inline-block;
  width: 88px;
  height: 2px;
  background-color: #ed4f5d;
  -webkit-transform: rotate(-60deg);
  transform: rotate(-60deg);
}
.main_title:after {
  right: 0;
}
@media screen and (max-width: 767px) {
.main_title {
  font-size: 1.2rem;
}
.main_title:before, .main_title:after {
  content: '';
  position: absolute;
  top: 50%;
  display: inline-block;
  width: 44px;
  height: 2px;
  background-color: #ed4f5d;
  -webkit-transform: rotate(-60deg);
  transform: rotate(-60deg);
}
.main_title:before {
  left: 0;
}
}


/* ＝＝＝＝＝＝＝＝＝＝＝＝＝　ナビゲーション　＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */

.navigation {
width:100%;
padding:0.5em;
 display: -webkit-box;
 display: -webkit-flex;
 display: -ms-flexbox;
 display: flex;
 -webkit-box-align: center;
    -ms-flex-align: center;
    -webkit-align-items: center;
    align-items: center;
    height:110px;
background: rgba(0,0,0,0.2);
}

.navigation >:last-child {
margin-left:auto;
}

@media only screen and (max-width: 1024px) {
.navigation {
    height: 70px;
  }
}

.is-fixed {/*かく順番大切　navigation より下に記入*/
  position: fixed;
  z-index:999999;
background: rgba(0,0,0,0.9);
    height: 70px;
}


@media only screen and (max-width: 1024px) {
.is-fixed {
    height: 70px;
}
}
.toplogo {
max-width:160px;
padding:0 20px 0 10px;
}
.tel {
	align-self:center;
	margin:0.8em 0 0 0;

}
.toggleMenu {
  position: absolute;
  top: 50%;
  bottom: auto;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
    background: #000;
    color: #fff;
z-index:999999;
  display: table;
  height: 100%;
  padding: 15px 1em;
  font-size: 0.8rem;/*アイコンの文字サイズ*/
  text-transform: uppercase;
  font-weight: bold;
  right: 0;
}
.toggleMenu span {
  /* vertically align inside parent element */
  display: table-cell;
  vertical-align: middle;
}
.toggleMenu span, .toggleMenu span::after, .toggleMenu span::before {
  /* this is the menu icon */
  display: block;
  position: relative;
  height: 2px;
  width: 30px;
  background: #FFF;/* ×印の色 */
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
}
.toggleMenu span {
  /* this is the menu central line */
  margin: 12px auto 14px;
  -webkit-transition: background-color .2s;
  transition: background-color .2s;
}
.toggleMenu span::before, .toggleMenu span::after {
  position: absolute;
  content: '';
  left: 0;
  -webkit-transition: -webkit-transform .2s;
  transition: -webkit-transform .2s;
  transition: transform .2s;
  transition: transform .2s, -webkit-transform .2s;
}
.toggleMenu span::before {
  /* this is the menu icon top line */
  -webkit-transform: translateY(-6px);
      -ms-transform: translateY(-6px);
          transform: translateY(-6px);
}
.toggleMenu span::after {
  /* this is the menu icon bottom line */
  -webkit-transform: translateY(6px);
      -ms-transform: translateY(6px);
          transform: translateY(6px);
}

.toggleMenu.active span{
  /* transform menu icon into a 'X' icon */
  background: rgba(255, 255, 255, 0);
}
.toggleMenu.active span::before {
  /* rotate top line */
  -webkit-transform: rotate(-45deg);
      -ms-transform: rotate(-45deg);
          transform: rotate(-45deg);
}
.toggleMenu.active span::after {
  /* rotate bottom line */
  -webkit-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
          transform: rotate(45deg);
}

.d_nav {
margin-bottom:0;/*余計なマージンをとる*/
    list-style: none;
}
.d_nav:before,
.d_nav:after {
    content: " "; 
    display: table; 
}
.d_nav:after {
    clear: both;
}
.d_nav ul {
    list-style: none;
    width: 14em;
}
.d_nav a {
    padding:10px;
    text-decoration: none;
    outline: none;
    color:#FFF;
}
.d_nav a:visited {
	text-decoration: none;
}

.d_nav a:hover {
    color:red;
}

.d_nav li {
    position: relative;
	padding:0;/*navとnavの間*/
}
.d_nav > li {
    float: left;
}
.d_nav > li > .parent {
    background-image: url("images/downArrow.png");
    background-repeat: no-repeat;
    background-position: right;
}
.d_nav > li > a {/*navのtitle*/
    display: block;
    font-size: 1rem;
	margin:0 3px;/*navとnavの間*/
}
.d_nav li  ul {
    position: absolute;
    left: -9999px;
}
.d_nav > li.hover > ul {
    left: 0;
}
/*.d_nav li li.hover ul {
    left: 100%;
    top: 0;
}

.d_nav li li a {
    display: block;
    background:#FFF;
    position: relative;
    z-index:100;
    border-top: 1px solid #000;
    font-size: 0.9rem;
}

.d_nav li li li a {
    background:#249578;
    z-index:200;
    border-top: 1px solid #1d7a62;
}
*/
@media screen and (min-width: 1024px) {
.sp_nav{
	display:none;
	}
}


@media screen and (max-width: 1024px) {
.navigation {/*これが重要*/
width:100%;
display:block;
padding:0;
}
}
@media screen and (max-width: 1024px) {
.d_nav {
margin-top:68px;
    }
.d_nav li {
    position: relative;
	padding:3px;
    border-top:1px solid #FFF;
    }
    .active {
        display: block;
    }
    .d_nav li ul {
padding-top:0;
}
    .d_nav > li {
background:#000;/*スマホメニューだけで色を設定したい場合はここに*/
        float: none;
    }
    .d_nav > li a {
    font-size: 0.9rem;
}
    .d_nav > li > .parent {
        background-position: 95% 50%;
    }
    .d_nav li li .parent {
        background-image: url("images/downArrow.png");
        background-repeat: no-repeat;
        background-position: 95% 50%;
    }
    .d_nav ul {
        display: block;
        width: 100%;
    z-index: -1;
    }
   .d_nav > li.hover > ul , .d_nav li li.hover ul {
        position: static;
    z-index: 1;
    }
}

.nav_tel {
color:#FFF;
}
.orange2 {
color :orange;
}
