@charset "utf-8";
/* 標準可変メディア
   メモ : 可変メディアでは、HTML からメディアの高さおよび幅の属性を削除する必要がある
   http://www.alistapart.com/articles/fluid-images/ 
*/
img, object, embed, video {
	max-width: 100%;
}
/* IE 6 では最大幅がサポートされていないため、デフォルトで幅 100% に設定される */
.ie6 img {
	width:100%;
}

/*
	Dreamweaver 可変グリッドプロパティ
	----------------------------------
	dw-num-cols-mobile:		5;
	dw-num-cols-tablet:		8;
	dw-num-cols-desktop:	10;
	dw-gutter-percentage:	25;
	
	以下からヒントを入手 : Ethan Marcotte 氏の「レスポンシブ Web デザイン」 
	http://www.alistapart.com/articles/responsive-web-design
	
	および Joni Korpi 氏の「Golden Grid System」
	http://goldengridsystem.com/ 
*/

/* モバイルレイアウト : 480 px およびそれ以下. */
.contents{
     background: linear-gradient(0deg, rgba(0,175,236,1) 0%, rgba(255,255,255,0) 100%);
}
.content2 p{
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 16px;
	line-height: 200%;
}
.topImage{
    position: relative;
}
.topImage > img{
    width: 200%;
}
.topImage .gradation{
    position: absolute;
    bottom:0;
    left: 0;
    width: 100%;
    background: linear-gradient(0deg, rgba(255,255,255,1) 0%, rgba(255,255,255,0) 100%);
    height: 10%;
}
.timeTableBlock{
    position: absolute;
    bottom: -40%;
    right: 3%;
    box-shadow: 4px 4px 3px 0px rgba(0, 0, 0, 0.75);
    background: #fff;
    padding: 10px 20px;
}
.timeTableBlock h2{
    font-size: 16px;
    margin: 0.25em;
}
.timeTableBlock table{
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 15px;
    border-collapse: separate;
    border-spacing: 3px;
    line-height: 110%;
}
.timeTableBlock thead th{
    background: #00AFEC;
    padding: 0.2em 0.5em;
    line-height: 100%;
}
.timeTableBlock tbody td{
    background: #E6E6E6;
    text-align: center;
    vertical-align: middle;
}
.timeTableBlock p{
    font-size: 22px;
    font-weight: bold;
    margin: 0.25em 0;
}
.timeTableBlock .linkButton{
    background: #F39700;
    font-size: 21px;
    border-radius: 6px;
    padding: 0.25em ;
    color:#fff;
}
.timeTableBlock .linkButton:hover{
    color:#fff;
}
.timeTableBlock .linkButton:visited{
    color:#fff;
}
.timeTableBlock .logo{
    position: absolute;
    top: -24%;
    right: 10%;
    text-align: right;
}
.timeTableBlock .logo img{
    width: 60%;
}
.banner{
    position: absolute;
    top: 23%;
    right: 3%;
}
.banner img{
    width: calc(100vw * 0.5);
}
.banner > div{
    position: absolute;
    bottom:5%;
    left: 0;
}
.banner p{
    font-family: 'Noto Sans JP', sans-serif;
    font-size: clamp(14px, 3.7vw, 28px);
    color: #fff;
    font-weight: bold;
    line-height: 120%;
    margin: 0 10px;
}
.banner .linkButton{
    font-size: clamp(10px, 1.8vw,14px) ;
    color: #fff;
    background: #f39700;
    padding: 0.5em 0;
    width: 10em;
    line-height: 120%;
    font-weight: bold;
}
.greetingContent .item1{
    margin: 100px 0 0 0;
}
.greetingContent .item1 > div{
    display: inline-block;
    vertical-align: middle;
}
.greetingContent .item1 .imageBox{
    width: 100%;
    margin: 0 0 0 0;
}
.greetingContent .item1 .imageBox img{
    width: 100%;
}
.greetingContent .item1 .textBox{
    width: 100%;
}
.director {
    font-size: 33px!important;
    font-weight: bold;
    line-height: 50%!important;
}
.director .small1{
    font-size: 24px!important;
}
.director .small2{
    font-size: 18px!important;
    font-weight: normal;
    padding: 0 0 0 6em;
}
.itemList > .item{
    display: inline-block;
    vertical-align: top;
    box-sizing: border-box;
    width: 100%;
    margin: 0 0;
}
.itemList h3{
    font-size: 22px;
}
.itemList table{
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 16px;
    font-weight: bold;
    line-height: 200%;
}
.itemList th{
    font-weight: bold;
    text-align: left;
    width: 8em;
    vertical-align: top;
}
.itemList ul{
	list-style-type: none;
    font-family: 'Noto Sans JP', sans-serif;
	font-size: 16px;
	line-height: 200%;
	padding: 0 0 0 0;
	margin: 0 0 0 0;
}
.itemList .item:nth-child(2){
	background-image: url("images/index05.png");
	background-repeat: no-repeat;
	background-position: bottom right;
}
.consultationContent h2{
    text-align: center;
}
.h2LineCenter{
    width: 100%;
    margin: 0 auto 50px auto;
}
.consultations{
    text-align: center;
}
.consultations a{
    display: inline-block;
    width: 30%;
    margin: 10px 1%;
    aspect-ratio: 1 / 1;
    border-radius: 50%;
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 14px;
    text-decoration: none;
    color:#000;
    box-sizing: border-box;
    font-weight: bold;
    padding: 11% 0 0 0;
    vertical-align: top;
    box-shadow: 5px 5px 5px 0px #aaa;
}
.consultations a:hover{
    opacity: 0.7;
}
.consultations a:nth-child(odd){
    background: #00AFEC;
}
.consultations a:nth-child(even){
    background: #fff;
}
.consultationBox{
    position: relative;
}
#dlg_detail{
    display: none;
    position: fixed;
    top:0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(255,255,255,0.5);
    z-index: 10000;
}
#dlg_detail > div{
    box-sizing: border-box;
    width: 98%;
    max-width: 736px;
    border:#000 1px solid;
    margin: 10vh auto;
    background: rgba(255,255,255,0.6);
    padding: 20px;
    position: relative;
}
#dlg_detail .detail{
    background: #fff;
}
#dlg_detail dl{
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 15px;
    padding: 1em 1em;
    line-height: 160%;
    margin: 0 0;
}
#dlg_detail dt {
	font-size: 22px;
	margin: 0 0 0.5em 0;
}
#dlg_detail dd{
    margin: 0 0 0 0;
}
#dlg_detail .closeButtonBox{
    position: absolute;
    top:0;
    right: 0;
}
#dlg_detail .closeButtonBox a{
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 20px;
    text-decoration: none;
    color: #000;
}
.large1{
    font-size: 24px!important;
    font-weight: bold;
}
.content2{
    margin: 0 0 100px 0;
}
.itemList2 > .item{
    position: relative;
}
.itemList2 .item > div{
    width: 94%;
    margin: 0 auto;
    max-width: 1161px;
    position: relative;
    padding: 80px 0 0 0;
}
.itemList2 .item > div > div{
    display: inline-block;
    vertical-align: top;
}
.itemList2 .item .imageBox{
    width: 100%;
    margin: 0 0 20px 0 ;
    box-sizing: border-box;
    border: #fff 6px solid;
    border-top-right-radius: 45px;
    overflow: hidden;
}
.itemList2 .item .imageBox img{
    width: 100%;
}
.itemList2 .item:nth-child(1){
    background-image: url("images/index02.png") ;
    background-position: bottom right;
    background-repeat: no-repeat;
    background-size:60%;
}
.itemList2 .item .textBox{
    width: 100%;
    margin: 0 0 20px 0 ;
}
.itemList2 .item .titleH2{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
}
.itemList2 .item .textBox h2{
    text-align: left;
}
.itemList2 .item2{
    max-width: 1161px;
    margin: 50px auto;
}
.itemList2 .item2 > div{
    vertical-align: top;
    width: 94%;
    position: relative;
    margin: 0 auto;
    max-width: 1161px;
}
.itemList2 .item2 .imageBox{
    width: 75%;
}
.itemList2 .item2 .textBox{
    position: absolute;
}
.itemList2 .item2 .textBox{
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 12px;
    width: 17em;
}
.itemList2 .item2 > div:nth-child(1) .textBox{
    top: -2em;
    right: 0;
}
.itemList2 .item2 > div:nth-child(2) .textBox{
    bottom: 1em;
    right: 0;
}
.itemList2 .item2 > div:nth-child(2) .imageBox{
    margin: 0 auto;
}
.itemList2 .item2 .textBox > div:nth-child(2){
    position: absolute;
    width: calc(100% - 2em);
}
.itemList2 .item2 .textBox p{
    margin: 0 0;
    font-size: 14px;
}
.itemList2 .item2 > div:nth-child(1) .textBox > div:nth-child(2){
    top:2em;
    left: 1em;
}
.itemList2 .item2 > div:nth-child(2) .textBox > div:nth-child(2){
    top:3em;
    left: 1em;
}

.itemList3 > .item{
    position: relative;
}
.itemList3 .item > div{
    width: 94%;
    margin: 0 auto;
    max-width: 1161px;
    position: relative;
}
.itemList3 .item:nth-child(1) > div{
    padding: 80px 0 0 0;
}
.itemList3 .item > div > div{
    display: inline-block;
    vertical-align: top;
}
.itemList3 .item:nth-child(3){
    background-image: url("images/index06.png") ;
    background-repeat: no-repeat;
    background-position: left bottom;
    background-size: 50%;
}
.itemList3 .item .imageBox{
    width: 100%;
    margin: 0 0 20px 0 ;
    box-sizing: border-box;
    border: #fff 6px solid;
    border-top-right-radius: 45px;
    overflow: hidden;
}
.itemList3 .item .imageBox img{
    width: 100%;
}
.itemList3 .item .textBox{
    width: 100%;
    margin: 0 0 20px 0 ;
}
.itemList3 .item .titleH2{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
}
.itemList3 .item .textBox h2{
    text-align: left;
}
.itemList3 .item h3{
    font-size: 22px;
    margin: 2em 0 0.5em 0;
    border-left: solid 4px #F7931E;
    padding: 0 0 0 0.5em;
}
.itemList3 .item .noFrame{
    border-style: none!important;
}
.bx-wrapper {
	box-shadow: none;
	border: none;
}
.bx-wrapper {
	margin-bottom: 0;
}
.bx-wrapper .bx-pager, .bx-wrapper .bx-controls-auto {
	bottom: 10px;
}
.newsContent {
/*	background-image: url("images/index08.png");
	background-repeat: no-repeat;
	background-position: right bottom; */
	padding: 200px 0 0 0;
	background-size: 40%;
    position: relative;
    margin: 0 0 0 0;
}
.newsContent > div{
    position: static;
    width: 100%;
}
.newsContent > div > div{
    width: 94%;
    margin: 0 auto;
    max-width: 1161px;
}
.newsContent h2{
    text-align: center;
}
.newsContent .h2Line{
    width: 60%;
    margin: 0 auto;
}
.newsBlock{
    box-sizing: border-box;
    width: 100%;
    border: 6px #e6e6e6 solid;
    border-top-left-radius: 24px;
    border-top-right-radius: 24px;
    background: #fff;
    padding: 10px 5%;
    position: relative;
    margin: 0 0 0 0;
}
.newsBlock .logo{
    position: absolute;
    top: -70px;
    left: 10%;
}
.newsBlock .logo img{
    width: 60%;
}
.newsBlock .linkButton {
    background: #F39700;
    font-size: 15px;
    border-radius: 6px;
    padding: 0.25em ;
    color:#fff;
}
.newsBlock .linkButton:hover{
    color:#fff;
}
.newsBlock .linkButton:visited{
    color:#fff;
}
.large2{
    font-size: 29px!important;
    color: #F15A24;
    text-align: center;
}
.accessContent h2{
    text-align: center;
}
.takeItems{
    width: 100%;
    margin: 0 auto 50px auto;
}
.takeItems ul{
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 24px;
    list-style-type: none;
    background: #fff;
}
.takeItems .row1 > div {
    display: inline-block;
    height: 0.5em;
    box-sizing: border-box;
    vertical-align: bottom;
}
.takeItems .row1 .leftCorner{
    border-top-left-radius: 15px;
    border-top: 3px #fff solid;
    border-left: 3px #fff solid;
    width: 2%;
    
}
.takeItems .row1 .left{
    border-top: 3px #fff solid;
    width: 2%;
}
.takeItems .row1 .center{
    width: 92%;
}
.takeItems .row1 .rightCorner{
    border-top-right-radius: 15px;
    border-top: 3px #fff solid;
    border-right: 3px #fff solid;
    width: 2%;
    
}
.takeItems .row1 .right{
    border-top: 3px #fff solid;
    width: 2%;
}
.takeItems .row2{
    border-left: 3px #fff solid;
    border-right: 3px #fff solid;
    padding: 20px 2%;
}
.takeItems ul{
    margin: 0;
    padding: 0.5em 0.25em 0.5em 1.25em;
    font-weight: bold;
    line-height: 180%;
}
.takeItems ul li{
    text-indent: -1em;
}
.takeItems .row3 > div {
    display: inline-block;
    box-sizing: border-box;
    height: 0.5em;
    vertical-align: top;
}
.takeItems .row3 .leftCorner{
    border-bottom-left-radius: 15px;
    border-bottom: 3px #fff solid;
    border-left: 3px #fff solid;
    width: 2%;
}
.takeItems .row3 .left{
    border-bottom: 3px #fff solid;
    width: 2%;
}
.takeItems .row3 .center{
    width: 92%;
}
.takeItems .row3 .rightCorner{
    border-bottom-right-radius: 15px;
    border-bottom: 3px #fff solid;
    border-right: 3px #fff solid;
    width: 2%;
    
}
.takeItems .row3 .right{
    border-bottom: 3px #fff solid;
    width: 2%;
}
.access{
    text-align: center;
}
.access .item{
    display: inline-block;
}
.access .item > div{
    display: inline-block;
    vertical-align: top;
}
.access .item .imageBox{
    width: 100%;
    margin: 0 0 0 0;
}
.access .item .textBox{
    width: 100%;
    text-align: left;
}
.access .large3{
    font-size: 23px!important;
}
.access p{
    font-size: 20px;
    line-height: 130%!important;
}
.access .company{
    font-size: 26px!important;
    color:#fff;
    margin: 0.25em 0;
}
.mapBlock{
    padding: 50px 0 100px 0;
}
/* タブレットレイアウト : 481 px ～ 768 px。モバイルレイアウトからスタイルを継承。 */

@media only print {
.timeTableBlock{
    bottom: -10%;
    right: 3%;
}
}

/* デスクトップレイアウト : 769 px ～最大 1232 px。モバイルレイアウトとタブレットレイアウトからスタイルを継承。 */

@media only print {
.topImage{
    height: auto;
}
.topImage > img{
    width: 100%;
}
.content2 p{
    font-size: 16px;
	line-height: 200%;
}
.timeTableBlock{
    top: 20%;
    bottom: auto;
    right: 5%;
}
.timeTableBlock h2{
    font-size: 19px;
    margin: 0.25em;
}
.timeTableBlock table{
    font-size: 17px;
    border-spacing: 5px;
}
.timeTableBlock p{
    font-size: 25px;
    margin: 0.25em 0;
}
.timeTableBlock .linkButton{
    font-size: 17px;
    border-radius: 6px;
    padding: 0.25em ;
}
.timeTableBlock .logo{
    top: -37%;
    right: 10%;
}
.timeTableBlock .logo img{
    width: auto;
}
.banner{
    top: calc(20% + 300px);
    right: 5%;
}
.banner img{
    width: auto;
}
.banner p{
    font-size: 28px;
    margin: 0 10px;
}
.banner .linkButton{
    font-size: 14px;
    width: 14em;
}
.newsContent {
	padding: 100px 0 120px 0;
	background-size: auto;
}
.newsContent > div{
    position: absolute;
    top: auto;
    left: 0 ;
}
.director {
    font-size: 33px!important;
}
.director .small1{
    font-size: 23px!important;
}
.director .small2{
    font-size: 25px!important;
    padding: 0 0 0 0;
}
.greetingContent .item1{
    margin: 200px 0 0 0;
}
.greetingContent .item1 .imageBox{
    width: 35%;
    margin: 0 3% 0 0;
}
.greetingContent .item1 .textBox{
    width: 62%;
}
.itemList > .item{
    width: 48%;
    margin: 0 1%;
}
.itemList .item:nth-child(2) {
	background: none;
}
.consultations a{
    width: 29%;
    margin: 10px 2%;
    border-radius: 50%;
    font-size: 33px;
    padding: 12% 0 0 0;
}
#dlg_detail > div{
    width: 60%;
    max-width: 736px;
    border:#000 1px solid;
    margin: 10vh auto;
    padding: 50px;
}
#dlg_detail dt{
    font-size: 33px;
}
#dlg_detail dl{
    font-size: 16px;
    padding: 4em 4em;
}
.large1{
    font-size: 33px!important;
}
.itemList2 .item > div{
    padding: 0 0 0 0;
}
.itemList2 .item:nth-child(even) > div{
    overflow: hidden;
    padding: 120px 0 0 0;
}
.itemList2 .item .imageBox {
	width: 55%;
	margin: 0 3% 0 0;
	border: #fff 12px solid;
	border-top-right-radius: 81px;
}
.itemList2 .item:nth-child(1){
    background-size:auto;
}
.itemList2 .item .textBox{
    width: 42%;
}
.itemList2 .item2{
    margin: 100px auto;
}
.itemList2 .item2 > div{
    display: inline-block;
    width: 50%;
}
.itemList2 .item2 .imageBox{
    width: auto;
}
.itemList2 .item2 .textBox{
    font-size: 16px;
    width: 17em;
}
.itemList2 .item .titleH2{
	position: static;
	top: auto;
	left: auto;
	width: auto;
}
.itemList2 .item2 .textBox p{
    font-size: 16px;
}
.itemList2 .item2 > div:nth-child(1) .textBox{
    top: -2em;
    right: -2em;
}
.itemList2 .item2 > div:nth-child(2) .textBox{
    bottom: 8em;
    right: 0;
}
.itemList2 .item2 > div:nth-child(1) .textBox{
    top: -2em;
    right: -2em;
}
.itemList2 .item2 > div:nth-child(2) .textBox{
    bottom: 8em;
    right: 0;
}
.itemList2 .item2 > div:nth-child(2) .textBox > div:nth-child(2){
    top:4em;
}
.itemList3 .item:nth-child(1) > div{
    padding: 0 0 0 0;
}
.itemList3 .item:nth-child(even) > div{
    padding: 120px 0 0 0;
}
.itemList3 .item:nth-child(odd) > div{
    overflow: hidden;
    padding: 120px 0 0 0;
}
.itemList3 .item:nth-child(3){
    background-size: auto;
}
.itemList3 .item .imageBox {
	width: 55%;
	margin: 0 3% 0 0;
	border: #fff 12px solid;
	border-top-right-radius: 81px;
}
.itemList3 .item .textBox{
    width: 42%;
}
.itemList3 .item .titleH2{
	position: static;
	top: auto;
	left: auto;
	width: auto;
}
.itemList3 .item:nth-child(odd) .imageBox{
    float: right;
    margin: 0 0 0 3%;
}
.newsBlock {
	border: 20px #e6e6e6 solid;
	border-top-left-radius: 68px;
	border-top-right-radius: 68px;
	padding: 35px 4%;
	margin: 0 0 0 0;
}
.newsBlock .linkButton {
    font-size: 17px;
    border-radius: 6px;
}
.newsBlock .logo{
    top: -120px;
    left: 10%;
}
.newsBlock .logo img{
    width: auto;
}
.h2LineCenter{
    width: 50%;
    margin: 0 auto 50px auto;
}
.large2{
    font-size: 33px!important;
}
.takeItems{
    width: 80%;
    margin: 0 auto 50px auto;
}
.takeItems ul{
    font-size: 20px;
}
.access{
}
.access .item .imageBox{
    width: 40%;
    margin: 0 2% 0 0;
}
.access .item .textBox{
    width: 58%;
    text-align: left;
}
.access .company{
    font-size: 26px!important;
    margin: 0;
}
.access .large3{
    font-size: 20px!important;
}
.access p{
    font-size: 16px;
}
.mapBlock{
    padding: 50px 0 150px 0;
}
}