@charset "utf-8";

/*********************************************
内容       : 共通CSS
ページURL  : https://reas.jp/
作成者     : 田中裕介
追記      : おおで 2016.09.01 1900行〜1931行くらい
*********************************************/

.clearfix:after {
  content: "";
  clear: both;
  display: block;
}

a {
  text-decoration: none;
  border: none;
}
a:link {
  color: #222;
  text-decoration: none;
}
a:visited { color: #222; }
a:hover {
  color: #0099ff;
  text-decoration: underline;
}

.page_content a:link,
.blog_text a:link {
  color: #0099ff;
  text-decoration: none;
}
.page_content a:visited,
.blog_text a:visited { color: #0099ff; }
.page_content a:hover,
.blog_text a:hover {
  color: #0099ff;
  text-decoration: underline;
}



.page_content .blog_tit a:link {
  color: #222;
  text-decoration: none;
}
.page_content .blog_tit a:visited { color: #222; }
.page_content .blog_tit a:hover {
  color: #0099ff;
  text-decoration: underline;
}

.page_content .top_cat a {
  color: #fff;
  text-decoration: none;
  border: none;
}
.page_content .top_cat a:visited { color: #fff; }
.page_content .top_cat a:hover {
  color: #0099ff;
  text-decoration: underline;
}

.page_content .top_blog_date a {	color: #999;}
.page_content .top_blog_date a:visited { color: #999;}
.page_content .top_blog_date a:hover {
  color: #0099ff;
  text-decoration: underline;
}

h1, h2, h3, h4, h5, h6 {
  font-size: 100%;
  font-weight: normal;
}

h1.logo,
p.logo {
  width: 180px;
  height: 110px;
  margin: 0 35px;
  background: url(../images/common/logo.png?250515) no-repeat;
  text-indent: -9999px;
}
h1.logo a,
p.logo a {
  display: block;
  overflow: hidden;
  width: 180px;
  height: 110px;
}

.page_title,
.page_title.is_blog,
h2.top_info {
  font-family: "????????????�???? Pro","Hiragino Kaku Gothic Pro";
  font-size: 38px;
  font-weight: bold;
  letter-spacing: 5px;
  text-align: center;
}
.accessmap h1.page_title { font-size: 26px;}
.page_title.is_blog,
.page-template-page h1.page_title,
.page-template-archive-staff h1.page_title,
.post-type-archive-staff h1.page_title,
.tax-staff_cat h1.page_title,
.page-template-archive-event h1.page_title,
.post-type-archive-news h1.page_title,
.single-news h1.page_title,
.tax-news_cat h1.page_title,
.page-template-archive-welfare h1.page_title,
.page-template-archive-approach_to_society h1.page_title,
.single-approach_to_society h1.page_title,
.tax-welfare_cat h1.page_title {
  position: absolute;
  top: 40%;
  z-index: 100;
  padding-left: 4%;
  font-size: 48px;
  display: inline-block;
  letter-spacing: 2px;
  line-height: 56px;
  filter: dropshadow(color=#fff,offX= 0,offY=-1) dropshadow(color=#fff,offX= 1,offY= 0) dropshadow(color=#fff,offX= 0,offY= 1) dropshadow(color=#fff,offX=-1,offY= 0);
  -webkit-text-stroke-color: #222;
  -webkit-text-stroke-width: 0px;
  text-shadow: #FFF 1px 1px 5px, #fff -1px 1px 5px, #FFF 1px -1px 5px, #fff 1px 1px 6px;
  text-align: left;
}
.term-disaster_support h1.page_title,
.tax_disaster_support h1.page_title {
  position: absolute;
  top: 30%;
  z-index: 100;
  padding-left: 4%;
  font-size: 48px;
  display: inline-block;
  letter-spacing: 2px;
  line-height: 50px;
  text-align: left;
  filter: dropshadow(color=#fff,offX= 0,offY=-1) dropshadow(color=#fff,offX= 1,offY= 0) dropshadow(color=#fff,offX= 0,offY= 1) dropshadow(color=#fff,offX=-1,offY= 0);
  -webkit-text-stroke-color: #222;
  -webkit-text-stroke-width: 0px;
  text-shadow: #FFF 1px 1px 5px, #fff -1px 1px 5px, #FFF 1px -1px 5px, #fff 1px 1px 6px;
}
.page_title.is_blog span {
  line-height: 2;
  font-size: 15px;
}
.page_title.is_blog span br { display: none;}

.page_title.is_blog:after,
.page-template-page h1.page_title:after,
.page-template-archive-staff h1.page_title:after,
.post-type-archive-staff h1.page_title:after,
.tax-staff_cat h1.page_title:after,
.page-template-archive-event h1.page_title:after,
.single-news h1.page_title:after,
.post-type-archive-news h1.page_title:after,
.tax-news_cat h1.page_title:after,
.page-template-archive-welfare h1.page_title:after,
.tax-welfare_cat h1.page_title:after,
.page-template-archive-approach_to_society h1.page_title:after,
.term-disaster_support h1.page_title:after,
.single-approach_to_society h1.page_title:after,
.tax_disaster_support h1.page_title:after {
  content:"";
  display: block;
  margin-top: 15px;
  height:1px;
  width:100%;
  background: -moz-linear-gradient(left 45deg, green, yellow, orange, red, indigo, blue);
  background: -webkit-gradient(linear, left top, right bottom, from(green), color-stop(0.2, yellow), color-stop(0.3, orange), color-stop(0.5, red), color-stop(0.7, indigo), color-stop(0.8, blue));
}

.greeting h1 {
  position: static;
  top: 0;
  z-index: 100;
  padding-left: 0;
  font-size: 48px;
  display: inline-block;
  letter-spacing: 4px;
  line-height: 20px;
  filter: none;
  -webkit-text-stroke-color: #222;
  -webkit-text-stroke-width: 0px;
  text-shadow: none;
}

h3 {
  padding-bottom: 10px;
  font-family: "????????????�???? Pro","Hiragino Kaku Gothic Pro";
  font-size: 28px;
  font-weight: bold;
}

.history h4 {
  margin-bottom: 15px;
  padding: 5px 0 5px 15px;
  background: #404040;
  color: #fff;
  font-family: "????????????�???? Pro","Hiragino Kaku Gothic Pro";
  font-size: 23px;
  font-weight: bold;
}

h5 {
  margin-bottom: 10px;
  font-size: 18px;
  font-weight: bold;
  border-bottom: 1px solid #848484;
}

.nav-livede55 h5 {
  border-bottom: none;
  margin-bottom: 5px;
}

body {
  margin: 0;
  padding: 0;
  background: #f2f2f2;
  color: #222;
  font-family: "????????????�???? ProN W3", "Hiragino Kaku Gothic ProN", "??��?��?????", Meiryo, sans-serif;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
  font-size: 16px;
  line-height: 1.4;
}

.editor-area a {
  color: #0099ff;
  text-decoration: none;
}
.editor-area h2 {
  margin-top: 30px;
  font-size: 23px;
  font-weight: bold;
}
.editor-area li {
  list-style: disc;
  margin-left: 20px;
}
.editor-area .wp-caption-dd {
  font-size: 80%;
  color: #999;
}

.sp_img img { display: none;}

/*-----------------------
グローバルナビゲーション
-----------------------*/
.gnav li.nav_home i.fa-fw::before {content: "\f015";}
.gnav li.nav_news i.fa-fw::before {content: "\f1ea";}
.gnav li.nav_company i.fa-fw::before {content: "\f1ad";}
.gnav li.nav_service i.fa-fw::before {content: "\f108";}
.gnav li.nav_governance i.fa-fw::before {font-family: 'Font Awesome 5 Brands'; content: "\f184";}
.gnav li.nav_recruit i.fa-fw::before {content: "\f234";}
.gnav li.nav_blog i.fa-fw::before {content: "\f15c";}
.gnav li.nav_contact i.fa-fw::before {content: "\f0e0";}

.gnav li a i.fr {display: none; content: none;}

.gnav li .nav_sub a i{display: none;}
.gnav li .nav_sub a i.fr{display: block;}
.gnav li .nav_sub a i.fr::before{content: "\f105";}
/*-----------------------
各ページサムネイル
-----------------------*/

.page_thumbnail { position: relative;}

.page-template-archive .page_thumbnail,
.single-post .page_thumbnail,
.category .page_thumbnail {
  position: relative;
  height: 420px;
  margin-bottom: 50px;
  background-size: cover;
}

.post-type-archive-blog_engineer .page_thumbnail,
.single-blog_engineer .page_thumbnail,
.tax-engineer_cat .page_thumbnail {
  position: relative;
  height: 420px;
  margin-bottom: 50px;
  background: url(../images/blog/blog_engineer_bg.jpg) top center no-repeat;
  background-size: cover;
}

.post-type-archive-blog_human_resources .page_thumbnail,
.single-blog_human_resources .page_thumbnail,
.tax-human_resources_cat .page_thumbnail,
.post-type-archive-blog_connect .page_thumbnail,
.single-blog_connect .page_thumbnail,
.tax-connect_cat .page_thumbnail {
  position: relative;
  height: 420px;
  margin-bottom: 50px;
  background: url(../images/blog/blog_human_resources_bg.jpg) top center no-repeat;
  background-size: cover;
}

.post-type-archive-blog_designer .page_thumbnail,
.single-blog_designer .page_thumbnail,
.tax-designer_cat .page_thumbnail {
  position: relative;
  height: 380px;
  margin-bottom: 50px;
  background: url(../images/blog/blog_designer_bg.jpg) top center no-repeat;
  background-size: cover;
}

.post-type-archive-blog_hr .page_thumbnail,
.single-blog_hr .page_thumbnail,
.tax-hr_cat .page_thumbnail {
  position: relative;
  height: 420px;
  margin-bottom: 50px;
  background: url(../images/blog/blog_hr_bg02.jpg) top center no-repeat;
  background-size: cover;
}

.post-type-archive-blog_24 .page_thumbnail,
.single-blog_24 .page_thumbnail,
.tax-24_cat .page_thumbnail {
  position: relative;
  height: 380px;
  margin-bottom: 50px;
  background: url(../images/blog/thumb_monitoring.jpg) top center no-repeat;
  background-size: cover;
}

.post-type-archive-blog_director .page_thumbnail,
.single-blog_director .page_thumbnail,
.tax-director_cat .page_thumbnail {
  position: relative;
  height: 420px;
  margin-bottom: 50px;
  background: url(../images/blog/thumb_director.jpg) top center no-repeat;
  background-size: cover;
}

.post-type-archive-news .page_thumbnail,
.single-news .page_thumbnail,
.tax-news_cat .page_thumbnail {
  position: relative;
  height: 380px;
  margin-bottom: 50px;
  background: url(../images/blog/thumb_inq.jpg) top center no-repeat;
  background-size: cover;
}

.tax-approach_to_society_cat .page_thumbnail,
.tax_disaster_support .page_thumbnail {
  position: relative;
  height: 380px;
  margin-bottom: 50px;
  background: url(../images/blog/thumb_inq.jpg) top center no-repeat;
  background-size: cover;
}

.page-template-archive-approach_to_society .page_thumbnail,
.single-approach_to_society .page_thumbnail {
  position: relative;
  height: 380px;
  margin-bottom: 50px;
  background: url(../images/blog/thumb_inq.jpg) top center no-repeat;
  background-size: cover;
}

.page_massage:hover{ margin-bottom: 0px;}

.page_massage iframe{
  position: absolute;
  width: 100%;
  height: 100%;
}

.page-template .page_thumbnail {
  position: relative;
  height: 420px;
  margin-bottom: 50px;
  background-size: cover;
  background-position: center;
}

.archive_title { padding: 0 20px;}

.archive_title img {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  max-width:852px;
  max-height:272px;
  width:100%;
  height:auto;
}

.blog_engineer_title { padding: 0 20px;}

.blog_engineer_title img {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  max-width:700px;
  max-height:152px;
  width:100%;
  height:auto;
}

.blog_designer_title { padding: 0 20px;}

.blog_designer_title img {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  max-width:700px;
  max-height:152px;
  width:100%;
  height:auto;
}

/*-----------------------
パンクズ
-----------------------*/

#breadcrumb span { font-size:14px;}
#breadcrumb br { display: none;}

.breadcrumb-lists li { float: left;}

.page-template-archive #breadcrumb,
.single-post #breadcrumb,
.category #breadcrumb,
.post-type-archive-blog_developer #breadcrumb,
.single-blog_developer #breadcrumb,
.tax-developer_cat #breadcrumb,
.post-type-archive-blog_human_resources #breadcrumb,
.single-blog_human_resources #breadcrumb,
.tax-human_resources_cat #breadcrumb,
.post-type-archive-blog_human_resources #breadcrumb,
.post-type-archive-blog_designer #breadcrumb,
.single-blog_designer #breadcrumb,
.tax-designer_cat #breadcrumb,
.post-type-archive-blog_engineer #breadcrumb,
.single-blog_engineer #breadcrumb,
.tax-engineer_cat #breadcrumb,
.post-type-archive-blog_hr #breadcrumb,
.single-blog_hr #breadcrumb,
.tax-hr_cat #breadcrumb,
.post-type-archive-blog_connect #breadcrumb,
.single-blog_connect #breadcrumb,
.tax-connect_cat #breadcrumb,
.post-type-archive-blog_24 #breadcrumb,
.single-blog_24 #breadcrumb,
.tax-24_cat #breadcrumb,
.post-type-archive-blog_director #breadcrumb,
.single-blog_director #breadcrumb,
.tax-director_cat #breadcrumb {
  display: block;
  position: absolute;
  bottom: -15px;
  z-index: 100;
  padding: 5px 1% 5px 4%;
  background: #3f9eff;
}

.nav-company-child #breadcrumb,
.nav-infringement #breadcrumb,
.nav-send-infringement #breadcrumb,
.nav-privacypolicy #breadcrumb,
.nav-ceo #breadcrumb,
.nav-coo #breadcrumb {
  display: block;
  position: absolute;
  bottom: -15px;
  z-index: 100;
  padding: 5px 1% 5px 4%;
  background: #ffe400;
}

.nav-service-child #breadcrumb {
  display: block;
  position: absolute;
  bottom: -15px;
  z-index: 100;
  padding: 5px 1% 5px 4%;
  background: #ffb11a;
}

.nav-governance-child #breadcrumb {
  display: block;
  position: absolute;
  bottom: -15px;
  z-index: 100;
  padding: 5px 1% 5px 4%;
  background: #ff6666;
}

.nav-recruit-child #breadcrumb,
.nav-backend-engineer #breadcrumb,
.nav-serverside-engineer #breadcrumb,
.nav-ios_app-engineer #breadcrumb,
.post-type-archive-staff #breadcrumb,
.post-type-archive-welfare #breadcrumb,
.nav-job01a #breadcrumb,
.nav-job01b #breadcrumb,
.nav-job02 #breadcrumb,
.nav-job03 #breadcrumb,
.nav-job04 #breadcrumb,
.nav-job05 #breadcrumb,
.nav-job06 #breadcrumb,
.nav-job07 #breadcrumb,
.nav-job08 #breadcrumb,
.nav-job08b #breadcrumb,
.nav-job08c #breadcrumb,
.nav-job08d #breadcrumb,
.nav-job09b #breadcrumb,
.nav-internship-php #breadcrumb,
.nav-internship-java #breadcrumb,
.nav-supportstaff #breadcrumb,
.nav-job10 #breadcrumb,
.tax-staff_cat #breadcrumb,
.tax-welfare_cat #breadcrumb,
.tax_disaster_support #breadcrumb,
.term-disaster_support #breadcrumb,
.single-approach_to_society #breadcrumb,
.nav-parttime-php-engineer #breadcrumb,
.nav-insede-sales #breadcrumb {
  display: block;
  position: absolute;
  bottom: -15px;
  z-index: 100;
  padding: 5px 1% 5px 4%;
  background: #ff64a6;
}
.nav-employee_data #breadcrumb,
.nav-workstyle_office #breadcrumb {
  display: block;
  position: inherit;
  bottom: 0;
  z-index: 100;
  padding: 0;
  background: none;
}

.nav-contact-child #breadcrumb {
  display: block;
  position: absolute;
  bottom: -15px;
  z-index: 100;
  padding: 5px 1% 5px 4%;
  background: #4ad4e9;
}

.single-staff #breadcrumb {
  display: block;
  position: absolute;
  bottom: -15px;
  z-index: 100;
  padding: 5px 1% 5px 4%;
  color: #fff;
  background: #141216;
}

.single-staff .post,
.single-staff .home { color: #fff;}

.post-type-archive-news #breadcrumb,
.single-news #breadcrumb,
.tax-news_cat #breadcrumb {
  display: block;
  position: absolute;
  bottom: -15px;
  z-index: 100;
  padding: 5px 1% 5px 4%;
  background: #aee800;
}

/*-----------------------
ページナビ
-----------------------*/

.wp-pagenavi {
  clear: both;
  padding: 20px 0;
  text-align: center;
}
.wp-pagenavi a,
.wp-pagenavi span {
  text-decoration: none;
  border: 1px solid #141216;
  padding: 5px 10px;
  margin: 2px;
}
.wp-pagenavi a:hover,
.wp-pagenavi span.current {
  border-color: #141216;
  background: #141216;
  color: #fff;
}

/*-----------------------
フッター
-----------------------*/

footer a:link {
  color: #b8b1bd;
  text-decoration: none;
}
footer a:visited { color: #b8b1bd; }
footer a:hover {
  color: #0099ff;
  text-decoration: underline;
}

footer {
  position: relative;
  margin: 0 0 0 255px;
  padding: 20px 0 30px;
  /*height: 90px;*/
  background: #141216;
  color: #b8b1bd;
  font-size: 12px;
}

footer .fa { display:none;}

.footer_nav {
  max-width: 970px;
  width: auto;
  margin: 0 0 0 20px;
}

.footer_link { padding: 20px 0 0 0;}
.footer_link ul { padding: 0 0 10px;}
.footer_link li {
  float: left;
  padding-right: 20px;
}
.footer_link li:last-child { padding-right: 0;}

.footer_logo {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  margin-top: 20px;
  width: 154px;
  height: 62px;
  background: url(../images/common/footer_logo.png?250515) no-repeat;
  text-indent: -9999px;
}
.footer_logo a {
  display: block;
  overflow: hidden;
  width: 154px;
  height: 62px;
}

.copyright {
  margin: 0;
  padding-top: 10px;
  text-align: left;
}

.footer_copyright {
  position: relative;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
  height: 80px;
  padding-left: 180px;
  border-top: 1px solid #323232;
  line-height: 80px;

}

/*------- top ------*/

.home .main { margin: 0 0 50px 255px;}

.main {
  margin: 0 0 0 255px;
  letter-spacing: 1.5px;
}
.main.company {	background-color: #ffe400;}
.main.service {	background-color: #ffb11a;}
.main.governance { background-color: #ff6666;}
.main.recruit,
.main.employee_data,
.main.workstyle_office {	background-color: #ff64a6;}
.main.blog { background-color: #3f9eff;}
.main.contact {	background-color: #4ad4e9;}

.top_slide {
  position: relative;
  overflow: hidden;
  width: 100%;
  min-height: 720px;
  height: auto;
  background: #141216;
}
.top_slide p { color:#FFF;}

video.bgvid {
  position:absolute;
  min-width: 100%;
  min-height: 100%;
  width: auto;
  height: auto;
  z-index: -100;
  background: url(../images/index/reasmovie_20201027_fix.jpg) no-repeat;
}

.toptitle {
  font-family: "????????????�???? Pro","Hiragino Kaku Gothic Pro";
  font-size: clamp(1.75rem, 5vw, 4.375rem);
  font-weight: bold;
  text-align: center;
  color: #fff;
  letter-spacing: 2px;
  filter: dropshadow(color=#666,offX= 0,offY=-1) dropshadow(color=#666,offX= 1,offY= 0) dropshadow(color=#666,offX= 0,offY= 1) dropshadow(color=#666,offX=-1,offY= 0);
  -webkit-text-stroke-color: #666;
  -webkit-text-stroke-width: 0px;
  text-shadow: #666 1px 1px 3px, #666 -1px 1px 3px, #666 1px -1px 3px, #666 1px 1px 3px;
}
.toptitle br { display: none;}

.toptext {
  padding: 0 30px;
  text-align: center;
  font-size: clamp(0.875rem, 3vw, 1.125rem);
  color: #fff;
  filter: dropshadow(color=#666,offX= 0,offY=-1) dropshadow(color=#666,offX= 1,offY= 0) dropshadow(color=#666,offX= 0,offY= 1) dropshadow(color=#666,offX=-1,offY= 0);
  -webkit-text-stroke-color: #666;
  -webkit-text-stroke-width: 0px;
  text-shadow: #666 1px 1px 3px, #666 -1px 1px 3px, #666 1px -1px 3px, #666 1px 1px 3px;
}

.hero {
  position: relative;
  width: 100%;
  height: 100vh;
  overflow: hidden;
  aspect-ratio: 16 / 9;
}
.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: #000;
  opacity: 0.15;
  mix-blend-mode: multiply;
  z-index: 2;
  pointer-events: none;
}
.hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background: #fff;
  opacity: 0.15;
  mix-blend-mode: overlay;
  z-index: 2;
  pointer-events: none;
}

/* スライド */
.slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  opacity: 0;
  transform: scale(1.2); /* 初期ズーム */
  transition: opacity 0.8s ease, transform 2.5s ease; /* フェード + ズーム */
  z-index: 0;
}

.slide.active {
  opacity: 1;
  transform: scale(1); /* ズームアウト */
  z-index: 1;
}

/* 半透明オーバーレイで文字を読みやすく */
.overlay {
  /* position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.3);
  z-index: 1; */
}

/* 白フラッシュ */
.fade-overlay {
  position: absolute;
  inset: 0;
  background: rgba(255, 255, 255, 0.8); /* 半透明白 */
  opacity: 0;
  z-index: 5;
  pointer-events: none;
  transition: opacity 0.3s ease-in-out;
  filter: blur(8px); /* ふんわり感 */
}

.top-slide-text {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  z-index: 10;
  color: #fff;
  text-align: center;
}

.top-slide-list-item {
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  filter: opacity(0.9);
  height: 100vh!important;
  margin: 0;
}

@keyframes zoomIn {
  0% {
    transform: scale(1.2);
  }
  100% {
    transform: scale(1); /* 拡大率 */
  }
}
.add-animation {
  animation: zoomIn 3s ease 0s normal both;
}

.slick-slide img {
  filter: opacity(0.7);
}

.content { padding: 70px 4%;}
.top_news { padding: 70px 0;}

.page_content,
.staff_single {
  padding: 70px 4% 100px;
  margin: 0 auto;
  max-width: 1050px;
  width: auto;
}

.page_content a {
  color: #0099ff;
  text-decoration: none;
  border: none;
}

.border,
.border02 {
  display: inline-block;
  margin-top: -15px;
  text-align:center;
  letter-spacing: 4px;
}
.border:before	{
  content:"";
  display: inline-block;
  height:1px;
  width:100%;
  background: -moz-linear-gradient(left 45deg, green, yellow, orange, red, indigo, blue);
  background: -webkit-gradient(linear, left top, right bottom, from(green), color-stop(0.2, yellow), color-stop(0.3, orange), color-stop(0.5, red), color-stop(0.7, indigo), color-stop(0.8, blue));
}
.border02:before	{
  content:"";
  display: inline-block;
  height:1px;
  width:100%;
  background: rgba(255,255,255,0.6);
}

.top_list,
.camp_list {
  padding: 70px 0 50px;
  max-width: 1050px;
  width: 100%;
  margin: 0 auto;
}

.page .top_list { padding: 20px 0 0;}

.nav_list {
  padding: 70px 0 50px;
  max-width: 1050px;
  width: 100%;
  margin: 0 auto;
  font-size: 14px;
  text-align: center;
}

.top_list .top_list_block,
.camp_list .camp_list_block,
.nav_list .nav_list_block{
  position: relative;
  background: #fff;
  float:left;
  width: 330px;
  height: 365px;
  margin: 0px 30px 30px 0px;
  box-shadow: 7px 7px 10px -6px #404040;
}
.top_list .top_list_block:nth-child(3n),
.camp_list .camp_list_block:nth-child(3n),
.nav_list .nav_list_block:nth-child(3n) { margin: 0px 0 30px 0px;}

.scale_img {
  width: 330px;
  height: 230px;
  overflow: hidden;
}

.scale_img img {
  -moz-transition: -moz-transform 0.5s linear;
  -webkit-transition: -webkit-transform 0.5s linear;
  -o-transition: -o-transform 0.5s linear;
  -ms-transition: -ms-transform 0.5s linear;
  transition: transform 0.5s linear;
}
.scale_img img:hover {
  -webkit-transform: scale(1.2);
  -moz-transform: scale(1.2);
  -o-transform: scale(1.2);
  -ms-transform: scale(1.2);
  transform: scale(1.2);
}

.top_cat {
  position: absolute;
  bottom:	140px;
  right: 5px;
  width: 250px;
  color: #fff;
  font-size: 12px;
}
.top_cat li {
  padding: 5px;
  margin: 3px 0 0 3px;
  float:right;
  background: rgba(20,18,22,0.75);
}
.top_cat a {
  color: #fff;
  text-decoration: none;
  border: none;
}

.top_cat a:visited { color: #fff; }
.top_cat a:hover {
  color: #0099ff;
  text-decoration: underline;
}

.staff_ico {
  position:absolute;
  z-index:100;
  bottom: 100px;
  left: 10px;
}
.staff_ico img {
  width:56px;
  height:auto;
  border: solid 3px #fff;
  border-radius: 120px;
}

.top_blog { background:#3f9eff;}
/*.top_blog > .content { padding: 70px 4% 0;}*/

.blog_tit {
  padding: 25px 20px 15px;
  font-family: "????????????�???? Pro","Hiragino Kaku Gothic Pro";
  font-size: 16px;
  font-weight: bold;
  letter-spacing: 1px;
}

.top_blog_date {
  padding: 5px 0 0 85px;
  color: #999;
  font-size:12px;
  letter-spacing: 1px;
}
.top_blog_date a {	color: #999;}
.top_blog_date a:visited { color: #999;}
.top_blog_date a:hover {
  color: #0099ff;
  text-decoration: underline;
}

.top_company {
  background: url(../images/index/company_bg.jpg) top center repeat-x;
  height: 664px;
  padding: 70px 0;
  font-size: 14px;
  letter-spacing: 1px;
  text-align: center;
}

.top_company .content,
.top_service .content,
.top_recruit .content{ padding: 0 4%;}

h3.top_company_tit,
h3.nav_list_tit {
  padding: 10px 10px 5px;
  font-family: "????????????�???? Pro","Hiragino Kaku Gothic Pro";
  font-size: 20px;
  font-weight: bold;
}

.top_company_text,
.nav_list_text { padding: 0 20px;}

.top_service {
  background: -webkit-gradient(linear, left top, left bottom, color-stop(1.00, #fff), color-stop(0.00, #f2f2f2));
  background: -webkit-linear-gradient(#f2f2f2, #fff);
  background: -moz-linear-gradient(#f2f2f2, #fff);
  background: -o-linear-gradient(#f2f2f2, #fff);
  background: -ms-linear-gradient(#f2f2f2, #fff);
  background: linear-gradient(#f2f2f2, #fff);
  padding: 70px 4%;
  text-align: center;
}

.service_img { padding: 50px 0;}
.service_img img {
  max-width: 990px;
  width: 100%;
  height: auto;
}

.top_recruit {
  background: url(../images/index/recruit_bg.jpg) top center no-repeat;
  background-size: cover;
  height: auto;
  padding: 100px 4% 40px;
  text-align: center;
}

.accessmap { padding-top: 70px;}

#map-canvas {
  width: 100%;
  height: 650px;
  margin-top: 70px;
}
.page_content > #map-canvas {
  margin-top: 0;
  margin-bottom: 30px;
}


.dn { display:none;}

/*-----------------------
ブログページ
-----------------------*/

.blog_title {
  font-family: "????????????�???? Pro", "Hiragino Kaku Gothic Pro";
  margin-bottom: 10px;
  padding-bottom: 10px;
  font-size: 28px;
  font-weight: bold;
  border-bottom: 1px solid #3f9eff;
}

.blog_date {
  padding-bottom: 20px;
  font-size: 14px;
  color: #999;
}
.blog_right .blog_date {
  padding-bottom: 0px;
}

.blog_inner {
  max-width: 1100px;
  margin: 0 auto 50px;
}

.blog_left {
  width: 735px;
  float: left;
}

.blog_right {
  width: 260px;
  float: right;
  font-size: 14px;
}
.blog_right h4 {
  padding-bottom: 15px;
  font-family: "????????????�???? Pro","Hiragino Kaku Gothic Pro";
  font-size: 18px;
  font-weight: bold;
  letter-spacing: 1px;
}
.blog_right ul { padding-bottom: 30px;}
.blog_right li { padding-bottom: 10px;}

.blog_cont {
  background: #fff;
  padding: 30px;
  margin-bottom: 40px;
  box-shadow: 7px 7px 10px -6px #acacac;
  word-wrap: break-word;
}

.blog_cont img.attachment-post-thumbnail {
  width: 100%;
  height: auto;
  padding-bottom: 10px;
}

.blog_nav { padding-top: 40px;}

.page-template-archive .blog_nav,
.post-type-archive-blog_human_resources .blog_nav,
.post-type-archive-blog_designer .blog_nav { padding-top: 50px;}
.blog_nav .staff_ico {
  position: static;
  z-index:0;
  bottom: 0;
  left: 0;
  float: left;
}
.blog_nav .staff_ico img {
  width:56px;
  height:auto;
  border: 0;
  border-radius: 120px;
}

.navPage{
  overflow: hidden;
  margin: 0 0 50px;
  padding-left: 0;
  list-style: none;
  font-size: 12px;
}

.navPage a{
  display: block;
  float: left;
  padding: 5px;
  border:1px solid #222;
}
.news-single .navPage a { padding: 20px;}

.navPage .prev {	float: left;}
.navPage .next {	float: right;}

.navPage .prev img {
  float: right;
  border:1px solid #222;
}
.navPage .prev span {
  float: left;
  padding: 23px 5px 23px 0;
}

.navPage .next img {
  float: left;
  border:1px solid #222;
}
.navPage .next span {
  float: right;
  padding: 23px 0 23px 5px;
}


.page_navi {
  overflow: hidden;
  margin: 0 auto 50px;
  padding-left: 0;
  list-style: none;
  font-size: 14px;
}

.page_navi li {	width: 30%;}
.page_navi a{
  display: block;
  padding: 5px;
  text-align: center;
  border:1px solid #222;
}
.page_navi .prev {	float: left;}
.page_navi .next {	float: right;}
.page_navi img {
  margin-bottom: 5px;
  width:100%;
  height: auto;
}

.blog_text {
  padding-top: 20px;
  line-height: 1.7;
}

.blog_text h2 {
  margin: 30px 0 24px;
  padding-bottom: 8px;
  font-size: 24px;
  font-weight: bold;
  border-bottom: 1px solid #cccccc;
  line-height: 1.4;
}
.blog_text h3 {
	margin: 24px 0 16px;
	padding: 5px 15px;
	font-size: 20px;
	border-left: solid 6px #cccccc;
	border-bottom: none;
	line-height: 1;
}

.blog_text img,
.news-single img {
  padding: 15px 0;
  max-width: 100%;
  width: auto;
  height: auto;
}
.blog_text li {
  list-style: disc;
  margin-left: 20px;
}

.blog_text > .wp-caption img {
  padding: 15px 0 5px;
}

.video-container {
  max-width:100%;
}

.video {
  position: relative;
  padding-bottom: 56.25%;
  padding-top: 30px;
  overflow: hidden;
  max-width: 100%;
  height: auto;
}

.video iframe,
.video object,
.video embed {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.wp-caption-text {
  font-size: 80%;
  color: #999;
}

.quotation {
  padding: 2%;
  background: #e1e1e1;
  font-style: italic;
}
.quotation:before {	content: "���?";}
.quotation:after { content: "���?";}

.blog-talk {
  display: block;
  position: relative;
  margin: 48px 0 72px;
  padding: 20px 0 0 110px;
}
.blog-talk-image {
  position: absolute;
  top: 0;
  left: 0;
  margin: 0 20px 0 0;
  width: 64px;
  height: 64px;
  border: 3px #F781BE solid;
  border-radius: 50%;
}
.blog-talk-image.is_blue { border: 3px #099cdc solid;}
.blog-talk-image img {
  padding: 0;
  width: 100%;
  height: auto;
  border-radius: 50%;
}

#toc_container { margin-top: 1em;}

/*-----------------------
社員紹介
-----------------------*/

.page-template-archive-staff .page_thumbnail,
.post-type-archive-staff .page_thumbnail,
.tax-staff_cat .page_thumbnail,
.page-template-archive-welfare .page_thumbnail,
.post-type-archive-welfare .page_thumbnail,
.tax-welfare_cat .page_thumbnail {
  position: relative;
  height: 420px;
  margin-bottom: 50px;
  background: url(https://reas.jp/wordpress/wp-content/uploads/2016/03/IMG_9291.jpg) top center no-repeat;
  background-size: cover;
}

.staff_list {
  padding: 70px 0 50px;
  max-width: 1050px;
  width: 100%;
  margin: 0 auto;
}

.staff_list a:link { color:#222;}
.staff_list a:visited { color:#222;}
.staff_list a:hover { color:#0099ff;}

.staff_list .staff_list_block {
  background: #fff;
  float: left;
  width: 330px;
  height: 365px;
  margin: 0px 30px 30px 0px;
  box-shadow: 7px 7px 10px -6px #404040;
}
.staff_list .staff_list_block:nth-child(3n) { margin: 0px 0 30px 0px;}

h3.staff_list_tit {
  padding: 15px 20px 10px;
  font-family: "????????????�???? Pro","Hiragino Kaku Gothic Pro";
  font-size: 20px;
  font-weight: bold;
  letter-spacing: 1px;
}

.staff_list_text {
  padding: 0 20px 5px;
}

.single-staff .page_thumbnail {
  position: relative;
  padding-bottom: 0;
  margin-bottom: 50px;
}

.single-staff h1 {
  text-align: left;
  font-size: 32px;
  letter-spacing: 1px;
}

.single-staff .border {
  display: inherit;
  padding-bottom: 20px;
  text-align: left;
}

.single-staff .border:before {
  display: inline-block;
}

.single_staff_prof {
  position: relative;
  float: left;
  width: 50%;
  height: 500px;
  background-color: #ff64a6;
}

.single-staff .staff_thumbnail {
  float: right;
  width: 50%;
  height: 500px;
  background-size: cover;
  background-position: center top;
}

.staff_prof_block {
  position: absolute;
  top: 30%;
  width: 60%;
  padding-left: 8%;
}

.size-staff_img01 {
  max-width: 460px;
  width: 100%;
  height: auto;
}

.size-staff_img02 {
  width: 100%;
  height: auto;
}

.staff-application-list-title {
  padding-bottom: 16px;
  font-size: 24px;
  text-align:center;
  letter-spacing:1em;
  text-indent:1em;
}
.staff-application-list {
  margin: auto;
  width: 620px;
}
.staff-application-list-item {
  float: left;
  margin: 0 0 20px 0;
}
.staff-application-list-item:nth-child(even) {
  margin: 0 0 20px 20px;
}
.staff-application-list-item-btn {
  display: inline-block;
  box-sizing: border-box;
  position: relative;
  width:300px;
  margin: 0 auto;
  z-index: 2;
  background-color: transparent;
  border: 1px solid #222;
  color: #222;
  text-align:center;
  letter-spacing: 0;
  line-height: 50px;
  overflow: hidden;
  text-decoration:none;
}
.staff-application-list-item-btn::before,
.staff-application-list-item-btn::after {
  position: absolute;
  z-index: -1;
  display: block;
  content: '';
}
.staff-application-list-item-btn,
.staff-application-list-item-btn::before,
.staff-application-list-item-btn::after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-transition: all .2s;
  transition: all .2s;
}
.staff-application-list-item-btn:hover {
  color: #fff;
  text-decoration: none;
}
.staff-application-list-item-btn::after {
  top: -100%;
  width: 100%;
  height: 100%;
}
.staff-application-list-item-btn:hover::after {
  top: 0;
  background-color: #222;
}

/*-----------------------
  社内イベント
-----------------------*/

.page-template-archive-event .page_thumbnail {
  position: relative;
  height: 420px;
  margin-bottom: 50px;
  background: url(../images/staff/staff_bg.jpg) top center no-repeat;
  background-size: cover;
}

/*-----------------------
ツイートボタン
-----------------------*/

.btn_tweet {
  float:left;
  margin: 10px 15px;
}
.btn_tweet a {
  position: relative;
  display: block;
  float: left;
  width: 90px;
  height: 40px;
  background: #00abf0;
  color: #fff !important;
  font-size: 15px;
  text-decoration: none;
  text-align:center;
  line-height: 40px;
  border-radius: 6px;
}
.btn_tweet i {
  position: absolute;
  top: 0;
  left: 0;
  margin: 0;
  width: 90px;
  height: 40px;
  line-height: 40px;
  text-align: center;
  border-radius: 6px;
}
.btn_tweet i:before { padding :0; line-height: 40px; }
.btn_tweet a:hover i {
  background: #51c3f1;
  -webkit-transition: all .2s;
  transition: all .2s;
}

.btn_fb {
  float:left;
  margin: 10px 0;
}
.btn_fb a {
  position: relative;
  display: block;
  float: left;
  width: 90px;
  height: 40px;
  background: #3a579a;
  color: #fff !important;
  font-size: 15px;
  text-decoration: none;
  text-align:center;
  line-height: 40px;
  border-radius: 6px;
}
.btn_fb i {
  position: absolute;
  top: 0;
  left: 0;
  margin: 0;
  width: 90px;
  height: 40px;
  line-height: 40px;
  text-align: center;
  border-radius: 6px;
}
.btn_fb i:before { padding :0; line-height: 40px; }
.btn_fb a:hover i {
  background: #537ad2;
  -webkit-transition: all .2s;
  transition: all .2s;
}

/*-----------------------
代表メッセージ
-----------------------*/

.greeting {
  position: absolute;
  top: 20%;
  left: 4%;
  z-index: 100;
  max-width: 364px;
  width: auto;
  padding: 5% 2%;
  background: rgba(255, 228, 0, 0.7);
}

.nav-ceo .career__title {
  margin-bottom: 15px;
  padding: 5px 0 5px 15px;
  background: #404040;
  color: #fff;
  font-family: "????????????�???? Pro", "Hiragino Kaku Gothic Pro";
  font-size: 20px;
  font-weight: bold;
}

.nav-ceo .career-wrap {
  display: flex;
  justify-content: space-between;
  padding-bottom: 50px;
}

.nav-ceo .career {
  width: 700px;
}

.nav-ceo .career-photo {
  width: 280px;
}

.nav-ceo .career-photo .career-photo__image {
  width: 100%;
  height: auto;
}

.nav-ceo .coreer-list-item {
  display: flex;
  padding: 20px;
  border-bottom: 1px solid #dfdfdf;
}

.nav-ceo .coreer-list-item__year {
  width: 17%;
}

.nav-ceo .coreer-list-item__data {
  width: 83%;
}

.nav-ceo .message-list-item__title {
  font-size: 26px
}

.nav-ceo .message-list-item__data {
  padding-bottom: 20px;
  line-height: 1.8;
}

.nav-ceo .message-list-item__data:last-child {
  padding-bottom: 0;
}

.nav-ceo .message-list-item__image {
  padding-bottom: 20px;
}

.nav-ceo .message-list-item__image img {
  display: block;
  width: 100%;
  height: auto;
}


/*-----------------------
サービス年表
-----------------------*/

.history_cont {
  width: 72%;
  float: right;
}

/*-----------------------
会社概要等
-----------------------*/

.company_info {
  padding: 20px;
  border-bottom: 1px solid #dfdfdf;
}

.company_info dt {
  width: 17%;
  float: left;
}
.company_info dd {
  float: left;
  width: 83%;
}

.company_info li { padding-bottom: 10px;}
.company_info li:last-child { padding-bottom: 0;}

.company_img img,
.box-graph-image img {
  width:100%;
  height:auto;
}

.graph-list-item img {
  width:100%;
  max-width: 364px;
  height:auto;
}

.company_info .fa:link,
.company_info .fa:visited,
.link-fa:link,
.link-fa:visited {
  padding-left: 5px;
  /*vertical-align: bottom;*/
  color: #3a579a !important;
  font-size: 20px;
}

.company_info .fa:hover,
.link-fa:hover {
  color: #5274c3 !important;
  text-decoration: none;
}

.link-tw:link,
.link-tw:visited {
  padding-left: 5px;
  /*vertical-align: bottom;*/
  color: #1DA1F2 !important;
  font-size: 20px;
}
.link-tw:hover {
  color: #55acee !important;
  text-decoration: none;
}

.link-note:before {
  content: "";
  display: inline-block;
  width: 16px;
  height: 18px;
  background: url(../images/common/logo-symbol.png) no-repeat;
  background-size: contain;
}
.link-note:hover {
  opacity: 0.6;
}

.representative-image img {
  margin-top: -4px;
  vertical-align: middle;
  width: 177px;
  height: auto;
}


/*-----------------------
健全性維持への取り組み
-----------------------*/

.sengen { padding: 0 0 30px 30px;}
.sengen li {
  padding-bottom: 10px;
  list-style-type: decimal;
}

/*-----------------------
お問い合わせ
-----------------------*/

.contactform {
  margin: 50px auto 50px;
  width: auto;
}
.contactform dl {
  margin-bottom: 20px;
}
.contactform dl dt,
.contactform dl dd {
  float: left;
}
.contactform dl dt {
  margin-right: 3%;
  width: 27%;
}
.contactform dl dd { width: 70%;}
.contactform dl dd input {
  width: 60%;
  height:25px;
  border: #cacaca 1px solid;
}

.contactform dl dd input[type="radio"],
.contactform dl dd input[type="checkbox"] {
  width: auto;
  height: auto;
  border: #cacaca 1px solid;
}

.contactform dl dd textarea {
  width: 80%;
  border: #cacaca 1px solid;
}

.contactform dl dd textarea {
  width: 80%;
  border: #cacaca 1px solid;
}

.contactform dl dd select {
  border: #cacaca 1px solid;
}

.input_day .year input[type="text"],
.input_day .day input[type="text"],
.input_day .month input[type="text"] { width:10%;}

.post01 input[type="text"] { width:20%;}
.post02 input[type="text"] { width:25%;}

.wpcf7-form-control-wrap { vertical-align: text-top;}

div.wpcf7-validation-errors {
  padding: 5px 0;
  background: #ffdbdb;
  color: #cc0000;
  text-align: center;
  border: 1px solid #faaaaa;
  border-radius: 5px;
}

.submit input,
.submit a {
  display: inline-block;
  position: relative;
  padding: 0 16px;
  margin: 10px;
  min-width:160px;
  width: auto;
  z-index: 2;
  background: rgba(0, 0, 0, 0);
  border: 1px solid #222;
  border-radius: 26px;
  font-size: 18px;
  color: #222;
  text-align:center;
  letter-spacing: 0;
  line-height: 35px;
  overflow: hidden;
  text-decoration:none;
}
.submit input::before,
.submit input::after,
.submit a::before,
.submit a::after {
  position: absolute;
  z-index: -1;
  display: block;
  content: '';
  background: rgba(0, 0, 0, 0);
}
.submit input,
.submit input::before,
.submit input::after,
.submit a,
.submit a::before,
.submit a::after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-transition: all .2s;
  transition: all .2s;
}
.submit a:visited { color:#333;}
.submit input:hover,
.submit a:hover {
  background: #222;
  color: #fff;
  text-decoration: none;
}
.submit input::after,
.submit a::after {
  top: -100%;
  width: 100%;
  height: 100%;
}

input[type="button"] { margin-right: 10px;}


.skill li {
  float: left;
  padding-bottom: 5px;
}
.skill li:first-child {width: 40%;}

.skill input[type="text"] {
  width: 40%;
  margin-left: 10px;
}

.birthday input[type="text"] {
  width: 10%;
}

.is_rice {
  font-size: 10px;
  color: red;
  vertical-align: top;
}

.is_form-image { border: none!important;}
.mw-wp-form_image img { width:80%; height: auto;}

.contactform-link {
  display: block;
  text-align: center;
}

/*-----------------------
プライバシーポリシー
-----------------------*/

.privacy-list { padding: 0 0 30px 30px;}
.privacy-list-item {
  padding-bottom: 10px;
  list-style-type: decimal;
}
.privacy-list-item:last-child {
  padding-bottom: 0;
}

/*-----------------------
採用情報
-----------------------*/

.recruit_info {
  padding: 20px;
  border-bottom: 1px solid #dfdfdf;
}

.recruit_info dt {
  float: left;
  width: 20%;
}
.recruit_info dd {
  float: right;
  width: 75%;
}

.recruit_info li { padding-bottom: 10px;}
.recruit_info li:last-child { padding-bottom: 0;}

.qa { padding-bottom: 40px;}
.qa:last-child { padding-bottom: 0;}
.qa li {
  margin-bottom: 15px;
  padding: 4px 0 4px 50px;
  background: url(../images/recruit/question_q_img.png) no-repeat;
}
.qa li:last-child {
  margin-bottom: 0;
  background: url(../images/recruit/question_a_img.png) no-repeat;
}

.office_img { padding: 50px 0;}
.office_img h3 {
  font-size: 16px;
  padding-bottom: 5px;
}
.office_img .fa {

  padding-right: 5px;
  vertical-align: baseline;
}

.office_img li {
  float: left;
  margin: 0px 30px 40px 0px;
  width: 330px;
  height: 400px;
}
.office_img li:nth-child(3n) { margin: 0px 0 40px 0px;}
.office_img li img { border-radius: 10px;}

.recruit-line {
  padding-top: 20px;
  text-align: center;
}
.recruit-line.is_pc { display: block;}
.recruit-line.is_sp { display: none;}
.recruit-line img {
  width: 180px;
  height: auto;
}

.recruit-line-list {
  margin: 5px auto 0;
  width: 200px;
}
.recruit-line-list-item {
  float: left;
}
.recruit-line-list-item:nth-child(even) { padding: 0 16px;}
.recruit-line-list-item img {
  width: 56px;
  height: auto;
  border: 0;
  border-radius: 120px;
}

.dialog {
  position: relative;
  margin: 0 auto 32px 60px;
  width: 80%;
  box-sizing: border-box;
  -webkit-box-sizing: border-box;
  padding: 20px;
  border-radius: 6px;
  border: 2px solid #999;
  background-color: #fff;
  z-index: 1;
}
.dialog.is_tanakaayako {
  margin: 0 60px 32px auto;
  background-color: #ddf5ff;
  border: 2px solid #099cdc;
}
.dialog.is_saraie {
  margin: 0 60px 32px auto;
  background-color: #ffe7f3;
  border: 2px solid #f16db9;
}
.dialog::before {
  position: absolute;
  content: "";
  top: 16px;
  right: -7px;
  width: 10px;
  height: 10px;
  background-color: #fff;
  border-right: 2px solid #999;
  border-bottom: 2px solid #999;
  transform: rotate(-45deg);
  -webkit-transform: rotate(-45deg);
  z-index: 2;
}
.dialog.is_tanakaayako::before {
  left: -7px;
  right: auto;
  background-color: #ddf5ff;
  border-right: 2px solid #099cdc;
  border-bottom: 2px solid #099cdc;
  transform: rotate(135deg);
  -webkit-transform: rotate(135deg);
}
.dialog.is_saraie::before {
  left: -7px;
  right: auto;
  background-color: #ffe7f3;
  border-right: 2px solid #f16db9;
  border-bottom: 2px solid #f16db9;
  transform: rotate(135deg);
  -webkit-transform: rotate(135deg);
}

.dialog::after {
  position: absolute;
  right: -80px;
  content: "";
  width: 56px;
  height: 56px;
  top: -10px;
  border-radius: 40px;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
}
.is_nakama::after {
  background-image: url(../images/avatar/avatar_3.jpg);
}
.is_tanakaayako::after {
  right: auto;
  left: -80px;
  background-image: url(../images/avatar/avatar_6.jpg);
}
.is_saraie::after {
  right: auto;
  left: -80px;
  background-image: url(../images/avatar/avatar_saraie.jpg);
}

.job-text-list-item {
  list-style: disc;
  padding-bottom: 0 !important;
  margin-left: 20px;
  word-break: break-all;
}

.box-graph {
  padding: 70px 4% 100px;
  margin: 0 auto;
  max-width: 750px;
  width: auto;
}
.graph-list-item {
  float: left;
  padding-bottom: 30px;
}
.graph-list-item:nth-child(even) { float: right;}

.box-infographics {
  padding-bottom: 50px;
  margin: 0 auto;
  width: 100%;
  max-width: 735px;
}
.box-infographics img {
  width: 100%;
  height: auto;
}
.box-infographics-tweet {
  float: right;
  padding-top: 20px;
}

.what-is-chatlady {
  margin: 0 auto 50px;
  width: 100%;
  max-width: 750px;
}
.what-is-chatlady__image {
  width: 100%;
  height: auto;
}
.diagnosis {
  padding: 20px;
  max-width: 690px;
  background: #ffe5e9;
  border-right: 10px #fff solid;
  border-left: 10px #fff solid;
  border-bottom: 10px #fff solid;
}
.diagnosis-title {
  padding-top: 20px;
  text-align: center;
}
.diagnosis-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.diagnosis-list-item {
  padding-top: 40px;
  max-width: 330px;
  text-align: center;
}
.diagnosis-list-item__title {
  padding-bottom: 20px;
}
.diagnosis-list-item-link {
  display: block;
}
.diagnosis-list-item-link__image {
  width: 100%;
  max-width: 330px;
  height: auto;
}
.diagnosis-list-item-link__image.is_mocom,
.diagnosis-list-item-link__image.is_famu {
  padding-top: 2px;
}


.staff-select-wrap {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  overflow: hidden;
  margin: 50px auto 0;
  width: 100%;
  max-width: 800px;
  border: 1px solid #222;
  border-radius: 26px;
  z-index: 1;
}
.staff-select {
  position: relative;
  -webkit-box-flex: 1;
  -webkit-flex: 1;
  -ms-flex: 1;
  flex: 1;
  height: 48px;
}
.staff-select-label {
  position: absolute;
  padding: 15px 10px 14px 20px;
  font-size: 14px;
  font-weight: 700;
  width: 100%;
  max-width: 770px;
  color: #b8b1bd;
  background-color: #fff;
}
.staff-select-label .fa {
  position: absolute;
  right: 20px;
  font-size: 20px;
  font-weight: 700;
  transform: rotate(90deg);
  -webkit-transform: rotate(90deg);
}
.staff-select-category {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  display: block;
  position: relative;
  width: 100%;
  height: 100%;
  border: none;
  opacity: 0;
  z-index: 2;
  cursor: pointer;
}

.recruit-tag-list__title {
  padding-bottom: 1em;
  font-size: 24px;
}
.recruit-tag-list {
  padding-bottom: 2em;
}
.recruit-tag-list-item {
  display: inline-block;
  padding: 5px 10px;
  margin: 0 5px 8px 0;
  font-size: 12px;
  border-radius: 5px;
  background: #ffe400;
}

/*-----------------------
当社をご検討の方へ
-----------------------*/

.profile {
  font-weight: bold;
}

.profile__name {
  font-size: 20px;
}


.career__title {
  margin-bottom: 15px;
  padding: 5px 0 5px 15px;
  background: #404040;
  color: #fff;
  font-family: "????????????�???? Pro", "Hiragino Kaku Gothic Pro";
  font-size: 20px;
  font-weight: bold;
}

.coreer-list-item {
  display: flex;
  padding: 20px;
  border-bottom: 1px solid #dfdfdf;
}

.coreer-list-item__year {
  width: 17%;
}

.coreer-list-item__data {
  width: 83%;
}

.message-list-item__title {
  font-size: 26px
}

.message-list-item__data {
  padding-bottom: 20px;
  line-height: 1.8;
}

.message-list-item__data:last-child {
  padding-bottom: 0;
}

.message-list-item__image {
  padding-bottom: 20px;
}

.message-list-item__image img {
  display: block;
  width: 100%;
  height: auto;
}

/*-----------------------
安心・安全なサービス提供のための取り組み
-----------------------*/

.safety-title {
  padding-bottom: 40px;
  text-align: center;
  font-size: 24px;
  font-weight: bold;
}
.safety-title__annotation {
  display: block;
  font-size: 16px;
  font-weight: normal;
}

.attempt {
  padding-bottom: 24px;
}

.attempt-title {
  padding-bottom: 16px;
}

.attempt-section {
  padding-bottom: 20px;
}

.attempt-section:last-child {
  padding: 0;
}

.attempt-section-detail-wrap {
  display: flex;
  justify-content: space-between;
}

.attempt-section-title {
  padding-bottom: 8px;
  font-size: 18px;
  font-weight: bold;
  color: #cc0000;
}

.attempt-section-text {
  padding-bottom: 10px;
}
.attempt-section-text:last-child {
  padding-bottom: 0;
}

.attempt-section-image-wrap {
  display: flex;
}

.attempt-section-detail {
  width: 760px;
}

.attempt-section-detail-image-wrap {
  width: 100%;
  max-width: 80px;
  height: auto;
}

.attempt-section-image,
.attempt-section-detail-image {
  margin: auto;
  width: 100%;
  max-width: 1000px;
  height: auto;
}

/*-----------------------
ライブでゴーゴー
-----------------------*/

.chat {
  margin: 0 auto;
  width: 800px;
}

.chat li {
  float: left;
  padding-right: 33px;
  width: 175px;
}

.chat li:last-child { padding-right: 0;}


/*-----------------------
55,Eazy,おチャベリ,アスリートapp
-----------------------*/

.app { padding-bottom: 50px;}
.app li {
  float: left;
  padding-right: 10px;
}

.app li { width: 180px;}


.app li img { width: 100%;}

.app_nolink img {
  opacity: 0.5;
}

.mission_list { padding-top: 90px;}

/*-----------------------
萌えチャット
-----------------------*/

.moe_iframe li {
  float: left;
  width: 480px;
}

.moe_iframe li:last-child { float: right;}

.moe_img img {
  max-width: 400px;
  width: 100%;
  height: auto;
}

.moe_img02 img {
  max-width: 950px;
  width: 100%;
  height: auto;
}

/*-----------------------
性的マイノリティLGBTへの取り組み
-----------------------*/

.lgbt_history {
  width: 100%;
  margin-bottom: 50px;
}

.lgbt_history th{
  padding: 10px;
  width: 12%;
  vertical-align: middle;
  border: #222 1px solid;
}


.lgbt_history_desc {
  padding: 10px;
  vertical-align: middle;
  width: auto;
  border: #222 1px solid;
}

.consciousness {
  padding:0 10px 0 13px;
  font-size: 18px;
  vertical-align: middle;
}

.era {
  padding: 15% 10px;
  width: 3%;
  background: -webkit-gradient(linear, left top, left bottom, color-stop(0.00, #ff7800), color-stop(1.00, #f3ce00));
  background: -webkit-linear-gradient(#ff7800, #f3ce00);
  background: -moz-linear-gradient(#ff7800, #f3ce00);
  background: -o-linear-gradient(#ff7800, #f3ce00);
  background: -ms-linear-gradient(#ff7800, #f3ce00);
  background: linear-gradient(#ff7800, #f3ce00);
  font-size: 20px;
  font-weight: bold;
}


/*-----------------------
アクセスマップ
-----------------------*/

.root { padding-bottom: 50px;}

.root li { float:left;}

.root li:last-child { padding-left:40px;}

a.root01 {
  position:relative;
  display:block;
  background: url(../images/root01/root01.jpg) no-repeat;
  width:300px;
  height:200px;
}

a.root02 {
  position:relative;
  display:block;
  background: url(../images/root02/root02.jpg) no-repeat;
  width:300px;
  height:200px;
}

a.root01 span,
a.root02 span {
  position:absolute;
  bottom:-30px;
  left:0;
  right:0;
  margin:0 auto;
  text-align: center;
}

/*-----------------------
btn
-----------------------*/

.btn {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  display: inline-block;
  width: 400px;
  margin-top: 30px;
  z-index: 2;
  background-color: rgba(34, 34, 34, 0.5);
  border: 1px solid #fff;
  border-radius: 26px;
  font-size: clamp(1rem, 3vw, 1.125rem);
  color: #fff;
  text-align: center;
  letter-spacing: 0;
  line-height: 50px;
  overflow: hidden;
  text-decoration: none;
}
.btn::before,
.btn::after {
  position: absolute;
  z-index: -1;
  display: block;
  content: '';
}
.btn,
.btn::before,
.btn::after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-transition: all .2s;
  transition: all .2s;
}
.btn:hover {
  color: #fff;
  text-decoration: none;
}
.btn::after {
  top: -100%;
  width: 100%;
  height: 100%;
}
.btn:hover::after {
  top: 0;
  background-color: #222;
}

a.btn:link { color: #fff; }
.btn:visited { color: #fff; }

.btn02 {
  display: inline-block;
  position: relative;
  width:400px;
  margin: 0 auto;
  z-index: 2;
  background-color: transparent;
  border: 1px solid #222;
  border-radius: 26px;
  font-size: 18px;
  color: #222;
  text-align:center;
  letter-spacing: 0;
  line-height: 50px;
  overflow: hidden;
  text-decoration:none;
}
.btn02::before,
.btn02::after {
  position: absolute;
  z-index: -1;
  display: block;
  content: '';
}
.btn02,
.btn02::before,
.btn02::after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-transition: all .2s;
  transition: all .2s;
}
.btn02:hover {
  color: #fff;
  text-decoration: none;
}
.btn02::after {
  top: -100%;
  width: 100%;
  height: 100%;
}
.btn02:hover::after {
  top: 0;
  background-color: #222;
}

.btn03 {
  display: inline-block;
  position: relative;
  width:160px;
  margin: 0 auto;
  z-index: 2;
  /*float: right;*/
  background-color: transparent;
  border: 1px solid #222;
  border-radius: 26px;
  font-size: 18px;
  color: #222;
  text-align:center;
  letter-spacing: 0;
  line-height: 35px;
  overflow: hidden;
  text-decoration:none;
}
.btn03::before,
.btn03::after {
  position: absolute;
  z-index: -1;
  display: block;
  content: '';
}
.btn03,
.btn03::before,
.btn03::after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-transition: all .2s;
  transition: all .2s;
}
.btn03:hover {
  color: #fff;
  text-decoration: none;
}
.btn03::after {
  top: -100%;
  width: 100%;
  height: 100%;
}
.btn03:hover::after {
  top: 0;
  background-color: #222;
}

.blog_btn a:link {
  display: inline-block;
  position: relative;
  max-width:400px;
  width:100%;
  margin: 20px auto 50px;
  z-index: 2;
  background-color: transparent;
  border: 1px solid #222;
  border-radius: 26px;
  font-size: 18px;
  color: #222;
  text-align:center;
  letter-spacing: 0;
  line-height: 50px;
  overflow: hidden;
  text-decoration:none;
}
.blog_btn a:visited { color: #222; }
.blog_btn a:hover {
  color: #fff;
  text-decoration: none;
}

a.btn04 {
  display: inline-block;
  position: relative;
  width:400px;
  margin: 0 auto;
  z-index: 2;
  background-color: transparent;
  border: 1px solid #222;
  border-radius: 26px;
  font-size: 18px;
  color: #222;
  text-align:center;
  letter-spacing: 0;
  line-height: 50px;
  overflow: hidden;
  text-decoration:none;
}
a.btn04::before,
a.btn04::after {
  position: absolute;
  z-index: -1;
  display: block;
  content: '';
}

a.btn04,
a.btn04::before,
a.btn04::after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-transition: all .2s;
  transition: all .2s;
}
a.btn04:hover {
  color: #fff;
  text-decoration: none;
}
a.btn04::after {
  top: -100%;
  width: 100%;
  height: 100%;
}
a.btn04:hover::after {
  top: 0;
  background-color: #222;
}
a.btn04:link {
  display: inline-block;
  position: relative;
  max-width:400px;
  width:100%;
  margin: 40px auto 0;
  z-index: 2;
  background-color: transparent;
  border: 1px solid #222;
  border-radius: 26px;
  font-size: 18px;
  color: #222;
  text-align:center;
  letter-spacing: 0;
  line-height: 50px;
  overflow: hidden;
  text-decoration:none;
}
a.btn04:link,
a.btn04:visited { color: #222; }
a.btn04:hover {
  color: #fff;
  text-decoration: none;
}
.parent-pageid-167 a.btn04,
.parent-pageid-167 a.btn04:link {
  background: #01DF01;
}
#rec-btn {
    position: fixed;
    bottom: 20px;
    right: 20px;
    z-index: 10;
    font-size: 77%;
}
#rec-btn a {
    background: #01DF01;
    text-decoration: none;
    color: #333;
    width: 110px;
    padding: 25px 0;
    text-align: center;
    display: block;
    border-radius: 15px;
}
#rec-btn a:hover {
    text-decoration: none;
    background: #00FF00;
}

#js-access-map a {
  position: relative;
  border-radius: 4px;
  color: #fff;
  line-height: 50px;
  -webkit-box-sizing: content-box;
  -moz-box-sizing: content-box;
  box-sizing: content-box;
  -webkit-transition: none;
  transition: none;
  text-shadow: 0px 1px 0px #f56778;
  margin-bottom: 20px;
}
#js-access-map a,
#js-access-map a:hover {
  padding: 8px;
  border-bottom: 4px solid #cb5462;
  background-color: #f56778;
  background-image: -webkit-linear-gradient(top, #f997b0, #f56778);
  background-image: linear-gradient(to bottom, #f997b0, #f56778);
  box-shadow: inset 1px 1px 0 #fbc1d0;
}
#js-access-map a::before,
#js-access-map a::after {
  bottom: -1px;
  left: -1px;
  width: 200px;
  height: 50px;
  border: 1px solid #ee8090;
  border-bottom: 1px solid #b84d5a;
  border-radius: 4px;
  -webkit-box-sizing: content-box;
  -moz-box-sizing: content-box;
  box-sizing: content-box;
  -webkit-transition: none;
  transition: none;
}
#js-access-map a::before {
  height: 48px;
  bottom: -4px;
  border-top: 0;
  border-radius: 0 0 4px 4px;
  box-shadow: 0 1px 1px 0px #bfbfbf;
}
#js-access-map a:link { color:#fff;}
#js-access-map a:visited { color:#fff;}
#js-access-map a:hover {
  background: #f56778;
  background-image: -webkit-linear-gradient(top, #f56778, #f997b0);
  background-image: linear-gradient(to bottom, #f56778, #f997b0);
  color: #913944;
  text-shadow: 0px 1px 0px #f9a0ad;
}
#js-access-map a:active {
  bottom: -4px;
  margin-bottom: 4px;
  border: none;
  box-shadow: 1px 1px 0 #fff, inset 0 1px 1px rgba(0, 0, 0, .3);
}
#js-access-map a:active::before,
#js-access-map a:active::after {
  border: none;
  box-shadow: none;
}

/*-----------------------
ニュース
-----------------------*/

.news-category-list {
  width: 340px;
  margin: 50px auto 20px;
}
.news-category-list li {
  float: left;
  font-size: 18px;
}
.news-category-list .cat-item-140 a,
.news-category-list .cat-item-141 a {
    display: block;
    padding: 5px 10px;
    border-radius: 5px;
    text-align: center;
}
.news-category-list .cat-item-141 a {
  background: #858585;
  color: #fff;
}
.news-category-list .cat-item-140 a {
  background: #ffe400;
  color: #333;
}
.term-140 .news-category-list .cat-item-141 a,
.term-141 .news-category-list .cat-item-140 a { opacity: 0.5;}
.term-140 .news-category-list .cat-item-141 a:hover,
.term-141 .news-category-list .cat-item-140 a:hover { opacity: 1;}
.news-category-list li:last-child { float: right;}
.news-list-wrap,
.news-single-wrap { padding-bottom: 50px;}
.news-list,
.news-single {
  padding: 30px 3%;
  margin: auto;
  max-width: 950px;
  width: 94%;
}
.news-list-item {
  position: relative;
  padding: 0 20px;
  border-bottom: 1px solid #dfdfdf;
  height: 56px;
  line-height: 56px;
}
.news-list-item__link {
  display: block;
  text-decoration: none;
}
.news-list-item__category.media {
  background: #858585;
  color: #fff;
}
.news-list-item__category.company-news {
  background: #ffe400;
  color: #333;
}
.news-list-item__category {
  display: block;
  position: absolute;
  top: 15px;
  left: 0;
  width: 100px;
  height: 24px;
  border-radius: 5px;
  font-size: 10px;
  text-align: center;
  line-height: 24px;
  letter-spacing: 0.5px;
}
.news-list-item-title {
  overflow: hidden;
  width: 100%;
  text-indent: 100px;
  white-space: nowrap;
  text-overflow: ellipsis;
}
.news-list-item-title__date { padding-right:16px;}
.news-single__title {
  margin-bottom: 10px;
  border-bottom: 1px solid #858585;
}
.news-single__text { margin-bottom: 50px;}



@media screen and (min-width:0) and (max-width: 768px) {

  /* WordPress Native Styles */

  .aligncenter {
    display: block;
    margin: 0 auto;
  }
  .alignright {
    display: block;
    float: none;
    margin: 0 auto;
  }
  .alignleft {
    display: block;
    float: none;
    margin: 0 auto;
  }

  .imgauto {
    float: none;
    padding: 0 0 10px 0;
    text-align: center;
  }
  .imgauto img {
    max-width: 500px;
    width: 100%;
    height: auto;
  }

  .sp_center {
    float: none;
    padding-bottom: 10px;
    padding-right: 0;
    text-align: center;
  }

  body {
    overflow-x:hidden;
    font-size: 14px;
  }

  h2 { font-size: 180%;}

  h3 { font-size: 150%;}

  .btn {
    margin-top: 20px;
  }

  .btn,
  .btn02 {
    max-width:300px;
    width: 100%;
  }

  /* .btn { top: 300px;} */

  .sp_img img { display: block;}
  .sp_noimg img { display: none;}

  /*-----------------------
  スマホheader,gnav
  -----------------------*/

  header#sidecontent {
    position: static;
    top: 0;
    left: 0;
    z-index: 9999;
    width: 100%;
    height: 60px;
    padding-top: 0;
    margin-top: 0;
    background: #141216;
    color: #e5e5e5;
  }

  #mobile-head {
    background: #141216;
    width: 100%;
    height: 70px;
    z-index: 999;
    position: fixed;
  }

  h1.logo,
  p.logo {
    width: 120px;
    height: auto;
    float: none;
    margin: 0 0 0 2%;
    background: url(../images/common/logo.png?250522) no-repeat;
    background-size: contain;
    text-indent: -9999px;
  }
  h1.logo a,
  p.logo a {
    display: block;
    overflow: hidden;
    width: 120px;
    height: 70px;
  }

  #mobile-head .fa-bars {
    display: block;
    position: absolute;
    top: 25%;
    right: 3%;
    padding-right: 0;
  }

  .fa { vertical-align: baseline;}
  .gnav .fa,
  .gnav .fab { padding-right: 15px;}

  nav {
    position: fixed;
    top: -499px;
    z-index: 110;
    display: block;
    padding: 0;
    width: 100%;
    height:auto;
    background: none;
    -webkit-transition: .5s ease-in-out;
    -moz-transition: .5s ease-in-out;
    transition: .5s ease-in-out;
  }

  #js-navi div {
    overflow: auto;
    background: none;
    width: 100%;
    /* height: 90%; */
  }

  .gnav li ul {
    list-style: none;
    position: static;
    width: auto;
    top: 0;
    left: 100%;
    margin: 0;
    padding: 0;
    background: #141216;
  }

  #js-toggle {
    display: block;
    position: absolute;
    right: 15px;
    top: 18px;
    width: 34px;
    height: 36px;
    cursor: pointer;
    z-index: 101;
  }
  #js-toggle div {
    position: relative;
  }
  #js-toggle span {
    display: block;
    position: absolute;
    height: 4px;
    width: 100%;
    background: #fff;
    left: 0;
    -webkit-transition: .20s ease-in-out;
    -moz-transition: .20s ease-in-out;
    transition: .20s ease-in-out;
  }
  #js-toggle span:nth-child(1) {
    top: 0;
  }
  #js-toggle span:nth-child(2) {
    top: 11px;
  }
  #js-toggle span:nth-child(3) {
    top: 22px;
  }

  .open #js-toggle span:nth-child(1) {
    top: 11px;
    -webkit-transform: rotate(315deg);
    -moz-transform: rotate(315deg);
    transform: rotate(315deg);
  }
  .open #js-toggle span:nth-child(2) {
    width: 0;
    left: 50%;
  }
  .open #js-toggle span:nth-child(3) {
    top: 11px;
    -webkit-transform: rotate(-315deg);
    -moz-transform: rotate(-315deg);
    transform: rotate(-315deg);
  }

  .gnav {
    list-style: none;
    position: static;
    overflow:auto;
    background: #141216;
  }
  .gnav li {
    position: static;
    border-top: 1px #0a090b solid;
  }
  .gnav li a {
    display: block;
    margin: 0;
    padding: 15px 0 15px 20px;
    color: #b8b1bd;
    line-height: 1;
    text-decoration: none;
  }
  .gnav li:hover ul li {
    height: auto;
  }
  .nav_sns { background: #141216;}

  /* nav opening */
  #js-navi {
    position: fixed;
    top: -100%;
    left: 0;
    display: block;
    width: 100%;
    height:100%;
    padding: 0;
    background: none;
  }
  #js-navi > div {
    position: absolute;
    z-index: 110;
    top: -499px;
    overflow: auto;
    background: none;
    width: 100%;
    height: 90%;
    -webkit-transition: .5s ease-in-out;
    -moz-transition: .5s ease-in-out;
    transition: .5s ease-in-out;
  }
  .open #js-navi {
    /*-moz-transform: translateY(559px);
    -webkit-transform: translateY(559px);
    transform: translateY(559px);*/
    top: 0;
  }
  .open #js-navi > div {
    top: 60px;
  }

  .nav_sub {
    display: inherit;
    position: static;
    width: auto;
    top: 0;
    left: 0;
    margin: 0;
    padding: 0;
  }

  .nav_sub ul li a {
    display: block;
    margin: 0;
    padding: 10px 20px;
    color: #b8b1bd;
    font-size: 14px;
    line-height: 1;
    text-decoration: none;
  }

  ul.nav_close { display:none;}
  ul.nav_open { display:block;}

  ul.nav_open li {
    background: #352D2D;
    border-top:1px #666666 solid;
  }
  ul.nav_open li:last-child {
    border-top:1px #666666 solid;
    border-bottom:1px #666666 solid;
  }

  .page-template-page-nav .content { padding: 0;}
  .page-template-page-nav .content > div {
    padding: 10px 4% 40px;
  }

  .page-template-page-nav .nav_list { padding: 0 0 30px 0;}
  .nav_list .nav_list_block {
    position: relative;
    float: none;
    width: 100%;
    height: auto;
    margin: 0;
    background: none;
    border-bottom: 1px solid rgba(255,255,255,0.6);
    box-shadow: none;
  }
  .page-template-page-nav #breadcrumb { display: none;}

  .nav_list .nav_list_block:nth-child(3n) { margin: 0;}
  .nav_list .nav_list_block:first-child { border-top: 1px solid rgba(255,255,255,0.6);}
  .nav_list_block p { display: none;}

  h3.nav_list_tit {
    font-size: 16px;
    font-weight: normal;
  }
  h3.nav_list_tit a {
    display: block;
  }

  .nav_sns{
      display: flex;
      justify-content: space-between;
      border-top: 1px #0a090b solid;
      border-bottom: 1px #0a090b solid;
  }
  .nav_sns li {
    display: block;
    width: 100%;
    text-align: center;
    border-right: 1px #0a090b solid;
  }
  .nav_sns li:last-child{
      border: none;
  }
  .nav_sns a {
    display: block;
    padding: 10px 0;
    color: #b8b1bd;
    width: 100%;
    font-size: 20px;
    text-decoration:none;
    position: relative;
    overflow: hidden;
    color: #fff;
  }
  .nav_sns a::before{
      position: relative;
      z-index: 10;
  }
  .nav_sns li:first-child a {
    background: #55acee;
  }
  .nav_sns li:nth-child(2) a {
    background: -webkit-linear-gradient(135deg, #427eff 0%, #f13f79 70%) no-repeat;
    background: linear-gradient(135deg, #427eff 0%, #f13f79 70%) no-repeat;
  }
  .nav_sns li:nth-child(2) a:after{
    content: '';
    z-index:9;
    width: 60px;
    height: 60px;
    position: absolute;
    bottom: -36px;
    left: -20px;
    background: -webkit-radial-gradient(#ffdb2c 10%, rgba(255, 105, 34, 0.65) 55%, rgba(255, 88, 96, 0) 70%);
    background: radial-gradient(#ffdb2c 10%, rgba(255, 105, 34, 0.65) 55%, rgba(255, 88, 96, 0) 70%);
  }
  .nav_sns li:last-child a {
    background: #e62117;
  }


  /*-----------------------
  スマホトップページ
  -----------------------*/

  .top_slide {
    height: 280px;
  }

  .home .main { margin: 0 0 50px 0;}

  .main {
    /* position: relative; */
    margin: 0;
    letter-spacing: 1px;
  }

  .top_slide {
    min-height: 380px;
    height: auto;
    background-size: cover;
  }

  .hero {
    width: 100%;
    height: 40vh;
    aspect-ratio: 9 / 16;
  }
  .hero::before,
  .hero::after {
    opacity: 0.45;
  }

  .toptitle {
    padding: 0 10px 20px;
    /* font-size: 200%; */
    line-height:110%;
  }

  video.bgvid {
    display: none;
    min-height: 380px;
  }

  .top-slide-text {
    padding-bottom: 50px;
  }

  .toptext {
    text-align: left;
  }

  .top_list, .camp_list {
    padding: 30px 0 30px;
  }

  .top_list .top_list_block {
    padding: 2%;
    background: #fff;
    float:none;
    width: auto;
    height: auto;
    margin: 0px auto 15px;
    box-shadow: 4px 4px 7px -3px #404040;
  }
  .top_list .top_list_block:nth-child(3n) {
    margin: 0px auto 15px;
  }

  .scale_img {
    width: auto;
    height: auto;
    overflow: auto;
  }

  .scale_img img {
    -moz-transition: none;
    -webkit-transition: none;
    -o-transition: none;
    -ms-transition: none;
    transition: none;
  }
  .scale_img img:hover {
    -webkit-transform: none;
    -moz-transform: none;
    -o-transform: none;
    -ms-transform: none;
    transform: none;
  }

  .topics_img {
    float: left;
    padding-right: 2%;
    width: 40%;
  }
  .topics_img img {
    width: 100%;
    height: auto;
  }
  /*
  .top_blog > .content {
  padding: 30px 4% 0;
  }*/

  .blog_index {
    float: left;
    width: 58%;
  }

  .blog_index .staff_ico {
    display: block;
    bottom: 2px;
    left: inherit;
    right: 4px;
  }

  .blog_index .staff_ico img {
    width: 35px;
    height: auto;
    border: solid 3px #fff;
    border-radius: 120px;
  }

  .top_blog_date {
    padding: 0;
    color: #999;
    font-size: 10px;
  }
  .top_blog_date a { color: #999;}
  .top_blog_date a:visited { color: #999;}

  .page .top_blog_date {
    padding: 0;
    color: #999;
  }
  .page .top_blog_date a { color: #999;}
  .page .top_blog_date a:visited { color: #999;}

  .blog_tit {
    padding: 3px 0 5px;
    font-size: 14px;
  }

  .top_cat {
    position: static;
    width: 75%;
    font-size: 10px;
  }
  .top_cat li {
    float: left;
    padding: 3px;
    margin-left: 3px;
    margin-bottom: 0px;
  }

  .top_company {
    background: #ffe400;
    height: auto;
    padding: 50px 3%;
    font-size: 14px;
    letter-spacing: 1px;
    text-align: center;
  }

  .camp_list .camp_list_block {
    float: none;
    margin: 0px auto 30px;
    max-width: 300px;
    width: 100%;
    height: 365px;
  }
  .camp_list .camp_list_block:nth-child(3n) { margin: 0 auto 30px;}

  .camp_list_block.is_sp { display: none;}

  .camp_list_block img {
    width: 100%;
    height:auto;
  }

  .top_recruit {
    background: url(../images/index/recruit_bg.jpg) top center no-repeat;
    background-size: cover;
    height: auto;
    padding: 50px 3%;
    text-align: center;
  }

  .top_service { padding: 50px 3%;}

  .service_img { padding: 50px 0;}
  .service_img img {
    width: 100%;
    height: auto;
  }

  .accessmap { padding: 50px 3% 0;}

  #map-canvas {
    width: 100%;
    height: 400px;
    margin-top: 70px;
  }

  footer {
    padding: 0 0 10px;
    margin: 0 0 0 0;
    height: auto;
  }
  footer .fa {
    display:block;
    font-size: 15px;
    font-weight: bold;
  }

  .footer_nav { margin: 0;}

  .footer_logo {
    position: static;
    margin: 10px auto;
    width: 81px;
    height: 30px;
    background-size: 81px 30px;
  }


  .footer_link {
    float: none;
    padding: 0 0 0 0;
  }
  .footer_link ul { padding: 0 0 25px;}
  .footer_link li {
    float: none;
    padding-right: 0;
    border-bottom:#404040 1px solid;
  }
  .footer_link a {
    display: block;
    padding: 15px 25px;
  }
  .footer_copyright {
    position: relative;
    -webkit-box-sizing: content-box;
    box-sizing: content-box;
    height: auto;
    padding-left: 0;
    border-top: none;
    line-height: 1;
  }
  .copyright {
    padding-top: 0;
    padding-bottom: 10px;
    border-top: none;
    text-align: center;
  }

  #js-access-map {
    display: block;
    margin-bottom: 20px;
  }

  .index_root li {
    padding-top:10px;
    max-width:130px;
    width:100%;
    height:auto;
    text-align:center;
    font-size:12px;
  }

  .index_root li img {
    width:100%;
    height:auto;
  }

  .dn { display:block;}




  /*-----------------------
  スマホ固定ページ
  -----------------------*/

  .page_content {
    padding: 70px 4% 20px;
    margin: 0 auto;
    max-width: 1050px;
    width: auto;
  }

  .page-template-archive h1.page_title,
  .page_title.is_blog,
  .page-template-page h1.page_title,
  .page-template-archive-staff h1.page_title,
  .post-type-archive-news h1.page_title,
  .tax-news_cat h1.page_title,
  .page-template-archive-event h1.page_title {
    top: 35%;
    padding-right: 4%;
    font-size: 115%;
    line-height: 1;
    letter-spacing: 0px;
    text-align: left;
    filter: dropshadow(color=#fff,offX= 0,offY=-1) dropshadow(color=#fff,offX= 1,offY= 0) dropshadow(color=#fff,offX= 0,offY= 1) dropshadow(color=#fff,offX=-1,offY= 0);
    -webkit-text-stroke-color: #222;
    -webkit-text-stroke-width: 0px;
    text-shadow: #FFF 1px 1px 3px, #fff -1px 1px 3px, #FFF 1px -1px 3px, #fff 1px 1px 3px;
  }

  .single-post .page_title,
  .nav-blog_ceo .page_title,
  .category .page_title,
  .single-blog_hr .page_title,
  .post-type-archive-blog_hr .page_title,
  .tax-hr_cat .page_title {
    position: absolute;
    top: 30%;
    padding-left: 4%;
    font-size: 140%;
    display: inline-block;
    line-height: 0.5;
    text-align: left;
  }
  .page_title.is_blog span {
    display: block;
    letter-spacing: 2px;
    line-height: 15px;
    font-size: 11px;
  }
  .page_title.is_blog span br { display: block;}

  .page-template .page_thumbnail,
  .single-post .page_thumbnail,
  .category .page_thumbnail,
  .post-type-archive-blog_developer .page_thumbnail,
  .single-blog_developer .page_thumbnail,
  .tax-developer_cat .page_thumbnail,
  .post-type-archive-blog_human_resources .page_thumbnail,
  .single-blog_human_resources .page_thumbnail,
  .tax-human_resources_cat .page_thumbnail,
  .single-post .page_thumbnail,
  .category .page_thumbnail,
  .page-template-archive-staff .page_thumbnail,
  .post-type-archive-staff .page_thumbnail,
  .post-type-archive-blog_designer .page_thumbnail,
  .single-blog_designer .page_thumbnail,
  .tax-designer_cat .page_thumbnail,
  .post-type-archive-blog_engineer .page_thumbnail,
  .single-blog_engineer .page_thumbnail,
  .tax-engineer_cat .page_thumbnail,
  .post-type-archive-blog_hr .page_thumbnail,
  .single-blog_hr .page_thumbnail,
  .tax-hr_cat .page_thumbnail,
  .post-type-archive-blog_connect .page_thumbnail,
  .single-blog_connect .page_thumbnail,
  .tax-connect_cat .page_thumbnail,
  .post-type-archive-blog_24 .page_thumbnail,
  .single-blog_24 .page_thumbnail,
  .tax-24_cat .page_thumbnail,
  .post-type-archive-blog_director .page_thumbnail,
  .single-blog_director .page_thumbnail,
  .tax-director_cat .page_thumbnail,
  .post-type-archive-news .page_thumbnail,
  .single-news .page_thumbnail,
  .tax-news_cat .page_thumbnail {
    height: 180px;
    margin-bottom: 0;
  }

  .blog_engineer_title img {
    top: -25px;
  }

  .content { padding: 70px 4% 20px;}
  .top_news { padding: 50px 0;}

  .page_navi { font-size: 12px;}

  .page_navi li {	width: 47%;}



  /*-----------------------
  代表メッセージ
  -----------------------*/

  .greeting {
    position: absolute;
    top: 40%;
    left: 4%;
    z-index: 100;
    max-width: 100%;
    width: 70%;
    padding: 0;
    background: none;
  }
  .greeting p { display: none;}

  .nav-ceo .career-wrap {
    justify-content: normal;
    flex-direction: column;
  }

  .nav-ceo .career {
    width: 100%;
  }

  .nav-ceo .career-photo {
    margin: auto;
    padding-bottom: 20px;
    width: 100%;
    max-width: 280px;
  }

  .nav-ceo .career-photo .career-photo__image {
    width: 100%;
    height: auto;
  }

  .nav-ceo .coreer-list-item {
    flex-direction: column;
  }

  .nav-ceo .coreer-list-item__year {
    width: 100%;
  }

  .nav-ceo .coreer-list-item__data {
    width: 100%;
  }


  /*-----------------------
  社員紹介ページ
  -----------------------*/

  .single-staff .page_thumbnail { padding-bottom: 0;}

  .staff_list .staff_list_block {
    background: none;
    float: none;
    width: auto;
    height: auto;
    margin: 0px 0 30px 0px;
    box-shadow: none;
  }

  h3.staff_list_tit { padding: 0 0 10px;}

  .staff_list_text {
    padding: 0;
    font-size: 12px;
  }

  .single_staff_prof {
    float: none;
    width: auto;
    height: auto;
  }

  .staff_prof_block {
    position: static;
    top: 0;
    width: auto;
    padding-left: 0;
    padding: 4%;
  }

  .single-staff .staff_thumbnail {
    float: none;
    width: auto;
    height: 300px;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center top;
  }

  .staff-application-list {
    width: auto;
  }
  .staff-application-list-item-btn {
    display: inline-block;
    box-sizing: border-box;
    position: relative;
    width:100%;
    margin: 0 auto;
    z-index: 2;
    background-color: transparent;
    border: 1px solid #222;
    color: #222;
    text-align:center;
    letter-spacing: 0;
    line-height: 50px;
    overflow: hidden;
    text-decoration:none;
  }

  .staff-application-list-item {
    float: none;
    margin: 0 0 0 0;
    height: 51px;
  }
  .staff-application-list-item:nth-child(even) {
    margin: 0 0 0 0;
  }

  /*-----------------------
  会社概要等
  -----------------------*/

  .company_info {
    padding: 20px;
    border-bottom: 1px solid #dfdfdf;
  }

  .company_info dt {
    padding-bottom: 5px;
    width: auto;
    float: none;
    font-weight: bold;
  }
  .company_info dd {
    float: none;
    width: auto;
  }

  .company_info li { padding-bottom: 10px;}
  .company_info li:last-child { padding-bottom: 0;}

  /*-----------------------
  ブログページ
  -----------------------*/

  .blog_inner {
    max-width: 1100px;
    width: auto;
    margin: 50px 4% 0;
  }

  .blog_left {
    width: auto;
    float: none;
  }

  .blog_right {
    float: none;
    max-width: 400px;
    width: auto;
    margin: 0 auto;
  }

  .blog_cont {
    background: #fff;
    padding: 3%;
    margin-bottom: 40px;
    box-shadow: 7px 7px 10px -6px #acacac;
  }

  .navPage{
    overflow: hidden;
    margin: 0 0 50px;
    padding-left: 0;
    list-style: none;
    font-size: 12px;
  }

  .navPage a{
    display: block;
    float: none;
    margin: 0 auto;
    width: 125px;
  }
  .news-single .navPage a { width: auto;}

  .navPage .prev { float: left;}
  .navPage .prev span {
    float: left;
    padding: 15px 0px 15px 0;
    letter-spacing: 1px;
  }
  .navPage .prev img {
    float: right;
    border: 1px solid #222;
    width: 45px;
    height: 45px;
  }

  .navPage .next { float: right;}
  .navPage .next span {
    float: right;
    padding: 15px 0 15px 0px;
    letter-spacing: 1px;
  }
  .navPage .next img {
    float: left;
    border: 1px solid #222;
    width: 45px;
    height: 45px;
  }

  .postid-874 .navPage .next span {
    width: 56%;
    padding: 0px 0 0px 5px;
  }

  .blog_designer_title img { width:90%;}

  .blog_text h4 {
    font-size: 130%;
  }
  .blog_text h5 {
  	font-size: 110%;
  }

  .blog-talk {
    padding: 20px 0 0 80px;
  }

  .blog_title {
    font-size: 140%;
  }


  /*-----------------------
  お問い合わせ
  -----------------------*/

  .wpcf7 {
    margin: 50px auto 0;
    width: auto;
  }
  .wpcf7 dl {
    margin-bottom: 20px;
  }
  .wpcf7 dl dt,
  .wpcf7 dl dd {
    float: none;
    width: auto;
  }
  .wpcf7 dl dt {
    /*padding: 3px 0;*/
    width: auto;
  }
  .wpcf7 dl dd textarea {
    width: 70%;
  }
  .wpcf7 dl dd .wpcf7-list-item {
    display: block;
    float: none;
  }


  .wpcf7-submit {
    display: inline-block;
    position: relative;
    width:160px;
    margin: 0 auto;
    z-index: 2;
    /*float: right;*/
    background-color: transparent;
    border: 1px solid #222;
    border-radius: 26px;
    font-size: 18px;
    color: #222;
    text-align:center;
    letter-spacing: 0;
    line-height: 35px;
    overflow: hidden;
    text-decoration:none;
  }
  .wpcf7-submit::before,
  .wpcf7-submit::after {
    position: absolute;
    z-index: -1;
    display: block;
    content: '';
  }
  .wpcf7-submit,
  .wpcf7-submit::before,
  .wpcf7-submit::after {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-transition: all .2s;
    transition: all .2s;
  }
  .wpcf7-submit:hover {
    background-color: #222;
    color: #fff;
    text-decoration: none;
  }
  .wpcf7-submit::after {
    top: -100%;
    width: 100%;
    height: 100%;
  }

  input[type="button"] { margin-right: 10px;}

  .post01 input[type="text"] { width:20%;}
  .post02 input[type="text"] { width:25%;}

  ul.skill { padding-bottom: 8px;}
  ul.pb20 { padding-bottom: 20px}
  .skill li {
    float: none;
    padding-bottom: 0;
  }
  .skill li:first-child {
    width: auto;
    margin-bottom: 0;
  }

  .contactform dl dt, .contactform dl dd {
    float: none;
    width: 100%;
  }
  .contactform dl dd input { width: 80%;}



  /*-----------------------
  採用情報
  -----------------------*/

  .recruit_info {
    padding: 20px;
    border-bottom: 1px solid #dfdfdf;
  }

  .recruit_info dt {
    float: none;
    width: auto;
    font-weight: bold;
  }
  .recruit_info dd {
    float: none;
    width: auto;
  }

  .office_img { padding-top: 50px;}
  .office_img h3 {
    font-size: 16px;
    padding-bottom: 5px;
  }
  .office_img .fa {
    padding-right: 5px;
    vertical-align: baseline;
  }

  .office_img li {
    float: none;
    margin: 0 auto 30px auto;
    max-width: 330px;
    width: auto;
  }
  .office_img li:nth-child(3n) { margin: 0 auto 30px auto;}
  .office_img li:nth-child(2n) { margin: 0 auto 30px auto;}
  .office_img li img { border-radius: 10px;}

  .recruit-line.is_pc { display: none;}
  .recruit-line.is_sp { display: block;}

  .dialog {
    display: inline-block;
    position: relative;
    right: 0;
    left: 0;
    margin: 64px 0 16px 0;
    width: auto;
    padding: 10px;
  }
  .dialog.is_tanakaayako,
  .dialog.is_saraie {
    right: 0;
    left: 0;
    margin: 64px 0 16px 0;
  }
  .dialog::before {
    top: -7px;
    right: 18px;
    transform: rotate(-135deg);
    -webkit-transform: rotate(-135deg);
  }
  .dialog.is_saraie::before,
  .dialog.is_tanakaayako::before {
    left: -7px;
    left: 18px;
    transform: rotate(225deg);
    -webkit-transform: rotate(225deg);
  }
  .dialog::after {
    top: -64px;
    right: 0;
    width: 48px;
    height: 48px;
  }
  .is_tanakaayako::after,
  .is_saraie::after {
    left: 0;
    top: -64px;
  }

  .box-graph {
    width: auto;
  }
  .graph-list-item {
    float: none;
  }
  .graph-list-item:nth-child(even) {
    float: none;
  }
  
/*-----------------------
当社をご検討の方へ
-----------------------*/

.career__title {
  margin-bottom: 0;
}

.coreer-list-item {
  display: flex;
  flex-direction: column;
}

.coreer-list-item__year {
  padding-bottom: 5px;
  width: auto;
  font-weight: bold;
}

.coreer-list-item__data {
  width: auto;
}

.message-list-item__title {
  font-size: 150%;
}


  /*-----------------------
  サービスページ
  -----------------------*/

  .history_cont {
    width: auto;
    float: none;
  }

  /*-----------------------
  55,Eazy,おチャベリ,アスリートapp
  -----------------------*/

  .app li {
    float: none;
    padding-right: 0;
    padding-bottom: 10px;
    text-align: center;
  }

  /*-----------------------
  ライブでゴーゴー
  -----------------------*/

  .chat {	width: auto;}

  .chat li {
    float: none;
    padding-right: 0;
    padding-bottom: 20px;
    width: auto;
  }

  .chat li div { text-align: center;}

  .mission_list { padding-top: 20px;}


  /*-----------------------
  萌えチャット
  -----------------------*/

  .moe_iframe li {
    position: relative;
    float: none;
    padding-bottom: 56.25%;
    padding-top: 30px;
    width: auto;
    height: 0;
    overflow: hidden;
  }
  .moe_iframe li:last-child {
    float: none;
    margin-top: 20px;
  }

  .moe_iframe li iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
  }


  /*-----------------------
  アクセスマップ
  -----------------------*/

  .root li {
    float:none;
    text-align:center;
  }

  .root li:last-child { padding-left:0;}

  a.root01 { margin: 0 auto 50px;}

  a.root02 { margin: 0 auto;}

  .googlemaps { display: none;}

  /*-----------------------
  ニュース
  -----------------------*/

  .news-category-list {
    width: 250px;
  }
  .news-category-list li,
  .news-category-list li:last-child {
    float: none;
    margin-top: 10px;
  }

  .news-list-item-title {
    text-indent: 90px;
    font-size: 12px;
    letter-spacing: 1px;
  }
  .news-list-item-title__date { padding-right: 8px;}

  /*-----------------------
  チャットレディ・メールレディとは
  -----------------------*/
  .diagnosis {
    border-right: none;
    border-left: none;
    border-bottom: none;
  }
  .diagnosis-list-item {
    margin: auto;
  }


  /*-----------------------
  安心・安全なサービス提供のための取り組み
  -----------------------*/

  .attempt-section-detail-wrap {
    flex-wrap: wrap;
  }

  .safety-title {
    padding-bottom: 32px;
    text-align: center;
    font-size: 20px;
    font-weight: bold;
  }
  .safety-title__annotation {
    display: block;
    font-size: 14px;
    font-weight: normal;
  }


}

@media screen and (min-width:769px) {

  header#sidecontent {
    display: block;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 101;
    width: 255px;
    height: 100%;
    padding-top: 40px;
    background: #141216;
    color: #e5e5e5;
  }

  .header_title {
    font-size: 160%;
    text-align: center;
  }

  #mobile-head .fa-bars { display: none;}


  .fa { vertical-align: baseline;}
  .gnav .fa,
  .gnav .fab { padding-right: 15px;}

  nav { padding-top: 20px;}

  .gnav {
    list-style: none;
    padding: 0;
  }

  .gnav li a {
    display: block;
    margin: 0;
    padding: 15px 0 15px 20px;
    color: #b8b1bd;
    line-height: 1;
    text-decoration: none;
    cursor: pointer;
  }
  .nav_sub {
    display: none;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 100%;
    background: #ffe400;
    width: 380px;
    padding-top: 150px;
  }
  .nav_sub.news { background:#aee800;}
  .nav_sub.service { background:#ffb11a;}
  .nav_sub.governance { background:#ff6666;}
  .nav_sub.recruit  { background:#ff64a6;}
  .nav_sub.blog  { background:#3f9eff;}
  .nav_sub.contact  { background:#4ad4e9;}

  .nav_sub ul li{
    overflow: hidden;
    width: 100%;
    height: 0;
    color: #222;
  }
  .nav_sub ul li a {
    display: block;
    margin: 0;
    padding: 15px 0 15px 20px;
    color: #222;
    line-height: 1;
    text-decoration: none;
  }

  .gnav li a:hover { color: #222;}

  .nav_home:hover,
  .home a.nav_home {
    background: linear-gradient(90deg, #6fcd00, #1eb700);
    color: #222;
  }

  .nav_company:hover,
  .nav-company a.nav_company,
  .nav-company-child a.nav_company,
  #js-nav_company_b a:hover
  {
    background: linear-gradient(90deg, #ffff42, #ffe400);
    color: #222;
  }

  .nav_service:hover,
  .nav-service a.nav_service,
  .nav-service-child a.nav_service {
    background: linear-gradient(90deg, #ffcc19, #ffb11a);
    color: #222;
  }
  .nav_governance:hover,
  .nav-governance a.nav_governance,
  .nav-governance-child a.nav_governance {
    background: linear-gradient(90deg, #ff818d, #ff6666);
    color: #222;
  }
  .nav_recruit:hover,
  .nav-recruit a.nav_recruit,
  .nav-recruit-child a.nav_recruit,
  .nav-backend-engineer a.nav_recruit,
  .nav-serverside-engineer a.nav_recruit,
  .nav-ios_app-engineer a.nav_recruit,
  .single-staff a.nav_recruit,
  .post-type-archive-staff a.nav_recruit,
  .nav-job01 a.nav_recruit,
  .nav-job02 a.nav_recruit,
  .nav-job03 a.nav_recruit,
  .nav-job04 a.nav_recruit,
  .nav-job05 a.nav_recruit,
  .nav-job06 a.nav_recruit,
  .nav-job07 a.nav_recruit,
  .nav-job08 a.nav_recruit,
  .nav-job08a a.nav_recruit,
  .nav-job08b a.nav_recruit,
  .nav-job08c a.nav_recruit,
  .nav-job08d a.nav_recruit,
  .nav-internship-php a.nav_recruit,
  .nav-internship-java a.nav_recruit,
  .nav-supportstaff a.nav_recruit {
    background: linear-gradient(90deg, #ff79c8, #ff64a6);
    color: #222;
  }

  .nav-blog_ceo a.nav_blog,
  .nav_blog:hover,
  .nav-blog a.nav_blog,
  .nav-blog-child a.nav_blog,
  .single-post a.nav_blog,
  .category a.nav_blog,
  .post-type-archive-blog_developer a.nav_blog,
  .single-blog_developer a.nav_blog,
  .tax-developer_cat a.nav_blog,
  .post-type-archive-blog_human_resources a.nav_blog,
  .single-blog_human_resources a.nav_blog,
  .tax-human_resources_cat a.nav_blog,
  .post-type-archive-blog_designer a.nav_blog,
  .single-blog_designer a.nav_blog,
  .tax-designer_cat a.nav_blog,
  .post-type-archive-blog_engineer a.nav_blog,
  .single-blog_engineer a.nav_blog,
  .tax-engineer_cat a.nav_blog,
  .post-type-archive-blog_hr a.nav_blog,
  .single-blog_hr a.nav_blog,
  .tax-hr_cat a.nav_blog,
  .post-type-archive-blog_connect a.nav_blog,
  .single-blog_connect a.nav_blog,
  .tax-connect_cat a.nav_blog,
  .post-type-archive-blog_24 a.nav_blog,
  .single-blog_24 a.nav_blog,
  .tax-24_cat a.nav_blog,
  .post-type-archive-blog_director a.nav_blog,
  .single-blog_director a.nav_blog,
  .tax-director_cat a.nav_blog {
    background: linear-gradient(90deg, #3fb0ff, #3f9eff);
    color: #222;
  }

  .nav_news:hover,
  .post-type-archive-news a.nav_news,
  .single-news a.nav_news,
  .tax-news_cat a.nav_news {
    background: linear-gradient(90deg, #bef616, #aee800);
    color: #222;
  }

  .nav_contact:hover,
  .nav-contact a.nav_contact,
  .nav-contact-child a.nav_contact {
    background: linear-gradient(90deg, #56e0ec, #4ad4e9);
    color: #222;
  }

  /*-----------------------
  SNSリンク
  -----------------------*/
  .nav_sns{
      display: flex;
      justify-content: space-between;
      border-top: 1px #0a090b solid;
      border-bottom: 1px #0a090b solid;
  }
  .nav_sns li {
    display: block;
    width: 100%;
    text-align: center;
  }
  .nav_sns a {
    display: block;
    padding: 10px 0;
    color: #b8b1bd;
    width: 100%;
    font-size: 20px;
    text-decoration:none;
    position: relative;
    overflow: hidden;
  }
  .nav_sns li:last-child a{
      border: none;
  }
  .nav_sns a::before{
      position: relative;
      z-index: 10;
  }
  .nav_sns li:first-child a:hover {
    background: #55acee;
    color: #e5e5e5;
  }
  .nav_sns li:nth-child(2) a:hover {
    color: #fff;
    background: -webkit-linear-gradient(135deg, #427eff 0%, #f13f79 70%) no-repeat;
    background: linear-gradient(135deg, #427eff 0%, #f13f79 70%) no-repeat;
  }
  .nav_sns li:nth-child(2) a:hover:after{
    content: '';
    z-index:9;
    width: 60px;
    height: 60px;
    position: absolute;
    bottom: -36px;
    left: -20px;
    background: -webkit-radial-gradient(#ffdb2c 10%, rgba(255, 105, 34, 0.65) 55%, rgba(255, 88, 96, 0) 70%);
    background: radial-gradient(#ffdb2c 10%, rgba(255, 105, 34, 0.65) 55%, rgba(255, 88, 96, 0) 70%);
  }
  .nav_sns li:last-child a:hover {
    background: #e62117;
    color: #e5e5e5;
  }


  #js-nav_sub { display:none;}

  /*-----------------------
  グローバルナビゲーション
  -----------------------*/
  .gnav li > a:hover{color: #222;}
  .gnav li > a.is_hover{color: #222;}
  .gnav li.nav_home > a:hover,
  .gnav li.nav_home.current_page_parent > a{
      color: #222;
      background: linear-gradient(90deg, #6fcd00, #1eb700);
  }
  .gnav li.nav_news > a:hover,
  .gnav li.nav_news.current_page_parent > a{
      color: #222;
      background: linear-gradient(90deg, #bef616, #aee800);
  }
  .gnav li.nav_company > a:hover,
  .gnav li.nav_company.current_page_parent > a{
      color: #222;
      background: linear-gradient(90deg, #ffff42, #ffe400);
  }
  .gnav li.nav_service > a:hover,
  .gnav li.nav_service.current_page_parent > a{
      color: #222;
      background: linear-gradient(90deg, #ffcc19, #ffb11a);
  }
  .gnav li.nav_governance > a:hover,
  .gnav li.nav_governance.current_page_parent > a{
      color: #222;
      background: linear-gradient(90deg, #ff818d, #ff6666);
  }
  .gnav li.nav_recruit > a:hover,
  .gnav li.nav_recruit.current_page_parent > a{
      color: #222;
      background: linear-gradient(90deg, #ff79c8, #ff64a6);
  }
  .gnav li.nav_blog > a:hover,
  .gnav li.nav_blog.current_page_parent > a{
      color: #222;
      background: linear-gradient(90deg, #3fb0ff, #3f9eff);
  }
  .gnav li.nav_contact > a:hover,
  .gnav li.nav_contact.current_page_parent > a{
      color: #222;
      background: linear-gradient(90deg, #56e0ec, #4ad4e9);
  }

  .gnav li.nav_news .nav_sub a:hover{background-color: #96c703;}
  .gnav li.nav_company .nav_sub a:hover{background-color: #E8D006;}
  .gnav li.nav_service .nav_sub a:hover{background-color: #E49E15;}
  .gnav li.nav_governance .nav_sub a:hover{background-color: #F78989;}
  .gnav li.nav_recruit .nav_sub a:hover{background-color: #F34B93;}
  .gnav li.nav_blog .nav_sub a:hover{background-color: #2F92F7;}
  .gnav li.nav_contact .nav_sub a:hover{background-color: #2FC5DC;}

  .gnav > li:hover .nav_sub { display:block;}

  .gnav li:hover ul li{ height: inherit;}

  .gnav li.nav_news .nav_sub{background-color: #aee800;}
  .gnav li.nav_company .nav_sub{background-color: #ffe400;}
  .gnav li.nav_service .nav_sub{background-color: #ffb11a;}
  .gnav li.nav_governance .nav_sub{background-color: #ff6666;}
  .gnav li.nav_recruit .nav_sub{background-color: #ff64a6;}
  .gnav li.nav_blog .nav_sub{background-color: #3f9eff;}
  .gnav li.nav_contact .nav_sub{background-color: #4ad4e9;}

  #js-access-map { display: none;}
}

@media screen and (min-width: 769px) and (max-width: 1026px) {

  .top_slide { min-height: 550px;}

  .toptitle {
    padding: 60px 0 40px;
    font-size: 50px;
    line-height: 1.2;
  }
  .toptitle br { display: block;}

  .toptext {
    padding: 0 30px;
    font-size: 16px;
    text-align: left;
  }

  .btn { top: 450px;}

  .top_company {
    background: url(../images/index/company_bg.jpg) top center;
    background-size: cover;
    height: auto;
  }

  .top_list .top_list_block, .camp_list .camp_list_block, .nav_list .nav_list_block {
    float: none;
    margin: 0px auto 30px auto;
  }

  .top_list .top_list_block:nth-child(3n), .camp_list .camp_list_block:nth-child(3n), .nav_list .nav_list_block:nth-child(3n) {
    margin: 0px auto 30px auto
  }

  .moe_iframe li {
    float: none;
    margin: 0 auto 20px;
  }
  .moe_iframe li:last-child { float: none;}

  .office_img {
    margin: 0 auto;
    max-width: 690px;
  }

  .office_img li {
    float: none;
    margin: 0px auto 40px;
    width: 330px;
  }

  .office_img li:nth-child(3n) { margin: 0px auto 40px;}
  .office_img li:nth-child(even) { margin: 0px auto 40px;}

  .history > div {
    float: none;
  }

  .history_cont { width: auto;}

  .mission_list { padding-top: 40px;}

  .consciousness { padding: 0 10px;}

  .root li {
    float:none;
    text-align:center;
  }

  .root li:last-child { padding-left:0;}

  a.root01 { margin: 0 auto 50px;}

  a.root02 { margin: 0 auto;}

  .blog_inner {
    max-width: 1100px;
    padding: 0 10px;
    margin: 0 auto 50px;
  }

  .blog_left {
    width: auto;
    float: none;
  }

  .blog_right {
    float: none;
    margin: 0 auto;
  }

  .graph-list-item {
    float: none;
    text-align: center;
  }
  .graph-list-item:nth-child(even) { float: none;}
  .graph-list-item img { width: auto;}
}
@media screen and (min-width: 1026px) and (max-width: 1411px) {

  .top-slide-text {
    top: 20%;
    left: 50%;
    transform: translateX(-50%) translateY(-20%);
  }

  .toptitle {
    padding: 80px 0 40px;
    line-height: 1.2;
  }
  .toptitle br { display: block;}
  .toptext { text-align: center;}

  .top_list,
  .camp_list,
  .nav_list {	max-width: 690px;}

  .top_company {
    background: url(../images/index/company_bg.jpg) top center;
    background-size: cover;
    height: auto;
  }

  .top_list .top_list_block:nth-child(3n),
  .camp_list .camp_list_block:nth-child(3n),
  .nav_list .nav_list_block:nth-child(3n) { margin: 0px 30px 30px 0px;}
  .top_list .top_list_block:nth-child(2n),
  .camp_list .camp_list_block:nth-child(2n),
  .nav_list .nav_list_block:nth-child(2n) { margin: 0px 0 30px 0px;}

  .moe_iframe li {
    float: none;
    margin: 0 auto 20px;
  }
  .moe_iframe li:last-child { float: none;}

  .staff_list {
    padding: 70px 0 50px;
    max-width: 690px;
    width: 100%;
    margin: 0 auto;
  }

  .staff_list .staff_list_block:nth-child(3n) { margin: 0px 30px 30px 0px;}
  .staff_list .staff_list_block:nth-child(even) { margin: 0px 0 30px 0px;}

  .office_img {
    max-width: 690px;
    width: 100%;
    margin: 0 auto;
  }
  .office_img li {
    margin: 0px 30px 0 0px;
    height: 440px;
  }
  .office_img li:nth-child(3n) { margin: 0px 30px 0 0px;}
  .office_img li:nth-child(even) { margin: 0px 0 0 0px;}

  .history_cont { width: 60%;}

}
