@charset "UTF-8";

/* reset
----------------------------------- */

* {
	margin:0px;
	padding:0px;
}

body,
h1, h2, h3, h4, h5, h6,
p, address, blockquote, pre, div,
dl, ol, ul, li,img,
form, input, select, textarea, fieldset, legend {
	margin: 0;
	padding: 0;
}

h1, h2, h3, h4, h5, h6,
p, address, blockquote, pre, div,
dl, ol, ul,
th {
	font-weight: normal;
	font-style: normal;
}

strong {
	font-weight:normal;
	font-style: normal;
}

img {
	border: none;
}

ul,ol {
list-style: none;
}


/* headline
----------------------------------- */

h1 {
	font-family:"Avenir";
		font-size:36px;
	color: #004797;
	font-weight:normal;
	letter-spacing:0.15rem;
	font-style:italic;
	display:table-cell;
}
h1 span {
	font-size:14px;
	letter-spacing:0rem;
	vertical-align:middle;
	padding-left:5px;
}
h2 {
	font-weight:normal;
}
h3 {
	font-size:18px;
	color:#a79632;
	line-height:60px;
	text-align:center;
	position:relative;
	margin-bottom:40px;
}
h3:before {
  content: '';
  position: absolute;
  bottom: -15px;
  display: inline-block;
  width: 90px;
  height: 2px;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  background-color:#a79632;
}
h3 em {
	font-style:normal;
	color:#9c0404;
}

h4 {
	font-size:17px;
	font-weight:bold;
	line-height:25px;
}

blockquote {
}

blockquote span {

}


/* body
----------------------------------- */

html{
overflow-x : hidden;
overflow-y : auto;
}
body {
	font-family:"Avenir","ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-size:18px;
	color:#242323;
	margin:0;
	padding:0;
	line-height:36px;
}

a {	 color:#242323; text-decoration:none; }
a:link {  color:#242323; text-decoration:none; }
a:hover {	color:#242323; text-decoration:none;
-webkit-transition: 0.3s ease-in-out;
  -moz-transition: 0.3s ease-in-out;
  -o-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;   }
a:hover img {
	transition:all 0.3s;
}

input, select, textarea {
	color: #434343;

border:none;
background:none;

}

.searcharea {
	-webkit-box-shadow:0 0 2px 2px rgba(200,200,200,0.2) inset;
   -moz-box-shadow:0 0 2px 2px rgba(200,200,200,0.2) inset;
        box-shadow:0 0 2px 2px rgba(200,200,200,0.2) inset;
		border:1px solid #a5a4a4;
		text-indent:13px;
		}



/* class
----------------------------------- */

.clear {
	font-size: 0;
	line-height: 0;
	clear: both;
	height: 0px;
	visibility: hidden;
}

.ud {
text-decoration:underline;

}

.r {
	float:right;
}

.l {
	float:left;
}


.center {
text-align:center;

}

.left {
	text-align:left;
}

a span {
}


.mt5 {
margin-top:10px;
}
.mt10 {
margin-top:10px;
}
.mt15 {
margin-top:15px;
}
.mt20 {
margin-top:20px;
}
.mt30 {
margin-top:30px;
}
.mt40 {
margin-top:40px;
}
.mt50 {
margin-top:50px;
}

.mb5 {
margin-bottom:5px;
}
.mb10 {
margin-bottom:10px;
}
.mb15 {
margin-bottom:15px;
}
.mb20 {
margin-bottom:20px;
}
.mb25 {
margin-bottom:25px;
}
.mb30 {
margin-bottom:30px;
}
.mb35 {
margin-bottom:35px;
}
.mb40 {
margin-bottom:40px;
}
.mb45 {
margin-bottom:45px;
}
.mb50 {
margin-bottom:50px;
}
.mb60 {
margin-bottom:60px;
}
.mb70 {
margin-bottom:70px;
}
.mb80 {
margin-bottom:80px;
}
.mb100 {
margin-bottom:100px;
}

.mr10 {
margin-right:10px;
}
.mr15 {
margin-right:15px;
}
.mr20 {
margin-right:20px;
}
.mr30 {
margin-right:30px;
}

.ml5 {
margin-left:5px;
}
.ml10 {
margin-left:10px;
}
.ml15 {
margin-left:15px;
}
.ml20 {
margin-left:20px;
}

.sp {
	display:none;
}
table {

    border-collapse:inherit;

}

/* oowaku
----------------------------------- */

#all {
	text-align:center;
	overflow:hidden; /* 固定ヘッダの高さ分 */
}

#container {
	text-align:center;
	margin:0 auto;
	scroll-padding-top: 150px;
}

/* head
----------------------------------- */
#header {
	width:100%;
	height: 94px;
	margin:0 auto;
	position:fixed;
	top:0;
	background-color: rgba(255,255,255);
	box-shadow: 0px 10px 16px rgba(211,209,209,0.34);
	-webkit-box-shadow: 0px 10px 16px rgba(211,209,209,0.34);
	-moz-box-shadow: 0px 10px 16px rgba(211,209,209,0.34);
	z-index:100;
	overflow:hidden;
}

.header_in {
	max-width:1180px;
	margin:0 auto;
	position: relative;
}

#header h1 {
	position:absolute;
	top:-9px;
	left:0px;
}
#header h1 a {
	color:#004797;
	display: block;
}

#header h1 a:hover,#header a:hover  {
	opacity:0.7;
	filter: alpha(opacity=70);
	-ms-filter: "alpha( opacity=70 )";
	-moz-opacity:0.70;
}

#header a.header_btn {
	position:absolute;
	top:4px;
	right:0px;
}

#header .header_llnk {
	font-size:14px;
	background:#f5f3ee;
	width:106px;
	height:94px;
	position:absolute;
	top:0px;
	right:0px;
	display:table;
}
#header .header_llnk span {
	color:#9b0404;
	display:table-cell;
	vertical-align:middle;
	text-align:center;
	line-height:32px;
}

/* key
----------------------------------- */
#key {
	width:100%;
	margin:0 auto;
	height:563px;
	margin-top:94px;
	position:relative;
	background :#f5f3ee url(../img/key01.png) no-repeat center top;
	background-size:cover;

}
@font-face{
    font-family: "kozL";
    src: url(KozGoPr6N-Light.otf);
}
#key h2{
	color:#fff;
	white-space:nowrap;
	position:absolute;
	top:50%;
	  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  -webkit- transform: translateY(-50%) translateX(-50%);
  background:rgba(255,255,255,0.5);
  line-height:80px;
  font-size:50px;
  width:100%;
  font-family: "KozGoPro-Light", "小塚ゴシック Pro L", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "游ゴシック", YuGothic, "メイリオ", Meiryo, sans-serif;

text-shadow: 1px 1px 0 #000,
             -1px 1px 0 #000,
             1px -1px 0 #000,
             -1px -1px 0 #000;

text-shadow: 1px 1px 1px #000,
             -1px 1px 1px #000,
             1px -1px 1px #000,
             -1px -1px 1px #000;
	z-index:10;
}
#key  img {
	position:absolute;
	top:23px;
	  right: 0;
	  min-width:847px;
	  max-width:947px;
	width:50%;
	height:auto;
filter: drop-shadow(4px 0px 4px #d3d1d1);
}
#key  .key02 {
	display:block;
	width:100%;
	margin:0 auto;
	height:586px;
	position:relative;
	background:url(../img/bg_key02.png) no-repeat right 23px;
	background-size:cover;
	z-index:1;
filter: drop-shadow(4px 0px 4px #d3d1d1);
}

#key  .key03 {
    display:block;
    width:100%;
    margin:0 auto;
    height:300px;
    position:relative;
    background:url(../img/key_03.jpeg) no-repeat right 23px;
    background-size:cover;
    z-index:1;
    filter: drop-shadow(4px 0px 4px #d3d1d1);
}


@media (max-width: 1240px) {
   /* 横幅が480px以上の場合に適用するスタイル */
#key  .key02 {
	background:url(../img/bg_key02.png) no-repeat 60% 23px;
}
}

#header_sm {
	display:none;
}

#key_sm {
	display:none;
}

#key_second {
	padding-top:94px;
	width:100%;
	height:411px;
	background:url(../img/key_form.png) no-repeat center center;
	background-size:cover;
	position:relative;
	box-sizing:border-box;
}
#key_second.key_faq {
	background:url(../img/key_faq.png) no-repeat center center;
	background-size:cover;
}
#key_second h2 {
	position:absolute;
	text-align:center;
	top:211px;    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
	color:#004797;
	line-height:80px;
	background:rgba(255,255,255,0.5);
	width:100%;
	font-size: 38px;
	color:#242323;
	font-weight:bold;
	letter-spacing:0.3rem;
}


/* footer
----------------------------------- */

#footer {
	width: 100%;
	background: #9f9f9a;
	padding: 19px 0;
	margin: 0 auto;
}
.footer_in {
	width: 100%;
	max-width: 1180px;
	height: 257px;
	margin: 0 auto;
	display: flex;
}

.footer_in .cont_l {
	color:#fff;
	position:relative;
	text-align:left;
	width:50%;
}
.footer_in  a {
	color:#fff;
}
.footer_in .cont_l a:hover {
	text-decoration:underline;
}
.footer_in .cont_l  dl.link01{
	width:210px;
	position:absolute;
	top:40px;
	left:80px;
}
.footer_in .cont_l  dl.link02{
	width:210px;
	position:absolute;
	top:40px;
	left:330px;
}
.footer_in .cont_l  dt{
	border-bottom:1px solid #fff;
	font-size:16px;
	padding-bottom:10px;
	margin-bottom:10px;
}
.footer_in .cont_l  dd{
	font-size:15px;
	line-height:30px;
}
.footer_in .cont_r{
	color: #fff;
	position: relative;
	text-align: left;
	width: 50%;
}

.footer_logo {
	position:absolute;
	top:55px;
	right:71px;
}
.footer_btn {
	display:block;
	color:#fff;
	border:1px solid #fff;
	border-radius:10px;
	line-height:46px;
	font-size:15px;
	text-align:center;
	width:226px;
	position:absolute;
	top:120px;
	right:98px;
}
.footer_btn:hover {
	display:block;
	background:#fff;
	color:#9f9f9a;
}

#copyright {
	font-size: 15px;
	color: #fff;
	font-family: "Avenir";
	line-height: 50px;
	position: absolute;
	top: 180px;
	right: 40px;
}
#copyright span {
	display:block;
}
#page-top {
	z-index:10;
	text-align:right;
	margin-right:30px;
}

#banner {
position: fixed;
bottom: 20px;
right: 0px;
z-index:10;
}
#banner:hover img {
	opacity:0.7;
}

#page-top {
position: fixed;
bottom: 20px;
right: 30px;
z-index:10;
}

#page-top div a #img{
display:block;
width:76px;
height:76px;
padding-top:60px;
overflow:hidden;
background:url(../img/pagetop.png) no-repeat;
text-indent:-9999px;
}

#page-top div a p:hover{
-moz-opacity:0.6;
opacity:0.6;
filter: alpha(opacity=60);
text-decoration:none;
}


/* main
----------------------------------- */

#main {
width:100%;
margin:0 auto 0;
position:relative;
}
/* index.html
----------------------------------- */

#cont01 {
	width:100%;
	margin:0 auto;
	padding:60px 0 80px;
	background:url(../img/bg_cont01_01.png) no-repeat left top,url(../img/bg_cont01_02.png) no-repeat right bottom;
	background-image:;

}
#cont01 h2{
  line-height:80px;
  font-size:46px;
  width:100%;
  font-family: 游明朝,"Yu Mincho",YuMincho,"Hiragino Mincho ProN","Hiragino Mincho Pro",HGS明朝E,メイリオ,Meiryo,serif;
  margin-bottom:40px;
}
#cont01 .cont01_in {
	width:100%;
	max-width:1100px;
	margin:0 auto;
}
.cont01_in ul  {
	display:flex;
	justify-content: space-between;
	margin-top:50px;
}
.cont01_in ul li  {
	display:table;
}
.cont01_in ul span {
	display:table-cell;
	vertical-align:middle;
		background: #fff;
		width: 359px;
		height: 208px;
		position: relative;
		background:url(../img/link_box.png) no-repeat;
		white-space:nowrap;
		transition: background-image 1s;
}
.cont01_in ul span img {
	margin-bottom:10px;
}

#cont02 {
	width:100%;
	background:#f5f3ee url(../img/bg_cont02.png) no-repeat top right;
	padding:70px 0 48px;
}
#cont02 h2 {
	font-weight:bold;
	margin-bottom:30px;
}
#cont02 .cont02_in {
	width:100%;
	max-width:1100px;
	margin:0 auto;
	display:flex;
}
#cont02 .cont_l {
	width:50%;
}
#cont02 .cont_l table {
	width:100%;
}
#cont02 .cont_l table td {
	width:33.3%;
	padding:10px 0;
	white-space:nowrap;
	text-align:left;
}
#cont02 .cont_r {
	width:50%;
}
#cont02 .cont_r .f_word {
	max-width:493px;
	margin:55px auto 0;
}
.f_word input {
	background:#fff;
	color: #666666;
	border: 1px solid #bbbbbb;
	width:100%;
	box-sizing:border-box;
	height:60px;
	font-size:18px;
	border-radius:5px;
}


/*フォーム全体*/
#form2{
position:relative;/*フォームの相対位置*/
    width: 90%;
    margin: 2em auto;
}

/*検索ボックス*/
#sbox2{
position:absolute;/*フォームの絶対位置*/
left:0;
top:0;
padding:0px 124px 0px 20px;
	border: 1px solid #sbox2;
	width:100%;
	box-sizing:border-box;
}

/*検索ボタン*/
#sbtn2{
width:104px;/*検索ボタンの横幅*/
height:60px;/*検索ボタンの縦幅*/
position:absolute;/*検索ボタンの絶対位置*/
right:0px;/*検索ボタンの位置調整*/
top:0;
background:#9c0404;/*検索ボタンの背景カラー*/
border:none;/*検索ボタンの枠線を消す*/
color:#fff;/*検索ボタンのテキストカラー*/
	border-radius:0 5px 5px 0;

}
/*検索ボタンマウスオーバー時*/
#sbtn2:hover{
	opacity:0.7
}
/* css checkbox01 */

.checkbox01 {
}
.checkbox01-input{
  display: none;
}
.checkbox02-input{
  display: none;
}
.checkbox01-parts{
  padding-left: 35px;
  position:relative;
  margin-right: 10px;
  letter-spacing:-0.03em;
  display:table-cell;
  line-height:22px;
}
.checkbox01-parts::before{
  content: "";
  display: block;
  position: absolute;
  top: 0px;
  left: 0;
  width: 18px;
  height: 18px;
  background:#fff;
  border:1px solid #ccc;
}
.checkbox01-input:checked + .checkbox01-parts{
  color: #535545;
}
.checkbox01-input:checked + .checkbox01-parts::after{
  content: "";
  display: block;
  position: absolute;
  top:0px;
  left: 6px;
  width: 7px;
  height: 12px;
  transform: rotate(40deg);
  border-bottom: 3px solid #535545;
  border-right: 3px solid #535545;
}


.checkbox02-parts{
  padding-left: 35px;
  position:relative;
  margin-right: 10px;
  letter-spacing:-0.03em;
  display:table-cell;
  line-height:22px;
}
.checkbox02-parts::before{
  content: "";
  display: block;
  position: absolute;
  top: 0px;
  left: 0;
  width: 18px;
  height: 18px;
  background:#fff;
  border:1px solid #ccc;
}
.checkbox02-input:checked + .checkbox02-parts{
  color: #535545;
}
.checkbox02-input:checked + .checkbox02-parts::after{
  content: "";
  display: block;
  position: absolute;
  top:0px;
  left: 6px;
  width: 7px;
  height: 12px;
  transform: rotate(40deg);
  border-bottom: 3px solid #535545;
  border-right: 3px solid #535545;
}



#cont03 {
	width:100%;
	padding:70px 0 53px;
	background:url(../img/bg_cont03.png) no-repeat bottom;
	background-size:cover;
	box-sizing:border-box;
}
#cont03 h2 {
	font-size:38px;
	padding-top:20px;
	margin-bottom:70px;
    font-family: 游明朝,"Yu Mincho",YuMincho,"Hiragino Mincho ProN","Hiragino Mincho Pro",HGS明朝E,メイリオ,Meiryo,serif;
}
#cont03 .cont03_in {
	width:100%;
	max-width:1100px;
	margin:0 auto;
	display:flex;	flex-wrap: wrap;
}

#cont03 .cont {
	background:#fff;

	border:2px solid #c5c6c8;
	width:500px;
	padding:20px 18px;
	box-sizing:border-box;
	margin:0 auto 60px;
}
#cont03 .cont table {
	width:100%;
}
.company_logo img {
	border:1px solid #ccc;
}
.company_name {
	font-size:16px;
	line-height:26px;
	text-align:left;
	padding:0 14px;
	vertical-align:bottom;
}
.company_name b {
	font-size:24px;
	line-height:40px;
}
.company_icon  {
	padding:30px 0;
	text-align:left;
}
.company_icon  span {
	font-size:16px;
	line-height:30px;
	color:#a79632;
	border:1px solid #a79632;
	min-width:104px;
	padding:0 15px;
	border-radius:15px;
	margin-right:10px;
}
#cont03 .cont  dl dt{
	background:#f5f3ee;
	line-height:38px;
}

#cont03 .cont  dl dd{
	text-align:left;
	padding:20px 10px;
	line-height:30px;
}
#cont03 .cont table td.half {
	width:50%;
	padding-right:12px;
}

#cont03 .cont table td.half2 {
	width:50%;
	padding-left:12px;
}
#cont03 .cont table td.half dl dd,#cont03 .cont table td.half2 dl dd {
	padding:15px 10px;
}
.btn_company_detail {
	padding:20px 0;
}
.btn_company_detail img {
	width:100%;
	height:auto;
}
.btn_company_detail a:hover img {
	opacity:0.7;
}
a.btn_more_see {
	display:block;
	text-align:center;
	margin:0 auto;
}
a.btn_more_see:hover {
	opacity:0.7;
}

#cont04 {
	width:100%;
	padding:70px 0 53px;
	background:#ecf1fa url(../img/bg_cont01_01.png) no-repeat left top;
}
#cont04 h2 {
	font-size:38px;
	padding-top:20px;
	margin-bottom:70px;
    font-family: 游明朝,"Yu Mincho",YuMincho,"Hiragino Mincho ProN","Hiragino Mincho Pro",HGS明朝E,メイリオ,Meiryo,serif;
}
#cont04 .cont04_in {
	width:870px;
	margin:0 auto;
}

#cont04 .cont {
	background:#fff;
	text-align:left;
	border:1px dashed #a79632;
	padding:20px;
	margin-bottom:25px;
}
.tit_q {
	background:#f5f3ee url(../img/bg_q.png) no-repeat 20px center;
	padding:13px 20px 13px 68px;
}
.tit_s {
    background: url(../img/46622.png) no-repeat 20px center;
    background-size:contain;
    padding:13px 20px 13px 80px;
}
.tit_a {
	background:url(../img/bg_a.png) no-repeat 20px 13px;
	padding:13px 20px 13px 68px;
}
a.btn_faq_more {
	background:#a79632;
	border-radius:30px;
	color:#fff;
	padding:0 47px;
	font-size:20px;
	line-height:52px;
	display:inline-block;
	margin:30px auto 0;
	min-width:348px;
	box-sizing:border-box;
}
a.btn_faq_more:hover {
	opacity:0.7;
}

#cont05 {
	width:100%;
	padding:70px 0 53px;
	background:url(../img/bg_cont05.png) no-repeat right top;
}
#cont05 h2 {
    font-size:38px;
    padding-top:20px;
    margin-bottom:70px;
    font-family: 游明朝,"Yu Mincho",YuMincho,"Hiragino Mincho ProN","Hiragino Mincho Pro",HGS明朝E,メイリオ,Meiryo,serif;
}
#cont05 .cont05_in {
	width:870px;
	margin:0 auto;
}
#cont05 .cont05_in dl {
    border-top:1px solid #d2d2d2;
	margin-bottom:50px;
}
#cont05 .cont05_in dl dt{
	line-height:42px;
	font-family:"Avenir";
	padding:10px 0;
}
#cont05 .cont05_in dl dt span{
	border:1px solid #ccc;
	padding:0 15px;
	margin-left:20px;
	font-size:16px;
}
.DivLink{
    position:relative;
    width:100%;
    border-bottom:1px solid #d2d2d2;
	text-align:left;
	background:url(../img/news_yajirushi.png) no-repeat 98% center;
	padding:20px 108px 20px 20px;
	box-sizing:border-box;
}

.DivLink .Link{
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
.DivLink:hover {
	opacity:0.7;
}
a.btn_news_more {
	border-radius:30px;
	padding:0 47px;
	font-size:20px;
	line-height:52px;
	display:inline-block;
	margin:30px auto 0;
	border:2px solid #d2d2d2;
	min-width:348px;
	box-sizing:border-box;
}
a.btn_news_more:hover {
	opacity:0.7;
}

#cont06 {
	width:100%;
	height:383px;
	background:url(../img/bg_cont06.png) repeat-x center bottom;
	box-sizing:border-box;
	padding-top:80px;
}
#cont06 p {
	margin-bottom:48px;
}
#cont06 a:hover img {
	opacity:0.7;
}
#cont06 .foot_btn {
	display:block;
	margin-bottom:40px;
}

#cont_example {
	width:100%;
	height:259px;
	background:url(../img/bg_banner.png) no-repeat center center;
	background-size:cover;
	position:relative;
}

#second #cont_example {
	width:100%;
	height:259px;
	background:url(../img/bg_banner02.png) no-repeat center bottom;
	background-size:100% 100%;
	position:relative;
}
#cont_example  img {
margin:47px auto 0;
}

#cont_example a:hover img {
	opacity:0.7;
}

/*second*/

#second {
width:100%;
margin:0 auto 0;
position:relative;
padding:0px 0 0;
}
#second  h3 {
}
#second  h3 b {
	font-size: 28px;
    color: #242323;
    line-height: 60px;
    text-align: center;
	display:block;
}
#second  h3.up::before {

    content: '';
    position: absolute;
    top: -35px;
    display: inline-block;
    width: 90px;
    height: 2px;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    background-color: #a79632;

}
body #second  .normal::before {
  content: '';
  position: absolute;
  bottom: -15px;
}
.breadcrumbs {
    max-width: 1200px;
    margin: 103px auto 20px;
}

.breadcrumbs ul {
    display: table;
    font-size: 13px;
}

.breadcrumbs ul li {
    float: left;
	padding-right:10px;
}

.breadcrumbs ul li:first-child::before {
    padding: 0 3px 0 0;
    font-size: 14px;
    content: "";
}

.breadcrumbs ul li::before {
    padding: 0 10px 0 0;
    content: ">";
    font-size: 14px;
}

.breadcrumbs2 {
    margin:0 auto 0px;
	height:63px;
	background:#f9f8f5;
	border-top:1px solid #cac8c8;
	border-bottom:1px solid #cac8c8;

}

.breadcrumbs2 ul {
    max-width: 1100px;
	margin:0 auto;
	text-align:left;
    font-size: 13px;
}

.breadcrumbs2 ul li {
    float: left;
	padding-right:10px;
	line-height:63px;
}

.breadcrumbs2 ul li:first-child::before {
    padding: 0 3px 0 0;
    font-size: 14px;
    content: "";
}

.breadcrumbs2 ul li::before {
    padding: 0 10px 0 0;
    content: ">";
    font-size: 14px;
}


#second #cont02 {

   background-image:
     url(../img/bg_cont02_r.png),
     url(../img/bg_cont02_l.png);
  background-repeat:
     no-repeat,
     no-repeat;
  background-position:
	top right,
	top left;
	background-color:#f9f8f5;
}
#second #cont06 {
	background:#f9f8f5 url(../img/bg_cont06.png) repeat-x center bottom;
}

/*会社詳細*/
#company {
	width:870px;
	margin:0 auto;
	padding-bottom:15px;
}

/*タブ切り替え全体のスタイル*/
.tabs {
  margin-top: 50px;
  padding-bottom: 55px;
  width: 100%;
  margin: 0 auto;
  }

/*タブのスタイル*/
.tab_item {
  width: 427px;
  box-sizing:border-box;
  height: 84px;
  border-bottom: 3px solid #5ab4bd;
  background-color: #fff;
  font-size: 20px;
  text-align: center;
  color: #a92727;
  display: block;
  float: left;
  text-align: center;
  padding-top:18px;
  box-sizing:border-box;
  transition: all 0.2s ease;
  border:1px solid #a92727;
}
.tab_item_l {
	margin-right:16px;
}
.tab_item i {
	display:block;
}
.tab_item:hover {
  opacity: 0.75;
}

/*ラジオボタンを全て消す*/
input[name="tab_item"] {
  display: none;
}

/*タブ切り替えの中身のスタイル*/
.tab_content {
  display: none;
  padding: 94px 40px 0;
  clear: both;
  overflow: hidden;
}


/*選択されているタブのコンテンツのみを表示*/
#all:checked ~ #all_content,
#programming:checked ~ #programming_content,
#design:checked ~ #design_content {
  display: block;
}

/*選択されているタブのスタイルを変える*/
.tabs input:checked + .tab_item {
  background-color: #a92727;
  border:none;
  color: #fff;
  position: relative;
  display: inline-block;
  border-bottom:7px solid #a79632;
}

.tabs input:checked + .tab_item:before {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -15px;
  border: 15px solid transparent;
  border-top: 15px solid #a92727;
}

#second h3 img.company_logo{
	margin-bottom:50px;
}
p.company_info {
	text-align:left;
	font-size:18px;
	line-height:42px;
	padding:40px 0 120px;
}

table.service {
	text-align:left;
	margin-bottom:80px;
}
table.service.top {
	margin: 56px auto 40px;
}
table.service td.img {
	width:195px;
}
table.service th {
	padding:0 22px;
	font-size:22px;
	line-height:36px;
	font-weight:bold;
	vertical-align:middle;
}
table.service .icon {
	margin:30px 0 0;
}
#second .icon span {
	color:#a79632;
	font-weight:normal;
	font-size:18px;
	line-height:30px;
	padding:3px 18px;
	border:1px solid #a79632;
	border-radius:15px;
	margin-right:13px;
}
ol.service_detail {
	width:100%;
	text-align:left;
  list-style: none;
  counter-reset: ol_li; /* ol_li カウンタをセットする(値もリセット) */
  font-size:20px;
  line-height:38px;
  font-weight:bold;
  margin-bottom:120px;
}
ol.service_detail li:before {
  margin-right: .25em;
  counter-increment: ol_li; /* ol_li カウンタの値に1加える */
  content: counter(ol_li)"."; /* before擬似要素のcontentで出力 */
  color: #a79632; /* 色を変更 */
}
ol.service_detail li {
	margin:40px 0;
}

table.profile {
	width:100%;
	font-size:18px;
	line-height:32px;
	border-top:1px solid #c5c6c8;
	border-left:1px solid #c5c6c8;
	margin-bottom:75px;
}
table.profile th {
	background:#f5f3ee;
	border-right:1px solid #c5c6c8;
	border-bottom:1px solid #c5c6c8;
	width:176px;
	padding:33px 53px;
	box-sizing:border-box;
	white-space:nowrap;
}
table.profile td {
	border-right:1px solid #c5c6c8;
	border-bottom:1px solid #c5c6c8;
	text-align:left;
	padding:33px;
}
a.btn_company_contact {
	display:block;
	margin-bottom:50px;
}
a.btn_company_contact:hover {
	opacity:0.7;
}
p.waku {
	padding:42px;
	text-align:left;
	border:1px solid #d2d2d2;
	font-size:18px;
	line-height:42px;
	margin-bottom:40px;
}
#design_content table.profile {
	margin-bottom:40px;
}

div.color_box {
	width:100%;
	background:#f5f3ee url(../img/bg_color_box.png) no-repeat center top;
	padding:62px 42px 42px;
	box-sizing:border-box;
	margin-bottom:40px;
}

div.color_box.another {
	width:100%;
	background:#ecf1fa url(../img/bg_color_box.png) no-repeat center top;
}
div.color_box h4 {
	font-size:28px;
	line-height:42px;
	margin-bottom:20px;
}
div.color_box p {
	text-align:left;
}

/*pre index*/
#price {
	width:100%;
	padding:70px 0 53px;
	background:url(../img/bg_cont03.png) no-repeat bottom;
	background-size:cover;
}
#price h2 {
	font-size: 38px;
    padding-top: 20px;
    margin-bottom: 70px;
}
#price h2 b{
	color:#A63F3D;
}

#price .price_in {
	border:1px solid #ccc;
	padding:40px;
	background:#fff;
	width:92%;
	box-sizing:border-box;
	max-width:870px;
	margin:0 auto;
	margin-bottom:50px;
}
#price .img_price {
	width:100%;
	max-width:860px;
	margin:0 auto;
}
#feature {
	width:100%;
	background:#f5f3ee url(../img/bg_cont02.png) no-repeat top right;
	padding:70px 0 48px;
}
#feature h2 {
	font-size:38px;
	padding-top:20px;
	margin-bottom:70px;
    font-family: 游明朝,"Yu Mincho",YuMincho,"Hiragino Mincho ProN","Hiragino Mincho Pro",HGS明朝E,メイリオ,Meiryo,serif;
}
#feature h4 {
    font-size: 24px;
    line-height: 36px;
    padding-top: 20px;
    margin-bottom: 20px;
    font-weight: bold;
    text-align: left;
}

#feature .feature_in01 p,#feature .feature_in02 p {
	text-align:left;
	line-height:30px;
	font-size:16px;
}
#feature .feature_in01,#feature .feature_in02 {
	width:92%;
	max-width:1020px;
	margin:0 auto 100px;
	height:auto;
	min-height:350px;
	display:flex;
}
	div.feature_in01{
		background: #fff;
		margin: 0px auto;
		position: relative;
/* box-shadow */
box-shadow: 20px 40px 0px -10px #aa0000;
	}
	div.feature_in01:before,
	div.feature_in01:after{
		width: calc(100% - 20px);
		height: 0;
		display: block;
		position: absolute;
		left: 0;
		content: "";
	}
	div.feature_in01:before{
		border-bottom: solid 20px #fff;
		border-right: solid 20px transparent;
		bottom: 100%;
	}
	div.feature_in01:after{
		border-top: solid 20px #fff;
		border-left: solid 20px transparent;
		top: 100%;
	}
	div.feature_in02{
		background: #9F9F9A;
		margin: 0px auto;
		position: relative;
		color:#fff;
box-shadow: 20px 40px 0px -10px #4d4d4d;
	}
	div.feature_in02:before,
	div.feature_in02:after{
		width: calc(100% - 20px);
		height: 0;
		display: block;
		position: absolute;
		left: 0;
		content: "";
	}
	div.feature_in02:before{
		border-bottom: solid 20px #9F9F9A;
		border-right: solid 20px transparent;
		bottom: 100%;
	}
	div.feature_in02:after{
		border-top: solid 20px #9F9F9A;
		border-left: solid 20px transparent;
		top: 100%;
	}
#feature .feature_in01 .feature_left {
	width:48%;
  background:url(../img/bg_feature01.png) no-repeat  center;
  background-size:cover;
  position:relative;
  margin-left:2%;
}

#feature .feature_in01 .feature_right {
	width:50%;
	padding:0 4%;
	box-sizing:border-box;
}
#feature .feature_in02 .feature_left {
	width:50%;
	padding:0 4%;
	box-sizing:border-box;
}

#feature .feature_in02 .feature_right {
	width:48%;
  background:url(../img/bg_feature02.png) no-repeat center;
  background-size:cover;
  position:relative;
  margin-right:2%;
}
#feature .feature_in01.feature_in03 .feature_left {
	width:50%;
  background:url(../img/bg_feature03.png) no-repeat center;
  background-size:cover;
  position:relative;
}
#feature .feature_in02.feature_in04 .feature_right {
	width:50%;
  background:url(../img/bg_feature04.png) no-repeat center;
  background-size:cover;
  position:relative;
}

#appeal {
	width:100%;
	padding:70px 0 53px;
	background:url(../img/bg_cont05.png) no-repeat right top;
}
#appeal h2 {
    font-size: 38px;
    padding-top: 20px;
    margin-bottom: 70px;
    font-family: 游明朝,"Yu Mincho",YuMincho,"Hiragino Mincho ProN","Hiragino Mincho Pro",HGS明朝E,メイリオ,Meiryo,serif;
}
#appeal .apeal_in {
	width:870px;
	margin:0 auto;
	margin-bottom:50px;
}
#appeal .apeal_in h4 {
	font-size:26px;
}
.triangle-bottom {
  display: inline-block;
  border-style: solid;
  border-width: 24px 34px 0 34px;
  border-color: #aa0000 transparent transparent transparent;
  margin-bottom:30px;
}
p.waku02 {
    padding:40px;
	font-size:24px;
    background: #aa0000;
	color:#fff;
box-shadow: 10px 10px 0px 0px #a79632;
}
p.waku02 span {
    margin: 0;
    padding: 0;
}
#achievement {
	width:100%;
	padding:70px 0 0px;
	background:url(../img/bg_cont05.png) no-repeat right top;
}
#achievement h2 {
	font-size: 38px;
    padding-top: 20px;
    margin-bottom: 70px;
    font-family: 游明朝,"Yu Mincho",YuMincho,"Hiragino Mincho ProN","Hiragino Mincho Pro",HGS明朝E,メイリオ,Meiryo,serif;
}
#achievement h4 {
  position: relative;
  overflow: hidden;
  padding: 1.5rem 2rem 1.5rem 130px;
  border: 2px solid #aa0000;
  text-align:left;
  font-size:24px;
  margin-bottom:20px;
}

#achievement h4:before {
  position: absolute;
  top: -150%;
  left: -100px;
  width: 220px;
  height: 300%;
  content: '';
  -webkit-transform: rotate(25deg);
  transform: rotate(25deg);
  background: #aa0000;
}

#achievement h4 span {
	font-size:18px;
  position: absolute;
  z-index: 1;
  top: 20px;
  left: 0;
  display: block;
  padding-top: 3px;
  padding-left: 16px;
  color: #fff;
}
#achievement .achievement_in {
	width:870px;
	margin:0 auto;
	margin-bottom:50px;
}
.achievement_in p.text {
	margin-bottom:80px;
}

/*エントリーフォーム
----------------------------------- */

/*タブ切り替え全体のスタイル*/
#entry .tabs {
  margin-top: 50px;
  padding-bottom: 55px;
  width: 100%;
  margin: 0 auto;
  position:relative;
  }
 #entry .tab_item {
	 width:36%;
	 position:absolute;
	 top:0px;
	 right:12%;
	 float:none;
 }
   #entry .tab_item.tab_item_l {
	   left:12%;
   }

#entry .tab_content {

    display: none;
    padding: 149px 0px 0;
    clear: both;
    overflow: hidden;

}
#entry {
	width:100%;
	margin:0 auto;
	padding:90px 0 120px;
}

#entry h3 {
	margin-bottom:70px;
}

#entry .h3 {
	width:100%;
	font-size:16px;
	line-height:75px;
	text-align:center;
	border-top:1px solid  #7c7c7a;
	border-bottom:1px solid  #7c7c7a;
	margin-bottom:60px;
	display:flex;
}
#entry .h3 span {
	width:33.3%;
}
#entry .h3 span.active {
	border-bottom:4px solid #a79632;
	/*background:#a92727;
	color:#fff;*/
}


#entry #form {
	width:100%;
	max-width:1240px;
	margin:0 auto;
}
#entry #form .cont_l {
	float:left;
	width:50%;
	box-sizing:border-box;
	padding:0 27px;
}
#entry #form .cont_r {
	float:right;
	width:50%;
}
#entry #form h4 {
	width:100%;
	height:60px;
	background:#a92727;
	padding:0 38px;
	line-height:60px;
	margin-bottom:30px;
	box-sizing:border-box;
	text-align:left;
	color:#fff;
}
#entry #form h4.last {
	margin-bottom:10px;
}
#entry #form  table.form {
	margin:0 auto;
	width:92%;
	box-sizing:border-box;
}

#entry #form  table.form th{
	color:#121621;
	font-size:16px;
	padding:16px 10px;
	text-align:left;
	border-top:1px dotted #979796;
	border-bottom:1px dotted #979796;
	position:relative;
}
#entry #form  table.form th em{
	display:block;
	color:#155bb8;
	font-size:14px;
	line-height:12px;
	font-style:normal;
}
#entry #form  table.form th em.em02{
	display:inline;
	color:#155bb8;
	font-size:14px;
	line-height:12px;
	font-style:normal;
	padding-left:10px;
}
#entry #form  table.form td{
	color:#121621;
	font-size:16px;
	padding:16px 10px;
	text-align:left;
	line-height:28px;
	border-top:none;
}
#entry #form  table.form .err_td{
	padding: 0px 1px;
}
#entry #form  table.form td span{
	font-size:16px;
	color:#121621;
}

#entry #form  table.form td input.form_text {
	width:100%;
	border:none;
	border:1px solid #dcdcdc;
	height:52px;
	margin-top:3px;
	font-size:14px;
	text-indent:10px;
	background:#f5f5f3;
	border-radius:5px;
}

#entry #form  table.form td input.form_text_half {
	width:48%;
	border:none;
	border:1px solid #dcdcdc;
	height:52px;
	margin-top:3px;
	font-size:14px;
	text-indent:10px;
	border-radius:5px;
	background:#f5f5f3;
}

#entry #form  table.form td input.form_text_half02 {
	width:28%;
	border:none;
	border:1px solid #dcdcdc;
	height:52px;
	margin-top:3px;
	font-size:14px;
	text-indent:10px;
	border-radius:5px;
	background:#f5f5f3;
}
.table_in {
	display:block;
}
.table_in i {
	width:100px;
	display:inline-table;
	font-style:normal;
}
/* css checkbox01 */

#entry #form .checkbox01 {
}
#entry #form .checkbox01-input{
  display: none;
}
#entry #form .checkbox01-parts{
  padding-left: 50px;
  position:relative;
  margin-right: 10px;
  line-height:52px;
  letter-spacing:-0.03em;
  display:table-cell;
  line-height:34px;
}
#entry #form .checkbox01-parts::before{
  content: "";
  display: block;
  position: absolute;
  top: 0px;
  left: 0;
  width: 32px;
  height: 32px;
  background:#f5f5f3;
}
#entry #form .checkbox01-input:checked + .checkbox01-parts{
  color: #535545;
}
#entry #form .checkbox01-input:checked + .checkbox01-parts::after{
  content: "";
  display: block;
  position: absolute;
  top:7px;
  left: 12px;
  width: 7px;
  height: 14px;
  transform: rotate(40deg);
  border-bottom: 3px solid #535545;
  border-right: 3px solid #535545;
}


#entry #form .checkbox02-parts{
  padding-left: 50px;
  position:relative;
  margin-right: 10px;
  line-height:52px;
  letter-spacing:-0.03em;
  display:table-cell;
  line-height:34px;
}
#entry #form .checkbox02-parts::before{
  content: "";
  display: block;
  position: absolute;
  top: 0px;
  left: 0;
  width: 32px;
  height: 32px;
  background:#f5f5f3;
}
#entry #form .checkbox02-input:checked + .checkbox02-parts{
  color: #535545;
}
#entry #form .checkbox02-input:checked + .checkbox02-parts::after{
  content: "";
  display: block;
  position: absolute;
  top:7px;
  left: 12px;
  width: 7px;
  height: 14px;
  transform: rotate(40deg);
  border-bottom: 3px solid #535545;
  border-right: 3px solid #535545;
}


/* ラジオボタン01 */
input[type=radio] {
    display: none;
}
.radio01 {
    box-sizing: border-box;
    cursor: pointer;
    display: inline-block;
    padding: 5px 30px;
    position: relative;
    width: auto;
}
.radio01::before {
    background: #fff;
    border: 1px solid #dfdfdf;
    border-radius: 50%;
    content: '';
    display: block;
    height: 16px;
    left: 5px;
    margin-top: -8px;
    position: absolute;
    top: 50%;
    width: 16px;
}
.radio01::after {
  transform: rotate(40deg);
  border-bottom: 3px solid #535545;
  border-right: 3px solid #535545;
    content: '';
    display: block;
    left: 6px;
    margin-top: -4px;
    opacity: 0;
    position: absolute;
    top: 16px;
  top: 12px;
  left: 12px;
  width: 7px;
  height: 14px;

}
input[type=radio]:checked + .radio01::after {
    opacity: 1;

}
#entry #form  table.form th strong {
	background:#a79632;
	color:#fff;
	font-size:13px;
	line-height:24px;
	width:67px;
	display:inline-block;
	text-align:center;
	position:absolute;
	right:5px;
	top:22px;
}

#entry #form  table.form td p {
	font-size:14px;
}

#entry #form .cont_bottom {
	width:988px;
	margin:50px auto 40px;
}
#entry #form .cont_bottom h4 {
	margin-bottom:40px;
	text-align:center;
}

#entry #form .base_menu {
	background:#d8d4c9;
	border-radius:15px;
	width:640px;
	margin:0 auto;
	padding:35px 0 15px;
}
#entry #form .base_menu table.form  {
	width:549px;

}
#entry #form .base_menu table.form th {
	border:none;
	background:#fff;
	padding:0px 20px;
	height:55px;
}
#entry #form .base_menu table.form th strong {
	right:20px;
	top:17px;
}

#entry #form .base_menu table.form select {
}
#entry #form .base_menu table.form td {
	border:none;
	padding:20px 0px;
}

#entry #form .base_menu table.form select.form_text {
    -webkit-appearance:none;
    -moz-appearance:none;
    appearance:none;
    text-indent: .01px; /*Firefox用*/
    text-overflow: ""; /*Firefox用*/
	height:55px;
	border:none;
	width:100%;
	font-size:16px;
	text-indent:10px;
	background-color:#f5f5f3;
	background-image:url(../img/select_arrow.png) no-repeat right;
	margin-top:3px;
}
table.form td.right {
	padding-bottom:15px;
}
/* アコーディオンA */
.menu-box{
width: 947px;
height:auto;
margin: 0px auto 30px;
position:relative;
}

.menu-box h5 {
	position:relative;
}

/*ラベル*/
.menu-box label.btn_menu{
	line-height:22px;
font-size: 14px;
border-radius: 15px;
padding:0px 20px 0px 20px;
text-align:center;
cursor: pointer;
transition: all 0.5s;
border:1px solid #40403e;
position:absolute;
top:14px;
right:0;
white-space:nowrap;

}


/*チェックを隠す*/
.menu-box input.open_btn{
display: none;
}
/*チェックのアイコン（↓）*/
.menu-box label.btn_menu:before{
content:"　 メニューを表示";
background:url(../img/open.jpg) no-repeat left center;
display:block;

}

/*チェックのアイコン（↑）*/
.menu-box input:checked ~ label.btn_menu::before {
font-family:"Avenir";
content:" 　　CLOSE　";
background:url(../img/close.jpg) no-repeat 10px center;
display:block;
}
.menu-box input:checked ~ label {

}

/*中身を非表示にしておく*/
.menu-box div{
height: 0px;
padding: 0px;
overflow: hidden;
opacity: 0;
transition: 0.5s;
}

/*クリックで中身を表示*/
.menu-box input:checked ~ div{
height: auto;
padding: 5px;
opacity: 1;
padding-top:34px;
}
.menu-small {
	width:100%;
	display:flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
.menu-small table {
	width:300px;
	border:2px solid #eaeaea;
	box-sizing:border-box;
	padding:20px;
	font-size:14px;
	margin-bottom:22px;
}

table.menu .menu_bottom {
	text-align:right;
	padding-top:5px;
}

#entry #form  table.menu td input.form_text_half {
	width:100px;
	border:none;
	border:1px solid #dcdcdc;
	height:52px;
	margin-top:3px;
	font-size:14px;
	text-indent:10px;
	border-radius:5px;text-align    : right;
	padding-right:10px;
	background: #f5f5f3;
	}


/* css checkbox01 */
table.form td.option span {
	color:#535545;

}
.checkbox01 {
}

#entry #form table.form td input.form-control {

    width: 100%;
    border: none;
    border: 1px solid #dcdcdc;
    height: 52px;
    font-size: 14px;
    text-indent: 10px;
    background: #f5f5f3;
	margin-top:3px;
    border-radius: 5px 0px 0px　5px;
	position: relative;
    -webkit-box-flex: 1;
    -ms-flex: 1 1 auto;
    flex: 1 1 auto;
    width: 1%;
    margin-bottom: 0;

}
#entry #form table.form td input:focus {color: #fff;
    background-color: #a92727;
    border-color: #a92727;
    outline: 0;
    -webkit-box-shadow: 0 0 0 0rem rgba(44,62,80,0.25);
    box-shadow: 0 0 0 0rem rgba(44,62,80,0.25);

}

.input-group-text {
	margin-top:3px;
}

#entry #form  table.form td textarea {width: 100%;
    padding: 10px;
    height: 370x;
    font-size: 14px;
    overflow-y: auto;
    border: none;
    margin-top: 3px;
    border: 1px solid #dcdcdc;
    margin-bottom: 30px;
	background: #f5f5f3;border-radius: 10px;
	box-sizing:border-box;
}



#entry #form  table.form div.policy {
	 width:100%;
	 padding: 20px;
	 height:187px;
	 margin:0 auto;
	 overflow-y:auto;
	border:1px solid #dcdcdc;
	background:#f5f5f2;
	line-height:23px;
	font-size:14px;
	margin-bottom:0px;
	box-sizing:border-box;

 }

#entry #form  table.form .submit_pc {
	margin-top:0;
}
 .submit_pc input {
	text-align:center;
	width:418px;
	height:60px;
	display:block;
	cursor:pointer;
	margin:40px auto 0;
	background:#a92727;
	border-radius:30px;
	color:#fff;
	font-size:16px;
}
.submit_pc input:hover {
	opacity:0.7;
}

.submit_pc  button{
    text-align:center;
    width:418px;
    height:60px;
    display:block;
    cursor:pointer;
    margin:40px auto 0;
    background:#a92727;
    border-radius:30px;
    color:#fff;
    font-size:16px;
}
.submit_pc button:hover {
    opacity:0.7;
}

p.to_policy {
	text-align:center;
}

p.to_policy a {
	text-decoration:underline;
	background:url(../img/bg_kiyaku.png) no-repeat center right;
	padding-right:17px;
	font-size:14px;
	line-height:28px;
}
p.to_policy a:hover {
	text-decoration:none;
}

div.agree {
	display:block;
	text-align:center;
	width:100%;
	margin:0px auto 0;
}
 div.policy h4{
	 font-size:16px;
	 line-height:52px;
 }

 div.policy {
	 width:100%;
	 padding: 20px;
	 height:187px;
	 margin:0 auto;
	 overflow-y:auto;
	border:1px solid #dcdcdc;
	background:#f5f5f2;
	line-height:23px;
	font-size:14px;
	margin-bottom:60px;

 }
.submit_sm {
	display:none;
}

.sm_only{
	display:none;
}

#entry #form table.form td span a{
	text-decoration: underline;
}

#entry #form table.form td span a:hover{
	opacity: 0.7;
}

.contact_time span{
	font-size:12px;
}

p.under_freedial  {
font-size: 16px;

color: #121621;

}
p.under_freedial a {
    text-decoration: underline;

}
/* iOSでのデフォルトスタイルをリセット */
input[type="submit"],
input[type="button"] {
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  appearance: button;
  border: none;
  box-sizing: border-box;
  cursor: pointer;
}
input[type="submit"]::-webkit-search-decoration,
input[type="button"]::-webkit-search-decoration {
  display: none;
}
input[type="submit"]::focus,
input[type="button"]::focus {
  outline-offset: -2px;
}

/* iOSでのデフォルトスタイルをリセット */
button[type="submit"],
button[type="button"] {
    -webkit-box-sizing: content-box;
    -webkit-appearance: button;
    appearance: button;
    border: none;
    box-sizing: border-box;
    cursor: pointer;
}
button[type="submit"]::-webkit-search-decoration,
button[type="button"]::-webkit-search-decoration {
    display: none;
}
button[type="submit"]::focus,
button[type="button"]::focus {
    outline-offset: -2px;
}



.sd-container {
  position: relative;
  float: left;
}

.sd {
}

.open-button {
  position: absolute;
  top: 50px;
  right: 3px;
  width: 25px;
  height: 25px;
  pointer-events: none;
}
.open-button  i {
	color:#666;
	font-size:16px;
}
.open-button button {
  border: none;
  background: transparent;
}

.freedial-banner {
    width: 450px;
    border: 1px solid #ccc;
    line-height: 1;
	margin:20px auto 50px ;
	white-space:nowrap;
	display:table;
}

.freedial-banner .number-wrap{
	padding:20px;
}

.freedial-banner .number{
    display: flex;
}

.freedial-banner .number .free-dial-info {
    width: 100%;
	margin:0 auto;
}

.freedial-banner .number div {
    font-size: 50px;
    font-weight: 700;
    letter-spacing: 2.0px;
	text-align:center;

}
.freedial-banner .number div i {
	padding-right:10px;
}

.freedial-banner .number .reception-time {
    font-size: 16px;
    font-weight: 500;
    letter-spacing: 0;
	padding-top:3px;
}

.freedial-banner .warning {
    background: #a92727;
    text-align: center;
    color: #fff;
    padding: 10px 5px;
    font-size: 13px;
}

.not-free{
    width: 275px;
}

.not-free dd span {
    font-size: 28px;
    font-weight: 700;
}

/*個人情報保護方針*/
#policy {
	text-align:left;
	width:100%;
	max-width:870px;
	margin:0 auto;
	padding:60px 0;
}
#policy .close a{

    text-align: center;
    margin: 50px auto;
    width: 418px;
    height: 60px;
    border-radius: 50px;
    background: #a79632;
    color: #fff;
    line-height:60px;
	display:block;

}
#policy .close a:hover {
	opacity:0.7;
}

/* form 追加 20201203 */

#form .err{
	text-align:left;
	font-size:14px;
	color:red;
	margin: 0 auto;
    /*width: 92%;*/
}

.thanx_sm h2{
	font-family: "ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", serif;
	font-size: 27px;
    text-align: center;
    color: #1b1b1b;
    line-height: 55px;
    font-weight: normal;
    letter-spacing: 0.15rem;
    margin-bottom: 20px;
}
/* 20201208追加 */
.index_midtext{
	color: #9c0404;
	font-size: 26px;
	font-weight: bold;
}
/* 20201209追加 */
.footer_pre{
    padding-top:15px;
    text-align: center;
    font-size:14px;
}
.footer_pre li{
    margin: 10px;
    display: inline;
}

.footer_pre li a:hover {
    text-decoration: underline;
}
/* 20210114追加　問合せ内容の必須 */
.disp4box{
    position: relative;
}

.disp4box #disp12{
	background: #a79632;
    color: #fff;
    font-size: 13px;
    line-height: 24px;
    width: 67px;
    display: inline-block;
    text-align: center;
    position: absolute;
    right: 31px;
    top: 17px;

}

/*よくある質問*/
#second #cont06.faq_cont06 {
background: #ecf1fa url(../img/bg_cont06.png) repeat-x center bottom;
}

/*お知らせ詳細*/
#cont05 .cont05_in dl.news_detail {
	border-top:none;
	text-align:left;
}
/*初めての方へ*/
#beginner {
	width:100%;
	padding:70px 0 53px;
	background:url(../img/bg_cont05.png) no-repeat right top;
}

.table03{
	display:flex;
}

.table04{
	display: flex;
}

/* 20210120追記 */
.scale_in input {
	background:#fff;
	color: #666666;
	border: 1px solid #bbbbbb;
	width:40%;
	box-sizing:border-box;
	height:60px;
	font-size:18px;
	border-radius:5px;
    padding: 0px 124px 0px 20px;
	box-sizing: border-box;
	margin-right: 20px;
}

.cont_free{
	margin-top:40px;
}

#cont02 .search_02{
	font-size: 38px;
    padding-top: 20px;
	font-weight:normal;
}

#cont02{
	padding: 40px 0 150px;
}
/*pre index*/
#price {
	width:100%;
	padding:70px 0 53px;
	background:url(../img/bg_cont03.png) no-repeat bottom;
	background-size:cover;
}
#price h2 {
	font-size: 38px;
    padding-top: 20px;
    margin-bottom: 70px;
    font-family: 游明朝,"Yu Mincho",YuMincho,"Hiragino Mincho ProN","Hiragino Mincho Pro",HGS明朝E,メイリオ,Meiryo,serif;
}
#price h2 b{
	color:#A63F3D;
    font-family: 游明朝,"Yu Mincho",YuMincho,"Hiragino Mincho ProN","Hiragino Mincho Pro",HGS明朝E,メイリオ,Meiryo,serif;
}

#price .price_in {
	border:1px solid #ccc;
	padding:40px;
	background:#fff;
	width:92%;
	box-sizing:border-box;
	max-width:870px;
	margin:0 auto;
	margin-bottom:50px;
}
#price .img_price {
	width:100%;
	max-width:860px;
	margin:0 auto;
}

/*20210128追記*/
#cont03 .cont table .table03_in {
	width:100%;
	word-break: break-all;
}
#cont03 .cont table .table03_in th{
	line-height: 38px;
	text-align:center;
	box-sizing:border-box;
	width:50%;
}
#cont03 .cont table .table03_in th span{
	background: #f5f3ee;
	display:block;
}
#cont03 .cont table .table03_in th.right{
	padding-right:2.5%;
}
#cont03 .cont table .table03_in th.left{
	padding-left:2.5%;
}
#cont03 .cont table .table03_in td{
	text-align: left;
	padding: 15px 20px;
    line-height: 30px;
	vertical-align:top;
	box-sizing:border-box;

}

#cont03 .cont03_in {

    width: 100%;
    max-width: 1100px;
    margin: 0 auto;
    display:inherit;
}
#cont03 .cont {
    width: 500px;
    padding: 20px 18px;
    box-sizing: border-box;
    margin: 0 25px 60px;
	float:left;
}
.btn_company_detail img {
	max-width:500px;

}
@media (max-width: 1120px) {
	#cont03 .cont {
    width: 70%;
    padding: 20px 18px;
    box-sizing: border-box;
    margin: 0 auto 60px;
	float:none;
}
}

#flow {
	width: 100%;
    background:#f5f3ee url(../img/bg_cont02.png) no-repeat top right;
    padding: 70px 0 48px;
}
#flow h2 {
    font-size: 38px;
    padding-top: 20px;
    margin-bottom: 70px;
    font-family: 游明朝,"Yu Mincho",YuMincho,"Hiragino Mincho ProN","Hiragino Mincho Pro",HGS明朝E,メイリオ,Meiryo,serif;
}
#flow .flow_in {
	width:92%;
    max-width: 870px;
    margin: 0 auto 100px
}

.flow {
  border: 2px solid #9F9F9A;
}
.flow > li {
 // padding: 30px;
}
.flow > li:not(:last-child) {
  border-bottom: 2px solid #9F9F9A;
  position: relative;
}
.flow > li:not(:last-child)::before,
.flow > li:not(:last-child)::after {
  content: "";
  border: solid transparent;
  position: absolute;
  top: 100%;
  left: 13%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
}
.flow > li:not(:last-child)::before {
  border-width: 21px;
  border-top-color: #9F9F9A;
}
.flow > li:not(:last-child)::after {
  border-width: 18px;
  border-top-color: #F5F3EE;
}
.flow > li dl {
  margin: 0;
  display:table;
  width:100%;
}
.flow > li dl dt {
	display:table-cell;
  font-size: 20px;
  font-weight: 600;
  color:#242323;
  width:25%;
  text-align: center;
  vertical-align:middle;
  padding:30px 30px;
}
.flow > li dl dt .icon {
  font-size: 14px;
  color: #fff;
  background: rgb(171,0,0);
  background: -moz-linear-gradient(left, rgba(171,0,0,1) 0%, rgba(197,0,0,1) 100%);
  background: -webkit-linear-gradient(left, rgba(171,0,0,1) 0%,rgba(197,0,0,1) 100%);
  background: linear-gradient(to right, rgba(171,0,0,1) 0%,rgba(197,0,0,1) 100%);
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ab0000', endColorstr='#c50000',GradientType=1 );
  padding: 5px 10px;
  margin-bottom: 10px;
  display: block;
  border-radius: 20px;
}
.flow > li dl dd {
	display:table-cell;
	text-align:left;
  vertical-align:middle;
  background:#fff;
  width:100%;
  padding:30px 20px;
  box-sizing:border-box;
}

/*20210128 野田追記*/
.company_logo img {
	width:80px;
	height:auto;
}
.company_icon {
	word-break:keep-all;
}
#second .icon span {
	line-height:40px;
}
table.service th {
	padding: 30px 22px !important;
}
.service_up {
	margin-top:80px;
}

#key_company_second {
	padding-top: 94px;
	width: 100%;
	height: 411px;
	background: url(../img/key_company.png) no-repeat center center;
	background-size: cover;
	position: relative;
	box-sizing: border-box;
}

#key_company_second h2 {
	position: absolute;
  text-align: center;
  top: 211px;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  color: #004797;
  line-height: 80px;
  background: rgba(255,255,255,0.5);
  width: 100%;
  font-size: 38px;
  color: #242323;
  font-weight: bold;
  letter-spacing: 0.3rem;
}

#key_second_topics {
	padding-top: 94px;
  width: 100%;
  height: 411px;
	background: url(../img/key_news.png) no-repeat center center;
	background-size: cover;
	position: relative;
  box-sizing: border-box;
}

#key_second_topics h2 {
	position: absolute;
  text-align: center;
  top: 211px;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  color: #004797;
  line-height: 80px;
  background: rgba(255,255,255,0.5);
  width: 100%;
  font-size: 38px;
  color: #242323;
  font-weight: bold;
  letter-spacing: 0.3rem;
}

#key_second_question {
	padding-top: 94px;
  width: 100%;
  height: 411px;
	background: url(../img/key_faq.png) no-repeat center center;
	background-size: cover;
  position: relative;
  box-sizing: border-box;
}

#key_second_question h2 {
	position: absolute;
  text-align: center;
  top: 211px;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  color: #004797;
  line-height: 80px;
  background: rgba(255,255,255,0.5);
  width: 100%;
  font-size: 38px;
  color: #242323;
  font-weight: bold;
  letter-spacing: 0.3rem;
}

/*問い合わせフォーム*/
.err_td {
	padding: 5px 10px !important;
}

.disp4box #disp12 {
  background: #a79632;
  color: #fff;
  font-size: 13px;
  line-height: 24px;
  width: 67px;
  display: inline-block;
  text-align: center;
  position: absolute;
  right: 31px;
  top: 17px;
}

#entry #form .checkbox02-parts {
    padding-left: 50px;
    position: relative;
    margin-right: 10px;
    line-height: 52px;
    letter-spacing: -0.03em;
    display: table-cell;
    line-height: 34px;
}
/*20210130追加*/
.company_info_det{
	text-align: left;
  font-size: 18px;
  line-height: 42px;
	padding: 15px 0 15px;
	margin-bottom: 80px;
	background: #f5f3ee;
}

.detail_company_logo img {
	width:220px;
	height:auto;
}

.contentA{
    width: 80%;
    text-align: left;
}
.contentB{
    width: 30%;
}
.contentB img {
    height: 100%;
    width: 100%;
}
.main{
    margin: 0px 30px 30px 30px;
    padding: 20px;
    background: #e2e4e5;
    display: flex;
}

.sdsjh{
    text-align: center;
    width: 160px;
    height: 40px;
    background: #a92727;
    border-radius: 10px;
    color: #fff;
}

.sdsjh-arrow{
    animation: flash 2s linear infinite;
    background:#0091EA;
}

@keyframes flash {
    0%,100% {
        opacity: 1;
    }

    50% {
        opacity: 0;
    }
}
