@charset "utf-8";


/* ************************************************ 
*	基本設定
* ************************************************ */	
body {
font-family: 'Roboto','Noto Sans JP','Sawarabi Gothic',sans-serif;
font-size: min(1.7vw,16px);
background:#fff;
color: #333;
line-height: 180%;
overflow-x: hidden;
}

/* リンク */
a{
	color:#333;
	text-decoration: none;
	transition: 0.5s;
	-webkit-transition: 0.5s;
	-moz-transition: 0.5s;
	-o-transition: 0.5s;
	-ms-transition: 0.5s;
}

a:hover{
color:#000;
}

a:active, a:focus {
outline: 0;
}


/* 画像 */
img{
border:0;
padding:0px;
margin:0px
vertical-align: bottom;
}

img a{
	transition: 0.5s;
	-webkit-transition: 0.5s;
	-moz-transition: 0.5s;
	-o-transition: 0.5s;
	-ms-transition: 0.5s;
}


/* フロート */
.right{ float: right; }
.left{ float: left; }
.clear{ clear:both; }


/* リスト */
ol{
margin: 0 0 0 5px;
padding: 0 0 0 0;
list-style: decimal;
}

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

li{
margin: 0 0 10px 15px;
padding: 0 0 0 0;
}

li a{
color:#444;
transition: 0.5s;
-webkit-transition: 0.5s;
-moz-transition: 0.5s;
-o-transition: 0.5s;
-ms-transition: 0.5s;
}

li a:hover{
color:#03335d;
}

#topcontrol{
z-index:99999;
}

ruby {
color: #fff;
}


/*---------------------------------------------------------------------------------
エフェクト
--------------------------------------------------------------------------------- */
/* 画面外にいる状態 */
.effect {
  opacity : 0;
  transition : all 900ms 300ms ease-out;
  transform: translate(0,0);
}
.fv-effect {
  transition : all 300ms 300ms ease-out;
  transform: translate(0,0);
  opacity: 0;
}
.fade-drop {
  transform: translate(0,-50px);
}
.fade-rize {
  transform: translate(0,50px);
}
.fade-left-in {
  transform: translate(-50px,0);
}
.fade-right-in {
  transform: translate(50px,0);
}
.fade-matrix {
  transform: translate(0,50px) matrix(1,0.09,0.00,1,0,0);
}

/* 画面内に入った状態 */
.effect-on {
  opacity: 1.0;
  transform: translate(0,0px);
}
.effect-on a:hover{
  opacity: 0.8;
  transform: translate(0,0px);
}
/*ファーストビューエフェクト*/
.loaded .fv-effect {
  opacity: 1;
  transform: translate(0,0)!important;
}


/* ************************************************ 
*	全体Wrapper
* ************************************************ */	
.wrapper {
margin: 0 auto; 
width: 1260px;
max-width: 90%;
padding: 0;
}
.wrapper2 {
margin: 0 auto; 
width: 100%;
padding: 0;
}
.wrapper1000 {
margin: 0 auto; 
width: 1000px;
max-width: 90%;
padding: 0;
}
.wrapper1120 {
margin: 0 auto; 
width: 1120px;
max-width: 90%;
padding: 0;
}
.contents-box {
margin: 0;
padding: 100px 0 0 0; 
width: 100%;
position:relative;
z-index:1;
-moz-box-shadow: 0px 3px 2px rgba(0,0,0,0.1);
-webkit-box-shadow: 0px 3px 2px rgba(0,0,0,0.1);
-o-box-shadow: 0px 3px 2px rgba(0,0,0,0.1);
-ms-box-shadow: 0px 3px 2px rgba(0,0,0,0.1);
box-shadow: 0px 3px 2px rgba(0,0,0,0.1);
}
.contents-wrapper {
margin: 0; 
padding: 0 0 100px 0;
}


/* ************************************************ 
*	ヘッダー
* ************************************************ */
#header {
width: 100%;
margin: 0;
background: #000;
position: absolute;
}
.header-inner {
margin: 0 auto;
padding: 0;
width: 90%;
position: relative;
z-index:9;
display: flex;
flex-wrap: wrap;
justify-content: space-between;
align-items: center;
}

#header h1 {
margin: 0 0 0 0;	
}

.logo {
float: left;
margin: 0;
padding: 0;
}
.logo img{
width: 240px;
}

.header-logobox {
padding: 0;
width:30%;
}
.header-navbox {
padding: 0;
display: flex;
justify-content: flex-end;
align-items: center;
align-content: center;
flex-wrap: wrap;
}


/* ************************************************ 
*	トップナビゲーション
* ************************************************ */	
#navDmy{
display:none !important;
}
#nav_bg {
width: 100%;
height:100px;
padding: 0;
margin: 0;
position: relative;
z-index:9999;
background: #000;
display: flex;
flex-wrap: wrap;
align-items: center;
}

/* 上部固定用 */
#nav_bg.active{
position:fixed;
top:0;
left:0;
z-index:99999;
background: rgba(0,0,0,0.9);
transition: 0.8s;
-moz-box-shadow: 0px 3px 3px rgba(0,0,0,0.1);
-webkit-box-shadow: 0px 3px 3px rgba(0,0,0,0.1);
-o-box-shadow: 0px 3px 3px rgba(0,0,0,0.1);
-ms-box-shadow: 0px 3px 3px rgba(0,0,0,0.1);
box-shadow: 0px 3px 3px rgba(0,0,0,0.1);
}
/* 上部固定用ここまで */

.nav {
width:100%;
margin: 0 auto 0px auto;
}

.nav ul {
list-style: none;
margin: auto;
letter-spacing: -0.5em; /* 隙間を埋める追加 */
}

.main-navigation {
clear: both;
margin: 0 auto;
position: relative;
}

ul.nav-menu,
div.nav-menu > ul {
margin: 0;
padding: 0;
}

.nav-menu li {
font-family: 'Noto Sans JP';
font-weight: 500;
display: inline-block;
line-height: 16px;
position: relative;
margin: 17px 20px 0 20px;
padding: 0;
float: left; 
text-align:center;
letter-spacing: normal; /* 隙間を埋める追加 */
cursor: pointer;
cursor: hand;
}
.nav-menu li a {
color: #fff;
display: block;
font-size: 16px;
text-decoration: none;
margin: 0;
padding: 0;
}
.nav-menu li a:after {
content: '';
width: 0;
transition: all 0.3s ease;
border-bottom: 3px solid #fff;
display: block;
padding-bottom:15px;
}
.nav-menu li a:hover:after {
width: 100%;
}



#nav_bg.active .nav-menu li a {
color: #fff;
}
#nav_bg.active .nav-menu li a:hover {
color: #fff;
}

.nav-menu li:hover > a,
.nav-menu li a:hover {
color: #fff;
}

.nav-menu .sub-menu {
background-color: rgba(255,255,255,0);
display:none;
position: absolute;
z-index: 99999;
padding: 0 0 0 0;
}

.nav-menu .sub-menu li {
padding: 0;
margin: 0;
}

.nav-menu .sub-menu li a {
color: #333;
display: block;
font-size: 15px;
text-decoration: none;
padding: 20px 0 20px 15px;
text-align: left;
width: 205px;
height:20px;
border-bottom: none;
background-color: rgba(255,255,255,0.9);
}
.nav-menu .sub-menu li a:hover {
border-bottom: none!important;
background-color:rgba(86,169,89,0.8);
color: #fff!important;
}

.nav-menu .sub-menu ul {
}

ul.nav-menu ul a,
.nav-menu ul ul a {
color: #fff;
margin: 0;
}

ul.nav-menu ul a:hover,
.nav-menu ul ul a:hover {
}

ul.nav-menu li:hover > ul,
.nav-menu ul li:hover > ul {
display: block;
}

.nav-menu .current_page_item > a,
.nav-menu .current_page_ancestor > a,
.nav-menu .current-menu-item > a,
.nav-menu .current-menu-ancestor > a {
}


/* ************************************************ 
*	スライド
* ************************************************ */	
@keyframes zoomUp { 
  0% {
      -webkit-transform: scale(1);
      transform: scale(1);
  }
  100% {
      -webkit-transform: scale(1);
      transform: scale(1);
  }
}
.swiper-wrapper {
  margin-top: 100px;
  margin-bottom: -100px;
}
.swiper-container {
-moz-box-shadow: 0px 3px 3px rgba(0,0,0,0.1);
-webkit-box-shadow: 0px 3px 3px rgba(0,0,0,0.1);
-o-box-shadow: 0px 3px 3px rgba(0,0,0,0.1);
-ms-box-shadow: 0px 3px 3px rgba(0,0,0,0.1);
box-shadow: 0px 3px 3px rgba(0,0,0,0.1);
}
.swiper-slide {
  overflow: hidden;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

.swiper-slide-active .slide-img,
.swiper-slide-duplicate-active .slide-img,
.swiper-slide-prev .slide-img { /* 8秒かけて拡大させる */
    -webkit-animation: zoomUp 8s linear 0s;
    animation: zoomUp 8s linear 0s;
    -webkit-animation-fill-mode: both;
    animation-fill-mode: both;
}

.swiper-pagination-bullets {
    bottom: 20px!important;
}
.swiper-pagination-bullet {
  border-radius: 0!important;
  margin: 0 5px!important;
  width: 55px!important;
  height: 5px!important;
}

.slide-img {
    background-size: cover; 
    background-position: center center; /* 背景画像は中央を軸に表示させる */
    height: 100vh; 
}

.slide-text {
position: absolute;
z-index: 10;
width: 90%;
bottom:7%;
left: 5%;
}
.slide-text h2{
font-family: 'Noto Sans JP';
font-size:2.75vw;
line-height: 1;
color: #fff;
font-weight: 500;
background-color: #000;
display: inline-block;
padding: 10px 10px 13px 10px;
margin: 0 0 10px 0;
}


/* ************************************************ 
*	各ブロックタイトル
* ************************************************ */	
.pagetitle-box {
margin: 0 auto;
padding: 0 0 60px 0;
text-align:center;
}
.pagetitle-box2 {
margin: 0 auto;
padding: 0;
text-align:left;
}
.pagetitle {
margin: 0 auto;
padding: 0 0 10px 0;
font-size: min(5.0vw,50px);
text-align:center;
font-weight:500;
letter-spacing: 0.05em;
}
.pagetitle-en {
margin: 0 auto;
padding: 0;
font-size: min(2.4vw,24px);
text-align:center;
font-weight:700;
letter-spacing: 0.05em;
}


/* ************************************************ 
*	パンくずリスト
* ************************************************ */	
.breadcrumbs {
margin: auto; 
padding: 15px 0;
text-align:left;
font-size: min(1.5vw,14px);;
overflow: hidden;
color: #333;
}
.breadcrumbs a{
color: #333;
transition: 0.5s;
-webkit-transition: 0.5s;
-moz-transition: 0.5s;
-o-transition: 0.5s;
-ms-transition: 0.5s;
}
.breadcrumbs a:hover{
color: #000;
text-decoration: underline;
}


/* ************************************************ 
*	メイン（本文）コンテンツ
* ************************************************ */	
#main {
margin:0 0 0 0;
padding: 0 0 0 0;
word-break:break-all;
}

.clear	{ clear: both; } 
.mT10	{ margin-top:10px; }
.mT20	{ margin-top:20px; }
.mT30	{ margin-top:30px; }
.mT40	{ margin-top:40px; }
.mB10	{ margin-bottom:10px; }
.mB20	{ margin-bottom:20px; }

.imgcenter{
text-align:center;
margin: 0 auto;
padding: 0;
}
.imgcenter img {
  vertical-align: bottom;
}
.htext{
text-align:center;
}

/* 記事部分 */	
p {
padding: 0;
line-height: 200%;
}

p a {
color:#ec817f;
text-decoration:underline;
transition: 0.5s;
-webkit-transition: 0.5s;
-moz-transition: 0.5s;
-o-transition: 0.5s;
-ms-transition: 0.5s;
}

p a:hover {
color:#000;
text-decoration:none;
}

p a:active, a:focus {
outline: 0;
}


/* フォント */	
.mincho {
font-family:'century','Times New Roman','Baskerville','Optima','Palatino','Georgia','ヒラギノ明朝 Pro W3','Hiragino Mincho Pro','HGS明朝E','ＭＳ Ｐ明朝','MS PMincho',serif;
}

.bold {
font-weight: bolder;
}

.italic {
font-style: italic; 
}
.dllink {
margin: 10px auto 5px auto;
padding: 0;
background-color:#1462be;
text-align:center;
width: 40%;
}
.dllink a{
color: #fff;
display: block;
padding: 10px 0px;
font-size:18px;
line-height: 210%;
}
.dllink a:hover{
color: #fff;
background-color:#03335d;
}
.alllink {
margin: 10px auto 5px auto;
padding: 0;
background-color:#fff;
text-align:center;
width: 30%;
}
.alllink a{
color: #333;
display: block;
padding: 15px 0px;
font-size: min(1.8vw,16px);
border: 1px solid #333;
border-radius: 50vh; /* CSS3 */
 -webkit-border-radius: 50vh; /* Firefox */
 -moz-border-radius: 50vh; /* Safari,Chrome */
}
.alllink a:hover{
color: #fff;
border: 1px solid #000;
background-color:#000;
border-radius: 50vh; /* CSS3 */
 -webkit-border-radius: 50vh; /* Firefox */
 -moz-border-radius: 50vh; /* Safari,Chrome */
}


/* ************************************************ 
*	トップスケジュール
* ************************************************ */	
.top-schedule-block {
width: 100%;
padding: 100px 0;
margin: 0 auto;
background-color: #e5f5f8;
}
.top-schedule {
width: 800px;
max-width: 90%;
padding: 0;
margin: 0 auto;
}
.top-schedule .month-box{
width: 100%;
display: flex;
flex-wrap: wrap;
justify-content: space-between;
align-items: center;
align-content: center;
}
.top-schedule .prevbox{
width: 15%;
text-align: left;
}
.top-schedule .monthbox{
width: 60%;
text-align: center;
}
.top-schedule .monthbox h3{
font-size: min(3.1vw,30px);
}
.top-schedule .nextbox{
width: 15%;
text-align: right;
}
.top-schedule .prevbox a,
.top-schedule .nextbox a{
padding: 4px 8px 5px 8px;
text-decoration: none;
border: 1px solid #999;
line-height: 1;
font-size: 15px;
background-color: #fff;
}
.top-schedule .prevbox a:hover,
.top-schedule .nextbox a:hover{
border: 1px solid #000;
background-color: #000;
color: #fff;
}

.top-schedule table#calendar {
width: 100%;
margin: 10px 0 0 0;
padding: 0 0 0 0;
border-top: 1px #999 solid;
border-left: 1px #999 solid;
border-collapse: collapse;
border-spacing: 0;
background-color: #fff;
}
.top-schedule table#calendar th {
font-weight: normal;
text-align: center;
padding: 2px 0;
color:#333;
white-space: nowrap; 
vertical-align: middle;
border-right: 1px #999 solid;
border-bottom: 1px #999 solid;
background-color:#efefef;
width: calc(100%/7);
}
.top-schedule table#calendar td {
text-align: right;
padding: 0px 3px;
white-space: normal;
vertical-align: top;
border-right: 1px #999 solid;
border-bottom: 1px #999 solid;
height:100px;
}
.top-schedule table#calendar td li{
margin: 0 0 0 0;
}

.top-schedule table#calendar tbody td:before {
  background: #efefef;
  margin-right: 10px;
  padding: 10px 5px;
  display: flex;
  justify-content: center;
  align-items: center;
}
.top-schedule table#calendar .day {
font-size:12px;
display:block;
color:#333;
float:left;
width:100%;
text-align: right;
}
.top-schedule table#calendar .day-g {
font-size:12px;
display:block;
color:#999;
float:left;
width:100%;
text-align: right;
}

.top-schedule table#calendar li a{
color:#fff;
background-color:#0099BF;
margin: 0 0 3px 0;
padding:3px 3px 2px 3px;
font-size:10px;
line-height:120%;
overflow-x: hidden;
float:left;
text-align:left;
text-decoration: none;
border-radius: 2px; /* CSS3 */
 -webkit-border-radius: 2px; /* Firefox */
 -moz-border-radius: 2px; /* Safari,Chrome */
}
.top-schedule table#calendar a:hover {
background-color:#000;
text-decoration: none;
}


/* ************************************************ 
*	お知らせ
* ************************************************ */
.topnews-block {
margin: 0;
padding: 100px 0;
}
.topnews-box {
margin: 0 auto;
padding: 0;
width: 1000px;
max-width: 90%;
}
table#topnewsbox {
width: 100%;
margin: 0px 0 45px 0;
padding: 0 0 0 0;
border-collapse: collapse;
border-spacing: 0;
}
table#topnewsbox th {
font-family: 'Roboto';
font-weight: normal;
text-align: left;
padding: 20px 10px;
white-space: nowrap; 
border-bottom: 1px #999 solid;
width:10%;
}
table#topnewsbox td {
text-align: left;
padding: 20px 10px;
white-space: normal;
vertical-align: middle;
border-bottom: 1px #999 solid;
}
table#topnewsbox td a{ color: #333; }
table#topnewsbox td a:hover{
color: #000;
text-decoration: underline;
}


/* ************************************************ 
*	創業65年
* ************************************************ */
.topfounding-block {
width: 100%;
margin: 0;
padding: 120px 0;
background:url("../images/founding_bg.jpg") no-repeat;
background-size:cover;
background-position: bottom center;
position: relative;
z-index:0;
height: auto;
overflow: hidden;
}
.topfounding-block::before {
content: "";
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
background:rgba(0,0,0,0.5);
transition: 0.5s;
-webkit-transition: 0.5s;
-moz-transition: 0.5s;
-o-transition: 0.5s;
-ms-transition: 0.5s;
}
.topfounding-box-inner {
width: 900px;
max-width: calc(90% - 20px);
margin: 0 auto;
padding: 70px 0;
background:rgba(255,255,255,0.8);
position: relative;
z-index:9;
}
.topfounding-title {
font-family: 'Shippori Mincho',sans-serif;
font-weight:500;
letter-spacing: 0.05em;
padding: 0;
margin: 0 0 70px 0;
text-align:center;
font-size: min(4.5vw,44px);
line-height: 1;
position: relative;
}
.topfounding-title span{
font-size: min(5.3vw,50px);
}
.topfounding-title::after {
content: "";
position: absolute;
top: 80px;
left: 50%;
-webkit-transform: translateX(-50%);
-moz-transform: translateX(-50%);
-ms-transform: translateX(-50%);
-o-transform: translateX(-50%);
transform: translateX(-50%);
width: 60px;
height: 3px;
background-color:#333;
}
.topfounding-box-inner p{
font-family: 'Shippori Mincho',sans-serif;
font-weight:500;
padding: 0;
margin: 0;
text-align:center;
font-size: min(2.3vw,22px);
line-height: 2.5;
}


/* ************************************************ 
*	カワサキについて
* ************************************************ */
.top-kawasaki-block {
width: 100%;
padding: 120px 0;
margin: 0 auto;
background-color: #e5f5f8;
position: relative;
z-index:1;
-moz-box-shadow: 0px 3px 3px rgba(0,0,0,0.1);
-webkit-box-shadow: 0px 3px 3px rgba(0,0,0,0.1);
-o-box-shadow: 0px 3px 3px rgba(0,0,0,0.1);
-ms-box-shadow: 0px 3px 3px rgba(0,0,0,0.1);
box-shadow: 0px 3px 3px rgba(0,0,0,0.1);
}
.top-kawasaki-inner {
width: 1260px;
max-width: 90%;
padding: 0;
margin: 0 auto;
display: flex;
flex-wrap: wrap;
justify-content: space-between;
}

.top-kawasaki-box{
margin: 0 0 0 0;
padding: 0;
position: relative;
z-index:0;
width: 47%;
overflow: hidden;
}
.top-kawasaki-box img{
border-radius: 10px;
vertical-align: bottom;
}
.top-kawasaki-box a:before {
content: "";
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
border-radius: 10px;
background:rgba(0,0,0,0.3);
transition: 0.5s;
-webkit-transition: 0.5s;
-moz-transition: 0.5s;
-o-transition: 0.5s;
-ms-transition: 0.5s;
}
.top-kawasaki-box a:hover:before {
background-color: rgba(255,255,255,0);
}
.top-kawasaki-title {
font-weight:500;
letter-spacing: 0.05em;
padding: 0;
margin: 0;
color: #fff;
text-align:center;
width:100%;
position: absolute;
top: 50%;
left: 50%;
-webkit-transform: translate(-50%,-50%);
-moz-transform: translate(-50%,-50%);
-ms-transform: translate(-50%,-50%);
-o-transform: translate(-50%,-50%);
transform: translate(-50%,-50%);
z-index:999;
font-size: min(3.2vw,36px);
line-height: 1;
}


/* ************************************************ 
*	フッターエリア
* ************************************************ */	
#footer {
clear:both;
width:100%;
font-size: 100%;
margin: 0 auto;
padding: 0;
background-color: #F8F8F8;
}

.footer-top {
margin: 0 auto;
padding: 75px 0;
width: 100%;
height: auto;
background-color: #fff;
text-align: center;
}
.footer-top p{ min(1.7vw,16px); }
.footer-logobox {
margin: 0 0 40px 0;
padding: 0;
}
.footer-logobox img{
width: 240px;
vertical-align: bottom;
}
p.footer-tel {
font-size: 27px;
font-weight: 700;
line-height: 1;
margin: 0 0 0 0;
}
p.footer-tel::before {
display:inline-block;
content: "";
position: relative;
top: 3px;
left: 0;
padding-left: 10px;
width: 30px;
height: 30px;
background:url("../images/icon_tel.svg") no-repeat;
background-size:contain;
}

.footer-inner {
margin: 0 auto;
padding: 70px 0;
width: 1260px;
max-width: 90%;
}

.footer-navbox {
width: 100%;
margin: 0;
padding: 0;
display: flex;
flex-wrap: wrap;
justify-content: start;
}
#footer ul {
width: 22.5%;
margin: 0 0 0 0;
padding: 0;
}
#footer ul li {
margin: 0 0 15px 0;
padding: 0 0 0 0;
}
#footer ul li a{
color:#333;
font-size: min(1.7vw,16px);
}
#footer ul li a:hover{
color:#000;
text-decoration: underline;
}
.footer-end-top {
margin: 0 auto;
padding: 0;
border: 1px solid #333;
width: 60px;
}
.copyright {
margin: 0px auto 0px auto;
padding: 30px 0;
text-align:center;
font-size: 85%;
width: 100%;
}


/* ************************************************ 
*	ライン
* ************************************************ */
.line-dotted {
margin: 0 0 0 0;
padding: 0 0 0 0;
border-bottom:1px dotted #CCC;
}

.line-solid {
margin: 0 0 0 0;
padding: 0 0 0 0;
border-bottom:1px solid #CCC;
}


/* ************************************************ 
*	画像装飾
* ************************************************ */
.pict_right {
margin:0 0 10px 20px; 
padding: 2px 2px 2px 2px; 
float: right;
border: 1px solid #DCDCDC;
}

.pict_left {
margin:0 10px 10px 0; 
padding: 2px 2px 2px 2px; 
float: left;
border: 1px solid #DCDCDC;
}

.pict1px{
margin: 0 0 5px 0; 
padding: 2px 2px 2px 2px; 
border: 1px solid #CCC;
}

.pict_shadow{
background: #fff;
margin: 0px auto;
border: 1px solid #ccc;
padding: 5px 5px 5px 5px;
border-radius: 1px; /* CSS3 */
 -webkit-border-radius: 1px; /* Firefox */
 -moz-border-radius: 1px; /* Safari,Chrome */
box-shadow: 2px 2px 3px #C0C0C0;
}



/* ************************************************ 
*	角丸
* ************************************************ */
.border-radius{
border-radius: 5px; /* CSS3 */
 -webkit-border-radius: 5px; /* Firefox */
 -moz-border-radius: 5px; /* Safari,Chrome */
}



/* ************************************************ 
*	ボックスシャドウ・テキストシャドウ
* ************************************************ */
.box-shadow{
box-shadow: 2px 2px 3px #ccc; /* CSS3 */
 -webkit-box-shadow: 2px 2px 3px #ccc; /* Safari,Chrome */
 -moz-box-shadow: 2px 2px 3px #ccc; /* Firefox */
}
.text-shadow{
text-shadow: 1px 1px 3px #DEDEDE; /* CSS3 */
 -webkit-text-shadow: 1px 1px 3px #DEDEDE; /* Safari,Chrome */
 -moz-text-shadow: 1px 1px 3px #DEDEDE; /* Firefox */
}



/* ************************************************ 
*	CSS3ボタン
* ************************************************ */
.bt-more a {
font-size: 9px;
font-weight: normal;
color: #333;
text-align: center;
text-decoration: none;
text-shadow: 0px -1px 0px #fff;
width: 50px;
float: left;
display: block;
padding: 0 0 0 0;
margin: 10px 0 0 0;
border: 1px solid #ccc;
border-radius: 5px;
 -webkit-border-radius: 5px;
 -moz-border-radius: 5px;
background-color: #eee;
background: -webkit-gradient(linear,left top,left bottom,color-stop(0, #ddd),color-stop(.75, #eee),color-stop(1, #ddd));
background: -moz-linear-gradient(#ddd, #eee 75%, #ddd);
}

.bt-more a:hover {
background-color: #fff;
background: -webkit-gradient(linear,left top,left bottom,color-stop(0, #eee),color-stop(.75, #fff),color-stop(1, #eee));
background: -moz-linear-gradient(#eee, #fff 75%, #eee);
}

.bt-more a:active {
background-color: #999;
background: -webkit-gradient(linear,left top,left bottom,color-stop(0, #999),color-stop(.75, #ccc),color-stop(1, #999));
background: -moz-linear-gradient(#999, #ccc 75%, #999);
}

.bt-order a{
font-size: 14px;
color:#fff;
display: block;
text-align:center;
background-color: #999;
margin: 20px 0 20px 0 ;
padding: 10px 15px;
border-radius: 3px;
 -webkit-border-radius: 3px;
 -moz-border-radius: 3px;
}

.bt-order a:hover{
color:#867888;
background: #ddd;
text-decoration:none;
transition: 0.5s;
-webkit-transition: 0.5s;
-moz-transition: 0.5s;
-o-transition: 0.5s;
-ms-transition: 0.5s;
}




/* ************************************************ 
*   レスポンシブ
* ************************************************ */
/* PC 画面の横幅が960px以上 */
@media only screen and (min-width: 960px){
 iframe {
    width: 100%;
    height:100%;
}
.logo-sp { display: none; }
.show_tb { display: none; }
.show_sp { display: none; }
}

/* Tablet (Portrait) 画面の横幅が768px〜959pxまで */
@media only screen and (min-width: 768px) and (max-width: 959px) {
.wrapper,
.wrapper1000,
.wrapper1120 {
width: 728px;
}
.contents-box {
margin: 0;
padding: 70px 0 0 0; 
}
.logo { padding: 0 0 0 20px; }
.logo img { width: 250px; }
.logo-sp { display: none; }
.header-inner { width: 95%; }
.nav-menu li { margin: 16px 10px 0 10px; }
.nav-menu li a { font-size: 15px; }
#top-slide{ margin: 0 auto; }
.slide-img { height: 45vh; }

.top-schedule-block { padding: 75px 0; }
.topnews-block { padding: 75px 0; }

.topfounding-block { padding: 90px 0; }
.topfounding-box-inner { padding: 60px 0; }
.topfounding-title { margin: 0 0 70px 0; }
.topfounding-title::after {
top: 70px;
left: 50%;
}
.top-kawasaki-block { padding: 75px 0; }

.pagetitle-box { padding: 0 0 30px 0; }
.pagetitle { font-size: 36px; }
.pagetitle-en { font-size: 21px; }

.alllink {
    width: 30%;
}
.alllink a{ font-size:16px; }

.footer-top { padding: 50px 0; }
.footer-logobox img{ width: 210px; }
.footer-inner { width: 728px;}
iframe { width: 100%; height:100%; max-width: 728px; }
.copyright { width: 728px;}
.show_sp { display: none; }
}


/* Mobile (Portrait) 画面の横幅が767pxまで */
@media only screen and (max-width: 767px) {
p { font-size: 4.25vw; }
.wrapper,
.wrapper1000,
.wrapper1120 { width: 90%;}
.contents-box { padding: 70px 0 0 0; }
.contents-wrapper { padding: 10px 0 70px 0; }
#header {
padding: 70px 0 0 0;
position: relative;
height: auto;
-moz-box-shadow: none;
-webkit-box-shadow: none;
-o-box-shadow: none;
-ms-box-shadow: none;
box-shadow: none;
}
.header-inner {
width: 100%;
position: static;
padding: 0 0 0 0;
}
#header h1 {
    margin: 0 0 0 0;
}

.logo,
.logo-active { display: none; }
#nav_bg.active .logo-active { display: none; }
.logo-sp {
float: none;
text-align:left;
margin: 0 auto;
padding: 0;
position: absolute;
top: 15px;
left: 15px;
z-index:999999;
}
.logo-sp img {
width: 70%;
max-height: 55px;
}

.swiper-wrapper {
  margin-top: 0;
  margin-bottom: 0;
}
.slide-img {
height: 30vh;
}
.swiper-pagination { display: none; }
.slide-text {
bottom: 2.5%;
left: 5%;
}
.slide-text h2{
font-size: 4.5vw;
padding: 5px 5px 8px 5px;
margin: 0 0 5px 0;
}

#nav_bg {
padding: 0;
margin:0;
position: absolute;
top:0;
left:0;
border-bottom: none;
height: 70px;
}
/* 上部固定用 */
#nav_bg.active{
position: absolute;
top:0;
left:0;
}
/* 上部固定用ここまで */

.nav { float: none; text-align:center; width: 100%; padding: 0; }
.nav-menu li {
display: inline-block;
position: relative;
margin: 0 0;
padding: 0;
  width: 100%;
  z-index:99999;
  text-align: left;
}
.nav-menu li a {
color: #333;
display: block;
font-size: 4.5vw;
text-decoration: none;
border-bottom: none;
}
#nav_bg.active .nav-menu li a:hover,
.nav-menu li:hover > a,
.nav-menu li a:hover {
color: #333;
border-bottom: none;
}

.nav-menu .sub-menu {
display: block;
padding: 0;
position: relative;
z-index: 99999;
}
.nav-menu .sub-menu li {
width: 100%;
margin: 0 0 0 0;
}
.nav-menu .sub-menu li a {
color: #333;
font-size: 4.5vw;
border-bottom: none;
background: none!important;
}
.nav-menu .sub-menu li a:hover {
color: #333!important;
}

.pagetitle-box { padding: 0 0 30px 0; }
.pagetitle { font-size: 8vw; }
.pagetitle-en { font-size: 5vw; padding: 0 0 5px 0;}

.top-schedule-block { padding: 60px 0; }
.top-schedule .monthbox h3{ font-size: 5.5vw; }
.top-schedule .prevbox a,
.top-schedule .nextbox a{
font-size: 4.5vw;
}
.top-schedule table#calendar th {
padding: 3px;
font-size:4vw;
}
.top-schedule table#calendar .day {
text-align: left;
font-size:4vw;
}
.top-schedule table#calendar .day-g {
text-align: left;
font-size:4vw;
}
.top-schedule table#calendar td {
text-align: center;
padding: 3px;
height: 50px;
}
.top-schedule table#calendar a{
font-size:3vw;
}

.topnews-block { padding: 60px 0; }

table#topnewsbox {
width: 100%;
margin: 0 0 45px 0;
font-size: 4vw;
}
table#topnewsbox th {
display:block;
width: 100%;
padding: 15px 0 5px 0;
border-bottom: none;
}
table#topnewsbox td {
display:block;
width: 100%;
padding: 0px 0 15px 0;
}

.alllink { width: calc(100% - 2px);}
.alllink a{
font-size:4vw;
padding: 20px 0;
}

.topfounding-block { padding: 60px 0; }
.topfounding-box-inner { padding: 40px 0; }
.topfounding-title {
margin: 0 0 40px 0;
font-size: 6vw;
}
.topfounding-title span { font-size: 7vw; }
.topfounding-title::after { top: 40px; }
.topfounding-box-inner p { font-size: 4vw; }

.top-kawasaki-block { padding: 60px 0 35px 0; }
.top-kawasaki-box {
margin: 0 0 25px 0;
width: 100%;
}
.top-kawasaki-title { font-size: 5.5vw; }

.footer-top { padding: 50px 0; }
.footer-top p{ font-size: 4vw; }
.footer-logobox img { width: 50%; }
p.footer-tel { font-size: 7vw; }
p.footer-tel::before {
width: 25px;
height: 25px;
}

.footer-inner { padding: 60px 0 30px 0; }
#footer ul { width: 100%; }
#footer ul li { margin: 0 0 30px 0; }
#footer ul li a { font-size: 4.25vw; }

.breadcrumbs { display: none; }
iframe { width: 100%; height:100%; }
.copyright {
width:100%;
font-size: 3.5vw;
}

#topcontrol {
right: 5%!important;
bottom: 5%!important;
}
#topcontrol img{
width:50px;
}
.show_pc { display: none; }
}
