/*
@import url('https://fonts.googleapis.com/earlyaccess/sawarabigothic.css');
body { font-family: "Sawarabi Gothic" , '游ゴシック体', 'Yu Gothic', YuGothic ,  sans-serif; }
*/

/*
@import url('https://fonts.googleapis.com/earlyaccess/mplus1p.css');
body { font-family: "Mplus 1p" , '游ゴシック体', 'Yu Gothic', YuGothic ,  sans-serif; }
*/

@import url('https://fonts.googleapis.com/earlyaccess/notosansjapanese.css');
/*body { font-family: "Noto Sans Japanese" , '游ゴシック体', 'Yu Gothic', YuGothic ,  sans-serif; }*/
body { font-family: '游ゴシック体', 'Yu Gothic', YuGothic ,  sans-serif; }

/*----------------------------------------------------
  レスポンシブに対応したフォントサイズはここで調整
----------------------------------------------------*/
html { font-size: 62.5%; }
@media ( min-width : 768px) { html { font-size: 62.5%; } }
@media ( min-width : 992px) { html { font-size: 62.5%; } }
@media ( min-width : 1200px) { html { font-size: 68%; } }

/*------------------基本サイズ指定------------------*/
body { font-size: 16px; font-size: 1.6rem; }
/*--------------------------------------------------*/

h1 { font-size: 32px; font-size: 3.2rem; }
h1, .h1, h2, .h2, h3, .h3 {
    margin-top: 0px;
    margin-bottom: 0px;
}
h2,h3 {
	font-weight: 900;
}

.pc_none { display: none; }
@media ( max-width : 480px) {
	.pc_none { display: block; }
}
.sp_none { display: block; }
@media ( max-width : 480px) {
	.sp_none { display: none; }
}

/*----------------------------------------------------
  テーブルレスポンシブ基本設定
----------------------------------------------------*/
section table { width: 100%; }
section th, section td  { padding: 10px; border: 1px solid #ddd; }
section th  { background: #f4f4f4; }
 
.demo01 th  { width: 30%; text-align: left; }
 
@media only screen and (max-width:480px){
    .demo01 { margin: 0 -10px; }
    .demo01 th,
    .demo01 td{
    width: 100%;
    display: block;
    border-top: none;
    }
  .demo01 tr:first-child th { border-top: 1px solid #ddd; }
}


/*----------------------------------------------------
  画像サイズ指定
----------------------------------------------------*/
#sample_img img {
    object-fit: cover;
    font-family: 'object-fit: cover;';
    height: 231px;	
}

/*----------------------------------------------------
  ページトップへ戻る
----------------------------------------------------*/
#page_top {
    width: 100px;
    height: 60px;
    position: fixed;
    right: 0;
    bottom: 0;
    background: #B81B26;
    opacity: 0.6;
    z-index: 100;
}
#page_top a {
    position: relative;
    display: block;
    width: 100px;
    height: 60px;
    text-decoration: none;
}
#page_top a:hover {
    opacity: 0.7;
    filter: alpha(opacity=70);
    -ms-filter: "alpha(opacity=70)";
}
#page_top a::before {
    font-family: "Font Awesome 5 Free";
    content: '\f102';
    font-size: 25px;
    color: #fff;
    position: absolute;
    width: 25px;
    height: 25px;
    top: -25px;
    bottom: 0;
    right: 0;
    left: 0;
    margin: auto;
    text-align: center;
    font-weight: 900;
}
#page_top a::after {
    content: 'PAGE TOP';
    font-size: 13px;
    color: #fff;
    position: absolute;
    top: 30px;
    bottom: 0;
    right: 0;
    left: 0;
    margin: auto;
    text-align: center;
}

#header {
	border-top: solid 10px #B81B26;
	position: fixed;
	z-index: 10;
	background-color: white;
    height: 130px;
}
@media ( min-width : 768px) {
#header {
	border-top: solid 22px #B81B26;
	position: relative;
	background-color: white;
    height: 100%;
}
}
#header h1 {
	font-size: 60%;;
	margin: 10px 0 0 0;
	text-align: center;
    line-height: 150%;
}
@media ( min-width : 768px) {
#header h1 {
	font-size: 70%;;
	margin: 10px 0 0 0;
	text-align: center;
}
}
 
@media ( min-width : 992px) {
#header h1 {
	font-size: 90%;;
	margin: 10px 0 0 0;
	text-align: center;
}
}
 
@media ( min-width : 1200px) {
#header h1 {
	font-size: 90%;;
	margin: 10px 0 0 0;
	text-align: center;
	
}
}

#header .logo {
    margin: 10px auto 0 auto;
    width: 200px;
    float: left;
    position: fixed;
    z-index: 10;
    top: 60px;
    left: 35px;
}
@media ( min-width : 768px) {
#header .logo {
	margin: 40px auto 0 auto;
	width: 200px;
	float: none;
	position: static;
}
}
@media ( min-width : 992px) {
#header .logo {
	margin: 40px auto 0 auto;
	width: 200px;
	float: none;
	position: static;
}
}
@media ( min-width : 1200px) {
#header .logo {
	margin: 40px 0 0 0;
	width: 280px;
	float: left;
	position: static;
}
}


#nav {
	float: none;
	display: none;
}
@media ( min-width : 768px) {
#nav {
	float: none;
	display: block;
}
}
@media ( min-width : 1200px) {
#nav {
	float: right;
}
}
#nav ul {
	margin: 50px 0 0 0;
	text-align: center;
}
@media ( min-width : 1200px) {
#nav ul {
	margin: 60px 0 0 0;
}
}
#nav li {
	display: inline-block;
    letter-spacing: normal;
    margin: 0 30px 0 0;
}
#nav li a {
	font-size: 100%;
	font-weight: bold;
	color: #707070;
}
@media ( min-width : 1200px) {
#nav li a {
	font-size: 100%;
	font-weight: bold;
	color: #707070;
}
}
#nav li a.contact {
	border: 1px solid #707070;
	padding: 10px 20px;
}
#nav li a:hover {
	color: #B81B26;
	text-decoration: none;
}

#nav li a:hover.contact {
	border: 1px solid #B81B26;
	background-color: #B81B26;
	color: #ffffff;
	padding: 10px 20px;
}

nav.globalMenuSp {
    position: fixed;
    z-index: 30;
    top: 0;
    left: 0;
    background: #fff;
    color: #000;
    text-align: center;
    transform: translateY(-100%);
    transition: all 0.6s;
    width: 100%;
    opacity:0;

}

nav.globalMenuSp ul {
    background: #6a4229;
    color: #ffffff;
    margin: 0 auto;
    padding: 0;
    width: 100%;
}

nav.globalMenuSp ul li {
    font-size: 1.1em;
    list-style-type: none;
    padding: 0;
    width: 100%;
    border-bottom: 1px dotted #f2f2f2;
}

/* 最後はラインを描かない */
nav.globalMenuSp ul li:last-child {
    padding-bottom: 0;
    border-bottom: none;
}

nav.globalMenuSp ul li a {
    display: block;
    color: #ffffff;
    padding: 10px 0;
    text-decoration: none;
    background-color: rgba(184, 28, 38, 0.74);
}
nav.globalMenuSp ul li a.newmenu {
    display: block;
    color: #ffffff;
    background-color: rgba(184, 28, 38, 0.74);
    padding: 10px 0;
    text-decoration: none;
}
nav.globalMenuSp ul li a.newmenu span{
	background-color: #ffffff;
	color: #a48673;
	border-radius: 10px;        /* CSS3草案 */  
    -webkit-border-radius: 10px;    /* Safari,Google Chrome用 */  
    -moz-border-radius: 10px;
    font-size: 80%;
    padding: 5px 10px 3px 10px;
    margin: 0 5px 0 0;
}
nav.globalMenuSp ul li a:hover {
    display: block;
    color: #ffffff;
    padding: 10px 0;
    background-color: rgba(184, 28, 38, 0.44);
    text-decoration: none;
}
/* このクラスを、jQueryで付与・削除する */
nav.globalMenuSp.active {
    transform: translateY(0%);
    opacity:1;
}


.navToggle {
    display: block;
    position: fixed;    /* bodyに対しての絶対位置指定 */
    right: 25px;
    top: 62px;
    width: 42px;
    height: 51px;
    cursor: pointer;
    z-index: 10000;
    background: #B81B26;
    text-align: center;
    transform: translate3d(0, 0, 0);
}

@media ( min-width : 768px) {
	.navToggle { display: none; }
}

.navToggle span {
    display: block;
    position: absolute;    /* .navToggleに対して */
    width: 30px;
    border-bottom: solid 3px #eee;
    -webkit-transition: .35s ease-in-out;
    -moz-transition: .35s ease-in-out;
    transition: .35s ease-in-out;
    left: 6px;
}

.navToggle span:nth-child(1) {
    top: 9px;
}

.navToggle span:nth-child(2) {
    top: 18px;
}

.navToggle span:nth-child(3) {
    top: 27px;
}

.navToggle span:nth-child(4) {
    border: none;
    color: #eee;
    font-size: 9px;
    font-weight: bold;
    top: 34px;
}


/* 最初のspanをマイナス45度に */
.navToggle.active span:nth-child(1) {
    top: 18px;
    left: 6px;
    -webkit-transform: rotate(-45deg);
    -moz-transform: rotate(-45deg);
    transform: rotate(-45deg);
}

/* 2番目と3番目のspanを45度に */
.navToggle.active span:nth-child(2),
.navToggle.active span:nth-child(3) {
    top: 18px;
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    transform: rotate(45deg);
}


#main_img {
	margin: 0 0 0 0;
}
@media ( min-width : 768px) {
#main_img {
	margin: 30px 0 0 0;
}
}
#main_img .box {
	position: relative;
}

#main_img .box p {
	position: absolute;
	top: 50%;
	left: 50%;
	-ms-transform: translate(-50%,-50%);
	-webkit-transform: translate(-50%,-50%);
	transform: translate(-50%,-50%);
	margin:0;
	padding:0;
	/*文字の装飾は省略*/
	font-size: 200%;
	font-weight: bold;
	text-align: center;
	line-height: 150%;
	width: 80%;
  text-shadow:1px 1px 0 #FFF, -1px -1px 0 #FFF,
              -1px 1px 0 #FFF, 1px -1px 0 #FFF,
              0px 1px 0 #FFF,  0-1px 0 #FFF,
              -1px 0 0 #FFF, 1px 0 0 #FFF;
}

#main_img .box img {
	width: 100%;
	object-fit: cover;
    font-family: 'object-fit: cover;';
    height: 650px;	
}


#top_about {
	margin: 80px 0 0 0;
}
#top_about h2 {
	font-size: 180%;
	color: #B81B26;
	text-align: center;
	line-height: 150%;
}
#top_about h3 {
	font-size: 130%;
	font-weight: 900;
	margin: 0 0 10px 0;
}
#top_about p {
	font-size: 110%;
	line-height: 150%;

}
#top_about .top_about_contents {
	margin: 60px auto 60px auto;
}
#top_about .left_img {
	width: 100%;
	float: none;
}
#top_about .left_img img {
	width: 100%;
	object-fit: cover;
    font-family: 'object-fit: cover;';
    height: 350px;
}
#top_about .right_contents {
	float: none;
	margin: 20px 0 0 0;
}

@media ( min-width : 768px) {
#top_about .left_img {
	width: 100%;
	float: none;
}
#top_about .left_img img {
	width: 100%;
	object-fit: cover;
    font-family: 'object-fit: cover;';
    height: 350px;
}
#top_about .right_contents {
	float: none;
	margin: 20px 0 0 0;
}
}
 
@media ( min-width : 992px) {
#top_about .left_img {
	width: 430px;
	float: left;
}
#top_about .left_img img {
	width: 100%;
	object-fit: cover;
    font-family: 'object-fit: cover;';
    height: 350px;
}
#top_about .right_contents {
	float: left;
	margin: 0 0 0 40px;
}
}



#top_about .about_menu {
	
}
#top_about .about_menu ul {
	text-align: center;
	padding: 0 0 0 0;
	margin: 40px 0 0 0;
}
#top_about .about_menu li {
	display: block;
    letter-spacing: normal;
    margin: 30px 10px;
}
#top_about .about_menu li a {
	border: 1px solid #707070;
	padding: 10px 20px;
	color: #707070;
	display: block;
}
#top_about .about_menu li a:hover {
	border: 1px solid #B81B26;
	background-color: #B81B26;
	color: #ffffff;
	padding: 10px 20px;
	text-decoration: none;
}

@media ( min-width : 768px) {
#top_about .about_menu {
	
}
#top_about .about_menu ul {
	text-align: center;
	padding: 0 0 0 0;
	margin: 40px 0 0 0;
}
#top_about .about_menu li {
	display: inline-block;
    letter-spacing: normal;
    margin: 0 10px;
}
#top_about .about_menu li a {
	border: 1px solid #707070;
	padding: 10px 20px;
	color: #707070;
	display: block;
}
#top_about .about_menu li a:hover {
	border: 1px solid #B81B26;
	background-color: #B81B26;
	color: #ffffff;
	padding: 10px 20px;
	text-decoration: none;
	
}
}
 
@media ( min-width : 992px) {
#top_about .about_menu {
	
}
#top_about .about_menu ul {
	text-align: left;
	padding: 0 0 0 0;
	margin: 20px 0 0 0;
}
#top_about .about_menu li:first-child {
	display: inline-block;
    letter-spacing: normal;
    margin: 0 10px 0 0;
}
#top_about .about_menu li {
	display: inline-block;
    letter-spacing: normal;
    margin: 0 10px;
}
#top_about .about_menu li a {
	border: 1px solid #707070;
	padding: 10px 20px;
	color: #707070;
	display: inline-block;
}
#top_about .about_menu li a:hover {
	border: 1px solid #B81B26;
	background-color: #B81B26;
	color: #ffffff;
	padding: 10px 20px;
	text-decoration: none;
}
}




#job_description {
	background-color: #B81B26;
	padding: 40px 0 40px 0;
	margin: 40px 0 0 0;
}

#job_description h2 {
	text-align: center;
	width: 260px;
}

#job_description ul {
	margin: 30px 0 0 0;
	padding: 0 0 0 0;
}
#job_description li {
	font-size: 90%;
	color: #ffffff;
	display: inline-block;
	width: 100%;
	margin: 0 10px 20px 0;
	line-height: 200%;
}
#job_description li.li33 {
	display: inline-block;
	width: 100%;
}

@media ( min-width : 768px) {
#job_description ul {
	margin: 30px 0 0 0;
	padding: 0 0 0 0;
}
#job_description li {
	font-size: 90%;
	color: #ffffff;
	display: inline-block;
	width: 64%;
	margin: 0 10px 0 0;
	line-height: 200%;
}
#job_description li.li33 {
	display: inline-block;
	width: 32%;
}
}


#results {
	margin: 40px 0 0 0;
}
#results h2 {
	text-align: center;
	width: 260px;
}

#results ul {
	margin: 0 0 0 0;
	padding: 0 0 0 0;
	text-align: center;
}
#results li {
	display: inline-block;
	width: 35%;
	padding: 0 15px 20px 15px;
}

#results table {
	width: 80%;
	margin: 0 auto;
}
#results table td {
	border: none;
}

#results .res-table {
	display: none;
}

@media ( min-width : 768px) {
#results ul {
	margin: 0 0 0 0;
	padding: 0 0 0 0;
	text-align: center;
}
#results li {
	display: inline-block;
	width: 18%;
	padding: 0 15px 20px 15px;
}
}

@media ( max-width : 990px) {
#results .pc-table {
	display: none;
}
#results .res-table {
	display: table;
    width: 80%;
    margin: 0 auto;

}
}
@media ( max-width : 480px) {
#results table {
    width: 100%;
}
#results table td {
	padding:10px 0;
}
}

#recruit {
	background-color: #B81B26;
	padding: 80px 0 80px 0;
	margin: 40px 0 0 0;
}

#recruit h2 {
	text-align: center;
	width: 260px;
}
#recruit p {
	text-align: center;
	color: #ffffff;
	margin: 20px 0 0 0;
}
#recruit ul {
	text-align: center;
	padding: 0 0 0 0;
	margin: 40px 0 0 0;
}
#recruit li {
	display: inline-block;
    letter-spacing: normal;
    margin: 20px 10px;
}
#recruit li a {
	border: 1px solid #ffffff;
	padding: 10px 20px;
	color: #ffffff;
}
#recruit li a:hover {
	border: 1px solid #ffffff;
	background-color: #ffffff;
	color: #B81B26;
	padding: 10px 20px;
	text-decoration: none;
}

#recruit_sub {
	margin: 40px 0 0 0;
}

#recruit_sub h2 {
    font-size: 180%;
    color: #B81B26;
    text-align: center;
}
#recruit_sub h2.partner {
    font-size: 180%;
    color: #333333;
    text-align: center;
}
#recruit_sub .red_box {
	background-color: #B81B26;
	padding: 40px 0 80px 0;
	margin: 40px 0 0 0;
}
#recruit_sub .red_box h3 {
    font-size: 180%;
    color: #ffffff;
    text-align: center;
}
#recruit_sub .red_box p {
    color: #ffffff;
    text-align: center;
    margin: 60px 0 0 0;
}

#recruit_sub .border {
	border: solid 1px #b2b2b2;
	padding: 40px 40px;
	margin: 10px 0 0 0;
}
#recruit_sub .border p {
	color: #707070;
	font-size: 90%;
	margin: 30px 0 30px 0;
}
#recruit_sub .border h4 {
	text-align: center;
	background-color: #a0a0a0;
	padding: 20px 0;
	color: #ffffff;
}	

#recruit_sub .border table { width: 100%; }
#recruit_sub .border th  { padding: 20px; border-top: 1px solid #b3b3b3; border-bottom: 1px solid #b3b3b3; border-left:1px solid #b3b3b3; border-right:1px solid #b3b3b3; color: #707070; }
#recruit_sub .border td  { padding: 20px; border-top: 1px solid #b3b3b3; border-bottom: 1px solid #b3b3b3; border-left:1px solid #b3b3b3; border-right:1px solid #b3b3b3; color: #707070; }
#recruit_sub .border th  { background: #dadada; font-weight: 500; }
#recruit_sub .border th span { color: #ff3c3c; }
 
#recruit_sub .border .about th  { width: 30%; text-align: left; }
 
@media only screen and (max-width:480px){
    #recruit_sub .border .about { margin: 0 -10px; }
    #recruit_sub .border .about th,
    #recruit_sub .border .about td{
    width: 100%;
    display: block;
    border-top: none;
    }
  #recruit_sub .border .about tr:first-child th { border-top: 1px solid #FF0012; }
}
#recruit_sub th{
	font-weight:normal;
}
#recruit_sub .recruit_button a {
    width: 100%;
    height: 100%;
    box-sizing: border-box;
    padding: 10px 60px;
    background-color: #ffffff;
    border: 1px solid #ffffff;
    color: #B81B26;
	max-width: 200px;
    margin: 20px auto;
}
#recruit_sub .recruit_button a:hover{
	padding: 10px 60px;
    background-color: #B81B26;
    border: 1px solid #ffffff;
    color: #ffffff;
    text-decoration: none;
}
.recruit-sublink{
	margin-top:40px;
	text-align:center;
}
.recruit-sublink a{
	text-decoration:none;
	color:#707070;
}
.recruit-sublink a:hover{
	text-align:center;
	color:#B81B26;
}
	
#contact {
	margin: 80px 0 0 0;
}

#contact h2 {
    font-size: 180%;
    color: #B81B26;
    text-align: center;
}

#contact ul {
	text-align: center;
	padding: 0 0 0 0;
	margin: 40px 0 0 0;
	list-style: none;
}
#contact li {
    letter-spacing: normal;
    margin: 20px 0 0 0;
    display: grid;

}
#contact li a {
	border: 1px solid #707070;
	padding: 10px 20px;
	color: #707070;
	font-weight: bold;
}
#contact li a:hover {
	border: 1px solid #B81B26;
	background-color: #B81B26;
	color: #ffffff;
	padding: 10px 20px;
	text-decoration: none;
}

#contact li span {
	text-align: right;
	float: right;
}



#contact_sub {
	margin: 40px 0 0 0;
}

#contact_sub h2 {
    font-size: 180%;
    color: #B81B26;
    text-align: center;
}
#contact_sub h2.partner {
    font-size: 180%;
    color: #333333;
    text-align: center;
}
#contact_sub .red_box {
	background-color: #B81B26;
	padding: 40px 0 40px 0;
	margin: 40px 0 0 0;
}
#contact_sub .white_box {
	background-color: #ffffff;
	padding: 40px 0 40px 0;
	margin: 40px 40px 0 40px;
}
#contact_sub .white_box p {
	text-align: center;
	color: #707070;
}
#contact_sub .white_box .contact_text_box {
	
}
#contact_sub .white_box .contact_text_box p{
	text-align: center;
	color: #707070;
}

#contact_sub .white_box .contact_text_box h4{
	text-align: center;
	font-size: 250%;
	font-weight: bold;
	margin: 0;
}
@media ( min-width : 992px) {
#contact_sub .white_box .contact_text_box p{
	text-align: left;
	color: #707070;
}

#contact_sub .white_box .contact_text_box h4{
	text-align: right;
	font-size: 250%;
	font-weight: bold;
	margin: 0;
}
}

#contact_sub .red_box h3 {
    font-size: 180%;
    color: #ffffff;
    text-align: center;
}
#contact_sub .border {
	border: solid 1px #b2b2b2;
	padding: 40px 40px;
	margin: 10px 0 0 0;
}
#contact_sub .border p {
	color: #707070;
	font-size: 90%;
	margin: 30px 0 30px 0;
}
#contact_sub .border h4 {
	text-align: center;
	background-color: #a0a0a0;
	padding: 20px 0;
	color: #ffffff;
}	

#contact_sub .border table { width: 100%; }
#contact_sub .border th  { padding: 20px; border-top: 1px solid #b3b3b3; border-bottom: 1px solid #b3b3b3; border-left:1px solid #b3b3b3; border-right:1px solid #b3b3b3; color: #707070; }
#contact_sub .border td  { padding: 20px; border-top: 1px solid #b3b3b3; border-bottom: 1px solid #b3b3b3; border-left:1px solid #b3b3b3; border-right:1px solid #b3b3b3; color: #707070; }
#contact_sub .border th  { background: #dadada; font-weight: 500; }
#contact_sub .border th span { color: #ff3c3c; }
 
#contact_sub .border .about th  { width: 30%; text-align: left; }
 
@media only screen and (max-width:480px){
    #contact_sub .border .about { margin: 0 -10px; }
    #contact_sub .border .about th,
    #contact_sub .border .about td{
    width: 100%;
    display: block;
    border-top: none;
    }
  #contact_sub .border .about tr:first-child th { border-top: 1px solid #FF0012; }
}



#sub_title {
	margin: 0 0 0 0;
	padding: 130px 0 0 0;
}
@media ( min-width : 768px) {
#sub_title {
	margin: 30px 0 0 0;
	padding: 0 0 0 0;
}
}

#sub_title .box {
	position: relative;
	background-color: rgba(0,0,0,0.8);
}

#sub_title .box p {
	position: absolute;
	top: 50%;
	left: 50%;
	-ms-transform: translate(-50%,-50%);
	-webkit-transform: translate(-50%,-50%);
	transform: translate(-50%,-50%);
	margin:0;
	padding:0;
	/*文字の装飾は省略*/
	font-size: 160%;
	font-weight: bold;
	text-align: center;
	line-height: 150%;
	color: #ffffff;
}

#sub_title .box img {
	width: 100%;
	object-fit: cover;
    font-family: 'object-fit: cover;';
    height: 325px;	
}


#about_candc {
	margin: 40px 0 0 0;
}

#about_candc h2 {
    font-size: 180%;
    color: #B81B26;
    text-align: center;
}
#about_candc h3 {
    text-align: center;
    width: 200px;
    margin: 0 auto 50px auto;
}
#about_candc h3.company {
    width: 300px;
}
#about_candc h4 {
	text-align: center;
	font-weight: bold;
	font-size: 140%;
	margin: 0 0 50px 0;
}
#about_candc .box-shadow {
  box-shadow: 0 0 10px #c8c8c8;
  width: 100%;
  padding: 20px;
  margin: 40px 0 0 0;
 
}
@media ( min-width : 768px) {
#about_candc .box-shadow {
  box-shadow: 0 0 10px #c8c8c8;
  width: 100%;
  padding: 80px;
  margin: 40px 0 0 0;
 
}
}
#about_candc p {
	line-height: 200%;
	color: #707070;
	margin: 0 0 20px 0;
}

#about_candc table { width: 100%; }
#about_candc th  { padding: 20px; border-top: 1px solid #FF0012; border-bottom: 1px solid #FF0012; border-left:none; border-right:none; color: #ffffff; }
#about_candc td  { padding: 20px; border-top: 1px solid #FF0012; border-bottom: 1px solid #FF0012; border-left:none; border-right:none; color: #707070; }
#about_candc th  { background: #B81B26; }
 
.about th  { width: 30%; text-align: left; }
 
@media only screen and (max-width:480px){
    .about { margin: 0 -10px; }
    .about th,
    .about td{
    width: 100%;
    display: block;
    border-top: none;
    }
  .about tr:first-child th { border-top: 1px solid #FF0012; }
}

#about_candc dl {
	margin: 30px 0 0 0;
	color: #707070;
}
#about_candc dt {
	float: left;
}
#about_candc dd {
	float: left;
}


#about_candc_list {
	margin: 0 0 0 0;
}
#about_candc_list .red_box {
    background-color: #B81B26;
    padding: 0 0 0 0;
    margin: 40px 0 0 0;
}
#about_candc_list .left_box {
	width: 30%;
	float: left;
	padding: 0 20px 0 0;
	
}
#about_candc_list .right_box {
	width: 70%;
	float: left;
	padding: 30px 20px 20px 20px;
}
#about_candc_list .right_box h3{
    font-size: 180%;
    color: #ffffff;
    text-align: left;	
}
#about_candc_list .right_box p {
    color: #ffffff;
    text-align: left;
    margin: 30px 0 0 0;
}
#about_candc_list .right_box p.link {
	text-align: center;
}
#about_candc_list .right_box a {
	padding: 10px 60px;
	background-color: #ffffff;
	border: 1px solid #ffffff;
	color: #B81B26;
}
#about_candc_list .right_box a:hover {
	padding: 10px 60px;
	background-color: #B81B26;
	border: 1px solid #ffffff;
	color: #ffffff;
	text-decoration: none;
}

#about_candc_list .col_box {
	padding: 20px 20px 20px 20px;
}

#about_candc_list .col_box h3{
    font-size: 180%;
    color: #ffffff;
    text-align: center;
    margin: 30px 0 0 0;
}
#about_candc_list .col_box p {
    color: #ffffff;
    text-align: center;
    margin: 10px 0 30px 0;
}
#about_candc_list .col_box p.link {
	text-align: center;
	margin: 10px 0 60px 0;
}
#about_candc_list .col_box a {
	padding: 10px 60px;
	background-color: #ffffff;
	border: 1px solid #ffffff;
	color: #B81B26;
}
#about_candc_list .col_box a:hover {
	padding: 10px 60px;
	background-color: #B81B26;
	border: 1px solid #ffffff;
	color: #ffffff;
	text-decoration: none;
}



#our_job {
	margin: 40px 0 0 0;
}

#our_job h2 {
    font-size: 180%;
    color: #B81B26;
    text-align: center;
}
#our_job h2.detail_titile {
    font-size: 160%;
    color: #333333;
    text-align: center;
    font-weight: bold;
}
#our_job h4 {
	font-size: 90%;
	text-align: center;
	color: #707070;
	margin: 10px 0 0 0;
}
#our_job .detail_contents {
	margin: 40px 0 20px 0;
}
#our_job .job_list {
	margin: 40px 10px 20px 10px;
	padding: 20px 10px 20px 10px;
	width: 100%;
	background-color: #B81B26;
	float: left;
	text-align: center;
}

@media ( min-width : 768px) {
#our_job .job_list {
	width: 47%;
}
}
 
@media ( min-width : 992px) {
#our_job .job_list {
	width: 30%;
}
}
 
@media ( min-width : 1200px) {
#our_job .job_list {
	width: 30%;
}
}

#our_job .job_list h3 {
	width: 120px;
}
#our_job .job_list p {
	margin: 20px 0 10px 0; 
}
#our_job .job_list a {
	border: 1px #ffffff solid;
	background-color: #ffffff;
	padding: 10px 80px 10px 80px;
	color: #B81B26;
	text-decoration: none;
	font-size: 90%;
	
}
#our_job .job_list a:hover {
	border: 1px #B81B26 solid;
	background-color: #B81B26;
	padding: 10px 80px 10px 80px;
	color: #ffffff;
	text-decoration: none;
	font-size: 90%;
}

#our_job a.page-numbers {
	display: block;
    float: left;
    width: auto;
    margin: 2px 5px 2px 0;
    padding: 5px 10px 6px 10px;
    background-color: #eee;
    border: 1px solid #bbb;
    -webkit-border-radius: 18px;
    -moz-border-radius: 18px;
    border-radius: 18px;
    color: #333;
    text-decoration: none;
}

#our_job span.page-numbers {
	display: block;
    float: left;
    width: auto;
    margin: 2px 5px 2px 0;
    padding: 5px 10px 6px 10px;
    background-color: #eee;
    border: 1px solid #bbb;
    -webkit-border-radius: 18px;
    -moz-border-radius: 18px;
    border-radius: 18px;
    color: #333;
    text-decoration: none;
}

#our_job a:hover {color: rgba(108,  67,  42, 0.50);}


#our_job_list {
	margin: 0 0 0 0;
}

#our_job_list .col_box {
	padding: 20px 20px 20px 20px;
    background-color: #B81B26;
    margin: 40px 0 0 0;
}

#our_job_list .col_box h3{
    font-size: 180%;
    color: #ffffff;
    text-align: center;
    margin: 30px 0 0 0;
}
#our_job_list .col_box p {
    color: #ffffff;
    text-align: center;
    margin: 10px 0 30px 0;
}
#our_job_list .col_box p.link {
	text-align: center;
	margin: 10px 0 60px 0;
}
#our_job_list .col_box a {
	padding: 10px 60px;
	background-color: #ffffff;
	border: 1px solid #ffffff;
	color: #B81B26;
}
#our_job_list .col_box a:hover {
	padding: 10px 60px;
	background-color: #B81B26;
	border: 1px solid #ffffff;
	color: #ffffff;
	text-decoration: none;
}


#our_job_list .red_box {
    background-color: #B81B26;
    padding: 10px 0 10px 0;
    margin: 40px 0 0 0;
}
#our_job_list .left_box {
	width: 30%;
	float: left;
	padding: 20px 20px 20px 20px;
	
}
#our_job_list .right_box {
	width: 70%;
	float: left;
	padding: 20px 20px 20px 20px;
}
#our_job_list .right_box h3{
    font-size: 180%;
    color: #ffffff;
    text-align: center;	
}
#our_job_list .right_box p {
    color: #ffffff;
    text-align: left;
    margin: 30px 0 0 0;
}
#our_job_list .right_box p.link {
	text-align: center;
}
#our_job_list .right_box a {
	padding: 10px 60px;
	background-color: #ffffff;
	border: 1px solid #ffffff;
	color: #B81B26;
}
#our_job_list .right_box a:hover {
	padding: 10px 60px;
	background-color: #B81B26;
	border: 1px solid #ffffff;
	color: #ffffff;
	text-decoration: none;
}

#our_job_description {
	margin: 20px 0 0 0;
	
}
#our_job_description .description_box {
	border: 1px solid #707070;
	padding: 20px 20px 20px 20px;
}
#our_job_description .description_box span {
	font-weight: bold;
}
#our_job_description .description_box p {
	color: #707070;
	line-height: 190%;
	word-wrap: break-word;
}
#our_job_description .description_box .download {
	text-align: center;
	margin: 40px 0 60px 0;
}
#our_job_description .description_box .download a {
    border: 1px solid #707070;
    padding: 10px 20px;
    color: #707070;
    font-weight: bold;
}
#our_job_description .description_box .download a:hover {
    border: 1px solid #B81B26;
    background-color: #B81B26;
    color: #ffffff;
    padding: 10px 20px;
    text-decoration: none;
}


#footer {
	padding: 40px 0 40px 0;
	margin: 80px 0 0 0;
	background-color: #EAEAEA;
	color: #707070;
}
#footer .address {
	margin: 40px 0 20px 0;
}
#footer .address dl {
	
}
#footer .address dt {
	float: left;
}
#footer .address dd {
	float: left;
}
#footer .menu dl {
	float: left;
	padding: 0 20px 0 20px;
	font-size: 90%;
}
#footer .menu dt {
	margin: 0 0 0 0;
}
#footer .menu dd {
	margin: 0 0 0 0;
}

#footer p {
	text-align: center;
	
	font-size: 90%;
}

#footer a {
	color: #707070;
}

#footer a:hover {
	color: #B81B26;
	text-decoration: none;
}


#privacy-policy {
	margin: 40px 0 0 0;
}

#privacy-policy h2 {
	margin: 0 0 40px 0;
    font-size: 180%;
    color: #B81B26;
    text-align: center;
}
#privacy-policy h3 {
    text-align: left;
    margin: 30px auto 20px;
}
#privacy-policy h4 {
    text-align: left;
    margin: 30px auto 10px;
}

#privacy-policy > .container{
	width:65%;
}


#privacy-policy > .container ul{
	margin: 40px 0 0 0;
}
#privacy-policy > .container ol{
	margin: 40px 0 0 0;
}
#privacy-policy > .container ol ul{
	margin: 20px 0 0 0;
	list-style-type: disc;
}
.policy-box {
	display:flex;
	flex-direction: row;
    justify-content: space-between;
	align-items: flex-end;
}
.policy-box > .box-left {
width: 60%;
}
.policy-box > .box-right {
width: 40%;
}
.point-box {
  position: relative;
  border: 2px solid #ddd; /* 枠の太さ・種類・色 */
  border-radius: 4px; /* 枠の丸み */
  margin: 1.8em 1em; /* 枠外の余白 */
  padding: 25px;
  max-width: 320px;
}
.point-title {
  position: absolute;
  padding: 0 0.5em;
  left: 20px;
  top: -13px; /* タイトルの位置を調整 */
  color: #555555; /* タイトルの文字色 */
  font-weight: bold;
  font-size:0.9em; /* タイトルの文字サイズ */
  background-color: #ffffff;
}

@media ( max-width : 768px) {
#privacy-policy {
    margin: 0 0 0 0;
    padding: 130px 0 0 0;
}
#privacy-policy > .container{
	width:95%;
}
.policy-box {
	flex-direction: column;
}
.policy-box > .box-left {
width: 90%;
}
.policy-box > .box-right {
width: 90%;
}
}

