@charset "utf-8";
/* CSS Document */


/* bootstrap.css基本の打消し（同じclass名での書き換え）
---------------------------------------------------- */
body{ margin:0px; padding:0px;}
h1,h2,h3,h4,h5,h6{ margin:0px; padding:0px; font-weight:normal; clear:both}
p{ margin:0px; padding:0px}

.navbar {
  margin-bottom:0px;
  border:none;
}
.table-striped > tbody > tr:nth-of-type(odd) { background-color: #efefef;}
.table{ margin-bottom:30px}
.table th{ width:30%}

@media (min-width: 768px) {.btn-group-vertical a{ padding-top:15px;padding-bottom:15px}}

img.img-fluid {display: block;}


/* 全体構造
---------------------------------------------------- */
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, dialog, figure, footer, header,
hgroup, menu, nav, section,
time, mark, audio, video {
	margin:0;
	padding:0;
	border:0;
	outline:0;
	font-size:100%;
	vertical-align:baseline;
	background:transparent;
}

.clearfix:after {
  content: ".";  /* 新しい要素を作る */
  display: block;  /* ブロックレベル要素に */
  clear: both;
  height: 0;
  visibility: hidden;
}
.clearfix {
    zoom:1;/*for IE 5.5-7*/
	overflow:hidden;
}
* html .clearfix {
  height: 1px;
  /*\*//*/
  height: auto;
  overflow: hidden;
  /**/
}

.clear{clear:both;}

img{border:0;vertical-align:bottom;}

a {
	outline:none;
	margin:0;
	padding:0;
	border:0;
	font-size:100%;
	vertical-align:baseline;
	background:transparent;
}

hr {
    display:block;
    height:1px;
    border-top:1px dotted #333;
    margin:0;
    padding:0;
	margin-bottom:20px
}

body{
	font-size:85%;/* 基本のフォントサイズ */
	line-height:185%;/* 基本の行間 */
	font-family:FontAwesome, "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	color:#17224f;
	letter-spacing: 0.05em;
}

.en{
	font-family: 'Montserrat', sans-serif;
	font-weight: 700;
}
.en2{
	font-family: 'Roboto', sans-serif;
	font-weight: 500;
}
.en3{
	font-family: 'Dosis', sans-serif;
	font-weight: 400;
}
sup {font-size: 80%;}

.en1{
	margin-left: 20px;
	font-size: 35px;
	font-weight: 700;
}
.font_mid {
    font-size: 70%;
    font-weight: 350;
}

header,
main,
footer{
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 500;
}


/* link
---------------------------------------------------- */
a:link,a:visited,a:hover,a:active{text-decoration:none; color:#17224f; }
/*.link_kon a:link,a:visited,a:hover,a:active{text-decoration:none; color:#f58599}*/


/* header
---------------------------------------------------- */
header{
	width: 100%;
	top: 0;
	z-index: 100;
	padding-top: 5px;
	padding-bottom: 10px;
}

h1 {float: left;}
h1 img{width: 160px; padding-top: 10px;}

@media only screen and (max-width: 991px) {
	header{
		position: fixed;
		top: 0;
		left: 0;
		right: 0;
	}
}
@media print, screen and (min-width: 992px) {
	header{
	padding-top: 0;
	padding-bottom: 0;
		background: #fff;
	}
	h1 img{width: 150px; padding-top: 10px;}
	.head_right{padding-right: 0;}
}
@media print, screen and (min-width: 1200px) {
	h1 img{width: 190px; padding-top: 5px;}
}




/* navi
---------------------------------------------------- */
/*
.gNav a:hover {
  color: #999;
}
*/

/*.nav { display: none; }なぜかこの指定をしていた。何かに影響するかも*/
nav li a {
	font-size: 100%;
	line-height: 1.4em;
}
nav .sub-menu,.mean-container .mean-nav ul ul {
	background: #e5edf3;
}

nav li.navi-on li a{color: #635e75; font-weight: normal;}

.mean-container .mean-nav ul li.navi-on2 a{color: #144faa!important;}
.gNav .sub-menu li.navi-on2 a{color: #144faa !important;}
@media only screen and (max-width: 767px) {
  .h_logo {
    width: 120px;
    position: absolute;
    top: 5px;
    left: 10px;
    z-index: 100;
  }
  .gNav .nav {
    overflow-y: auto;
    height: 100vh;
  }
  .mean-nav .container {
    padding: 0;
  }
  nav li .fa {
    display: none;
  }
	nav .en {display: none;}

	.mean-nav img.img-fluid{
		display: inline-block!important;
		width: 50px;
		vertical-align: middle;
		padding-right: 10px;
	}
	.mean-nav li{
		border-bottom: 1px solid #fff;
	}

}
@media only screen and (min-width: 768px) {
  .h_logo {
    width: 130px;
    position: absolute;
    top: 0;
    left: 10px;
    z-index: 100;
  }
	.mean-nav li{
		border-bottom: 1px solid #fff;
	}
	.meanmenu-reveal {
	  margin: 15px 17px 27px 17px!important;
	}
}

@media print, screen and (min-width: 992px) {
  .h_logo img {  width: 20px;}
  .h_top {
    /*display: flex;*/
    justify-content: space-between;
    align-items: center;
  }
  .gNav>ul {
    position: relative;
    /*display: flex;*/
	  display: table;
	  width: auto!important;
	  float: right;
  }
  .gNav li {
    position: relative;
    /*margin-right: 3em;*/
	  display: table-cell;
  }
  .gNav li:last-child {
    margin-right: 0;
  }
  .gNav li i {
    font-size: 16px;
    margin-left: 5px;
  }
  .gNav li a {
    position: relative;
    display: block;
    /*line-height: 80px;*/
	  padding: 10px 0;
	  margin-left: 5px;
  }
  .gNav .sub-menu {
    visibility: hidden;
    opacity: 0;
    z-index: 1;
    display: block;
    position: absolute;
    top: 45px!important;
    left: 60%;
    margin-left: -90px;
    width: 150px;
    -webkit-transition: all .2s ease;
    /*transition: all .2s ease;*/
	  transition: opacity .2s ease;
  }
  .gNav .sub-menu.long_pc {width: 280px;}
  .gNav .sub-menu a {
    padding: 10px;
    display: block;
    border-bottom: none;
    padding: 15px;
    line-height: 1.2em;
	border-bottom: 1px solid #fff;
	font-size: 90%;
  }
  .gNav .sub-menu a:hover:after {

  }
  .gNav .sub-menu li {
    display: block;
    /*font-size: 16px;*/
    padding: 0;
    margin: 0;
  }
  .gNav .sub-menu li:last-child {
    border-bottom: none;
  }
  .gNav ul > li:hover {
    -webkit-transition: all .5s;
    transition: all .5s;
  }
  .gNav li:hover ul.sub-menu {
    top: 80px;
    visibility: visible;
    opacity: 1;
    z-index: 9999;
  }
  .gNav li ul li:after {
    content: none;
  }
  .gNav .sub-menu li a{margin-left: 0;}
  .gNav .sub-menu li a:hover {
    background: #fff;
  }

	nav li a {
	    color: #17224f;
		font-size: 80%;
	}
	nav li a:hover{
		color: #17224f!important;
		background: url(../images/navi-on.png) repeat-x bottom;
		opacity: 1;
	}
	nav li.navi-on li a{
		background: none;
	}
	nav li .en{
		display: block;
		font-size: 50%;
		line-height: 1.4em;
		margin-top: 3px;
	}
	nav li .en a{font-weight: normal;}
}
@media print, screen and (min-width: 992px) {
	nav {margin-right: 15px;}
	.gNav>ul { margin-top: 0; margin-bottom: 0;}
	nav li a { font-size: 95%;	}
	.gNav li a { margin-left: 15px;}
	.gNav li.g_mail a {
		background-color: #144faa;
		color: #fff;
		padding: 25px 30px;
		line-height: 1.4em;
	}
	.gNav li.g_mail a:hover{
		background-color: #1e5fc3;
		background-image: none;
		color: #fff!important;
		opacity: 1;
	}
    /* .gNav li.g_mail_pink a {
        background-color: #FFB6C1;
        color: #fff;
        padding: 25px 30px;
        line-height: 1.4em;
    } */
    /* .gNav li.g_mail_pink a:hover {
        background-color: #f0dddf;
        background-image: none;
        color: #fff!important;
        opacity: 1;
    } */
	.gNav li.g_mail i{
		font-size: 160%!important;
		margin-left: 0;
	}
	.gNav > ul {margin-right: -15px;}
}
@media print, screen and (min-width: 1200px) {
	nav li a { font-size: 100%;}
	.gNav li a { margin-left: 30px;}
	.gNav .sub-menu { top: 75px!important;}
	.gNav .sub-menu a { font-size: 100%; }
	.gNav .sub-menu.long_pc { width: 300px;}
	.gNav li.g_mail a {
		padding: 30px 30px;
	}
}
@media print, screen and (min-width: 1600px) {
	nav li a { font-size: 105%;}
}


.sub_navi{
	border-top: 2px solid #fff;
}
.sub_navi p{
	width: 50%;
	float: left;
	border-bottom: 1px solid #fff;
}
.sub_navi.long p{
	width: 100%;
	float: none;
	border-bottom: 1px solid #fff;
}
.sub_navi p a:link,
.sub_navi p a:visited{
	background-color: #e5edf3;
	padding: 12px 15px!important;
}
.sub_navi p:nth-of-type(2n+1) { clear: both;}

nav li.navi-on .sub_navi a{
	color: #17224f!important;
}
nav li.navi-on .sub_navi a:hover{
	color: #951c5a!important;
}
@media print, screen and (min-width: 576px) {
	.sub_navi p{
		width: 25%;
	}
	.sub_navi p:nth-of-type(2n+1) { clear: none;}
	.sub_navi p:nth-of-type(4n+1) { clear: both;}
}
@media print, screen and (min-width: 768px) {
	.sub_navi.long p{
		width: 50%;
		float: left;
	}
}


.menu-item {
  position: relative !important;
  margin-bottom: 5px;
  background-color: #e5edf3;
}



/* 基本の .submenu スタイル */
/* サブメニュー非表示 */
.submenu {
  display: none;
  position: absolute;
  top: -1px;       /* 少し上にずらす（マイナスで上方向） */
  left: 100.265%;       /* 右に少しずらす（100%より大きい値で右側へ） */
  background-color: #fff;
  min-width: 200px;
  box-shadow: 0 2px 5px rgba(0,0,0,0.2);
  padding: px 0;
  z-index: 1000;
  flex-direction: column;
  text-transform: none !important;
}

.submenu a {
  color: #0667B1;
  text-decoration: none;
  padding: 10px;
  display: block;
}

.sub-menu-item .submenu {
    display: none;
    position: absolute;
    top: 0;
    background: #fff;
    min-width: 200px;
    box-shadow: 0 2px 5px rgba(0,0,0,0.2);
    padding: 10px 0;
    z-index: 1000;
}

.menu-item.active > .submenu { display: flex; }

/* 画面幅992px以下用 */
@media (max-width: 992px) {
  .submenu {
    display: none; /* デフォルトでは非表示に */
    position: absolute; /* 親要素の下に表示させる */
    left: 0;
    top: 100%;
    background-color: #D5F2FF; /* 背景色を追加 */
    width: 100%; /* サブメニューの幅を親要素と同じに */
    z-index: 2; /* 重なり順を調整 */
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1); /* シャドウで浮き上がる感じを追加 */
  }

/* サブメニュー内リンク */
.submenu li a {
  color: #0667B1;
  text-decoration: none;
  padding: 8px 15px;
  display: block;
  white-space: nowrap;
}

  .submenu a {
    padding: 10px; /* サブメニューアイテムの余白を増加 */
    font-size: 14px; /* フォントサイズを少し調整 */
  }

  /* アクティブな場合 */
  .menu-item.active .submenu {
    display: block; /* メニューがアクティブのときに表示 */
  }
}




.mean-container .mean-nav ul li li{
	width: 50%!important;
	float: left;
}
.mean-container .mean-nav ul li li:nth-of-type(2n+1) { clear: both;}
.mean-container .mean-nav ul li .long_pc li{
	width: 100%!important;
	float: left;
}
.sub-menu{
	border-top: 2px solid #fff;
}
@media (max-width: 991px) {
  .sub-menu {
       max-height: 300px !important;  /* 最大高さを設定 */
       overflow-y: auto !important;   /* 縦スクロールを強制表示 */
  }
}

.mean-container .mean-nav ul li li a {
  padding: 1em 15px!important;
}

/* 基本の toggle スタイル */
.toggle {
  width: 100%;
  background-color: #D5F2FF;
  color: #0667B1;
  padding: 10px;
  display: inline-block;
  text-decoration: none;
  text-transform: none !important;
  cursor: pointer;
  position: relative; /* ::afterの絶対配置の基準 */
  z-index: 1;
}

.toggle::after {
  content: "▼";
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 14px;
  color: #0667B1;
  pointer-events: none;
}

.menu-item.active .toggle::after {
  transform: translateY(-50%) rotate(270deg); /* 右向きに回転 */
}

/* 画面幅992px以下用 */
@media (max-width: 992px) {
  .toggle {
    background-color: #e5edf3; /* 背景色を変更 */
    color: #005F8D; /* 文字色を少し濃く */
    padding: 12px; /* 余白を少し増加 */
    font-size: 16px; /* 文字サイズを調整 */
    text-align: center; /* テキスト中央揃え */
  }

  .toggle::after {
    display: none;
    content: ""!important;
    font-size: 18px; /* 矢印を少し大きく */
    right: 15px; /* 矢印の位置を少し右に調整 */
  }
}




.mean-container .mean-bar{background-color: #fff!important;}/*ナビの背景*/

@media (max-width: 991px) {
  .mean-ber {
    max-height: 300px !important;  /* 最大高さを設定 */
    overflow-y: auto !important;   /* 縦スクロールを強制表示 */
  }
}


.osu1 {position: relative; z-index: 1;}
.osu2 {position: relative; z-index: 2;}
.osu3 {position: relative; z-index: 3;}

.f-right {float: right;}

/*ナビ固定*/
.cb-header {
	position: fixed; /* ヘッダーバーを固定 */
	top: -145px;
	left: 0;
	width: 100%;
	z-index: 1000;
	background-color: #fff;
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 500;
}


.nav { display: none; }/*一瞬ナビが開くのをやめる*/
/*
#top03 .nav{display: flex;}
*/

/* midashi
---------------------------------------------------- */
.fs60 {font-size:60%;}
.fs70 {font-size:70%;}
.fs75 {font-size:75%;}
.fs80 {font-size:80%; line-height: 1.6em;}
.fs85 {font-size:85%;}
.fs90 {font-size:90%;}
.fs110 {font-size:110%; line-height:1.4em;}
.fs120 {font-size:120%;}
.fs140 {font-size:130%; line-height:1.4em;}
.fs160 {font-size:160%;}
.fs180 {font-size:180%;}

.fs100_sm90_md90_lg100 {font-size: 100%;}
@media print, screen and (min-width: 768px) {
	.fs100_sm90_md90_lg100 {font-size: 90%;}
}
@media print, screen and (min-width: 1200px){
	.fs100_sm90_md90_lg100 {font-size: 100%;}
}

@media print, screen and (min-width: 768px){
	.fs90_smmd{ font-size: 90%;}
}
@media print, screen and (min-width: 1200px){
	.fs90_smmd{ font-size: 100%;}
}

.fs60_sm80_md70{font-size: 80%;}
@media print, screen and (min-width: 992px){
	.fs60_sm80_md70{font-size: 70%;}
}
@media print, screen and (min-width: 1200px) {
	.fs60_sm80_md70{font-size: 60%;}
}

.fs160_sp140 {font-size: 140%;}
@media print, screen and (min-width: 768px) {
	.fs160_sp140 {font-size: 160%;}
}

.text_large{font-size: 100%; line-height: 1.8em;}
@media print, screen and (min-width: 768px){
	.text_large{font-size: 110%;line-height: 2.0em;}
}
@media print, screen and (min-width: 992px){
	.text_large{font-size: 120%;}
}
@media print, screen and (min-width: 1200px){
	.text_large{font-size: 130%;}
}
@media print, screen and (min-width: 1600px){
	.text_large{font-size: 140%;}
}

#midashi_h2{padding: 40px 0 10px 0; color: #fff; margin-top: 60px; position: relative;}
#midashi_h2 h2{
	line-height: 1.4em;
	margin-bottom: 30px;
	text-align: center;
	font-size: 100%;
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 500;
}
#midashi_h2 h2 span{
	display: block;
	font-size: 200%;
	font-family: 'Montserrat', sans-serif;
	line-height: 1.4em;
}
#midashi_h2.h2_news{background: url(../images/h2_news.jpg) no-repeat 50% 50% / cover;}
#midashi_h2.h2_contents{background: url(../images/h2_contents.jpg) no-repeat 50% 50% / cover;}
#midashi_h2.h2_cloud{background: url(../images/h2_cloud.jpg) no-repeat 50% 50% / cover;}
#midashi_h2.h2_sale{background: url(../images/h2_sale.jpg) no-repeat 50% 50% / cover;}
#midashi_h2.h2_alclean{background: url(../images/alclean/h2_alclean.jpg) no-repeat 50% 50% / cover;}
#midashi_h2.h2_secureface2{background: url(../images/secureface2/h2_secureface2.jpg) no-repeat 0% 50% / cover;}
#midashi_h2.h2_system{background: url(../images/h2_system.jpg) no-repeat 50% 50% / cover;}
#midashi_h2.h2_case{background: url(../images/h2_case.jpg) no-repeat 50% 50% / cover;}
#midashi_h2.h2_company{background: url(../images/h2_company.jpg) no-repeat 50% 50% / cover;}
#midashi_h2.h2_contact{background: url(../images/h2_contact.jpg) no-repeat 50% 50% / cover;}
#midashi_h2.h2_privacy{background: url(../images/h2_privacy.jpg) no-repeat 50% 50% / cover;}
#midashi_h2.h2_environment{background: url(../images/h2_environment.jpg) no-repeat 50% 50% / cover;}
#midashi_h2.h2_management{background: url(../images/management/h2_management.jpg) no-repeat 50% 50% / cover;}
#midashi_h2.h2_recruit{background: url(../images/recruit/h2_recruit.jpg) no-repeat 50% 50% / cover;}


.pankuzu{ font-size: 85%; font-family: 'Noto Sans JP', sans-serif; position: relative; z-index: 5;}
.pankuzu a:link,
.pankuzu a:visited{
	text-decoration: underline;
	color: #fff;
}
@media print, screen and (min-width: 576px){
	#midashi_h2 h2{ font-size: 130%;}
	#midashi_h2 h2 span{ font-size: 220%;}
}
@media print, screen and (min-width: 768px){
	#midashi_h2{padding: 70px 0 10px 0; margin-top: 60px; }
	#midashi_h2 h2{ margin-bottom: 40px; font-size:140%;}
	#midashi_h2 h2 span{ font-size: 280%;}
}
@media print, screen and (min-width: 992px){
	#midashi_h2{ padding: 90px 0 10px 0;margin-top: 0; }
	#midashi_h2 h2{ margin-bottom: 60px; font-size: 160%;}
}
@media print, screen and (min-width: 1600px){
	#midashi_h2{padding: 130px 0 10px 0;}
	#midashi_h2 h2{ margin-bottom: 100px; font-size: 180%;}
}

/*--------------------------*/


/*タイトルエフェクト*/
.title_waku {display: inline-block;}
.block-revealer__element {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #000;
    pointer-events: none;
    opacity: 0;
}

/* 画像を使うときはvertical-align bottomをしないと下に余白ができてしまうので注意！！ */
.revealImg {
    width: 300px;
    height: 200px;
    -o-object-fit: cover;
       object-fit: cover;
    vertical-align: bottom;
}

/*--------------------------*/


.midashi1{
	font-size: 100%;
	line-height: 1.4em;
}
.midashi1 .en{
	display: block;
	font-size: 200%;
	line-height: 1.4em;
}

.midashi2{
	font-size: 150%;
	line-height: 1.4em;
	font-weight: 300;
}

.midashi3{
	font-size: 150%;
	line-height: 1.4em;
	font-weight: 300;
}

.midashi4{
	font-size: 130%;
	line-height: 1.4em;
	font-weight: 300;
	border-collapse: collapse;
	border-bottom: 1px solid #17224f;
	padding-bottom: 10px;
}

.midashi41 {
	border-bottom: 3px solid #17224f;
}

.midashi42{
	border-left: 6px solid yellow;
	padding: 10px 0 10px 10px;
	font-size: 140%;
	line-height: 1.4em;
	font-weight: 700;
	border-collapse: collapse;
}
.midashi43 {
    font-size: 140%;
	padding: 20px 0;
    line-height: 1.4em;
    font-weight: 700;
    border-collapse: collapse;
}
.midashi4.sen_none{
	border-bottom: none;
	padding-bottom: 0;
}
.midashi4.sen_t{
	border-top: 1px solid #17224f;
	padding: 20px 10px;
}

.midashi5{
	border-collapse: collapse;
	border-left: 6px solid #299dd5;
	padding: 3px 0 3px 10px;
	font-size: 110%;
	line-height: 1.4em;
	margin-bottom: 10px;
}

.midashi51{
	border-collapse: collapse;
	padding: 3px 0px;
	font-size: 110%;
	line-height: 1.4em;
	margin-bottom: 10px;
}

.midashi52{
	border-collapse: collapse;
	padding: 3px 0 3px 10px;
	font-size: 110%;
	line-height: 1.4em;
	margin-bottom: 10px;
}

.midashi53{
	border-collapse: collapse;
	padding: 3px 0 3px 10px;
	font-size: 110%;
	line-height: 1.4em;
	margin-bottom: 10px;
}

.midashi54{
	border-collapse: collapse;
	padding: 3px 0 3px 10px;
	font-size: 150%;
	line-height: 1.4em;
}


.mb301{
	padding-left: 35px;
}
.midashi6{
	font-size: 120%;
	line-height: 1.4em;
	font-weight: 300;
	background-image : linear-gradient(-90deg, #4d5289 0%, #28a1d9 100%);
	color: #fff;
	padding: 10px 15px;
}

.midashi_box{
	background-color: #fff;
	padding: 20px 15px;
}

.midashi7{
    font-size:150%;
    color: #fff;
}

.midashi8{
	font-size: 150%;
	line-height: 1.4em;
	font-weight: 300;
	color: #FFF;
}




@media print, screen and (min-width: 576px){
	.midashi2{ font-size: 160%;}
}
@media print, screen and (min-width: 768px){
	.midashi1{ font-size: 110%;}
	.midashi1 .en{ font-size: 250%;}
	.midashi2{ font-size: 170%;}
	.midashi3{ font-size: 180%;}
	.midashi4{ font-size: 150%;}
	.midashi6{ font-size: 130%;}
}
@media print, screen and (min-width: 992px){
	.midashi1 .en{ font-size: 300%;}
	.midashi2{ font-size: 180%;}
	.midashi3{ font-size: 220%;}
	.midashi4{ font-size: 170%;}
	.midashi6{ font-size: 140%;}
}
@media print, screen and (min-width: 1200px){
	.midashi1{ font-size: 120%;}
	.midashi1 .en{ font-size: 320%;}
	.midashi2{ font-size: 200%;}
	.midashi3{ font-size: 250%;}
	.midashi4{ font-size: 190%;}
	.midashi6{ font-size: 150%;}
}
@media print, screen and (min-width: 1600px){
	.midashi1 .en{ font-size: 350%;}
	.midashi2{ font-size: 250%;}
	.midashi3{ font-size: 300%;}
	.midashi6{ font-size: 160%;}
}




/*リンク・ボタン関係
---------------------------------------------------- */
a:hover{opacity:0.7;filter: alpha(opacity=70);/*transition: 0.5s;*/}

.btn{ padding-top:10px; padding-bottom:10px;}
@media print, screen and (min-width: 768px) {.btn{ padding:10px 25px;}}


/* 青ボタンスタイル */
.blue_btn {
  display: inline-block;               /* 横に並べられるブロック要素として表示（幅や高さが使える） */
  padding: 12px 24px;                 /* 上下に12px、左右に24pxの余白（内側のスペース） */
  background-color: #D5F2FF;          /* 背景色（水色） */
  color: #0667B1 !important;          /* 文字色（濃い青）、!important で他のスタイルより優先 */
  text-decoration: none;             /* 下線などのテキスト装飾をなしにする（リンク用） */
  border: none;                      /* 枠線なし */
  border-radius: 6px;                /* 角を6px丸める（角丸） */
  font-size: 16px;                   /* 文字サイズ（16px） */
  font-weight: normal;              /* 通常の太さ（boldではない） */
  cursor: pointer;                  /* マウスオーバー時にポインターカーソルに変更 */
  transition: background-color 0.3s ease; /* 背景色の変化に0.3秒かけて滑らかにする */
  text-align: left;                 /* テキストを左寄せにする */
  width: 335px;                     /* ボタンの横幅を固定（350px） */
  white-space: nowrap;             /* テキストを折り返さず、1行で表示 */
}

/* グレーボタンスタイル（青ボタンとほぼ同じ構成） */
.gray_btn {
  display: inline-block;               /* 横並び可能なブロック要素 */
  padding: 12px 24px;                 /* 内側の余白 */
  background-color: #D6D6D6;          /* 背景色（グレー） */
  color: #333333 !important;          /* 文字色（濃いグレー） */
  text-decoration: none;             /* テキストの下線などを消す */
  border: none;                      /* 枠なし */
  border-radius: 6px;                /* 角丸（6px） */
  font-size: 16px;                   /* 文字サイズ */
  font-weight: normal;              /* 文字の太さ（通常） */
  cursor: pointer;                  /* ポインターカーソルを表示 */
  transition: background-color 0.3s ease; /* 背景色の変化を滑らかにする */
  text-align: left;                 /* テキストを左揃えに */
  width: 335px;                    /* 幅固定 */
  white-space: nowrap;             /* テキストの折り返しを防ぐ */
}


.cyn_btn {
  display: inline-block;                /* インラインブロック要素として表示。幅や高さの指定が可能 */
  padding: 0px 20px;                   /* 上下に10px、左右に20pxの内側余白 */
  background-color: #e5edf3 !important; /* 背景色（水色系）を適用 */
  color: #0667B1 !important;            /* 文字色（青系）を強制適用 */
  text-align: left;                     /* テキストを左揃えに */
  text-decoration: none;                /* テキストの下線などの装飾を無しに */
  text-transform: none !important;      /* テキストの大文字・小文字変換を無効化（強制） */
  border: none;                         /* ボーダーを消す */
  border-radius: 4px;                   /* 角を4px丸めて柔らかい印象に */
  font-size: 16px;                      /* 文字サイズを16pxに設定 */
  transition: all 0.3s ease;            /* すべてのプロパティ変化に0.3秒の滑らかなアニメーション */
  width: 100% !important;               /* 幅を親要素いっぱいに広げる（強制適用） */
  text-indent: 13px;                    /* テキストの先頭を13px右にずらす（インデント） */
}


.cyn_btn:hover {
  background-color: #ffffff !important; /* ホバー時に白くなる */
  color: #0667B1 ; /* 文字色はそのまま */
}



@media (max-width: 991px) {
  .cyn_btn {
    padding: 12px 25px;
    color: #0667B1 !important; /* 文字色を明示的に指定 */
    background-color: #e5edf3;
  }
}

.gray_btn2 {
  display: inline-block;                  /* インラインブロック表示。幅・高さ指定が可能で、横に並ぶ */
  padding: 10px 20px;                     /* 上下10px、左右20pxの内側余白 */
  background-color: #F0F0F0 !important;  /* 背景色を薄いグレーに設定。!importantで強制適用 */
  color: #333333 !important;              /* 文字色を濃いグレーに設定。強制適用 */
  text-align: left;                       /* テキストを左揃え */
  text-decoration: none;                  /* 下線などの装飾をなしに */
  text-transform: none !important;        /* 文字変換（大文字・小文字化）を無効に。強制適用 */
  border: none;                          /* ボーダーを消す（枠線なし） */
  border-radius: 4px;                    /* 角を4px丸くして柔らかい印象に */
  font-size: 16px;                       /* 文字サイズ16px */
  transition: all 0.3s ease;             /* 変化時に0.3秒かけて滑らかに変化 */
  width: 100% !important;                /* 幅を親要素いっぱいに広げる。強制適用 */
  text-indent: 13px;                     /* テキストの先頭を13px右にずらしてインデント */
}


.gray_btn2:hover {
  background-color: #ffffff !important; /* ホバー時に白くなる */
  color: #333333; !important/* 文字色はそのまま */
}


/* スマホサイズ用スタイル */
@media (max-width: 768px) {
  .gray_btn2 {
    padding: 12px 25px;
    border: 1px solid #ffffff; /* 白線のボーダー追加 */
    color: #333333 !important; /* 文字色を明示的に指定 */
    background-color: #e5edf3;
  }
}

/* !!これは受託開発のみにつけています。 */
.gray_btn3 {
  display: inline-block;
  padding: 10px 20px;
  background-color: #F0F0F0 !important; /* 灰色 */
  color: #333333 !important; /* 文字色 */
  text-align: left;
  text-decoration: none;
  text-transform: none !important;
  border: none; /* ボーダーを削除 */
  border-radius: 4px; /* 角を丸くする */
  font-size: 16px;
  transition: all 0.3s ease;
}

.gray_btn3:hover {
  background-color: #ffffff !important; /* ホバー時に白くなる */
  color: #333333; /* 文字色はそのまま */
}


/* スマホサイズ用スタイル */
@media (max-width: 768px) {
  .gray_btn3 {
    padding: 12px 25px;
    border: 1px solid #ffffff; /* 白線のボーダー追加 */
    color: #333333 !important; /* 文字色を明示的に指定 */
  }
}

.btn.dsb_sp {display: block;}
@media print, screen and (min-width: 768px) {.btn.dsb_sp {display: inline-block;}}




.btn1{
	font-size: 100%;
	line-height:1.4em;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
	position: relative;
}
.btn1:link,
.btn1:visited{
	color:#17224f;
	border-collapse: collapse;
	border: 1px solid #17224f;
}
.btn1:hover{
	opacity: 1;
	background-color: #17224f;
	color: #fff;
}

.btn1.white:link,
.btn1.white:visited{
	color:#fff;
	border-collapse: collapse;
	border: 1px solid #fff;
}
.btn1.white:hover{
	opacity: 1;
	background-color: #fff;
	color: #17224f;
}
.btn1 i{margin-right:5px;}
.btn1.btn {border-radius: 50px; padding:10px 20px;}

@media print, screen and (min-width: 1200px) {
	.btn1.btn { padding:13px 30px;}
}


.btn2{
	font-size: 100%;
	line-height:1.4em;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
	position: relative;
}
.btn2:link,
.btn2:visited{
	color:#fff;
	background-image : linear-gradient(-90deg, #28a1d9 0%, #4d5289 100%) ;
}
.btn2:hover{
	opacity: 1;
	letter-spacing: 0.4em;
}
.btn2 i{margin-right:5px;}
.btn2.btn {border-radius: 0; padding:12px 35px;}

.btn2 img{
	position: absolute;
	right: -20px;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
}
@media print, screen and (min-width: 1200px) {
	.btn2.btn { padding:16px 55px;}
}


.btn_detail{
	font-size: 70%;
	line-height:1.4em;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
	position: relative;
	font-family: 'Dosis', sans-serif;
}
.btn_detail:link,
.btn_detail:visited{
	color:#fff;
	background-color: #144faa;
}
.btn_detail:hover{
	opacity: 1;
	background-color: #1e5fc3;
}
.btn_detail i{margin-right:5px;}
.btn_detail.btn {border-radius: 0; padding:5px 7px;}




.btn_pdf{
	font-size: 90%;
	line-height:1.4em;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
	position: relative;
	font-family: 'Dosis', sans-serif;
}
.btn_pdf:link,
.btn_pdf:visited{
	color:#fff;
	background-color: #635e75;
}
.btn_pdf:hover{
	opacity: 1;
	background-color: #1e5fc3;
}
.btn_pdf i{margin-right:5px;}
.btn_pdf.btn {border-radius: 0; padding:5px 7px;}


.pdf_list li{
	list-style: none;
	margin-bottom: 3px;
}
.pdf_list li a:link,
.pdf_list li a:visited{
	padding: 10px 15px;
	background-color: #635e75;
	color: #fff;
	display: block;
}
.pdf_list li i {margin-right: 5px;}
@media print, screen and (min-width: 768px){
	.pdf_list{
		margin-left: -1%;
		margin-right: -1%;
	}
	.pdf_list li{
		width: 31.3%;
		float: left;
		margin: 1%;
	}
}

a.text_link {text-decoration: underline; color: #17224f;}
a.text_link2 {text-decoration: underline; color: #fff;}

.cate_text a:link,
.cate_text a:visited{
	text-decoration: underline;
	color: #00ac9a;
}
@media only screen and (max-width: 767px) {
	.text_link_sp {text-decoration: underline; color: #17224f;}
	.text_link_sp2 {text-decoration: underline!important; color: #fff;}
}


/* リスト
---------------------------------------------------- */
ol.list_ol{
	list-style:decimal;
	margin-left:25px;
}
ul.list_ul{
	list-style:disc;
	margin-left:20px;
}


ol.list_num {
  counter-reset: my-counter;
  list-style: none;
  padding: 0;
}

ol.list_num > li {
  margin-bottom: 10px;
  padding-left: 35px;
  position: relative;
}
ol.list_num > li:before {
  content: counter(my-counter);
  counter-increment: my-counter;
  background-color: #144faa;
  color: #fff;
  display: block;
  float: left;
  line-height: 25px;
  margin-left: -35px;
  text-align: center;
  height: 25px;
  width: 25px;
  border-radius: 50%;
	font-family: 'Roboto', sans-serif;
	margin-top: 5px;
}



ul.list_maru li{ list-style:none;text-indent: -1em; padding-left:1em;}
ul.list_maru li:before{
	font-family: "Font Awesome 6 Free";
	font-weight: 900;
	content: "\f28d";
	margin-right: 5px;
	color: #299dd5;
}



ul.list_large li{
	list-style: none;
	font-size: 110%;
	line-height: 1.4em;
	font-weight: 300;
	border-collapse: collapse;
	border-bottom: 1px solid #17224f;
	padding: 10px;
}
ul.list_large.sen_none li{
	border-bottom: none;
}
ul.list_large li:before{
	font-family: "Font Awesome 6 Free";
	font-weight: 900;
	content: "\f28d";
	margin-right: 5px;
	color: #299dd5;
}
@media only screen and (max-width: 575px) {
	ul.list_large li{
		text-indent: -1.5em; padding-left:1.5em;
	}
}
@media print, screen and (min-width: 992px) {
	ul.list_large li{
		font-size: 120%;
		padding: 15px 10px;
	}
	ul.list_large.sen_none li{
		padding: 10px 10px;
	}
}

/* color
---------------------------------------------------- */
.red{color:#951c5a;}
.white{color:#fff;}
.black{color:#17224f;}
.mizuiro{color:#299dd5;}
.orange{color:#e4662e;}


/* hanyo
---------------------------------------------------- */
.large{font-size:130%;line-height:1.7em}
.small{font-size:80%;line-height:1.5em; font-weight:normal}
.lsn{ list-style:none;}
.ln{ line-height:normal}
.dsb{ display:block}
.dsi{ display:inline}

.kome {text-indent:-1em; margin-left:1em;}
.kome_num {text-indent:-2.8em; margin-left:2.8em;}

.emplyee_name{ text-align:center;margin:5px 0;}
.tal{ text-align:left}
.tac{ text-align:center}
.tar{ text-align:right}
.bold {font-weight:bold;}

.tar_sptac {text-align:center;}
@media print, screen and (min-width: 768px) {
.tar_sptac {text-align:right;}
}

.tar_spsmtac {text-align:center;}
@media print, screen and (min-width: 992px) {
.tar_spsmtac {text-align:right;}
}

.tar_sptal {text-align:left;}
@media print, screen and (min-width: 768px){
.tar_sptal {text-align:right;}
}

.tal_lgtar {text-align:left;}
@media print, screen and (min-width: 1200px){
.tal_lgtar {text-align:right;}
}

.tal_smtac {text-align:center;}
@media print, screen and (min-width: 576px){
.tal_smtac {text-align:left;}
}

.tal_sptac {text-align:center;}
@media print, screen and (min-width: 768px){
.tal_sptac {text-align:left;}
}

.tal_xltac {text-align:center;}
@media print, screen and (min-width: 1200px){
.tal_xltac {text-align:left;}
}

.tal_spsmtac {text-align:center;}
@media print, screen and (min-width: 992px){
.tal_spsmtac {text-align:left;}
}

.tac_smtal {text-align:left;}
@media print, screen and (min-width: 576px){
.tac_smtal {text-align:center;}
}
.tac_sptal {text-align:left;}
@media print, screen and (min-width: 768px){
.tac_sptal {text-align:center;}
}

.img_c img{
	margin: 0 auto;
}
.horizontal-line {
  height: 2px;  /* 線の太さ */
  background-color: #FFF;  /* 線の色 */
  width: 100%;  /* 画面幅いっぱいにする */
  margin: 0;  /* 上下の余白をなくす */
}




/* dl
---------------------------------------------------- */
/*
.dl_list dt{
	background: url(../images/dl_sen.jpg) no-repeat left center;
	padding: 3px 0 3px 25px;
}
.dl_list dd{
	line-height: 1.8em;
	padding-left: 25px;
}
*/

/* テーブル
---------------------------------------------------- */
table{border-spacing:0;border-collapse:separate;}
table ul.list_ul, table ol.list_ol{margin-left:20px;}

.nw {width:1%; white-space:nowrap;}
@media only screen and (max-width: 767px){
	.nw_sp {width:1%; white-space:nowrap;}
}
@media print, screen and (min-width: 768px){
	.nw_spnone {width:1%; white-space:nowrap;}
}

.table1{
	width:100%;
	border-collapse: collapse;
	border-top: 1px solid #ccc;
}
.table1 th{
	width:100%;
	padding:10px 10px 0 10px;
	display: block;
	color: #6b7499;
}
.table1 td{
	width:100%;
	padding:0 10px 10px 10px;
	display: block;
	border-bottom: 1px solid #ccc;
}

.table1.white th,
.table1.white td {color: #fff;}
@media print, screen and (min-width: 768px) {
	.table1 th{
		width:27%;
		padding:12px 12px;
		vertical-align:middle;
		/* text-align:center; */
		display:table-cell;
		border-bottom: 1px solid #ccc;
		font-weight: normal;
		color: #17224f;
	}
	.table1 td{
		width:100%;
		padding:12px 12px;
		display:table-cell;
		vertical-align: middle;
	}
}
@media print, screen and (min-width: 992px) {
	.table1 th{ width:30%;}
}
@media print, screen and (min-width: 1200px) {
	.table1 th{ width:27%;}
}

.gnavi__list{
	display:inline-block;
}
.plat {
	position: absolute;
	display: none;
	background-color: #3a7ab2;
	min-width:200px;
	box-shadow: 0px 8px 16px 0px rgba(0,0,0,0.2);
	z-index: 1;
}
.gnavi__list:hover .plat{
	display: block;
}
/* .plat_pink {
    position: absolute;
    display: none;
    background-color: #f0dddf;
    min-width: 200px;
    box-shadow: 0px 8px 16px 0px rgba(0, 0, 0, 0.2);
    z-index: 1;
} */
.plat1{
	border-bottom: 1px solid #fff;
}




.table2{
	width: 100%;
	border-collapse: collapse;
	border-top: 1px solid #ccc;
	border-left: 1px solid #ccc;
}
.table2 th,.table2 td{
	padding: 4px 10px;
	border-bottom: 1px solid #ccc;
	border-right: 1px solid #ccc;
	/* text-align: center; 20220927 Add */
	vertical-align: middle;
}
.table2 th{
	background-color: #17224f;
	color: #fff;
}
.table2 td{background-color: #fff;}
.table2 tr.bg_blue td{background-color: #efefef;}
/*.table2 tr:nth-child(odd){background-color: #e8eef7;}奇数番目の要素にスタイルを適用*/

/* サイズ指定
---------------------------------------------------- */
.mb05{ margin-bottom:5px}
.mb10{ margin-bottom:10px}
.mb15{ margin-bottom:15px}
.mb20{ margin-bottom:20px}
.mb30{ margin-bottom:30px}
.mb40{ margin-bottom:40px}
.mb50{ margin-bottom:50px}
.mb60{ margin-bottom:60px}
.mb70{ margin-bottom:70px}
.mb80{ margin-bottom:80px}

.mt10{ margin-top:10px}
.mt20{ margin-top:20px}
.mt40{ margin-top:40px}
.mt80{ margin-top:80px}
.btnmt {
  display: flex;
  flex-wrap: nowrap; /* 折り返さず横一列に並べる */
  justify-content: flex-start;
  gap: 0 50px; /* 横方向の間隔のみ */
}

.btnmt > * {
  margin-bottom: 30px; /* 縦方向の間隔（下のみ） */
}




.ml20{ margin-left:20px}
.ml05{ margin-left:5px}
.ml10{ margin-left:10px}
.ml50{ margin-left:50px }


.pl40 {padding-left: 40px;}

@media print, screen and (min-width: 768px) {.pr30_sp0 {padding-right: 30px;}}

.mb10_sp {margin-bottom:10px;}
@media print, screen and (min-width: 768px) {.mb10_sp {margin-bottom:0;}}

.mb15_sp {margin-bottom:15px;}
@media print, screen and (min-width: 768px) {.mb15_sp {margin-bottom:0;}}

.mb20_sp {margin-bottom:20px;}
@media print, screen and (min-width: 768px) {.mb20_sp {margin-bottom:0;}}

.mb30_sp {margin-bottom:30px;}
@media print, screen and (min-width: 768px) {.mb30_sp {margin-bottom:0;}}

.mb50_sp {margin-bottom:50px;}
@media print, screen and (min-width: 768px) {.mb50_sp {margin-bottom:0;}}

.mb50_lg0 {margin-bottom:50px;}
@media print, screen and (min-width: 992px) {.mb50_lg0 {margin-bottom:0;}}

.mb50_sp_sm0 {margin-bottom:50px;}
@media print, screen and (min-width: 576px) {.mb50_sp_sm0 {margin-bottom:0;}}

@media print, screen and (min-width: 768px) {.mb30_sp0 {margin-bottom:30px;}}

@media print, screen and (min-width: 992px) {.mb30_spsm0 {margin-bottom:0;}}

.mt10_sm20_md30 {margin-top: 10px;}
@media print, screen and (min-width: 768px) {.mt10_sm20_md30 {margin-top: 20px;}}
@media print, screen and (min-width: 992px) {.mt10_sm20_md30 {margin-top: 30px;}}

.mt20_sm40_md50 {margin-top: 20px;}
@media print, screen and (min-width: 768px) {.mt20_sm40_md50 {margin-top: 40px;}}
@media print, screen and (min-width: 992px) {.mt20_sm40_md50 {margin-top: 50px;}}

.mb10_md0 {margin-bottom: 10px;}
@media print, screen and (min-width: 992px) {.mb10_md0 {margin-bottom: 0;}}

.mb10_lg0 {margin-bottom: 10px;}
@media print, screen and (min-width: 1200px) {.mb10_lg0 {margin-bottom: 0;}}

.mb10_sm30 {margin-bottom: 10px;}
@media print, screen and (min-width: 768px) {.mb10_sm30 {margin-bottom: 30px;}}

.mb10_md20 {margin-bottom: 10px;}
@media print, screen and (min-width: 992px) {.mb10_md20 {margin-bottom: 20px;}}

@media print, screen and (min-width: 768px) {.mb20_sp0 {margin-bottom: 20px;}}

.mb20_md0 {margin-bottom: 20px;}
@media print, screen and (min-width: 992px) {.mb20_md0 {margin-bottom: 0;}}

.mb20_lg0 {margin-bottom: 20px;}
@media print, screen and (min-width: 992px) {.mb20_lg0 {margin-bottom: 0;}}

.mb20_sm30 {margin-bottom: 20px;}
@media print, screen and (min-width: 768px) {.mb20_sm30 {margin-bottom: 30px;}}

.mb20_md30 {margin-bottom: 20px;}
@media print, screen and (min-width: 992px) {.mb20_md30 {margin-bottom: 30px;}}

.mb30_md0 {margin-bottom: 30px;}
@media print, screen and (min-width: 992px) {.mb30_md0 {margin-bottom: 0;}}

.mb30_sm50 {margin-bottom:30px;}
@media print, screen and (min-width: 768px) {.mb30_sm50 {margin-bottom:50px;}}

.mb30_md50 {margin-bottom:30px;}
@media print, screen and (min-width: 992px) {.mb30_md50 {margin-bottom:50px;}}

.mb30_lg40_xl50 {margin-bottom:30px;}
@media print, screen and (min-width: 992px) {.mb30_lg40_xl50 {margin-bottom:40px;}}
@media print, screen and (min-width: 1200px) {.mb30_lg40_xl50 {margin-bottom:50px;}}

.mb40_md50 {margin-bottom:40px;}
@media print, screen and (min-width: 992px) {.mb40_md50 {margin-bottom:50px;}}

.mb30_sm60 {margin-bottom:30px;}
@media print, screen and (min-width: 768px) {.mb30_sm60 {margin-bottom:60px;}}

.mb30_sp10 {margin-bottom:10px;}
@media print, screen and (min-width: 768px) {.mb30_sp10 {margin-bottom:30px;}}

.pl50_sm0 {padding-left: 50px;}
@media print, screen and (min-width: 768px) {.pl50_sm0 {padding-left: 0;}}


@media print, screen and (min-width: 768px) {
	.mt20_sp0 {margin-top: 20px;}
}

@media print, screen and (min-width: 992px) {
	.mt40_sm0 {margin-top: 40px;}
	.mt40_md_20_sm0 {margin-top: 20px;}
}
@media print, screen and (min-width: 1200px) {
	.mt40_md_20_sm0 {margin-top: 40px;}
}

.mb_content {margin-bottom: 50px;}
.mt_content {margin-top: 50px;}
@media print, screen and (min-width: 768px) {
	.mb_content {margin-bottom: 60px;}
	.mt_content {margin-top: 60px;}
}
@media print, screen and (min-width: 992px) {
	.mb_content {margin-bottom: 80px;}
	.mt_content {margin-top: 80px;}
}
@media print, screen and (min-width: 1200px){
	.mb_content {margin-bottom: 100px;}
	.mt_content {margin-top: 100px;}
}

@media (max-width: 992px) {
  .btnmt {
    flex-direction: column; /* 縦一列に並べる */
    align-items: flex-start; /* 左揃え */
    gap: 15px; /* ボタン間の縦の隙間 */
  }

  .btnmt > * {
    margin-bottom: 0; /* 縦のマージンをなくす */
    width: 95%; /* 画面幅に応じたボタン幅 */
    padding: 15px 30px; /* ボタンのパディングを増やしてボタンを大きく */
    height: auto; /* 高さを自動調整 */
    font-size: 18px; /* 文字の大きさを少し大きく */
  }
}

/* より小さい画面（最大幅 480px）向けの設定 */
@media (max-width: 480px) {
  .btnmt > * {
    width: 100%; /* 画面幅いっぱいに広げる */
    padding: 15px 30px; /* より大きなボタンのパディング */
    height: auto; /* 高さを自動調整 */
    font-size: 14px; /* 文字サイズを少し大きく */
  }
}

.lh160 {line-height: 160%;}
.lh200 {line-height: 200%;}

/* content
---------------------------------------------------- */
main { line-height: 2.0em; font-size: 105%;}


.content_pd {padding-top: 50px; padding-bottom: 50px;}
.content_pd2 {padding-top: 30px; padding-bottom: 30px;}
.content_pd3 {padding-top: 30px; padding-bottom: 30px;}
.pd20 { padding: 20px;}
.pd30 { padding: 30px;}
@media only screen and (max-width: 767px){
	.content_pd.pt0_sp {padding-top: 0;}
}
@media print, screen and (min-width: 768px){
	main {font-size: 100%;}
	.content_pd {padding-top: 60px; padding-bottom: 60px;}
	.content_pd2 {padding-top: 50px; padding-bottom: 50px;}
}
@media print, screen and (min-width: 992px){
	.content_pd {padding-top: 80px; padding-bottom: 80px;}
}
@media print, screen and (min-width: 1200px){
	main {font-size: 110%;}
	.content_pd {padding-top: 100px; padding-bottom: 100px;}
}
.content_pd.pt0{padding-top: 0;}
.content_pd.pb0{padding-bottom: 0;}
.content_pd.pb10{padding-bottom: 10px;}
.content_pd.pb30{padding-bottom: 30px;}




/* mainimage
---------------------------------------------------- */
/* 画面用 */
@media screen {
#main_print { display: none; }
}

/* 印刷用 */
@media print {
#main_print img { margin: 0 auto;}
}



.swiper-wrapper img{
	margin: 0 auto;
}

.swiper-container-horizontal > .swiper-pagination-bullets, .swiper-pagination-custom, .swiper-pagination-fraction{
	bottom: 0px!important;
}
@media print, screen and (min-width: 1200px) {
	.swiper-container-horizontal > .swiper-pagination-bullets, .swiper-pagination-custom, .swiper-pagination-fraction{
		bottom: 10px!important;
	}
}


.swiper-button-next, .swiper-button-prev{ z-index: 200!important; position: absolute!important;}



#mainimage {
	position: relative;
	margin-top: 50px;
}
#mainimage h2{
    position: absolute;
    top: 50%;
    left: 0%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
	z-index: 1;
	width: 100%;
}
#mainimage h2 img {width: 80%; max-width: 1082px; margin: 0 auto;}
.swiper-button-next, .swiper-button-prev{ z-index: 200!important; position: absolute!important;}
@media print, screen and (min-width: 768px){
	#mainimage h2 img {width: 80%;}
}
@media print, screen and (min-width: 992px){
	#mainimage  { margin-top: 0;}
}



/*---------------
幾何学模様
---------------*/
#hoge{
  width:100%;
  height:200px;
  margin:0 auto;
	z-index: 1;
}
.parent {
  /*親要素はrelativeに*/
  position: relative;
}
.absolute {
  position: absolute;
  top: 0;
  left: 0;
}

#midashi_h2 #hoge{
	height: 100px;
}
@media print, screen and (min-width: 768px) {
	#hoge{ height:500px;}
	#midashi_h2 #hoge{
		height: 200px;
	}
}




/* ヘッダー固定で上空ける
---------------------------------------------------- */


/* 背景
---------------------------------------------------- */
.bg_blue {background-color: #e7eef7;
}
/* .bg_pink {
    background-color: #f0dddf;
} */
.bg_white {
    background-color: white;
}
.bg_gradient {background-image : linear-gradient(-90deg, #4d5289 0%, #28a1d9 100%);}
/* .bg_pink_gradient {
    background-image: linear-gradient(-90deg, #d796c3 0%, #975184 100%);
} */
.bg_gara{
	background: url(../images/bg_gara.jpg) no-repeat scroll 50% 50% / cover;
}

/* レイアウト
---------------------------------------------------- */

.num {
    display: block;
    width: fit-content;
    border-bottom: 2px solid #1d264d;
    font-size: 18px;
    font-family: 'Archivo', 'Noto Sans JP', sans-serif;
    letter-spacing: 0.1em;
    margin-bottom: 10px;

}

.question {
    width: fit-content;
    font-size: 24px;
    font-family: 'Archivo', 'Noto Sans JP', sans-serif;
    letter-spacing: 0.1em;
    margin:20px 0 20px;
}

.answer {
    width: fit-content;
    font-family: 'Archivo', 'Noto Sans JP', sans-serif;
    letter-spacing: 0.1em;
    font-size: 16px;
    line-height: 2.0;
    margin-bottom: 2.2em
}
.scroll-area {
    max-height: 330px;
    padding-right: 10px;
    margin-bottom: 40px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    overflow-y: auto;
    background-color: #FFFFFF;
    border: solid 1px #CCCCCC;
    z-index: 1;
}

/* 共通
---------------------------------------------------- */
a:hover img {
	opacity:0.9;
	filter: alpha(opacity=90);
}

.close {
    float: none;
}

/* 縦横比固定 */
.photo-ofi {
	 height: 0;
	 display: block;
	padding-bottom: 75%; /* 高さを指定（ボックスの横幅を基準） */
	/*background-color: #EFEFEF;*/
	overflow: hidden;
	position: relative;
	/*margin-bottom: 10px;*/
}
.photo-ofi img {
	 max-width: inherit;
	 max-height: inherit;
	width: 100%;
	height: 100%;
	 object-fit: scale-down;
	 font-family: 'object-fit: scale-down;';
	 position: absolute;
	 left: 0;
	 top: 0;
}

.object-fit img{
	object-fit: cover;
	font-family: 'object-fit: cover;'; /*IE対策*/
}


div.paging { text-align: center; font-size: 90%; margin-top: 20px; line-height: 1.4em; font-family: 'Roboto', sans-serif;}
div.paging span.current,
div.paging span.paging-text{
	margin:0px 0.5px;
	color:#17224f;
	border:1px solid #17224f;
	display:inline;
	zoom:1;
	display:inline-block;
	overflow:hidden;
	text-decoration:none;
}
div.paging span.paging-text a{
	padding:5px 8.5px;
	display:block;
	color: #17224f;
}
div.paging span.current{
	background: #17224f;
	border:1px solid #17224f;
	color:#fff;
	zoom:1;
	padding:5px 8.5px;
	text-decoration:none;
	display:inline-block;
	cursor:pointer;
}
div.paging span.paging-text a:hover{
	background: #17224f;
	color:#fff;
	text-decoration:none;
	cursor:pointer;
	opacity: 1;
}

/*左右の余白*/

.yohaku2{ padding: 30px;}
@media print, screen and (min-width: 768px){
	.yohaku{
		margin-left: 8.333333%;
		margin-right: 8.333333%;
	}
}
@media print, screen and (min-width: 992px){
	.yohaku2{ padding: 50px 50px;}
}
@media print, screen and (min-width: 1200px){
}
@media print, screen and (min-width: 1500px){
	.yohaku{
		margin-left: 16.666667%;
		margin-right: 16.666667%;
	}
	.yohaku2{ padding: 60px 80px;}
}



/* 01 index
---------------------------------------------------- */
/*--------------------------------------
新着情報
--------------------------------------*/
.news_table{
	width:100%;
	border-collapse: collapse;
	line-height: 1.6em;
}
.news_table th{
	width:100%;
	padding:15px 10px 2px 10px;
	display: block;
	font-weight: normal;
	font-size: 80%;
}
.news_table td{
	width:100%;
	padding:0px 10px 15px 10px;
	display: block;
	word-break: break-all;
	border-bottom: 1px solid #c0cbd8;
}
.new{
	margin-left: 10px;
	font-size: 80%;
	line-height: 1.0em;
	color: #951c5a;
}

.news_table a.btn_detail{
	text-decoration: none!important;
}

.news_table td a:link,
.news_table td a:visited{
	text-decoration: underline;
}

.news_table td li{
	list-style: none;
}

.news_table td li.btn_area {text-align: right;}
@media print, screen and (min-width: 576px) {
	.news_table td ul{
		display: table;
		width: 100%;
	}
	.news_table td li{
		display: table-cell;
	}
	.news_table td li.btn_area{
		white-space: nowrap;
		width: 1%;
		padding-left: 10px;
	}
}
@media print, screen and (min-width: 992px) {
	.news_table th{
		width:20%;
		padding:15px 10px;
		vertical-align:top;
		text-align:left;
		display:table-cell;
		font-weight: normal;
		border-bottom: 1px solid #c0cbd8;
	}
	.news_table td{
		width:100%;
		padding:15px 10px;
		display:table-cell;
	}
}
@media print, screen and (min-width: 1200px) {
	.news_table th{ padding:20px 10px;}
	.news_table td{ padding:20px 10px;}
}


#top02{ background: url(../images/top02_bg2.jpg) no-repeat scroll 50% 50% / cover; overflow: hidden; position: relative;}
/* #recruit_bg_01{ background: url(/images/recruit/bg_pink.jpg) no-repeat scroll 50% 50% / cover; overflow: hidden; position: relative;} */
@media print, screen and (min-width: 1600px){
	#top02{ background: url(../images/top02_bg.jpg) no-repeat scroll 50% 50% / cover;}
}



/*製品＆ソリューション*/
#top02 ul{
	display: table;
}
.sp-slide {padding: 0 15px;}

.sp-button {
    width: 10px!important;
    height: 10px!important;
}


.top_products .text{
	background-color: #fff;
	padding: 20px;
}
.top_products .text .midashi2 {margin-bottom: 10px;}
@media print, screen and (min-width: 992px){
	.top_products {
		background-color: #fff;
	}
	.top_products .image{
		float: left;
		width: 300px;
	}
	.top_products .image img{
		width: 100%;
		height: auto;
	}
	.top_products .text{
		overflow: hidden;
		zoom:1;
		padding: 30px 40px;
	}
	.sp-slide {padding: 0;}
}
@media print, screen and (min-width: 1600px){
	.top_products .image{
		float: left;
		width: 400px;
	}
	.top_products .text{
		padding: 40px 50px;
	}
}



#top03{ background: url(../images/top03_bg.jpg) no-repeat scroll 50% 50% / cover; overflow: hidden; position: relative;}


#top04{ background: url(../images/top04_bg.jpg) no-repeat scroll 50% 50% / cover; color: #fff;}
#top05{ background-image : linear-gradient(-90deg, #4d5289 0%, #28a1d9 100%); color: #fff;}

/* 02 index
---------------------------------------------------- */
#cate_head{
	margin-top:-50px;
	padding-top:50px;
}
@media print, screen and (min-width: 992px){
	#cate_head{
		margin-top:-70px;
		padding-top:70px;
	}
}
@media print, screen and (min-width: 1200px){
	#cate_head{
		margin-top:-80px;
		padding-top:80px;
	}
}


.news_box .image{
	margin-bottom: 20px;
}
@media print, screen and (min-width: 576px){
	.news_box .image{
		width: 200px;
		float: left;
		margin-right: 30px;
	}
	.news_box .image.right{
		float: right;
		margin-right: 0;
		margin-left: 30px;
	}
	.news_box .text{
		overflow: hidden;
		zoom:1;
	}
}
@media print, screen and (min-width: 992px){
	.news_box .image{ width: 300px;}
}
@media print, screen and (min-width: 1200px){
	.news_box .image{ width: 350px;}
}


/* 03 contents
---------------------------------------------------- */

.contents_box .text{
	background-color: #fff;
	padding: 20px;
}
.contents_box .text .midashi2 {margin-bottom: 10px;}
@media print, screen and (min-width: 992px){
	.contents_box {
		background-color: #fff;
	}
	.contents_box .image{
		float: left;
		width: 250px;
	}
	.contents_box .image img{
		width: 100%;
		height: auto;
	}
	.contents_box .text{
		overflow: hidden;
		zoom:1;
		padding: 30px 40px;
	}
}
@media print, screen and (min-width: 1200px){
	.contents_box .image{
		width: 300px;
	}
}
@media print, screen and (min-width: 1600px){
	.contents_box .image{
		float: left;
		width: 400px;
	}
	.contents_box .text{
		padding: 40px 50px;
	}
}

/* 04 cloud
---------------------------------------------------- */
.cloud_icon2 li{
	list-style: none;
	width: 33.3%;
	float: left;
	text-align: center;
	font-size: 110%;
	padding: 5px 0;
}
.cloud_icon2 img{
	max-height: 95px;
	margin: 0 auto;
	height: 60px;
	padding-bottom: 5px;
}
@media print, screen and (min-width: 576px){
	.cloud_icon2 li{
		width: 25%;
		padding: 10px 0;
	}
}
@media print, screen and (min-width: 992px){
	.cloud_icon2{
		display: table;
		margin: 0 auto;
	}
	.cloud_icon2 li{
		width: auto;
		padding: 0 20px;
		display: table-cell;
		float: none;
	}
}
@media print, screen and (min-width: 1200px){
	.cloud_icon2 li{
		padding: 0 30px;
	}
	.cloud_icon2 img{
		height: 80px;
		padding-bottom: 10px;
	}
}

/* 05 sale
---------------------------------------------------- */
#sale1,
#sale2{
	margin-top:-50px;
	padding-top:50px;
}
@media print, screen and (min-width: 992px){
	#sale1,
	#sale2{
		margin-top:-70px;
		padding-top:70px;
	}
}
@media print, screen and (min-width: 1200px){
	#sale1,
	#sale2{
		margin-top:-80px;
		padding-top:80px;
	}
}


.sale_list{
	padding: 20px 0;
}
.sale_list li{
	list-style: none;
	border-collapse: collapse;
	border-bottom: 1px solid #8594bb;
}
.sale_list a:link,
.sale_list a:visited{
	padding: 10px;
	display: block;
	color: #fff;
}
.sale_list li a:before{
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	content: "\f0da";
	margin-right: 5px;
}
.sale_list a:hover{
	color: #ccc;
	opacity: 1;
}
@media print, screen and (min-width: 768px){
	.sale_list{
		display: table;
		width: 100%;

	}
	.sale_list li{
		display: table-cell;
		width: auto;
		float: none;
		border-bottom: none;
	}
}
@media print, screen and (min-width: 992px){
	.sale_list{font-size: 110%;}
}
@media print, screen and (min-width: 1200px){
	.sale_list{font-size: 120%;}
}


.sale_title{
	background: url(../images/sale_bg1.jpg) no-repeat scroll 50% 50% / cover;
	color: #fff;
	text-align: center;
	padding: 70px 10px;
}
.sale_title.bg2{
	background: url(../images/sale_bg2.jpg) no-repeat scroll 50% 50% / cover;
}
.sale_title h3{
	font-size: 130%;
	line-height: 1.4em;
}
@media print, screen and (min-width: 576px){
	.sale_title h3{ font-size: 150%;}
}
@media print, screen and (min-width: 992px){
	.sale_title{ padding: 100px 10px;}
	.sale_title h3{ font-size: 180%;}
}
@media print, screen and (min-width: 1600px){
	.sale_title{ padding: 150px 10px;}
	.sale_title h3{ font-size: 220%;}
}


.sale_icon{
	display: table;
	width: 100%;
	border-bottom: 4px solid #328cc4;
}

.sale_icon li{
	list-style: none;
	display: table-cell;
	vertical-align: middle;
}
.sale_icon img{
	max-height: 116px;
	height: 60px;
	margin: 0 auto;
	padding-bottom: 10px;
}
.sale_icon li:after {
	content: "";
	flex-grow: 1;
	height: 20px;
	width: 5px;
	background: #328cc4;
	display: block;
}
.sale_icon li:after {
	margin-left: 50%;
}
@media print, screen and (min-width: 768px){
	.sale_icon img{ height: 80px;}
}
@media print, screen and (min-width: 992px){
	.sale_icon img{ height: 90px;}
}
@media print, screen and (min-width: 1200px){
	.sale_icon img{ height: 116px;}
}


.sale2_zu01 img{
	max-width: 638px;
	width: 100%;
	height: auto;
	margin: 0 auto;
}
@media print, screen and (min-width: 576px){
	.sale2_zu01 img{ width: 60%;}
}



.sale2_option li{
	list-style: none;
	width: 50%;
	float: left;
	text-align: center;
	margin-bottom: 15px;
}
.sale2_option img{
	height: 100px;
	padding-bottom: 10px;
	margin: 0 auto;
	max-height: 160px;
}
@media print, screen and (min-width: 576px){
	.sale2_option li{
		width: 33.3%;
		margin-bottom: 15px;
	}
}
@media print, screen and (min-width: 1200px){
	.sale2_option li {margin: 15px 0;}
	.sale2_option img{
		height: 160px;
	}
}
@media print, screen and (min-width: 1600px){
	.sale2_option{
		display: table;
		width: 100%;
	}
	.sale2_option li{
		display: table-cell;
		float: none;
		width: auto;
	}
}

/* 06 system
---------------------------------------------------- */
/*cloud.htmlでも使用*/
.system_box img{
	max-height: 107px;
	margin: 30px auto;

}

.system_step{
	border-collapse: collapse;
	border-left: 1px solid #17224f;
}
.system_step li{
	list-style: none;
	padding: 10px 0 10px 20px;
	font-weight: 300;
	font-size: 90%;
	line-height: 1.6em;
}
.system_step li .title{
	font-size: 130%;
	color: #299dd5;
	font-weight: 500;
	margin-bottom: 5px;
	line-height: 1.8em;
}
.system_step li .title .en{font-size: 80%; color: #17224f; }
.system_step li .title:before{
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	content: "\f28d";
	margin-right: 5px;
	color: #299dd5;
}
@media print, screen and (min-width: 992px){
	.system_step{
		border-left: none;
	}
	.system_step li{
		width: 20%;
		float: left;
		padding: 20px 20px 0 0;
	}
	.system_step li .title{display: none;}
}


/* 07 case
---------------------------------------------------- */
.case_box_ichiran{
	border-collapse: collapse;
	border: 1px solid #17224f;
	padding: 20px;
}
.case_box_ichiran.waku_none{
	border: 0;
	padding: 0;
}
.case_box_ichiran.waku_kasen{
	border-right: none;
	border-left: none;
	border-bottom: none;
	padding: 40px 0;
}

.case_box_ichiran .image{
	margin-bottom: 20px;
}
@media print, screen and (min-width: 768px){
	.case_box_ichiran .image{
		width: 200px;
		float: left;
		margin-right: 30px;
		margin-bottom: 0;
	}
	.case_box_ichiran .image.right{
		float: right;
		margin-right: 0;
		margin-left: 30px;
	}
	.case_box_ichiran .text{
		overflow: hidden;
		zoom:1;
	}
}
@media print, screen and (min-width: 992px){
	.case_box_ichiran .image{ width: 300px;}
}
@media print, screen and (min-width: 1200px){
	.case_box_ichiran .image{ width: 350px;}
}


/*詳細*/


.case_box{
	border-collapse: collapse;
	border: 1px solid #17224f;
	padding: 20px;
}
.case_box.waku_none{
	border: 0;
	padding: 0;
}
.case_box.waku_kasen{
	border-right: none;
	border-left: none;
	border-bottom: none;
	padding: 40px 0;
}

.case_box .image{
	margin-bottom: 20px;
	margin-left: -1%;
	margin-right: -1%;
}
.case_box .image .photo{
	width: 48%;
	float: left;
	margin: 1%;
}
.case_box .image .photo:nth-of-type(2n+1) { clear: both;}
@media print, screen and (min-width: 768px){
	.case_box .image{
		width: 400px;
		float: left;
		margin-right: 30px;
		margin-bottom: 0;
	}
	.case_box .image.right{
		float: right;
		margin-right: 0;
		margin-left: 30px;
	}
	.case_box .text{
		overflow: hidden;
		zoom:1;
	}
}
@media print, screen and (min-width: 992px){
	.case_box .image{ width: 600px;}
}
@media print, screen and (min-width: 1200px){
	.case_box .image{ width: 700px;}
}

/* 08 company
---------------------------------------------------- */
#company1,
#company2,
#company3,
#company4,
#company5{
	margin-top:-50px;
	padding-top:50px;
}
@media print, screen and (min-width: 992px){
	#company1,
	#company2,
	#company3,
	#company4,
	#company5{
		margin-top:-70px;
		padding-top:70px;
	}
}
@media print, screen and (min-width: 1200px){
	#company1,
	#company2,
	#company3,
	#company4,
	#company5{
		margin-top:-80px;
		padding-top:80px;
	}
}

.company_list{
	padding: 20px 0;
}
.company_list li{
	list-style: none;
	width: 50%;
	float: left;
	border-collapse: collapse;
	border-bottom: 1px solid #8594bb;
}
.company_list a:link,
.company_list a:visited{
	padding: 10px;
	display: block;
	color: #fff;
}
.company_list li a:before{
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	content: "\f0da";
	margin-right: 5px;
}
.company_list a:hover{
	color: #ccc;
	opacity: 1;
}
@media print, screen and (min-width: 576px){
	.company_list{
		display: table;
		width: 100%;

	}
	.company_list li{
		display: table-cell;
		width: auto;
		float: none;
		border-bottom: none;
	}
}
@media print, screen and (min-width: 1200px){
	.company_list{font-size: 110%;}
}

.name{
	float: right;
}
.name img{
	max-width: 250px;
	width: 100%;
	height: auto;
}



@media print, screen and (min-width: 768px){
	.company_img{
		width: 70%;
		margin: 0 auto;
	}
}
@media print, screen and (min-width: 992px){
	.company_img{
		width: 100%;
	}
}



.company_kyoka{
	display: table;
}
.company_kyoka li{
	display: table-cell;
}
.company_kyoka .title{
	width: 160px;
}

@media print, screen and (min-width: 768px) {
  .company_client {
    text-align: left;
  }

  .company_client .list_maru {
    column-count: 2;           /* 两栏 */
    column-gap: 3em;           /* 栏之间的间隔 */
    list-style: disc inside;
    padding: 0;
    margin-left: 20%;
  }

  .company_client .list_maru li {
    break-inside: avoid;       /* 避免单个 <li> 跨栏 */
    margin-bottom: 0.5em;
  }
}

.company_otoiawase li{
	list-style: none;
}
.company_otoiawase i{
	margin-right: 10px;
}

/* 09 contact
---------------------------------------------------- */
.contact_tel_waku{
	border-collapse: collapse;
	border: 1px solid #17224f;
	padding: 30px 20px;
}
.contact_tel{
	text-align: center;
}
.contact_tel li{
	list-style: none;
	line-height: 1.4em;
	font-size: 90%;
}
.contact_tel .num{font-size: 180%;}
@media print, screen and (min-width: 576px) {
	.contact_tel li{ font-size: 100%;}
}
@media print, screen and (min-width: 768px) {
	.contact_tel{ display: table; margin: 0 auto;}
	.contact_tel li{
		display: table-cell;
		vertical-align: middle;
		padding: 0 20px;
		font-size: 110%;
	}
}
@media print, screen and (min-width: 992px) {
	.contact_tel_waku{
		padding: 50px 20px;
	}
	.contact_tel .num{font-size: 220%;}
}




.contact_box{
	border-collapse: collapse;
	border: 1px solid #fff;
	padding: 30px;
	display: block;
	color: #fff;
}
.contact_box .text{
	margin: 20px 20px 10px 20px;
}
@media print, screen and (min-width: 576px) {
	.contact_box{padding: 30px 50px; display: inline-block;}
	.contact_box .image{
		width: 30%;
		float: left;
		margin-right: 30px;
	}
	.contact_box .text{
		overflow: hidden;
		zoom:1;
	}
	.contact_box .text{
		margin: 0;
	}
}



/* 11 alclean
---------------------------------------------------- */
.alclea_display{
	display: flex; /* 使用flex布局 */
	margin-bottom: 20px;
	justify-content: center; /* 水平居中对齐 */
	align-items: center; /* 垂直居中对齐 */
}

.alclea_display img{
	height: 110%;
	width: 13%;
	margin-left:20%;
}

  .alcean_temporary img{
	width: 100%;
  }


  .alcean_temporary p{
	position: absolute;
	margin-bottom: 100px;
  }



/*フォームのテーブル*/
.table_form{
	width:100%;
	border-collapse:collapse;
	border-top:1px solid #ccc;
}
.table_form th{
	width:100%;
	padding:10px 5px 3px 5px;
	display: block;
	color: #6b7499;
	font-weight: normal;
}
.table_form td{
	width:100%;
	border-bottom:1px solid #ccc;
	padding:3px 5px 10px 5px;
	display: block;
}
.table_form th span{/*必須*/
	font-size:70%;
	color:#fff;
	padding:0px 6px;
	float:right;
	border-radius:3px;
	font-weight: normal;
	background-color: #951c5a;
}
.table_form td.last {border-bottom:none;}


.table_form th.sen_none,
.table_form td.sen_none{
	border:0;
}

@media print, screen and (min-width: 768px) {
	.table_form th{
		width:35%;
		border-bottom:1px solid #ccc;
		padding:15px 20px;
		vertical-align:middle;
		text-align:left;
		display:table-cell;
		color: #17224f;
	}
	.table_form td{
		width:100%;
		padding:15px 20px;
		display:table-cell;
	}

	.table_form.sen_none .last td{padding-bottom: 10px;}
	.table_form.sen_none th{
		padding:10px 20px 0 20px;
	}
	.table_form.sen_none td{
		padding:10px 25px 0 25px;
	}

}
@media print, screen and (min-width: 992px) {
	.table_form th{width:30%;}
}

/* フォーム関係 */
.required input[type="text"], .required input[type="password"], .required select, .required textarea{border:1px solid #c36;}
input[type="checkbox"], input[type="radio"] {vertical-align:middle; margin:5px 5px 5px 0;}
input{font-size:100%;vertical-align:middle; padding:9px}
input[type="file"]{width: 99%;}
input[type="text"], select{border:1px solid #ccc; border-radius:3px; color: #17224f;}
input[type="email"]{color: #17224f;}

input:focus[type="text"]{border:1px solid #06c;}
textarea{font-size:100%;border:1px solid #ccc;width:99%; border-radius:3px; }
input,textarea{
  /*display: inline-block;
  font-family: FontAwesome; */
  font-style: normal;
  font-weight: normal;
  line-height: 1;
  -Webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
select {padding: 9px; color: #17224f; }

.form-control {color: #17224f;}
.form-control.w50 {width:50px; display: inline-block; margin-right: 10px;}
.form-control.w300 {width:200px;}
@media (min-width: 768px) {
.form-control.w300 {width:250px;}
}


.privacy_waku{
	padding:30px 20px;
	font-size: 90%;
	background-color: #f6f6f6;
}
@media print, screen and (min-width: 992px){
	.privacy_waku{	padding:40px 20px;}
}


.privacy_scroll {
  max-height:200px;
  overflow-y: scroll;
  padding-right:10px;
	z-index: 1;
}
@media print, screen and (min-width: 768px) {
.privacy_scroll {max-height:400px;}
}


.btn-primary{
	border-radius:0;
	font-size: 100%;
}
.btn-primary:hover{
	background-color: #1e5fc3;
	opacity: 1;
}


.form-control {
    height: 50px;
    padding: 12px 10px;
    font-size: 14px;
    line-height: 1.42857143;
    background-image: none;
    border: 1px solid #cccccc;
    border-radius: 4px;
    -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
    box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
    -webkit-transition: border-color ease-in-out .15s, -webkit-box-shadow ease-in-out .15s;
    -o-transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;
    transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;
}



/*▼メールフォームの「例」のカラー変更*/
::placeholder {
  color: #959595!important;
}
/* 旧Edge対応 */
::-ms-input-placeholder {
  color: #959595!important;
}
/* IE対応 */
:-ms-input-placeholder {
  color: #959595!important;
}

/* footer
---------------------------------------------------- */
footer {
	font-size: 100%;
	line-height: 1.6em;
}
footer.sen_t{
	/*
	border-collapse: collapse;
	border-top: 1px solid #17224f;
	*/
}


footer .in {
	/*background-color: #fff;*/
	background-color: #f2f2f2;
	color: #17224f;
}
@media only screen and (max-width: 991px) {
	footer  .yohaku2{padding-bottom: 0;}
}

.foot_list li{
	list-style: none;
	text-align: center;
}
.foot_logo img{
	margin: 0 auto;
	max-width: 150px;
	width: 50%;
	margin-bottom: 20px;
}

footer .foot_link{
	font-size: 90%;
	text-align: left;
	float: left;
}
footer .foot_link:nth-child(1){
	margin-right: 20px;
}
footer .foot_link li {
	list-style: none;
	display: block;
	margin-bottom: 5px;
}
footer .foot_link li a:link,
footer .foot_link li a:visited{
	color: #17224f;
}
footer .foot_link ul li{
	background: url(../images/foot_link_sen.gif) no-repeat left center;
	padding-left: 10px;
	font-size: 90%;
	margin-bottom: 0;
}


@media print, screen and (min-width: 992px) {
	.foot_list li{
		text-align: left;
	}
	.foot_logo img{
		margin: 0;
		width: 50%;
		margin-bottom: 20px;
	}
	footer .foot_link{
		font-size: 100%;
	}
}
@media print, screen and (min-width: 1200px) {
	.foot_list{
		display: table;
	}
	.foot_list li{
		display: table-cell;
		vertical-align: top;
	}
	.foot_list li.address{
		padding-left: 30px;
		padding-top: 15px;
	}
	.foot_logo img{
		width: 100%;
		margin-bottom: 0;
	}
}
@media print, screen and (min-width: 1600px) {
	.foot_list li.address{
		padding-left: 50px;
	}
}

/*copy*/
.copy {
	font-size: 80%;
	line-height: 1.4em;
	color: #8289a7;
	text-align: center;
	margin-bottom: 20px;
}
@media print, screen and (min-width: 992px) {
	.copy {text-align: right; margin-top: 20px; margin-bottom: 0;}
}

/* pagetop
---------------------------------------------------- */
#pagetop { position: fixed; bottom:10px; right:10px; z-index: 100;}
@media (min-width: 1200px) {
	#pagetop { position: fixed; bottom:20px; right:20px; z-index: 100;}
}

.case_logo{
	margin-left: -1%;
	margin-right: -1%;
}
.case_logo li{
	list-style: none;
	width: 48%;
	float: left;
	margin: 1% 1% 30px 1%;
}
.case_logo img{
	padding: 5px;
	border-collapse: collapse;
	border: 1px solid #ccc;
	margin: 0 auto;
}
.case_logo p{
	text-align: center;
	font-size: 80%;
	line-height: 1.4em;
	margin-top: 5px;
}
.case_logo li:nth-of-type(2n+1) { clear: both;}
@media print, screen and (min-width: 768px) {
	.case_logo li{
		width:31.3%;
	}
	.case_logo li:nth-of-type(2n+1) { clear: none;}
	.case_logo li:nth-of-type(3n+1) { clear: both;}
}
@media print, screen and (min-width: 1200px) {
	.case_logo li{
		width:23%;
	}
	.case_logo li:nth-of-type(3n+1) { clear: none;}
	.case_logo li:nth-of-type(4n+1) { clear: both;}
}


/*20220315*/
.top_case{
	margin-left: -1%;
	margin-right: -1%;
}
.top_case .box{
	width: 48%;
	float: left;
	margin: 1%;
}
.top_case .box p{
	background-color: #fff;
	padding: 5px 10px;
	text-align: center;
	font-size: 90%;
	line-height: 1.4em;
	color: #17224f;
}
.top_case .box:nth-of-type(2n+1) { clear: both;}
@media print, screen and (min-width: 1200px) {
	.top_case .box{
		width: 31.3%;
	}
	.top_case .box:nth-of-type(2n+1) { clear: none;}
	.top_case .box:nth-of-type(3n+1) { clear: both;}
}

/* contact仮入れ
本番コーディングで
・見出しの大きさを整える
・ボケを無くす（今は画像なのでボケが出る）
・スマホ時のボタンが小さくならないよう調整
よろしくお願いいたします。
本番コーディング時こちらのcssは削除お願いします。



.contactUs{
	position: relative;
	padding: 30px 0 100px 0;
	width: 100%;
}

.contactUs img{
	display: block;
	margin: 0 auto;
	width: 30%;
}

@media screen and (min-width: 1500px) {
	.contactUs img{width: 25%;}
}

@media screen and (max-width: 768px) {
	.contactUs img{width: 35%;}
}

@media screen and (max-width: 576px) {
	.contactUs img{width: 50%;}
}
/* ここまで */

.contactUs{
	max-width: 360px;
	margin: 0 auto;
	width: 80%;
}
.contactUs img{
	width: 100%;
	margin: 0 auto;
}
@media print, screen and (min-width: 1200px) {
	.contactUs{ width: 100%;}
}
/* scroll */

#license {
    height: 350px;
    border: 1px solid #ccc;
    margin: 50px auto 0px;
    overflow: auto;
}

#license>p {
    margin: 0;
}

#license>p:nth-of-type(1) {
    text-align: center;
}


