@charset "utf-8";


/* ************************************************ 
*	基本設定
* ************************************************ */	
body {
font-family: 'Roboto','Noto Sans JP','Sawarabi Gothic',sans-serif;
font-size: 15px;
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;
}

.sanrock-linebox {
width: 120px;
margin: 0 auto;
}
.sanrock-linebox2 {
width: 100%;
margin: 0 auto;
}
.sanrock-line1 {
background-color: #56a959;
width: 100%;
height: 3px;
margin: 0 0 2px 0;
}
.sanrock-line2 {
background-color: #3c4975;
width: 100%;
height: 3px;
margin: 0 0 2px 0;
}


/*---------------------------------------------------------------------------------
エフェクト
--------------------------------------------------------------------------------- */
/* 画面外にいる状態 */
.effect {
  opacity : 0;
  transition : all 900ms 300ms ease-out;
  transform: translate(0,0);
}
/* 画面内に入った状態 */
.effect-on {
  opacity: 1.0;
  transform: translate(0,0px);
}
.effect-on a:hover{
  opacity: 0.8;
  transform: translate(0,0px);
}


/* ************************************************ 
*	全体Wrapper
* ************************************************ */	
.wrapper {
margin: 0px auto 0px auto; 
width: 1260px;
max-width: 90%;
padding: 0;
}
.wrapper2 {
margin: 0px auto 0px auto; 
width: 100%;
padding: 0px 0px 0px 0px;
}
.wrapper1000 {
margin: 0px auto 0px auto; 
width: 1000px;
max-width: 90%;
padding: 0;
}
.wrapper1120 {
margin: 0px auto 0px auto; 
width: 1120px;
max-width: 90%;
padding: 0;
}
.contents-box {
margin: 0;
padding: 50px 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;
	position: absolute;
}
.header-inner {
margin: 0 auto;
padding: 20px 0 0 0;
width: 1260px;
max-width: 90%;
position: relative;
z-index:9;
display: flex;
flex-wrap: wrap;
justify-content: space-between;
}

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

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

.header-logobox {
padding: 0px 0px 0px 0px;
width:30%;
}
.header-navbox {
padding: 0px 0px 0px 0px;
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;
display:block;
background: #fff;
}

/* 上部固定用 */
#nav_bg.active{
position:fixed;
top:0;
left:0;
z-index:99999;
background:rgba(255,255,255,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: 700;
display: inline-block;
line-height: 16px;
position: relative;
margin: 18px 20px 0 20px;
padding: 0;
float: left; 
text-align:center;
letter-spacing: normal; /* 隙間を埋める追加 */
cursor: pointer;
cursor: hand;
}
.nav-menu li a {
color: #333;
display: block;
font-size: 16px;
text-decoration: none;
margin: 0;
padding: 0 0 18px 0;
border-bottom: 4px solid rgba(255,255,255,0);
}
#nav_bg.active .nav-menu li a {
color: #333;
}
#nav_bg.active .nav-menu li a:hover {
color: #333;
border-bottom: 4px solid #56a959;
}

.nav-menu li:hover > a,
.nav-menu li a:hover {
color: #333;
border-bottom: 4px solid #56a959;
}

.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.2);
      transform: scale(1.2);
  }
  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:5%;
left: 5%;
}
.slide-text h2{
font-family: 'Noto Sans JP';
font-size:3.5vw;
line-height: 180%;
color: #fff;
font-weight: 600;
text-shadow: 0px 0px 3px rgba(0,0,0,0.3);
}


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


/* ************************************************ 
*	パンくずリスト
* ************************************************ */	
.breadcrumbs {
margin: auto; 
padding: 15px 0;
text-align:left;
font-size: 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;
border: 1px solid #333;
text-align:center;
width: 30%;
border-radius: 50vh; /* CSS3 */
 -webkit-border-radius: 50vh; /* Firefox */
 -moz-border-radius: 50vh; /* Safari,Chrome */
}
.alllink a{
color: #333;
display: block;
padding: 15px 0px;
font-size:16px;
}
.alllink a:hover{
color: #fff;
background-color:#333;
border-radius: 50vh; /* CSS3 */
 -webkit-border-radius: 50vh; /* Firefox */
 -moz-border-radius: 50vh; /* Safari,Chrome */
}


/* ************************************************ 
*	トップカテゴリーボックス
* ************************************************ */	
.topcategory-box{
margin: 100px 0;
padding: 0;
position: relative;
z-index:0;
height: auto;
max-height: 400px;
overflow: hidden;
}
.topcategory-box a:before {
content: "";
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
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;
}
.topcategory-box a:hover:before {
background-color: rgba(255,255,255,0);
}
.topcategory-title {
font-weight:500;
letter-spacing: 0.05em;
padding: 0;
margin: 0;
color: #fff;
text-align:center;
position: absolute;
bottom: 5%;
right: 15%;
z-index:999;
font-size: 36px;
line-height: 100%;
}
.topcategory-title span{
font-size: 24px;
}
.topcategory-arrow {
width: 7%;
position: absolute;
bottom: 9%;
right: 4%;
z-index:999;
}
.topcategory-arrow img{
vertical-align: bottom;
}

/* ************************************************ 
*	お知らせ
* ************************************************ */
.topnews-block {
margin: 0;
padding: 0;
position: relative;
z-index:0;
}
.topnews-box {
margin: 0;
padding: 80px 0 80px 0;
}
.topnews-block-under {
position: absolute;
bottom: 0;
left: 0;
width: 100%;
z-index:-1;
}
.topnews-block-under img{
vertical-align: bottom;
}
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;
}
.new-icon {
  display        : inline-block;       /* インラインボックス定義  */
  color          : #ff0000;          /* 文字色                  */
  font-weight    : bold;               /* 太字                    */
  font-size      : 8pt;                /* ベースの文字サイズ      */
  vertical-align : middle;             /* 基準の高さ位置          */
  margin-left    : 5px;                /* 左外余白                */
  animation      : s1bAnime 1.5s infinite alternate; /* アニメ    */
}
@keyframes s1bAnime{                   /* 横軸回転                */
  90% { transform: rotateX(360deg) }
 100% { transform: rotateX(360deg) }
}

/* ************************************************ 
*	事業紹介
* ************************************************ */
.topbusiness-box {
background-color: #ebedf1;
margin: 0;
padding: 100px 0;
position:relative;
z-index: 1;
-moz-box-shadow: 0px 2px 3px rgba(0,0,0,0.2);
-webkit-box-shadow: 0px 2px 3px rgba(0,0,0,0.2);
-o-box-shadow: 0px 2px 3px rgba(0,0,0,0.2);
-ms-box-shadow: 0px 2px 3px rgba(0,0,0,0.2);
box-shadow: 0px 2px 3px rgba(0,0,0,0.2);
}

.top3business-box{
margin: 10px 0 30px 0;
padding: 0;
position: relative;
z-index:0;
height: auto;
max-height: 255px;
overflow: hidden;
}
.top3business-box a:before {
content: "";
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
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;
}
.top3business-box a:hover:before {
background-color: rgba(255,255,255,0);
}
.top3business-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: 24px;
line-height: 100%;
}
.top3business-arrow {
width: 7%;
position: absolute;
bottom: 7%;
right: 5%;
z-index:999;
}
.top3business-arrow img{
vertical-align: bottom;
}


/* ************************************************ 
*	フッターエリア
* ************************************************ */	
.footer_linebox {
position: relative;
z-index:0;
}
.footer_line1 {
background-color: #3c4975;
width: 100%;
height: 5px;
}
#footer {
clear:both;
width:100%;
font-size: 100%;
margin: 0px auto 0px auto;
padding: 0px 0px 0px 0px;
}

.footer-top {
margin: 0 0 0 0;
padding: 45px 0 50px 0;
width: 100%;
height: auto;
background-color: #fff;
}
.footer-top .form{
margin: 15px auto 0 auto;
padding: 0;
text-align: center;
}
.footer-top .form img{
width: 155px;
}
.footer-top .tel{
margin: 0 auto;
padding: 0;
text-align: center;
}
.footer-top .tel img{
width: 210px;
}

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

.footer-navbox {
margin: 0;
padding: 0;
}
#footer ul li {
    margin: 0 0 15px 0;
    padding: 0 0 0 0;
}
#footer ul li a{
color:#333;
font-size: 16px;
}
#footer ul li a:hover{
color:#000;
text-decoration: underline;
}

#footer ul ul{
    margin: 0 0 0 1em;
    padding: 0;
}
#footer ul li li{
    margin: 7px 0 7px 0;
    padding: 0 0 0 0;
}
.footer-rightbox {
margin: 0;
padding: 0;
float: right;
}
.footer-logo {
margin: 0 0 0 0;
padding: 0 0 0 0;
text-align: left;
font-size: 20px;
}
.footer-logo img{ width: 290px; }

.name-box {
margin: 30px 0 0 0;
padding: 0 0 0 0;
}
.name {
font-size: 16px;
margin: 0 0 5px 0;
padding: 0 0 0 0;
font-weight: bold;
}
.add {
font-size: 14px;
margin: 0 0 0 0;
padding: 0 0 0 0;
line-height: 180%;
white-space: nowrap;
}
.instagram{
margin: 50px 0 0 0;
padding: 0 0 0 0;
text-align: right;
}
.instagram img{
width: 30px;
height: 30px;
}
.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;
}
.logo { padding: 0 0 0 20px; }
.logo img { width: 250px; }
.logo-sp { display: none; }
.header-inner { width: 95%; }
.header-rightbox {
position: absolute;
top:10px;
right:0px;
width: 50%;
}
.header-btn a{
	padding: 0 8px;
	font-size: 10px;
}
#nav_bg { height:90px; }
.nav-menu li { margin: 16px 15px 0 15px; }
.nav-menu li a { font-size: 15px; }
#top-slide{ margin: 0px auto 0px auto; }

.topcategory-box {
margin: 100px 0 0 0;
height: 220px;
}
.topcategory-title {
font-size: 24px;
}
.topcategory-title span{
font-size: 18px;
}
.topcategory-arrow {
width: 7%;
bottom: 11%;
right: 4%;
}

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

.topnews-box,
.topbusiness-box{
padding: 80px 0 120px 0;
}
.top3business-box{
margin: 10px 0 10px 0;
height: 150px;
}
.top3business-title { font-size: 16px; }
.top3business-arrow {
width: 7%;
position: absolute;
bottom: 7%;
right: 5%;
z-index:999;
}

.alllink {
    width: 30%;
}
.alllink a{ font-size:16px; }
.dllink { width: 40%; }
.dllink a{
font-size:15px;
line-height: 210%;
}

.footer-inner { width: 728px;}
.footer-logo { font-size: 18px; }
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) {
.wrapper,
.wrapper1000,
.wrapper1120 { width: 90%; margin: 15px auto 0px auto; padding: 0;}
.contents-box { padding: 20px 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: 0px auto 0px auto;
	padding: 0px 0px 0px 0px;
	position: absolute;
	top: 10px;
	left: 15px;
	z-index:999999;
}
.logo-sp img {
    width: 95%;
    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: 6vw;
line-height: 150%;
}

#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;
}

.topcategory-box {
    height: auto;
    margin: 50px 0 0 0;
}
.topcategory-title {
    font-size: 6.5vw;
bottom: 5%;
right: 17%;
}
.topcategory-title span{
font-size: 5vw;
}
.topcategory-arrow {
width: 9%;
bottom: 9%;
right: 4%;
}

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

.topnews-box,
.topbusiness-box {
padding: 30px 0 70px 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;
}

.top3business-box{
margin: 0 0 30px 0;
height: auto;
}
.top3business-title { font-size: 5.5vw; }
.top3business-arrow {
width: 9%;
bottom: 6%;
right: 4%;
}

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


.dllink { width: 100%; }
.dllink a{
font-size:16px;
line-height: 210%;
}

.footer-top .form { margin: 0 auto 50px auto; }
.footer-top .form img { width: 55%; }
.footer-top .tel img { width: 55%; }

.footer-inner {
    margin: auto;
    padding: 50px 0;
    width: 90%;
}
#footer ul li { margin: 0 0 20px 0; }
#footer ul li a { font-size: 5vw; }
#footer ul li li { margin: 15px 0; }

.footer-rightbox {
margin: 30px 0 0 0;
float: left;
width: 100%;
}
.footer-logo img { width: 80%; }
.name-box { margin: 20px 0 0 0 ; }
.name {
margin: 0 0 5px 0;
line-height: 180%;
}
.add { font-size: 4.5vw; }
.instagram{
margin: 50px auto 0 auto;
text-align: center;
}
.instagram img{
width: 40px;
height: 40px;
}
.breadcrumbs { display: none; }
iframe { width: 100%; height:100%; }
.copyright {
width:100%;
}
.show_pc { display: none; }
}
