/*@mixin mq-pc() {
	@media screen
	and (min-width: 980px)
	screen and (min-width: 769px){
		@content;
	}
}*/
* {
  -webkit-box-sizing: border-box;
  box-sizing: border-box; }

body, table {
  min-width: 1px; }

.people .page_top_img {
  position: relative;
  height: 700px; }
  .people .page_top_img .warp {
    background-size: 100%;
    background-attachment: fixed;
    height: 100%; }

/*@mixin mq-pc() {
	@media screen
	and (min-width: 980px)
	screen and (min-width: 769px){
		@content;
	}
}*/
.jobboard-top .page_top_img {
  position: relative;
  height: 700px; }
  .jobboard-top .page_top_img .warp {
    opacity: 0;
    height: 100%;
    background: url("../img/jobboard/jobboard-mv.jpg") center top no-repeat;
    background-size: 100% auto;
    background-attachment: fixed; }
    @media screen and (min-width: 2500px) {
      .jobboard-top .page_top_img .warp {
        background-size: 2500px auto; } }
    @media screen and (min-width: 2101px) {
      .jobboard-top .page_top_img .warp {
        background-position: center 15%; } }
    @media screen and (min-width: 1700px) and (max-width: 2100px) {
      .jobboard-top .page_top_img .warp {
        background-position: center top; } }
    @media screen and (max-width: 1500px) {
      .jobboard-top .page_top_img .warp {
        background-size: auto 100%;
        background-position: center top; } }
    .jobboard-top .page_top_img .warp .page_title {
      opacity: 0;
      position: absolute;
      top: 50%;
      left: 13.5%;
      -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
      transform: translateY(-50%); }
      .jobboard-top .page_top_img .warp .page_title h2, .jobboard-top .page_top_img .warp .page_title p {
        text-shadow: 0px 0px 30px #FFF, 0px 0px 30px #FFF, 3px 7px 40px #FFF, -3px -7px 40px #FFF; }
      .jobboard-top .page_top_img .warp .page_title h2 {
        color: #2A2F88;
        font-size: 120px;
        line-height: 1; }
      .jobboard-top .page_top_img .warp .page_title p {
        color: #DC2525;
        font-size: 22px;
        font-weight: bold;
        line-height: 100%;
        /*text-shadow:
					0px 0px 30px #FFF,
					0px 0px 30px #FFF,
					0px 0px 30px #FFF,
					3px 7px 40px #FFF,
					3px 7px 40px #FFF,
					3px 7px 40px #FFF,
					-3px 3px 30px #FFF,
					-3px 3px 30px #FFF,
					;*/ }

.jobboard-top_warp {
  padding-top: 130px;
  padding-bottom: 200px; }
  .jobboard-top_warp h2 {
    text-align: center;
    position: relative;
    color: #2A2F88;
    font-size: 67px;
    letter-spacing: 2px;
    z-index: 10; }
    .jobboard-top_warp h2 small {
      display: block;
      color: #B4B4B5;
      font-size: 18px;
      font-weight: bold;
      line-height: 35px; }
    .jobboard-top_warp h2:before {
      position: absolute;
      content: '';
      background: url("../img/interview/h2_icon.png") no-repeat 0 0;
      width: 15px;
      height: 15px;
      top: -10px;
      margin-left: -20px; }
  .jobboard-top_warp .h2_small {
    text-align: center;
    font-size: 19px;
    margin-top: 27px;
    line-height: 28px;
    color: #191919; }
  .jobboard-top_warp.content_width {
    max-width: 2500px; }

.jobboard-top_title {
  /*max-width: 1480px;*/
  margin: 0 auto 90px;
  padding-top: 30px;
  position: relative;
  overflow: hidden; }
  .jobboard-top_title:after {
    position: absolute;
    content: '';
    width: 100%;
    height: 60%;
    right: 42%;
    top: 0;
    background: url(../img/top/content1_bg.png) right top no-repeat;
    background-size: cover; }

.jobboard-top .job-art {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  max-width: 780px;
  margin: 0 auto; }
  .jobboard-top .job-art:not(:last-child) {
    margin-bottom: 67px; }
  .jobboard-top .job-art dt {
    width: 310px;
    padding-top: 10px; }
    .jobboard-top .job-art dt span {
      display: inline-block;
      position: relative;
      font-size: 24px;
      font-weight: bold;
      padding-left: 54px;
      line-height: 1.3;
      text-shadow: 0.5px 0px 0 #595757; }
      .jobboard-top .job-art dt span:after {
        position: absolute;
        content: '';
        width: 40px;
        height: 3px;
        left: 0;
        top: 15px;
        background: #2A2F88; }
  .jobboard-top .job-art dd {
    margin: 0;
    width: -webkit-calc(100% - 310px);
    width: -moz-calc(100% - 310px);
    width: calc(100% - 310px); }

.jobboard-top .job-list li + li {
  margin-top: 20px; }

.jobboard-top .job-list li a {
  display: block;
  color: #2A2F88;
  font-size: 21px;
  font-weight: bold;
  text-align: center;
  border: 2px solid #2A2F88;
  padding: 20px;
  text-shadow: 0.5px 0px 0 #2A2F88; }
  .jobboard-top .job-list li a:hover {
    opacity: 0.7; }

/*@mixin mq-pc() {
	@media screen
	and (min-width: 980px)
	screen and (min-width: 769px){
		@content;
	}
}*/
.jobboard-detail .page_top_img {
  position: relative;
  height: 500px; }
  .jobboard-detail .page_top_img .warp {
    opacity: 0;
    height: 100%;
    background: url("../img/jobboard/jobboard-kv.jpg") center top no-repeat;
    background-size: 100% auto;
    background-attachment: fixed;
    /*@media screen and (max-width: 980px) {
			background-size: 980px auto;
			background-position: 0px 0px;
		}*/ }
    @media screen and (min-width: 2500px) {
      .jobboard-detail .page_top_img .warp {
        background-size: 2500px auto; } }
    @media screen and (min-width: 2101px) {
      .jobboard-detail .page_top_img .warp {
        background-position: center 15%; } }
    @media screen and (min-width: 1700px) and (max-width: 2100px) {
      .jobboard-detail .page_top_img .warp {
        background-position: center top; } }
    @media screen and (max-width: 1500px) {
      .jobboard-detail .page_top_img .warp {
        background-size: auto 100%;
        background-position: center bottom; } }

.job-entry_warp {
  padding: 120px 0 160px; }
  .job-entry_warp .content_width {
    max-width: 900px;
    min-width: 900px; }

.job-entry_title {
  margin-bottom: 50px; }
  .job-entry_title h1 {
    font-size: 30px;
    color: #595757;
    text-shadow: 0.5px 0px 0 #595757;
    position: relative;
    padding-left: 42px; }
    .job-entry_title h1:after {
      position: absolute;
      content: '';
      left: 0;
      top: 50%;
      margin-top: -14px;
      width: 28px;
      height: 28px;
      background: url(../img/jobboard/h2_icon.png) left top no-repeat;
      background-size: cover; }

.job-entry_head {
  font-size: 19px;
  margin-bottom: 60px; }

.job-info {
  margin-bottom: 70px; }
  .job-info_ttl {
    font-size: 24px;
    padding-left: 15px;
    margin-bottom: 20px;
    color: #595757;
    text-shadow: 0.5px 0px 0 #595757;
    position: relative; }
    .job-info_ttl:after {
      position: absolute;
      content: '';
      width: 5px;
      height: 30px;
      left: 0;
      top: 3px;
      background: #DC2525;
      border-radius: 10px; }
  .job-info_tbl {
    font-size: 17px;
    width: 100%;
    max-width: 900px;
    min-width: 900px;
    margin: 0 auto;
    border-collapse: collapse;
    background: url(../img/environment/tb-line.png) left top no-repeat;
    background-size: 100% 1px; }
    .job-info_tbl th, .job-info_tbl td {
      background: url(../img/environment/tb-line.png) left bottom no-repeat;
      background-size: 100% 1px;
      text-align: left;
      padding: 15px;
      -webkit-box-sizing: border-box;
      box-sizing: border-box;
      font-size: 17px;
      vertical-align: top; }
    .job-info_tbl th {
      width: 235px; }
    .job-info_tbl a {
      color: #2A2F88;
      text-shadow: 0.5px 0px 0 #2A2F88; }

.job-schedule {
  margin-bottom: 140px; }
  .job-schedule .job-info_ttl {
    margin-bottom: 0; }
  .job-schedule ul li {
    margin-top: 20px;
    float: left;
    border: 2px solid #2A2F88;
    font-size: 18px;
    font-weight: bold;
    color: #2A2F88;
    text-align: center;
    padding: 20px; }
    .job-schedule ul li + li {
      margin-left: 50px;
      position: relative; }
      .job-schedule ul li + li:after {
        position: absolute;
        content: '';
        left: -32px;
        top: 50%;
        margin-top: -12px;
        width: 0;
        height: 0;
        border-top: 10px solid transparent;
        border-bottom: 10px solid transparent;
        border-left: 14px solid #2A2F88; }

.job-btn.content_width {
  max-width: 1000px;
  min-width: 1000px; }

.job-btn .apply-btn {
  display: block;
  color: #fff;
  background: #DC2525;
  text-align: center;
  font-size: 42px;
  position: relative;
  padding-top: 38px;
  padding-bottom: 32px; }
  .job-btn .apply-btn span {
    position: relative;
    z-index: 5; }
  .job-btn .apply-btn .back {
    content: '';
    display: block;
    width: 0%;
    height: 100%;
    background: #F02525;
    position: absolute;
    top: 0;
    z-index: 0;
    -webkit-transition: width 300ms cubic-bezier(0.455, 0.03, 0.515, 0.955);
    -o-transition: width 300ms cubic-bezier(0.455, 0.03, 0.515, 0.955);
    transition: width 300ms cubic-bezier(0.455, 0.03, 0.515, 0.955); }
  .job-btn .apply-btn:hover .back {
    width: 100%; }

.job-info_tbl h1:first-child, .job-info_tbl h2:first-child, .job-info_tbl h3:first-child, .job-info_tbl h4:first-child {
  margin-top: 0; }

.job-info_tbl p, .job-info_tbl li {
  font-size: 17px;
  color: #595757; }

.job-info_tbl ul li {
  list-style: disc;
  margin-left: 30px; }

.job-info_tbl p {
  margin-bottom: 10px; }

@media screen and (min-width: 769px) {
  .show_pc {
    display: inline-block; }
  .show_sp {
    display: none; } }

@media screen and (max-width: 768px) {
  /*@mixin mq-pc() {
	@media screen
	and (min-width: 980px)
	screen and (min-width: 769px){
		@content;
	}
}*/
  .jobboard-top .page_top_img {
    position: relative;
    height: 320px; }
    .jobboard-top .page_top_img .warp {
      opacity: 0;
      height: 100%;
      background: url("../img/jobboard/jobboard-mv_sp.jpg") center top no-repeat;
      background-size: 100% auto;
      background-attachment: fixed; } }
    @media screen and (max-width: 768px) and (max-width: 768px) {
      .jobboard-top .page_top_img .warp {
        background-size: 100% auto;
        background-position: center top; } }

@media screen and (max-width: 768px) {
      .jobboard-top .page_top_img .warp .page_title {
        opacity: 0;
        position: absolute;
        top: 71%;
        left: 13.5%;
        -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
        transform: translateY(-50%); }
        .jobboard-top .page_top_img .warp .page_title h2 {
          font-size: 52px; }
        .jobboard-top .page_top_img .warp .page_title p {
          font-size: 13px; }
  .jobboard-top_warp {
    padding-top: 30px;
    padding-bottom: 80px; }
    .jobboard-top_warp h2 {
      font-size: 34px; }
      .jobboard-top_warp h2 small {
        font-size: 12px;
        line-height: 1.7; }
      .jobboard-top_warp h2:before {
        width: 10px;
        height: 10px;
        top: -10px;
        margin-left: -12px;
        background-size: 100%; }
    .jobboard-top_warp .h2_small {
      font-size: 12px;
      margin-top: 20px;
      line-height: 1.7; }
    .jobboard-top_warp.content_width {
      max-width: 2500px; }
  .jobboard-top_title {
    /*max-width: 1480px;*/
    margin: 0 auto 30px;
    padding-top: 20px;
    position: relative;
    overflow: hidden; }
    .jobboard-top_title:after {
      position: absolute;
      content: '';
      width: 100%;
      height: 45%;
      right: 30%;
      top: 5%;
      background: url(../img/top/content1_bg.png) right top no-repeat;
      background-size: cover; }
  .jobboard-top .job-art {
    display: block;
    width: 100%;
    padding: 0 20px; }
    .jobboard-top .job-art:not(:last-child) {
      margin-bottom: 40px; }
    .jobboard-top .job-art dt {
      width: 100%;
      padding-top: 0;
      margin: 0 0 15px 0; }
      .jobboard-top .job-art dt span {
        font-size: 13px;
        padding-left: 25px; }
        .jobboard-top .job-art dt span:after {
          width: 20px;
          height: 2px;
          left: 0;
          top: 7px; }
    .jobboard-top .job-art dd {
      margin: 0;
      width: 100%;
      padding: 0 25px; }
  .jobboard-top .job-list li + li {
    margin-top: 15px; }
  .jobboard-top .job-list li a {
    font-size: 13px;
    border: 1px solid #2A2F88;
    padding: 10px; }
  /*@mixin mq-pc() {
	@media screen
	and (min-width: 980px)
	screen and (min-width: 769px){
		@content;
	}
}*/
  .jobboard-detail .page_top_img {
    position: relative;
    height: 240px; }
    .jobboard-detail .page_top_img .warp {
      opacity: 0;
      height: 100%;
      background: url("../img/jobboard/jobboard-kv_sp.jpg") center top no-repeat;
      background-size: 100% auto;
      background-attachment: fixed; }
  .job-entry_warp {
    padding: 60px 20px 60px; }
    .job-entry_warp .content_width {
      min-width: 1px; }
  .job-entry_title {
    margin-bottom: 30px; }
    .job-entry_title h1 {
      font-size: 15px;
      color: #595757;
      text-shadow: 0.5px 0px 0 #595757;
      position: relative;
      padding-left: 20px; }
      .job-entry_title h1:after {
        margin-top: -8px;
        width: 14px;
        height: 14px; }
  .job-entry_head {
    font-size: 12px;
    margin-bottom: 40px; }
  .job-info {
    margin-bottom: 50px; }
    .job-info_ttl {
      font-size: 13px;
      padding-left: 10px;
      margin-bottom: 15px;
      color: #595757;
      text-shadow: 0.5px 0px 0 #595757;
      position: relative; }
      .job-info_ttl:after {
        position: absolute;
        content: '';
        width: 3px;
        height: 15px;
        left: 0;
        top: 3px;
        background: #DC2525;
        border-radius: 10px; }
    .job-info_tbl {
      font-size: 12px;
      width: 100%;
      min-width: 1px; }
      .job-info_tbl th, .job-info_tbl td {
        display: block;
        padding: 15px 0;
        font-size: 12px; }
      .job-info_tbl th {
        width: 100%;
        background: none;
        padding-bottom: 0; }
      .job-info_tbl td {
        padding: 7px 0 15px; }
      .job-info_tbl a {
        color: #2A2F88;
        text-shadow: 0.5px 0px 0 #2A2F88; }
  .job-schedule {
    margin-bottom: 60px; }
    .job-schedule ul {
      display: block; }
      .job-schedule ul li {
        width: 100%;
        border: 1px solid #2A2F88;
        font-size: 13px;
        padding: 10px; }
        .job-schedule ul li + li {
          margin: 30px 0 0 0; }
          .job-schedule ul li + li:after {
            position: absolute;
            content: '';
            left: 50%;
            top: -22px;
            margin-top: 0;
            margin-left: -12px;
            width: 0;
            height: 0;
            border-left: 8px solid transparent;
            border-right: 8px solid transparent;
            border-top: 12px solid #2A2F88; }
  .job-btn.content_width {
    min-width: 1px; }
  .job-btn .apply-btn {
    font-size: 21px;
    padding-top: 18px;
    padding-bottom: 18px; }
  .content_width {
    min-width: 1px; }
  footer .footer_content {
    margin: 0; }
  footer .copyright {
    margin: 0; }
  .show_pc {
    display: none; }
  .show_sp {
    display: inline-block; } }

/*# sourceMappingURL=jobboard.css.map */