@charset "utf-8";

/*
Theme Name:     ★watp子テーマ★
Template:       watp
*/
 
@import url("../watp/style.css");

body {
font-family: "Zen Maru Gothic",'Roboto','Noto Sans JP','Sawarabi Gothic',sans-serif;
font-size: 16px;
font-weight: 400;
background:#fff;
color: #333;
line-height: 200%;
-webkit-text-size-adjust:100%;
overflow-x: hidden;
}

/* リンク */
a{
color:#3684C6;
text-decoration:underline;
transition: 0.5s;
-webkit-transition: 0.5s;
-moz-transition: 0.5s;
-o-transition: 0.5s;
-ms-transition: 0.5s;
}
a:hover{
color:#000;
text-decoration:none;
}
a:active, a:focus {
outline: 0;
}

/* フロート */
.alignright { float: right; }
.alignleft { float: left; }
.right{ float: right; }
.left{ float: left; }

/* 画像 */
img{
border:0;
padding:0px;
margin:0px
}
img.aligncenter {
display: block;
margin-left: auto;
margin-right: auto;
}
img.alignright {
padding:4px;
margin: 0 0 10px 20px;
display: inline;
}
img.alignleft {
padding: 4px;
margin: 0 20px 10px 0;
display: inline;
}


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

/* リスト */
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: disc;
}

li{
margin: 0 0 0 15px;
padding: 0 0 0 0;
}
li a{
color:#45AAB8;
transition: 0.5s;
-webkit-transition: 0.5s;
-moz-transition: 0.5s;
-o-transition: 0.5s;
-ms-transition: 0.5s;
}
li a:hover{
color:#666;
}


/* 画像拡大 */
img.grow {
	-webkit-transition:0.2s ease-in-out;
	-moz-transition:0.2s ease-in-out;
	-ms-transition:0.2s ease-in-out;
	-o-transition:0.2s ease-in-out;
	transition:0.2s ease-in-out;
}

img.grow:hover {
	-webkit-transform:scale(1.2,1.2);
	-moz-transform:scale(1.2,1.2);
	-ms-transform:scale(1.2,1.2);
	-o-transform:scale(1.2,1.2);
	transform:scale(1.2,1.2);
}

.wrapper {
width: 1200px;
max-width: 90%;
margin: 0 auto;
padding: 80px 0;
position:relative;
}
.wrapper100 {
width: 100%;
margin: 0 auto;
padding: 80px 0;
}

.row {
    margin-bottom: 0em;
}

/* 各ページ共通 */
.alllink { text-align: center; }
.alllink a{
color: #333;
background-color:#fff;
font-size: 18px;
display: inline-block;
padding: 15px 5vw 15px;
border: 1px solid #333;
text-decoration:none;
border-radius: 50vh; /* CSS3 */
 -webkit-border-radius: 50vh; /* Firefox */
 -moz-border-radius: 50vh; /* Safari,Chrome */
}
.alllink a:hover{
color: #fff;
border: 1px solid #333;
background-color:#333;
}
.alllink a::after{
position:relative;
top: 2px;
right: -15px;
content:"";
display:inline-block;
width:7px;
height:15px;
background:url("../watp/images/more-arrow.svg") no-repeat;
background-size:contain;
}
.alllink a:hover::after{
position:relative;
top: 2px;
right: -15px;
content:"";
display:inline-block;
width:7px;
height:15px;
background:url("../watp/images/more-arrow-mo.svg") no-repeat;
background-size:contain;
}


/* ************************************************ 
*	ブラー用の白背景
* ************************************************ */
.contents-box {
position: relative;
z-index: 0;
background-color: #fff;
width: 100%;
margin: 115vh 0 0 0;
}


/*---------------------------------------------------------------------------------
エフェクト
--------------------------------------------------------------------------------- */
/* 画面外にいる状態 */
.effect {
  opacity : 0;
  transition : all 900ms 300ms ease-out;
  transform: translate(0,0);
}
.effect-long {
  opacity : 0;
  transition : all 900ms 500ms ease-out;
  transform: translate(0,0);
}
.fv-effect {
  transition : all 900ms 900ms ease-out;
  transform: translate(0,0);
  opacity: 0;
}
.fade-drop {
  transform: translate(0,-50px);
}
.fade-up {
  transform: translate(0,50px);
}
/* 画面内に入った状態 */
.effect-on {
  opacity: 1.0;
  transform: translate(0,0px);
}
/*ファーストビューエフェクト*/
.loaded .fv-effect {
  opacity: 1;
  transform: translate(0,0)!important;
}


/* ************************************************ 
*	ヘッダー
* ************************************************ */
#header {
width: 100%;
margin: 0;
position: relative;
top:0;
left:0;
z-index: 99999;
}
#header h1 {
margin: 0;	
}
.header-inner {
margin: 0 5%;
padding: 0 0 0 0;
width: 90%;
height: 100px;
position: relative;
z-index:9;
display: flex;
flex-wrap: wrap;
justify-content: space-between;
align-items: center;
transition: 0.5s;
-webkit-transition: 0.5s;
-moz-transition: 0.5s;
-o-transition: 0.5s;
-ms-transition: 0.5s;
}

.logo-box {
margin: 0;
padding: 0;
width:10%;
max-width:130px;
}
.nav-box {
margin: 0 100px 0 0;
padding: 0;
display: flex;
flex-wrap: wrap;
justify-content: flex-end;
align-items: center;
}

#header h1.logo {
	margin: 0;
	padding: 0;
}
.logo img{ width: 100%;}


/* ************************************************ 
*	トップナビゲーション
* ************************************************ */	
#navDmy{
display:none !important;
}
#nav_bg {
width: 100%;
height: 100px;
padding: 0;
position:fixed;
top:0;
left:0;
z-index: 999;
background:rgba(255,255,255,0.8);
transition: 0.5s;
-webkit-transition: 0.5s;
-moz-transition: 0.5s;
-o-transition: 0.5s;
-ms-transition: 0.5s;
}

/* 上部固定用 */
#nav_bg.active{
position:fixed;
top:0;
left:0;
height: 100px;
background:rgba(255,255,255,0.8);
/* -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); */
transition: 0.5s;
-webkit-transition: 0.5s;
-moz-transition: 0.5s;
-o-transition: 0.5s;
-ms-transition: 0.5s;
}
/* 上部固定用ここまで */

#nav_bg.active .header-inner {
height: 100px;
transition: 0.5s;
-webkit-transition: 0.5s;
-moz-transition: 0.5s;
-o-transition: 0.5s;
-ms-transition: 0.5s;
}


#nav {
margin: 0 auto 0 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-weight: 400;
display: inline-block;
position: relative;
margin: 0 0 0 30px;
padding: 0;
float: left; 
text-align:center;
letter-spacing: normal; /* 隙間を埋める追加 */
cursor: pointer;
cursor: hand;
}
.nav-menu li img{
vertical-align: bottom;
}

.nav-menu li a {
color: #898989;
display: block;
font-size: min(1.6vw,15px);
text-decoration: none;
margin: 0;
padding: 0;
letter-spacing: 0.1em;
}

.nav-menu li:hover > a,
.nav-menu li a:hover {
color: #333;
}
.nav-menu .sub-menu,
.nav-menu .children {
background-color: rgba(255,255,255,0);
display:none;
position: absolute;
z-index: 99999;
padding: 0 0 0 0;
}

.nav-menu .sub-menu ul,
.nav-menu .children ul {
border-left: 0;
left: 100%;
top: 0;
}

.nav-menu .sub-menu li {
width: 215px;
padding: 0;
margin: 0;
border-left: none;
}

.nav-menu .sub-menu li a {
background:rgba(89,87,87,0.8);
color: #fff;
display: block;
font-size: 15px;
text-decoration: none;
padding: 15px 0 15px 15px;
text-align: left;
width: 200px;
}
.nav-menu .sub-menu li a:after {
    content: '';
    width: 0;
    border-bottom: none;
    display: block;
    padding-bottom: 0;
}

.nav-menu .sub-menu ul {
}

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

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 {
background-color: rgba(255,255,255,0.9);
color: #333;
}

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 {
}


/* ************************************************ 
*	メインイメージ
* ************************************************ */
.main-img {
width: 100%;
height: 100vh;
margin: 0 0 0 0;
position:fixed;
top: 0;
left: 0;
z-index: -1;
}
.main-img img{
vertical-align: bottom;
width: 100%;
}

.top-tagline1 {
position: absolute;
top: 28%;
right: 15%;
z-index: 1;
}
.top-tagline2 {
position: absolute;
top: 28%;
right: calc(15% + 60px);
z-index: 1;
}
h2.top-tagline1,
h2.top-tagline2{ 
padding: 0;
margin: 0 auto;
font-size: min(3.3vw,33px);
font-weight: 500;
color: #fff;
text-shadow: 0px 0px 3px rgba(0,0,0,0.3);
letter-spacing: 0.5em;
-ms-writing-mode: tb-rl;
  writing-mode: vertical-rl; /* 縦書き指定 */
text-orientation: upright; /* 英数字も縦方向に表示 */
}
/* 画面の高さが630pxまで */
@media only screen and (max-height: 630px) {
h2.top-tagline1,
h2.top-tagline2{ 
letter-spacing: 0.25em;
}
}

.main-newsbox {
position: absolute;
bottom: 20px;
left: 5%;
z-index: 1;
background-color: rgba(255, 255, 255, 0.2);
backdrop-filter: blur(8px);
-webkit-backdrop-filter: blur(8px);
padding: 10px 20px;
border-radius: 10px;
}
.main-newsbox-news {
width: 100%;
line-height: 1;
margin: 0;
padding: 0;
}
.main-newsbox-news a{
font-size: min(1.3vw,13px);
color: #fff;
text-decoration: none;
}
.main-newsbox-news a:hover{
color: #fff;
text-decoration: none;
}
.main-newsbox-news span{
font-weight: 400;
margin: 0 20px 0 0;
color: #fff;
}


.scrolldown {
position: absolute;
z-index: 10;
color: #fff;
font-size: min(2.0vw,18px);
letter-spacing: 0.02em;
writing-mode : vertical-rl;
bottom: 80px;
right: 3%;
transform: translateX(-50%) translateY(-50%);
}
.scrolldown::after {
content : '';
display : inline-block;
position : absolute;
background-color: #fff;
right : 50%;
bottom : -115px;
transform : translateX(-50%);
width : 1px;
height : 105px;
animation: scrolldown 2.0s infinite;
}
@keyframes scrolldown {
  0% {
    transform: scale(1, 0);
    transform-origin: 0 0;
  }
  50% {
    transform: scale(1, 1);
    transform-origin: 0 0;
  }
  50.1% {
    transform: scale(1, 1);
    transform-origin: 0 100%;
  }
  100% {
    transform: scale(1, 0);
    transform-origin: 0 100%;
  }
}


/* ************************************************ 
*	メイン　Slide
* ************************************************ */
.slider-1 {
z-index: 0;
list-style: none;
}
.slider-1 .slick-slide {
position: relative;
overflow: hidden;
margin: 0;
position: relative;
z-index:0;
}
.slider-1 .slick-slide::before{
content: "";
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
background: rgba(0,160,180,0.05);
}
.slider-1 .slick-slide img {
object-fit: cover;
height: 100vh;
}


/* ************************************************ 
*	パンくずリスト
* ************************************************ */	
.breadcrumbs {
width: 1120px;
max-width: 90%;
margin: auto; 
padding: 15px 0;
text-align:left;
font-size: 14px;
}
.breadcrumbs a{
color:#333;
transition: 0.5s;
-webkit-transition: 0.5s;
-moz-transition: 0.5s;
-o-transition: 0.5s;
-ms-transition: 0.5s;
text-decoration: none;
}
.breadcrumbs a:hover{
color: #000;
text-decoration: underline;
}


/* ************************************************ 
*	トップリードボックス
* ************************************************ */
.top-leadbox {
width: 100%;
padding: 100px 0;
margin: 0 0 0 0;
}
.top-leadbox h2{
font-size: min(4.8vw,48px);
text-align: center;
margin: 0 auto 30px auto;
font-weight: 400;
letter-spacing: 0.2em;
}
.top-leadbox h2 span{
letter-spacing: -0.2em;
}
.top-leadbox h4{
font-size: min(1.8vw,18px);
text-align: center;
margin: 0 auto 30px auto;
font-weight: 400;
letter-spacing: 0;
color: #999;
}
.top-leadbox h4 span{
color: #0075c1;
}
.top-leadbox h3{
font-size: min(2.0vw,21px);
text-align: center;
margin: 0 auto;
font-weight: 400;
letter-spacing: 0.1em;
line-height: 2;
}
.longline{
position: relative;
padding: 0 100px 0 0;
}
.longline::after {
content : '';
display : inline-block;
position : absolute;
background-color: #333;
right : 18px;
top : 50%;
transform : translateY(-50%);
width : 80px;
height : 2px;
}


/* ************************************************ 
*	トップINFOMATION
* ************************************************ */
.top-infobox {
width: 100%;
padding: 100px 0;
margin: 0 0 0 0;
background-color: #f5f8fc;
}
.top-infobox-inner{
width: 1200px;
max-width: 90%;
margin: 0 auto;
padding: 0;
display: flex;
flex-wrap: wrap;
justify-content: space-between;
}

.top-infobox-inner-left{
width: 40%;
margin: 0;
padding: 0;
position: relative;
}
.top-infobox-inner-right{
width: 55%;
margin: 0;
padding: 0;
}

.top-infoboxlink {
margin: 0 auto;
text-align:center;
width: 300px;
}
.top-infoboxlink a{
color: #333;
background-color:#fff;
font-size: min(1.8vw,16px);
display: block;
height: 60px;
align-content: center;
padding: 0;
line-height: 1;
border: 1px solid #333;
text-decoration:none;
letter-spacing: 0.2em;
}
.top-infoboxlink a:hover{
color: #fff;
border: 1px solid #0075c1;
background-color:#0075c1;
}
.top-infoboxlink a::after{
position:relative;
top: -1px;
right: -10px;
content:"";
display:inline-block;
width:15px;
height:10px;
background:url("../watp/images/arrow.svg") no-repeat;
background-size:contain;
}
.top-infoboxlink a:hover::after{
position:relative;
top: -1px;
right: -10px;
content:"";
display:inline-block;
width:15px;
height:10px;
background:url("../watp/images/arrow-mo.svg") no-repeat;
background-size:contain;
}


.top-infoboxlink-thumb {
margin: 40px 0 0 0;
}
.top-infoboxlink-thumb a{
color: #0075c1;
font-size: min(1.8vw,16px);
display: inline-block;
align-content: center;
padding: 0;
line-height: 1;
text-decoration:none;
letter-spacing: 0;
position:relative;
height:30px;
left: 40px;
letter-spacing: 0.1em;
}
.top-infoboxlink-thumb a::before{
position:absolute;
top:0;
left: -40px;
content:"";
display:inline-block;
width:30px;
height:30px;
background:url("../watp/images/view-more.svg") no-repeat;
background-size:contain;
}
.top-infoboxlink-thumb a:hover::before{
transform: rotateY(360deg);
transition: 0.5s;
}

.top-infoboxlink-thumb a:hover{
opacity: 0.6;
}


/* ************************************************ 
*	ABOUT Slide
* ************************************************ */
.swiper-container {
position: relative;
margin: 0 0 0 0;
}
.swiper-wrapper {
margin: 0;
align-items: baseline;
}

.swiper-slide img {
height: 100%;
width: calc(100% - 230px);
margin: 0 25px;
object-fit: cover;
border-radius: 50vh; /* CSS3 */
border: 90px solid #fff;
}
.swiper-slide a{
display: none;
}
.swiper-slide-active a{
display: block;
}

.swiper-slide01.swiper-slide-active,
.swiper-slide02.swiper-slide-active,
.swiper-slide03.swiper-slide-active,
.swiper-slide04.swiper-slide-active {
width: 100%!important;
margin: 0 0 0 0;
}

.swiper-slide h3{
display: none;
}
.swiper-slide-active h3{
display: block;
text-align: left;
font-size: min(4.8vw,48px);
margin: 0 0 10px 0;
padding: 0;
font-weight: 400;
letter-spacing: 0.05em;
line-height: 1;
}
.swiper-slide h4{
display: none;
}
.swiper-slide-active h4{
display: block;
text-align: left;
font-size: min(1.8vw,16px);
margin: 0;
color: #898989;
font-weight: 400;
margin: 0 0 30px 0;
padding: 0;
letter-spacing: 0.1em;
}
.swiper-slide p{
display: none;
}
.swiper-slide-active p{
display: block;
text-align: left;
font-size: min(1.6vw,15px);
margin: 0;
letter-spacing: 0.1em;
}

.bar {
  position: relative;
  width: 100%;
  height: 1px;
  background: #ddd;
  border-radius: 10px;
  margin: 10px auto 0;
  overflow: hidden;
}
.bar span {
  display: inline-block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  background: #0075c1;
  border-radius: 10px;
  transform: scaleX(0);
  transform-origin: left center;
  transition-timing-function: linear;
}


/* ************************************************ 
*	トップお知らせ
* ************************************************ */
.topnewsbox-inner {
width: 1200px;
margin: 0 auto;
padding: 100px 0 150px 0;
display: flex;
flex-wrap: wrap;
justify-content: space-between;
}
.topnewsbox-inner-left{
width: 20%;
margin: 0;
padding: 0;
position: relative;
}
.topnewsbox-inner-right{
width: 80%;
margin: 100px 0 0 0;
padding: 0;
}


.topnewsbox-inner-left h3{
text-align: left;
font-size: min(4.8vw,48px);
margin: 0 0 10px 0;
padding: 0;
font-weight: 400;
letter-spacing: 0.05em;
line-height: 1;
}
.topnewsbox-inner-left h4{
display: block;
text-align: left;
font-size: min(1.8vw,16px);
margin: 0;
color: #898989;
font-weight: 400;
margin: 0 0 30px 0;
padding: 0;
letter-spacing: 0.1em;
}


.topnewsbox-inner ul{
float:left;
margin: 0;
padding: 0;
width: 100%;
}

.topnewsbox-inner li{
float:left;
margin: 0 0 0 0;
padding: 50px 0;
list-style: none;
width: 100%;
border-bottom: 1px solid #999;
position:relative;
font-size: min(1.6vw,15px);
letter-spacing: 0.05em;
}

.topnewsbox-inner li a{
color:#333;
margin: 0 0 0 0;
padding: 0 0 0 0;
list-style: none;
line-height:1;
text-decoration: none;
}
.topnewsbox-inner li a::after{
position:absolute;
top:50%;
right: 15px;
transform : translateY(-50%);
content:"";
display:inline-block;
width:40px;
height:40px;
background:url("../watp/images/news-view-more.svg") no-repeat;
background-size:contain;
transition: 0.5s;
}
.topnewsbox-inner li a:hover::after{
background:url("../watp/images/news-view-more-mo.svg") no-repeat;
transition: 0.5s;
}

.topnewsbox-inner li a:hover{
text-decoration:none;
text-underline-offset:0.3em;
color:#0075c1;
}


.item-title-news {
width: calc(100% - 25px);
line-height: 150%;
margin: 0;
padding: 0;
display: flex;
flex-wrap: wrap;
justify-content: start;
}
.item-title-news-date{
width: 10%;
font-weight: 400;
margin: 0;
padding: 0;
color: #898989;
}
.item-title-news-title{
width: 85%;
font-weight: 400;
margin: 0;
padding: 0;
}

.news-alllink {
margin: 40px 0 0 0;
width: 100%;
display: flex;
flex-wrap: wrap;
justify-content: flex-end;
}
.news-alllink a{
color: #0075c1;
font-size: min(1.8vw,16px);
display: block;
align-content: center;
padding: 0;
line-height: 1;
text-decoration:none;
letter-spacing: 0;
position:relative;
height:30px;
left: 0;
letter-spacing: 0.1em;
}

.news-alllink a::before{
position:absolute;
top:0;
left: -40px;
content:"";
display:inline-block;
width:30px;
height:30px;
background:url("../watp/images/view-more.svg") no-repeat;
background-size:contain;
}

.news-alllink a:hover::before{
transform: rotateY(360deg);
transition: 0.5s;
}

.news-alllink a:hover{
opacity: 0.6;
}


/* ************************************************ 
*	ウィジット
* ************************************************ */
.widget{
margin: 0 0 0 0;
}
.textwidget{
font-size: 13px;
color: #444;
line-height:170%;
margin: 0 0 0 0;
padding: 5px 0 0 0;
}
#topbox li a{
font-size:13px;
color:#444;
margin: 0 0 0 0;
padding: 3px 0px 2px 0px;
list-style: none;
transition: 0.5s;
-webkit-transition: 0.5s;
-moz-transition: 0.5s;
-o-transition: 0.5s;
-ms-transition: 0.5s;
}
#topbox li a:hover{
color:#45AAB8;
}


/* ************************************************ 
*	サイドバー　新着表示
* ************************************************ */
#sidebar {
width: 100%;
margin: 0px 0px 40px 0px;
padding: 0 0 0 0;
}
.sidebar-title{
color: #333;
font-size: 16px;
font-weight: bold;
letter-spacing: 0.05em;
font-style:normal;
margin: 0px 0px 10px 0px;
padding: 0 0 0 0;
border-bottom:3px solid #ccc;
}
#sidebar li{
font-size: 13px;
margin: 0 0 0 0;
padding: 15px 0;
list-style: none;
border-bottom: 1px dotted #999;
}
#sidebox-new {
margin: 0 0 50px 0 ;
padding: 0 0 0 0 ;
}
#sidebox-new li a:hover{
color:#000;
}
#sidebox-works {
margin: 0 0 50px 0 ;
padding: 0 0 0 0 ;
}
#sidebox-works li{
font-size: 13px;
margin: 0 0 0 0;
padding: 5px 0;
list-style: none;
border-bottom: 1px dotted #999;
}
#sidebox-works li a{
color:#333;
}
#sidebox-works li a:hover{
color:#3684C6;
}
#sidebox-archives {
margin: 0 0 50px 0 ;
padding: 0 0 0 0 ;
}



/* ************************************************ 
*	レスポンシブ
* ************************************************ */
/* PC 画面の横幅が1160px以上 */
@media only screen and (min-width: 1160px) {
iframe { width: 100%; height:100%; max-width: 100%; }
a[href*="tel:"] {
pointer-events: none;
cursor: default;
text-decoration: none;
}

.logo-spbox { display: none; }
.show_sp { display: none; }
}


/* Tablet (Portrait) 画面の横幅が768px〜1159pxまで */
@media only screen and (min-width: 768px) and (max-width: 1159px) {
iframe { width: 100%; height:100%; max-width: 100%; }
.logo-spbox { display: none; }

.header-inner {
margin: 0 5%;
width: 90%;
}

.logo-box {
width: 15%;
max-width: 120px;
}
.nav-box { margin: 0 70px 0 0; }
.nav-menu li { margin: 0 0 0 15px; }

.main-img { height: 50vh; }
.slider-1 .slick-slide img { height: 50vh;  }

.contents-box {
position: relative;
z-index: 0;
background-color: #fff;
width: 100%;
margin: 50vh 0 0 0;
}

.top-infobox { padding: 100px 0; }
.top-infobox-inner-left { width: 45%; }
.top-infobox-inner-right { width: 50%; }

.swiper-slide {
margin: 0;
}
.swiper-slide img {
height: 100%;
width: calc(100% - 110px);
border: 40px solid #fff;
margin: 0 15px;
}

.topnewsbox-inner {
width: 90%;
padding: 75px 0;
margin: 0 auto;
}
.topnewsbox-inner-left {
width: 17.5%;
}
.topnewsbox-inner-right {
width: 82.5%;
}
.topnewsbox-inner li a::after {
right: 0;
width: 30px;
height: 30px;
}
.item-title-news {
width: calc(100% - 20px);
}
.item-title-news-date{
width: 17%;
}
.item-title-news-title{
width: 80%;
}


a[href*="tel:"] {
pointer-events: none;
cursor: default;
text-decoration: none;
}
select {
  -webkit-appearance: none;
  appearance: none;
  border: 1px solid #333;
  border-radius: 0px;
background-color: #fff;
padding: 5px;
font-size:14px;
}
.show_sp { display: none; }
}


/* Mobile (Portrait) 画面の横幅が767pxまで */
@media only screen and (max-width: 767px) {
body { font-size: 4vw; }
iframe { width: 100%; height:100%; max-width: 100%; }
.wrapper,
.wrapper100 { padding: 50px 0; }
.breadcrumbs { display: none; }

#header { height: 70px; }
.header-inner { height: 70px; }

.logo-box { display:none; }

#navDmy{ display:none !important; }
#nav_bg { display:none; }

.logo-spbox {
width: calc(100% - 75px);
margin: 0;
padding: 15px 0 0 15px;
position: relative;
top: 0;
left: 0;
z-index: 8;
}
.logo-sp {
margin: 0;
padding: 0;
}
.logo-sp img{
height: 44px;
}

.main-img {
height: calc(100svh - 70px);
position:fixed;
top: 70px;
}
h2.top-tagline1,
h2.top-tagline2 {
font-size: 6vw;
}
.top-tagline1 {
top: 20%;
right: 15%;
}
.top-tagline2 {
top: 20%;
right: calc(15% + 40px);
}
.scrolldown {
font-size: 3vw;
bottom: 10%;
right: 2%;
}

.main-newsbox {
width: calc(90% - 30px);
bottom: 20px;
padding: 10px 15px;
border-radius: 5px;
}
.main-newsbox-news {
line-height: 1.5;
}
.main-newsbox-news a{
font-size: 3.5vw;
}

.item-title-news-date{
width: 100%;
}
.item-title-news-title{
width: 100%;
}

.top-leadbox {
width: 100%;
padding: 75px 0 50px 0;
margin: 30vh 0 0 0;
}

.top-leadbox h2{
font-size: 5.5vw;
margin: 0 auto 20px auto;
}
.top-leadbox h4{ font-size: 3vw; }
.top-leadbox h3{ font-size: 4.5vw; }

.top-infobox-inner-left {
width: 100%;
margin: 0 0 50px 0;
}
.top-infobox-inner-right {
width: 100%;
margin: 0;
}
.top-infobox { padding: 75px 0 100px 0; }
.top-infobox h3 { font-size: 9vw; }
.top-infobox h4 { font-size: 4.25vw; }
.swiper-slide p { font-size: 4.25vw; }
.top-infobox-inner {
width: 90%;
margin: 0 auto;
}
.top-infoboxlink-thumb a {
font-size: 4vw;
}


.swiper-container {
position: relative;
}
.top-infoboxlink {
width: 100%;
}
.top-infoboxlink a{
font-size: 4vw;
height: 60px;
}
.swiper-slide {
margin: 0;
}
.swiper-slide img {
height: 100%;
width: calc(100% - 110px);
border: 45px solid #fff;
margin: 0 10px;
}
.swiper-slide-active {
width: 100%!important;
}


.topnewsbox-inner {
width: 90%;
max-width: 100%;
padding: 75px 0;
margin: 0 auto;
}
.topnewsbox-inner-left {
width: 100%;
margin: 0;
}
.topnewsbox-inner-right {
width: 100%;
margin: 0;
}
.topnewsbox-inner h3 { font-size: 9vw; }
.topnewsbox-inner h4 { font-size: 4.25vw; }
.topnewsbox-inner li { padding: 25px 0; }
.topnewsbox-inner li a::after {
right: 0;
width: 30px;
height: 30px;
}
.item-title-news {
width: calc(100% - 40px);
}
.news-alllink a {
font-size: 4vw;
}

.sidebar-title{ font-size: 4.5vw; }
table.similar-side td{ font-size: 4vw; }

select {
  -webkit-appearance: none;
  appearance: none;
  border: 1px solid #333;
  border-radius: 0px;
background-color: #fff;
padding: 5px;
font-size:4vw;
}
.show_pc { display: none; }
}