@charset "utf-8";

/* ************************************************ 
*	事業所一覧
* ************************************************ */
.att-blue {
color:#57c3ea;
}
.jobsearch-box {
width: 1200px;
max-width: 90%;
margin: 120px auto 0 auto;
padding: 80px 0;
}

.topsearch-link-inner {
width: 550px;
max-width: 100%;
margin: 0 auto 100px auto;
}

.top-searchlink {
color: #333;
display: block;
padding: 30px 0;
margin: 0;
font-size: min(3.0vw,30px);
text-align:center;
background-color:#fff;
border: 1px solid #333;
width: 100%;
transition: 0.5s;
border-radius: 50vh; /* CSS3 */
 -webkit-border-radius: 50vh; /* Firefox */
 -moz-border-radius: 50vh; /* Safari,Chrome */
}
.top-searchlink span{
font-size: min(1.8vw,18px);
}
.top-searchlink::before{
position:relative;
top: 5px;
left: -10px;
content:"";
display:inline-block;
width:30px;
height:30px;
background:url("../images/icon_search.svg") no-repeat;
background-size:contain;
}
.top-searchlink:hover{
color: #fff;
background-color:#000;
transition: 0.5s;
}
.top-searchlink:hover::before{
background:url("../images/icon_search_w.svg") no-repeat;
}

.hidden_box {
margin: 0;
padding: 0;
}
.hidden_box_waku {
margin: 0;
padding: 20px;
background-color: #efefef;
}
.hidden_box-inner {
width: calc(100% - 20px);
padding: 10px;
background-color: #fff;
}

/*ボタン装飾*/
.hidden_box label {
cursor :pointer;
text-decoration:none;
}

/*ボタンホバー時*/
.hidden_box label:hover {
color:#000;
text-decoration:none;
}

/*チェックは見えなくする*/
.hidden_box input {
display: none;
}

/*中身を非表示にしておく*/
.hidden_box .hidden_show {
height: 0;
padding: 0;
overflow: hidden;
opacity: 0;
transition: 0.8s;
text-align: left;
}

/*クリックで中身表示*/
.hidden_box input:checked ~ .hidden_show {
padding: 20px 0;
height: auto;
opacity: 1;
}

.hidden_box-inner input {
margin: 0;
padding: 10px;
display: inline-block;
}
.hidden_box-inner input[type="image"]{
	margin: 0;
	padding: 0;
	width: 8.5%!important;
}
.hidden_box-inner .submit-box {
margin: 0 0 30px 0;
padding: 0 0 0 0;
text-align: center;
}
.hidden_box-inner .submit-box input {
margin: 0;
padding: 15px 0;
font-size: min(1.8vw,18px);
background-color:#fff;
border: 1px solid #000;
width: 50%;
transition: 0.5s;
border-radius: 50vh; /* CSS3 */
 -webkit-border-radius: 50vh; /* Firefox */
 -moz-border-radius: 50vh; /* Safari,Chrome */
}
.hidden_box-inner .submit-box input:hover{
color: #fff;
background-color:#000;
border-radius: 50vh; /* CSS3 */
 -webkit-border-radius: 50vh; /* Firefox */
 -moz-border-radius: 50vh; /* Safari,Chrome */
}

table.jobsearch {
width: 100%;
font-size: min(1.8vw,16px);
margin: 20px 0 50px 0;
padding: 0 0 0 0;
border: none;
border-collapse: collapse;
border-spacing: 0;
border-top: 1px solid #999;
}
table.jobsearch tr{
border-bottom: 1px solid #999;
}
table.jobsearch th {
font-weight: bold;
text-align: left;
padding: 15px 10px;
white-space: nowrap;
vertical-align: middle;
background-color: #efefef;
width: 25%;
}
table.jobsearch td {
text-align: left;
padding: 15px 10px;
white-space: normal;
vertical-align: middle;
}



/* ************************************************ 
*	タブ
* ************************************************ */
/*タブ切り替え全体のスタイル*/
.tabs {
width: 100%;
margin: 0;
display: flex;
flex-wrap: wrap;
justify-content: start;
}

/*タブのスタイル*/
.tab_item,
.tab_item2,
.tab_item3,
.tab_item4 {
width: 150px;
height: 70px;
margin: 0 10px 0 0;
background-color: #fdf5e0;
border-radius: 20px 20px 0 0;
font-size: min(1.6vw,17px);
text-align: center;
color: #796bae;
display: block;
align-content: center;
text-align: center;
font-weight: normal;
transition: all 0.5s ease;
cursor: pointer;
cursor: hand;
}
.tab_item4 {
margin: 0;
}
.tab_item:hover,
.tab_item2:hover,
.tab_item3:hover,
.tab_item4:hover {
color: #fff;
background-color: #796bae;
}

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

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


/*選択されているタブのコンテンツのみを表示*/
#all:checked ~ #all_content,
#kaetsu:checked ~ #kaetsu_content,
#chuetsu:checked ~ #chuetsu_content,
#joetsu:checked ~ #joetsu_content {
  display: block;
}

/*選択されているタブのスタイルを変える*/
.tabs input:checked + .tab_item,
.tabs input:checked + .tab_item2,
.tabs input:checked + .tab_item3,
.tabs input:checked + .tab_item4 {
  background-color: #796bae;
  color: #fff;
}



/* ************************************************ 
*	検索結果リスト
* ************************************************ */
.jobsearch-listbox {
margin: 0 0 30px 0;
padding: 20px;
border: 1px solid #333;
border-radius: 30px; /* CSS3 */
 -webkit-border-radius: 30px; /* Firefox */
 -moz-border-radius: 30px; /* Safari,Chrome */
}
.jobsearch-list-furiganabox {
width: calc(100% - 290px);
margin: 0 0 0 290px;
padding: 0;
align-items: center;
}
.jobsearch-list-furiganabox p{
font-size: min(1.4vw,14px);
font-weight: 400;
margin: 0;
padding: 0;
line-height: 1;
}
.jobsearch-list-titlebox {
  display: flex;
  justify-content: start;
  flex-wrap: wrap;
  width: 100%;
  margin: 0 0 15px 0;
  padding: 0;
font-weight: 500;
align-items: center;
}
.jobsearch-list-titlebox__box1 {
font-size: min(1.4vw,16px);
margin: 0;
line-height: 1;
width: 100px;
}
.jobsearch-list-titlebox__box2 {
font-size: min(1.6vw,18px);
margin: 0 20px 0 0;
line-height: 1;
}
.jobsearch-list-titlebox__box2 a:hover{
text-decoration: none;
}
.jobsearch-list-titlebox__box3 {
width: 150px;
font-size: min(1.2vw,14px);
text-align: center;
margin: 0 20px 0 0;
line-height: 1;
color: #fff;
background-color: #47c2d1;
padding: 8px 10px 10px 10px;
border-radius: 5px; /* CSS3 */
 -webkit-border-radius: 5px; /* Firefox */
 -moz-border-radius: 5px; /* Safari,Chrome */
}
.jobsearch-list-titlebox__box4 {
}
.jobsearch-list-titlebox__box4 img{
width: 55px;
vertical-align: bottom;
}

.jobsearch-list-inner {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  width: 100%;
  margin: 0;
  padding: 0;
}
.jobsearch-list-inner__img {
  width: 25%;
}
.jobsearch-list-inner__detaile {
  width: 72.5%;
}
.jobsearch-list-inner__detaile h3{
  position: relative;
  padding: 0 0 5px 0;
  margin: 0 0 15px 0;
font-size: min(2.1vw,21px);
font-weight: 500;
  display: block;
}
.jobsearch-list-inner__detaile h3::after{
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  content: '';
background-color: #333;
}

.jobsearch-list-inner-tablebox {
  width: 100%;
  margin: 0 0 5px 0;
  padding: 0;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.jobsearch-list-inner-tablebox table.lefttable{
width: 65%;
font-size: min(1.5vw,15px);
}
.jobsearch-list-inner-tablebox table.righttable{
width: 32.5%;
font-size: min(1.5vw,15px);
}
.jobsearch-list-inner-tablebox table.lefttable th{
font-weight: 500;
padding: 3px 10px 3px 0;
white-space: nowrap;
width: 30%;
}
.jobsearch-list-inner-tablebox table.righttable th{
font-weight: 500;
padding: 3px 10px 3px 0;
white-space: nowrap;
width: 55%;
}
.jobsearch-list-inner-tablebox table.lefttable td,
.jobsearch-list-inner-tablebox table.righttable td{
padding: 3px 0;
word-break: break-all;
}

.jobsearch-list-inner-link {
margin: 0;
padding: 0;
text-align:center;
width: 280px;
border-radius: 50vh; /* CSS3 */
 -webkit-border-radius: 50vh; /* Firefox */
 -moz-border-radius: 50vh; /* Safari,Chrome */
}
.jobsearch-list-inner-link a{
color: #000;
font-size: min(1.8vw,16px);
text-decoration: none;
display: block;
padding: 10px 0px;
background-color:#fff;
border: 1px solid #333;
border-radius: 50vh; /* CSS3 */
 -webkit-border-radius: 50vh; /* Firefox */
 -moz-border-radius: 50vh; /* Safari,Chrome */
}
.jobsearch-list-inner-link a:hover{
color: #fff;
background-color:#796bae;
border: 1px solid #796bae;
border-radius: 50vh; /* CSS3 */
 -webkit-border-radius: 50vh; /* Firefox */
 -moz-border-radius: 50vh; /* Safari,Chrome */
}
.jobsearch-list-inner-link a::after{
position:relative;
top: -1px;
right: -10px;
content:"";
display:inline-block;
width:5px;
height:10px;
background:url("../images/arrow.svg") no-repeat;
background-size:contain;
}
.jobsearch-list-inner-link a:hover::after{
position:relative;
top: -1px;
right: -10px;
content:"";
display:inline-block;
width:5px;
height:10px;
background:url("../images/arrow_mo.svg") no-repeat;
background-size:contain;
}

.pager{
margin: 0 auto;
padding: 50px 0;
text-align:center;
}
.list-page-navi{
margin: 0 3px;
padding: 0;
text-align:center;
display: inline-block;
}
.list-page-navi a{
color: #333;
border: 1px solid #333;
font-size: min(2vw,16px);
display: inline-block;
line-height: 1;
padding: 10px 5px 0 5px;
text-decoration:none;
height: 30px;
width: 30px;
border-radius: 50vh; /* CSS3 */
 -webkit-border-radius: 50vh; /* Firefox */
 -moz-border-radius: 50vh; /* Safari,Chrome */
}
.list-page-navi a:hover{
color: #fff;
background-color:#796bae;
border: 1px solid #796bae;
text-decoration:none;
border-radius: 50vh; /* CSS3 */
 -webkit-border-radius: 50vh; /* Firefox */
 -moz-border-radius: 50vh; /* Safari,Chrome */
}


/* ************************************************ 
*   レスポンシブ
* ************************************************ */
/* PC 画面の横幅が960px以上 */
@media only screen and (min-width: 960px){

}

/* Tablet (Portrait) 画面の横幅が768px〜959pxまで */
@media only screen and (min-width: 768px) and (max-width: 959px) {
.topsearch-link-inner { margin: 0 auto 70px auto; }
.tab_item,
.tab_item2,
.tab_item3,
.tab_item4 {
width: 120px;
height: 50px;
margin: 0 5px 0 0;
}

.jobsearch-box {
margin: 100px auto 0 auto;
padding: 70px 0;
}
.jobsearch-listbox {
border-radius: 15px;
-webkit-border-radius: 15px;
-moz-border-radius: 15px;
}
.jobsearch-list-furiganabox {
width: calc(100% - 170px);
margin: 0 0 0 170px;
}
.jobsearch-list-titlebox__box1 {
width: 60px;
}
.jobsearch-list-titlebox__box2 {
margin: 0 10px 0 0;
}
.jobsearch-list-titlebox__box3 {
width: 90px;
margin: 0 10px 0 0;
padding: 7px 5px 7px 5px;
}
.jobsearch-list-titlebox__box4 img{
width: 25px;
}
.jobsearch-list-inner__img {
  width: 20%;
}
.jobsearch-list-inner__detaile {
  width: 77.5%;
}
.jobsearch-list-inner-link { width: 230px; }
.jobsearch-list-inner-link a::after { top: 0; }
.pager { padding: 10px 0; }

}

/* Mobile (Portrait) 画面の横幅が767pxまで */
@media only screen and (max-width: 767px) {
.jobsearch-box {
margin: 70px auto 0 auto;
padding: 50px 0;
}
.topsearch-link-inner { margin: 0 auto 50px auto; }

.top-searchlink {
padding: 25px 0;
font-size: 5vw;
line-height: 1.3;
}
.top-searchlink span{
font-size: 3.5vw;
}
.top-searchlink::before{
top: 5px;
left: -10px;
width:25px;
height:25px;
}
table.jobsearch {
font-size: 4vw;
margin: 20px 0 50px 0;
}
table.jobsearch th {
display: block;
width: calc(100% - 20px);
padding: 10px;
}
table.jobsearch td {
display: block;
width: calc(100% - 20px);
padding: 10px;
overflow: hidden;
}

.hidden_box-inner .submit-box input {
padding: 15px 0;
font-size: 4.5vw;
width: 80%;
}


.tab_item,
.tab_item2,
.tab_item3,
.tab_item4 {
width: 24%;
height: 60px;
margin: 0 1% 0 0;
border-radius: 10px 10px 0 0;
font-size: 4.5vw;
}
.tab_item4 {
margin: 0 0 0 0;
}


.jobsearch-listbox {
border-radius: 15px;
-webkit-border-radius: 15px;
-moz-border-radius: 15px;
}
.jobsearch-list-titlebox__box1 {
width: 100%;
font-size: 3.5vw;
margin: 0 0 10px 0;
}
.jobsearch-list-titlebox__box2 {
width: 100%;
font-size: 4.5vw;
margin: 0 0 10px 0;
line-height: 150%;
}
.jobsearch-list-titlebox__box3 {
font-size: 3.5vw;
margin: 0 15px 0 0;
}
.jobsearch-list-inner__img {
width: 100%;
margin: 0 0 20px 0;
}
.jobsearch-list-furiganabox {
width: 100%;
margin: 15px 0 5px 0;
}
.jobsearch-list-furiganabox p{
font-size:3.5vw;
}

.jobsearch-list-inner__detaile { width: 100%; }
.jobsearch-list-inner__detaile h3 { font-size: 4.5vw; }

.jobsearch-list-inner-tablebox { margin: 0; }
.jobsearch-list-inner-tablebox table.lefttable,
.jobsearch-list-inner-tablebox table.righttable {
width: 100%;
font-size: 4vw;
margin: 0;
}
.jobsearch-list-inner-tablebox table.lefttable th{
width: 50%;
padding: 5px 0;
}
.jobsearch-list-inner-tablebox table.righttable th{
width: 50%;
padding: 5px 0;
}
.jobsearch-list-inner-tablebox table.lefttable td,
.jobsearch-list-inner-tablebox table.righttable td{
padding: 5px 0;
}
.jobsearch-list-inner-link {
width: 100%;
margin: 15px 0 0 0;
}
.jobsearch-list-inner-link a {
font-size: 4vw;
padding: 20px 0px;
}
.jobsearch-list-inner-link a::after {
top: 0;
right: -10px;
width: 6px;
height: 12px;
}
.pager { padding: 20px 0; }
.list-page-navi a {
font-size: 4vw;
padding: 11px 5px 0 5px;
height: 30px;
width: 30px;
}
}
