@charset "UTF-8";
/* CSS Document */
@media screen and (max-width: 1023px) {
  body {
    -webkit-text-size-adjust: 100%;
    width: 100%;
    min-width: 100% !important;
    padding-top: 60px;
  }

  .pc {
    display: none !important;
  }

  .sp {
    display: block !important;
  }

  /* HEADER */
  header {
    width: 100%;
  }

  header .wrap {
    min-width: 100%;
    height: 60px;
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }

  header img {
    width: 165px;
  }

  header .wrap .logo a {
    font-size: 10px;
  }

  .header-btn {
    display: none;
  }

  /* MENU */
  .menu_toggle > div {
    position: relative;
    height: 29px;
    width: 40px;
    z-index: 10002;
    top: 0;
    right: 0;
  }

  .menu_toggle > div:hover {
    cursor: pointer;
  }

  .menu_toggle > div > span {
    display: block;
    width: inherit;
    height: 3px;
    background: #fff;
    position: absolute;
    left: 0;
    -webkit-transition: all 0.3s 0s ease;
    transition: all 0.3s 0s ease;
  }

  .menu_toggle > div > span:nth-of-type(2) {
    top: 12px;
  }

  .menu_toggle > div > span:last-of-type {
    top: 24px;
  }

  .menu_toggle.open > div > span {
    width: 40px;
    top: 12px;
    left: 0;
    background-color: #fff;
  }

  nav.menu {
    padding: 60px 2em 2em;
  }

  /* FOOTER */
  footer {
    padding: 20px 0 0;
    width: 100%;
  }

  footer .wrap {
    display: block;
    width: 100%;
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
  }

  .footer-menu1 li,
.footer-ulwrap .footer-menu2 {
    width: 50%;
  }

  .footer-ulwrap {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }

  .footer-ulwrap .footer-menu2:nth-of-type(n + 3) {
    margin-left: 50%;
  }

  footer ul li a {
    padding: 0.5em 0;
    font-size: 12px;
    display: block;
  }

  footer ul li a.entry {
    padding: 0.3em 1em;
    font-size: 12px;
    display: inline-block;
    border: 1px solid #000;
    margin-top: 1em;
  }

  .footer-copywrap {
    display: block;
    text-align: center;
  }

  .copyright {
    font-size: 12px;
    line-height: 1;
    padding-top: 1.5em;
  }

  /*TOP*/
  .mv {
    width: 100%;
    height: 100%;
    background: url(../img/mv.png) no-repeat;
    background-size: cover;
    position: relative;
    margin-top: -60px;
    padding-top: 60px;
    background-position: center top;
    padding-bottom: 20px;
  }

  .mv ul {
    width: 100%;
    padding: 0 4% 20px;
    height: auto;
    display: block;
    position: relative;
  }
  .mv ul li {
    width: 100%;
    margin: 20px auto;
    max-width: 400px;
  }
  .mv ul li a h2 {
    font-size: 17px;
  }
  .mv ul li a h2 span {
    font-size: 20px;
  }
  .mv ul li.graduate a, .mv ul li.career a {
    width: 100%;
    height: 100px;
    background-size: cover;
  }
  .mv ul li.part a {
    width: 100%;
    height: 100px;
    background-size: contain;
    padding-left: 0;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .mv ul li.part a h2 {
    text-align: center;
    font-size: 17px;
  }
  .mv ul li.part a h2 span {
    font-size: 20px;
  }

  /*新卒・中途各トップ*/
  .mv_g {
    /*height: 440px;*/
    z-index: 1;
    margin-top: -60px;
  }

  .mv_g ul.slider li.mv1 {
    /*
    background-position: center right 35%;
    height: 440px;*/
  }

  .mv_g ul.slider li .txt {
    position: absolute;
    margin: auto;
    top: 60%;
    right: auto;
    left: 4%;
    -webkit-transform: translateY(-40%);
    transform: translateY(-40%);
  }

  .mv_g ul.slider li .txt .ttl {
    font-size: 21px;
  }

  .mv_g ul.slider li .txt .ttl .rubik_i {
    font-size: 28px;
  }

  .mv_g ul.slider li .txt p {
    font-size: 11px;
  }

  .mv_g .newswrap {
    display: block;
    bottom: -58px;
  }
  .mv_g .newswrap dt {
    width: 100%;
    font-size: 14px;
    text-align: left;
    padding: 0.25em 4%;
  }
  .mv_g .newswrap dd {
    width: 100%;
    font-size: 13px;
    padding: 0.5em 4%;
    text-overflow: ellipsis;
    white-space: nowrap;
    overflow: hidden;
  }
  .news_txt_link {
    margin: 58px auto 0;
    padding: 2em 4% 0;
    width: 100%;
  }
  .news_txt_link a{
    font-size: 14px;
  }
  .pagelist1g ul {
    width: 100%;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    padding: 0 1%;
  }
  .pagelist1g ul li {
    width: 44%;
    margin: 30px 3%;
    -webkit-box-shadow: 3px 3px 0 #e4e8ea;
            box-shadow: 3px 3px 0 #e4e8ea;
  }
  .pagelist1g ul li a {
    height: 175px;
  }
  .pagelist1g ul li a .box {
    padding: 0.5em 0;
    height: auto;
    min-height: 81px;
  }

  .pagelist1g ul li a .box::before {
    content: "";
    border: 1px solid #fff;
    width: calc(100% + 8px);
    height: calc(100% + 8px);
    display: block;
    position: absolute;
    left: -4px;
    top: -4px;
  }

  .pagelist1g ul li a::after {
    content: "";
    position: absolute;
    bottom: 10px;
    right: 10px;
    display: block;
    width: 20px;
    height: 20px;
    background: url(../img/ic1.svg) no-repeat;
    background-size: contain;
    z-index: 1;
    -webkit-transition: 0.25s;
    transition: 0.25s;
  }

  .pagelist1g ul li a .slug {
    font-size: 32px;
    left: -4px;
    top: -30px;
  }

  .pagelist1g ul li a .box .ttl {
    font-size: 17px;
    width: 100%;
  }
  .pagelist1g ul li a .box .ttl span {
    font-size: 12px;
  }

  .pagelist1g ul li a .box p {
    font-size: 10px;
  }

  .pagelist1g ul li a.service,
.pagelist1g ul li a.work,
.pagelist1g ul li a.training,
.pagelist1g ul li a.plan {
    background-size: cover;
  }

  .pagelist1g::before {
    display: none;
  }

  .pagelist1g {
    padding: 30px 0 50px;
  }
  .pagelist1g.gtop {
    padding-bottom: 50px;
  }

  .message_g {
    height: auto;
    background-size: cover;
    padding-bottom: 40px;
  }
  .message_g .wrap {
    width: 100%;
    padding: 0 4%;
    margin: 0 auto;
    height: auto;
  }
  .message_g .wrap img {
    position: relative;
    left: 0;
    top: 0;
    margin-top: -30px;
    width: 70%;
  }
  .message_g .wrap .box {
    position: relative;
    top: 0;
    right: 0;
    margin-top: -50px;
    margin-left: auto;
    width: 96%;
    -webkit-box-shadow: 3px 3px 0 #0068b7;
            box-shadow: 3px 3px 0 #0068b7;
    padding: 2em 1em;
  }
  .message_g .wrap .box .ttl {
    font-size: 20px;
  }
  .message_g .wrap .box p {
    font-size: 13px;
  }

  .message_g .wrap .box .slug {
    font-size: 30px;
    right: 0;
    top: -0.8em;
  }

  .message_g .wrap .btn {
    display: block;
    width: 260px;
    margin: 20px auto 0;
    border: 2px solid #000;
    text-align: center;
    position: relative;
    left: 0;
    bottom: 0;
    padding: 1em 0;
    font-size: 15px;
  }

  .message_g .wrap .btn::before {
    content: "";
    right: 15px;
    top: calc(50% - 10px);
    width: 20px;
    height: 20px;
    z-index: 1;
    background: url(../img/ic_b.svg) no-repeat;
    background-size: cover;
  }

  .parsonlist {
    padding: 40px 0 60px;
  }
  .parsonlist .ttl {
    font-size: 20px;
    padding-bottom: 1em;
    margin-top: 0.25em;
  }
  .parsonlist .ttl span {
    font-size: 12px;
    padding-left: 0;
    padding-top: 0.75em;
  }
  .parsonlist ul {
    display: block;
    padding: 0 4%;
  }
  .parsonlist ul li {
    width: auto;
    max-width: 300px;
    margin-bottom: 30px;
    margin-left: auto;
    margin-right: auto;
  }
  .parsonlist ul li .name {
    padding-top: 1.5em;
    font-size: 16px;
  }
  .parsonlist ul li .name::before {
    width: 22px;
    height: 22px;
  }
  .parsonlist ul li .name span.degree {
    font-size: 12px;
    padding-right: 2em;
  }
  .parsonlist ul li .name span.join {
    font-size: 12px;
  }
  .parsonlist ul li p {
    font-size: 14px;
  }
  .parsonlist ul li img {
    -webkit-box-shadow: 3px 3px 0 #e4e8ea;
            box-shadow: 3px 3px 0 #e4e8ea;
  }
  .parsonlist .tolistbtn {
    width: 225px;
  }

  .parsonlist .tolistbtn {
    display: block;
    width: 260px;
    margin: 20px auto 0;
    border: 2px solid #000;
    text-align: center;
    position: relative;
    left: 0;
    bottom: 0;
    padding: 1em 0;
    font-size: 15px;
  }

  .parsonlist .tolistbtn::before {
    content: "";
    right: 15px;
    top: calc(50% - 10px);
    width: 20px;
    height: 20px;
    z-index: 1;
    background: url(../img/ic_b.svg) no-repeat;
    background-size: cover;
  }

  .tosympobtn {
    width: 92%;
    margin: 40px auto 0 auto;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    display: block;
    height: auto;
    padding-bottom: 2em;
  }
  .tosympobtn::before {
    content: "";
    position: absolute;
    left: 4px;
    top: 4px;
    display: block;
    width: calc(100% - 8px);
    height: calc(100% - 8px);
  }
  .tosympobtn img {
    top: -5px;
    margin: 0 auto;
  }
  .tosympobtn .ttl {
    font-size: 25px;
    padding-bottom: 0.5em;
  }
  .tosympobtn .ttl span {
    font-size: 17px;
    display: inline;
    padding-left: 1em;
  }
  .tosympobtn .desc {
    width: 96%;
    margin: 0 auto;
  }
  .tosympobtn .desc span {
    font-size: 14px;
  }

  .pagelist2g {
    height: auto;
    background-size: 200%;
    background-repeat: repeat;
    padding-bottom: 2em;
  }
  .pagelist2g ul {
    width: 84%;
    display: block;
    padding: 10px 0;
    margin: 0 auto;
    max-width: 340px;
  }
  .pagelist2g ul li {
    width: 100%;
    margin: 2em auto 0 auto;
  }
  .pagelist2g ul li::before {
    width: 28px;
}

  .pagelist2g ul li .slug {
    font-size: 30px;
    margin-left: -0.25em;
  }
  .pagelist2g ul li .ttl {
    font-size: 20px;
    margin-top: 0.75em;
  }
  .pagelist2g ul li p {
    font-size: 14px;
  }

  .footer_link {
    background: url(../img/footerlink_bg_sp.png) no-repeat center top;
    height: auto;
    padding: 40px 0 50px;
  }
  .footer_link ul {
    width: 100%;
    display: block;
    position: relative;
  }
  .footer_link ul::before {
    content: "Smile&Heartful";
    font-family: "Rubik-It";
    text-align: center;
    display: block;
    position: absolute;
    left: 0;
    right: 0;
    top: -1.1em;
    bottom: 0;
    margin: 0 auto;
    font-size: 40px;
    opacity: 0.4;
    color: #fff;
  }
  .footer_link ul li a {
    display: block;
    width: 260px;
    margin: 20px auto 0;
    border: 2px solid #0068b7;
    text-align: center;
    position: relative;
    left: 0;
    bottom: 0;
    padding: 0.25em 0;
    font-size: 30px;
    height: auto;
  }
  .footer_link ul li a::before {
    content: "";
    right: 15px;
    top: calc(50% - 10px);
    width: 20px;
    height: 20px;
    z-index: 1;
    background: url(../img/ic_ao.svg) no-repeat;
    background-size: cover;
  }

  .footer_link ul li:last-of-type a {
    border: 2px solid #000;
    color: #000;
    font-size: 15px;
    font-weight: 700;
    padding: 1.5em 0;
    margin-top: 0.75em;
  }

  .footer_link ul li:last-of-type a::before {
    content: "";
    position: absolute;
    right: 15px;
    top: calc(50% - 10px);
    display: block;
    width: 20px;
    height: 20px;
    background: url(../img/ic_b.svg) no-repeat;
    background-size: contain;
  }

  /*中途採用TOP*/
  .mv_c {
    /*height: 330px;*/
    z-index: 1;
    margin-top: 0;
  }

  .mv_c ul.slider li.mv1 {
    /*
    background-position: center right 37%;
    height: 330px;
    */
  }

  .mv_c ul.slider li .txt {
    position: absolute;
    margin: auto;
    top: 50%;
    left: 4%;
    -webkit-transform: translateY(-40%);
            transform: translateY(-40%);
  }

  .mv_c ul.slider li .txt .ttl .rubik_i {
    font-size: 28px;
  }

  .mv_c ul.slider li .txt p {
    font-size: 11px;
  }

  .about_c {
    padding: 60px 4%;
  }
  .about_c .box {
    width: 100%;
    padding: 4em 4% 2em;
    -webkit-box-shadow: 3px 3px 0 #123072;
            box-shadow: 3px 3px 0 #123072;
  }
  .about_c .box .txt {
    width: 100%;
  }
  .about_c .box .txt .ttl3 {
    font-size: 20px;
    margin-bottom: 0.5em;
    padding-bottom: 0.5em;
  }
  .about_c .box .txt p {
    font-size: 13px;
  }
  .about_c .box .ttl {
    font-size: 20px;
    top: -15px;
    left: 4%;
  }
  .about_c .box .ttl span.rubik_i {
    font-size: 30px;
  }
  .about_c .box .btn {
    position: relative;
    left: 0;
    bottom: 0;
    width: 260px;
    text-align: center;
    font-size: 15px;
    padding-right: 1em;
    margin: 2em auto 0 auto;
  }
  .about_c .box .btn::before {
    width: 20px;
    height: 20px;
    top: calc(50% - 10px);
    background-size: cover;
  }

  .pagelist1g.type_c {
    padding: 30px 0 0;
  }
  .pagelist1g.type_c::before, .pagelist1g.type_c::after {
    display: none;
  }
  .pagelist1g.type_c ul {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
    padding: 0 1%;
  }
  .pagelist1g.type_c ul li {
    width: 44%;
    margin: 30px 3%;
    -webkit-box-shadow: 3px 3px 0 #e4e8ea;
            box-shadow: 3px 3px 0 #e4e8ea;
  }
  .pagelist1g.type_c ul li a {
    height: 175px;
  }
  .pagelist1g.type_c ul li a .slug {
    letter-spacing: -0.05em;
  }

  .reclist_c {
    padding: 30px 0;
  }
  .reclist_c > .ttl {
    font-size: 20px;
    padding-bottom: 20px;
  }
  .reclist_c ul {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
    display: block;
  }
  .reclist_c ul li {
    width: 100%;
    margin-bottom: 20px;
    margin-right: 0;
  }
  .reclist_c ul li a .head .job, .reclist_c ul li a .head .area {
    font-size: 16px;
  }
  .reclist_c ul li a .ttl {
    font-size: 18px;
  }
  .reclist_c ul li a p span {
    font-size: 14px;
  }
  .reclist_c ul li a .btn {
    font-size: 14px;
  }
  .reclist_c .reclist_btn {
    width: 260px;
    padding-right: 1em;
    font-size: 15px;
  }
  .reclist_c .reclist_btn:before {
    content: "";
    right: 15px;
    top: calc(50% - 10px);
    width: 20px;
    height: 20px;
    background-size: cover;
  }

  .parsonlist.type_c {
    padding: 0 0 60px;
  }

  .parsonlist.type_c .ttl {
    font-size: 12px;
  }
  .parsonlist.type_c .ttl span.rubik_i {
    font-size: 30px;
  }

  .pagelist2g.type_c {
    padding-bottom: 3em;
  }

  .footer_link.type_c ul li:last-of-type a {
    width: 320px;
    padding-right: 1em;
  }

  .footer_link.type_c ul::before {
    display: none;
  }

  /* CONTENTS ------------*/
  .ttl2cmn {
    height: 120px;
    font-size: 25px;
  }
  .ttl2cmn span {
    font-size: 12px;
  }

  .pankuzu ul {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
    flex-wrap: wrap;
  }
  .pankuzu ul li {
    font-size: 12px;
  }
  .pankuzu ul li a {
    font-size: 12px;
  }

  /*中途採用*/
  .search_box {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
    padding-top: 30px;
  }
  .search_box .ttl {
    font-size: 16px;
  }
  .search_box ul.job_search {
    padding: 0.75em;
    margin-bottom: 15px;
  }
  .search_box ul.job_search:nth-last-of-type(3n) {
    margin-right: 1%;
  }
  .search_box ul.job_search li {
    width: 32%;
    margin-right: 1%;
  }
  .search_box ul.job_search li label {
    font-size: 12px;
    margin-top: 0.25em;
    margin-bottom: 0.25em;
    padding: 0.25em  0.25em 0.25em  0.5em;
    height: auto;
  }
  .search_box ul.job_search li label input {
    margin-right: 0.25em;
  }
  .search_box ul.area_search {
    padding: 0.75em;
    margin-bottom: 15px;
  }
  .search_box ul.area_search:nth-last-of-type(3n) {
    margin-right: 1%;
  }
  .search_box ul.area_search li {
    width: 32%;
    margin-right: 1%;
  }
  .search_box ul.area_search li label {
    font-size: 12px;
    margin-top: 0.25em;
    margin-bottom: 0.25em;
    padding: 0 0.25em 0 0.5em;
    height: 30px;
  }
  .search_box ul.area_search li label input {
    margin-right: 0.25em;
  }

  .rec_campaign {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
    margin-bottom: 30px;
  }

  
  .rec_campaign .ttl {
    font-size: 18px;
  }
  .rec_campaign p {
    text-align: left;
    font-size: 13px;
    padding: 0.75em 1em;
  }
  .rec_campaign.part a.btn {
    font-size: 14px;
    width: 100%;
}
.rec_campaign.part a.btn::before {
  right: 20px;
  top: calc(50% - 9px);
  width: 18px;
  height: 18px;
}

  .rec_list ul {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
    padding-top: 30px;
    padding-bottom: 30px;
  }
  .rec_list ul li a {
    -webkit-box-shadow: 0 0 3px rgba(18, 48, 114, .4);
            box-shadow: 0 0 3px rgba(18, 48, 114, .4);
    padding: 0.75em 0.5em;
    margin-bottom: 10px;
  }
  .rec_list ul li a .ttl3 {
    padding: 0.25em;
    font-size: 13px;
    margin-bottom: 0.25em;
  }
  .rec_list ul li a .ttl3 span {
    padding: 0.1em 1em;
    font-size: 12px;
    background-color: #fff;
    border-radius: 10px;
    margin-right: 0.5em;
    white-space: nowrap;
  }
  .rec_list ul li a dl {
    width: 98%;
    margin: 0 auto;
    padding-bottom: 0.25em;
    margin-bottom: 0.25em;
  }
  .rec_list ul li a dl dt {
    font-size: 14px;
    padding: 0.25em 0.75em 0.25em 0;
    width: 70px;
  }
  .rec_list ul li a dl dd {
    font-size: 12px;
    padding: 0.5em 0;
    width: calc(100% - 70px);
  }

  .bnr_service {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
    margin-top: 30px;
  }
  .bnr_service a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
    height: 110px;
    background: url(../img/bnr_service.png) no-repeat center top;
    background-size: cover;
    position: relative;
  }
  .bnr_service a:hover .wrap::before {
    right: 0;
    opacity: 0;
    -webkit-transition: 0.5s;
    transition: 0.5s;
  }
  .bnr_service a::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    display: block;
    width: 100%;
    height: 100%;
    background: -webkit-gradient(linear, right top, left top, color-stop(1%, #123072), to(transparent));
    background: linear-gradient(to left, #123072 1%, transparent);
  }
  .bnr_service a::after {
    content: "";
    position: absolute;
    left: 5px;
    top: 5px;
    display: block;
    width: calc(100% - 10px);
    height: calc(100% - 10px);
    border: 1px solid #fff;
  }
  .bnr_service a .wrap {
    color: #fff;
    font-size: 19px;
    font-weight: 900;
    text-align: right;
    padding-right: 3em;
    display: block;
    position: relative;
  }
  .bnr_service a .wrap::before {
    content: "";
    position: absolute;
    right: 1em;
    bottom: calc(50% - 15px);
    width: 20px;
    height: 20px;
    display: block;
    background: url(../img/ic1.svg) no-repeat;
    z-index: 2;
    background-size: cover;
  }
  .bnr_service a .wrap .txt {
    font-size: 12px;
    display: block;
    padding-top: 0.5em;
  }
  .bnr_service a .wrap .rubik_i {
    color: #fff;
    font-size: 17px;
    opacity: 0.6;
    display: block;
  }

  #career .bnr_msg {
    margin-top: 0;
  }

  .bnr_msg {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
    margin-top: -30px;
  }
  .bnr_msg a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
    height: 110px;
    background-size: cover;
    position: relative;
  }
  .bnr_msg a:hover .wrap::before {
    right: 0;
    opacity: 0;
    -webkit-transition: 0.5s;
    transition: 0.5s;
  }
  .bnr_msg a::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    display: block;
    width: 100%;
    height: 100%;
    background: -webkit-gradient(linear, right top, left top, color-stop(1%, #0068b7), to(transparent));
    background: linear-gradient(to left, #0068b7 1%, transparent);
  }
  .bnr_msg a::after {
    content: "";
    position: absolute;
    left: 5px;
    top: 5px;
    display: block;
    width: calc(100% - 10px);
    height: calc(100% - 10px);
    border: 1px solid #fff;
  }
  .bnr_msg a .wrap {
    color: #fff;
    font-size: 19px;
    font-weight: 900;
    text-align: right;
    padding-right: 3em;
    display: block;
    position: relative;
  }
  .bnr_msg a .wrap::before {
    content: "";
    position: absolute;
    right: 1em;
    bottom: calc(50% - 15px);
    width: 20px;
    height: 20px;
    display: block;
    background: url(../img/ic1.svg) no-repeat;
    z-index: 2;
    background-size: cover;
  }
  .bnr_msg a .wrap .txt {
    font-size: 12px;
    display: block;
    padding-top: 0.5em;
  }
  .bnr_msg a .wrap .rubik_i {
    color: #fff;
    font-size: 17px;
    opacity: 0.6;
    display: block;
  }

  /*募集要項（求人詳細）*/
  .rec_table {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
    padding-top: 30px;
  }
  .rec_table .ttl3 {
    font-size: 18px;
  }
  .rec_table dl {
    display: block;
    margin-top: -1px;
  }
  .rec_table dl dt {
    font-size: 14px;
    text-align: left;
    padding: 1em;
    width: 100%;
    display: block;
  }
  .rec_table dl dd {
    font-size: 12px;
    padding: 1em;
    margin-left: 0;
    margin-top: -1px;
    width: 100%;
  }
  .rec_table dl dd address {
    font-size: 14px;
  }
  .rec_table .req_btn {
    display: block;
    padding: 10px 0;
  }
  .rec_table .req_btn li {
    width: 88%;
    margin: 20px auto;
  }
  .rec_table .req_btn li a {
    display: block;
    width: 100%;
    padding: 1em 0;
    text-align: center;
    position: relative;
    background-color: #0068b7;
    color: #fff;
    font-size: 14px;
    font-weight: 700;
    border: 1px solid #0068b7;
  }
  .rec_table .req_btn li a:hover::before {
    right: 0;
    opacity: 0;
    -webkit-transition: 0.5s;
    transition: 0.5s;
  }
  .rec_table .req_btn li a::before {
    content: "";
    position: absolute;
    right: 20px;
    top: calc(50% - 10px);
    display: block;
    width: 20px;
    height: 20px;
    background: url(../img/ic1.svg) no-repeat;
    background-size: contain;
    -webkit-transition: 0.25s;
    transition: 0.25s;
  }
  .rec_table .req_btn li:last-of-type a {
    background-color: #fff;
    color: #0068b7;
    font-size: 14px;
    font-weight: 700;
  }
  .rec_table .req_btn li:last-of-type a:hover::before {
    right: 0;
    opacity: 0;
    -webkit-transition: 0.5s;
    transition: 0.5s;
  }
  .rec_table .req_btn li:last-of-type a::before {
    content: "";
    position: absolute;
    right: 20px;
    top: calc(50% - 10px);
    display: block;
    width: 20px;
    height: 20px;
    background: url(../img/ic_ao.svg) no-repeat;
    background-size: contain;
    -webkit-transition: 0.25s;
    transition: 0.25s;
  }

  .entryform {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
    padding-top: 30px;
  }
  .entryform .ttl3 {
    font-size: 18px;
  }
  .entryform dl {
    display: block;
    margin-top: -1px;
  }
  .entryform dl dt {
    font-size: 14px;
    text-align: left;
    padding: 1em;
    width: 100%;
    display: block;
  }
  .entryform dl dd {
    font-size: 12px;
    padding: 1em;
    margin-left: 0;
    margin-top: -1px;
    width: 100%;
  }
  .entryform dl dd address {
    font-size: 14px;
  }
  .entryform .req_btn {
    display: block;
    padding: 10px 0;
  }
  .entryform .req_btn li {
    width: 88%;
    margin: 20px auto;
  }
  .entryform .req_btn li a {
    display: block;
    width: 100%;
    padding: 1em 0;
    text-align: center;
    position: relative;
    background-color: #0068b7;
    color: #fff;
    font-size: 14px;
    font-weight: 700;
    border: 1px solid #0068b7;
  }
  .entryform .req_btn li a:hover::before {
    right: 0;
    opacity: 0;
    -webkit-transition: 0.5s;
    transition: 0.5s;
  }
  .entryform .req_btn li a::before {
    content: "";
    position: absolute;
    right: 20px;
    top: calc(50% - 10px);
    display: block;
    width: 20px;
    height: 20px;
    background: url(../img/ic1.svg) no-repeat;
    background-size: contain;
    -webkit-transition: 0.25s;
    transition: 0.25s;
  }
  .entryform .req_btn li:last-of-type a {
    background-color: #fff;
    color: #0068b7;
    font-size: 14px;
    font-weight: 700;
  }
  .entryform .req_btn li:last-of-type a:hover::before {
    right: 0;
    opacity: 0;
    -webkit-transition: 0.5s;
    transition: 0.5s;
  }
  .entryform .req_btn li:last-of-type a::before {
    content: "";
    position: absolute;
    right: 20px;
    top: calc(50% - 10px);
    display: block;
    width: 20px;
    height: 20px;
    background: url(../img/ic_ao.svg) no-repeat;
    background-size: contain;
    -webkit-transition: 0.25s;
    transition: 0.25s;
  }

  .list .ttl1 {
    background-color: #000099;
    font-size: 20px;
    color: #fff;
    padding: 1em 0;
    text-align: center;
    font-weight: bold;
    width: calc(100% + 20px);
    margin-left: -10px;
  }

  ul.archive li {
    display: block;
    position: relative;
    padding-bottom: 2em;
    margin-bottom: 2.5em;
  }

  ul.archive li::after {
    content: "";
    position: absolute;
    display: block;
    width: calc(100% + 20px);
    height: 1px;
    bottom: 0;
    left: -10px;
    background-color: #e2e2e2;
  }

  ul.archive li a img {
    width: 100%;
    height: auto;
    margin-right: 0;
  }

  .list_head {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    font-size: 14px;
    margin-bottom: 1em;
    margin-top: 1em;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }

  .blog_navi {
    padding-bottom: 50px;
  }

  .blog_navi ul li {
    margin: 0.5em 0.5em 2.5em 0.5em;
  }

  .single_head {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    font-size: 16px;
  }

  .single_head .cat {
    margin-top: 0.5em;
  }

  .single .ttl1 {
    font-size: 28px;
    font-weight: bold;
    margin-top: 0.5em;
  }

  .single .post {
    padding-bottom: 60px;
  }

  .single .post h2:first-of-type {
    margin-top: 40px;
  }

  .single .post h2 {
    margin-top: 50px;
  }

  .single .post p {
    margin-top: 1.5em;
  }

  .single .single_tab a {
    font-size: 16px;
  }

  .single .auth_box img {
    width: 100%;
    max-width: 180px;
    height: auto;
    display: block;
    margin: 0 auto 20px auto;
  }

  .single .contact_box .btn a {
    width: 100%;
    max-width: 380px;
    font-size: 14px;
  }

  .single .post_navi {
    width: calc(100% + 20px);
    margin-left: -10px;
  }

  .single .post_navi li a .post_navi_head {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }

  .single .post_navi li a .post_navi_head time {
    width: 100%;
  }

  .single .post_navi li a .post_navi_head .cat {
    margin-left: 0;
  }

  .single .ttl2 {
    background-color: #000099;
    font-size: 20px;
    color: #fff;
    padding: 1em 0;
    text-align: center;
    font-weight: bold;
    width: calc(100% + 20px);
    margin-left: -10px;
  }

  #contact {
    padding: 40px 0 40px 0;
  }

  #contact p {
    text-align: center;
    font-size: 14px;
    padding: 3em auto 0 auto;
    width: 94%;
  }

  #contact table {
    margin: 20px auto 0 auto;
    width: 94%;
    font-size: 15px;
    line-height: 2;
  }

  #contact table th {
    width: 100%;
    display: block;
    padding: 0.5em;
    text-align: left;
    vertical-align: top;
  }

  #contact table th span.type1 {
    font-size: 12px;
    color: #fff;
    background-color: #B71515;
    padding: 0.25em 0.5em;
    position: relative;
    margin-left: 1em;
  }

  #contact table th span.type1::before {
    content: "必須";
  }

  #contact table th span.type2 {
    font-size: 12px;
    color: #fff;
    background-color: #353535;
    padding: 0.25em 0.5em;
    position: relative;
    margin-left: 1em;
  }

  #contact table th span.type2::before {
    content: "任意";
  }

  #contact table td {
    width: 100%;
    display: block;
    padding: 0.5em 0.5em 0.5em 0.5em;
  }

  #contact table input[type=text],
#contact table input[type=tel],
#contact table input[type=email],
#contact table textarea,
#contact table select {
    -webkit-transition: all 0.3s ease 0s;
    transition: all 0.3s ease 0s;
    width: 100%;
    padding: 8px 15px;
    border: solid 1px #d8d8d8;
    border-radius: 0;
    line-height: 22px;
    vertical-align: bottom;
    -webkit-appearance: none;
  }

  #contact table input {
    margin-right: 5px;
  }

  #contact table label {
    display: block;
    margin-bottom: 0.5em;
  }

  #contact .privacy {
    width: 94%;
    margin: 20px auto 0 auto;
    border: 1px solid #A5A5A5;
    padding: 1em;
    text-align: left;
    height: 150px;
    overflow-y: scroll;
  }

  #contact .privacy .ttl {
    font-size: 13px;
    font-weight: bold;
  }

  #contact .privacy p {
    font-size: 11px;
    margin-top: 2em;
    text-align: left;
    padding: 0;
    line-height: 1.75;
  }

  input[type=submit],
input[type=button] {
    border-radius: 0;
    -webkit-box-sizing: content-box;
    -webkit-appearance: button;
    -moz-appearance: button;
         appearance: button;
    border: none;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    cursor: pointer;
  }

  input[type=submit]::-webkit-search-decoration,
input[type=button]::-webkit-search-decoration {
    display: none;
  }

  input[type=submit]::focus,
input[type=button]::focus {
    outline-offset: -2px;
  }

  .btnwrap {
    text-align: center;
    margin-top: 30px;
  }

  .btnwrap input[type=submit].sendbtn {
    margin-top: 1em;
  }

  .btnwrap input[type=submit] {
    -webkit-transition: all 0.3s ease 0s;
    transition: all 0.3s ease 0s;
    display: inline-block;
    width: 280px;
    margin: 0 20px;
    padding: 18px 0;
    border: none;
    text-align: center;
    font-size: 11px;
    font-size: 1.1rem;
    color: #fff;
    cursor: pointer;
    border-radius: 5px;
  }

  /*社員一覧*/
  .person_list > ul {
    display: block;
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
    padding-top: 2em;
    padding-bottom: 2em;
  }
  .person_list > ul li {
    width: 100%;
    max-width: 346px;
    margin-right: 0;
    margin-bottom: 2em;
  }
  .person_list > ul li:nth-of-type(3n) {
    margin-right: 0;
  }
  .person_list > ul li a {
    display: block;
    width: 100%;
    height: 100%;
    position: relative;
  }
  .person_list > ul li a .degree {
    position: absolute;
    left: 1em;
    top: 1em;
    display: inline-block;
    background-color: #fff;
    font-size: 14px;
    padding: 0.25em 0.5em;
    color: #0068b7;
    font-weight: 900;
  }
  .person_list > ul li a .ttl3 {
    background-color: #ccdde5;
    padding: 1em;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    font-weight: 900;
    font-size: 16px;
    position: relative;
    margin-top: -1px;
  }
  .person_list > ul li a .ttl3 span {
    font-size: 12px;
    font-weight: 900;
    color: #5e5e5e;
    padding-left: 1em;
  }
  .person_list > ul li a .ttl3::before {
    content: "";
    position: absolute;
    right: 1em;
    top: calc(50% - 10px);
    display: block;
    width: 20px;
    height: 20px;
    background: url(../img/ic_ao.svg) no-repeat;
    background-size: contain;
    -webkit-transition: 0.25s;
    transition: 0.25s;
  }
  .person_list > ul li a p {
    padding: 1em;
    font-size: 14px;
  }

  .blog_navi {
    margin-top: 0;
    margin-bottom: 0;
  }

  .blog_navi ul {
    width: 98%;
    margin: 0 auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    font-size: 12px;
  }

  /*社員詳細*/
  .person_head .bgwrap {
    height: 300px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
    background-size: cover;
    padding-bottom: 1em;
    background-position: center top;
  }
  .person_head .bgwrap p {
    font-size: 16px;
    font-weight: 900;
    color: #fff;
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
    text-shadow: 0 0 5px rgba(0, 0, 0, .75);
    padding-bottom: 0.75em;
    line-height: 1.4;
  }
  .person_head .bgwrap .degree {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
    padding-bottom: 0.25em;
  }
  .person_head .bgwrap .degree span {
    font-size: 12px;
    font-weight: 900;
    color: #fff;
    background-color: #0068b7;
    padding: 0.25em 0.5em;
    display: inline-block;
  }
  .person_head .bgwrap .kana {
    font-size: 25px;
    color: #fff;
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
    text-shadow: 0 0 5px rgba(0, 0, 0, .75);
  }
  .person_head .bgwrap .ttl3 {
    font-size: 20px;
    color: #fff;
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
    text-shadow: 0 0 5px rgba(0, 0, 0, .75);
  }
  .person_head .data_box {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
  }
  .person_head .data {
    margin-top: 1.5em;
    padding: 0;
    width: 100%;
    background-color: #fff;
    border: 1px solid #b2b2b2;
    -webkit-box-shadow: 0 0 0 #e5e5e5;
            box-shadow: 0 0 0 #e5e5e5;
  }
  .person_head .data .ttl {
    background-color: #d0e7f4;
    color: #0068b7;
    font-size: 16px;
    font-weight: 900;
    padding: 0.5em 1em;
  }
  .person_head .data dl {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .person_head .data dl dt {
    border-top: 1px solid #b2b2b2;
    width: 50%;
    padding: 0.6em 1em;
    font-size: 13px;
    color: #0068b7;
  }
  .person_head .data dl dd {
    border-top: 1px solid #b2b2b2;
    border-left: 1px solid #b2b2b2;
    width: 50%;
    padding: 0.6em;
    font-size: 13px;
  }

  .person_qa .ttl {
    font-size: 20px;
    font-weight: 900;
    text-align: left;
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
    padding-top: 3em;
    color: #0068b7;
  }
  .person_qa ul {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
  }
  .person_qa ul li {
    display: block;
    padding-top: 2em;
  }
  .person_qa ul li:nth-of-type(even) {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-flow: row-reverse;
            flex-flow: row-reverse;
  }
  .person_qa ul li img {
    width: 100%;
  }
  .person_qa ul li dl {
    width: 100%;
    padding-top: 1em;
  }
  .person_qa ul li dl.full {
    width: 100%;
  }
  .person_qa ul li dl dt {
    font-size: 16px;
    font-weight: 700;
    color: #44494c;
    line-height: 1.75;
    padding-bottom: 1em;
    margin-bottom: 1em;
    position: relative;
  }
  .person_qa ul li dl dt span {
    font-size: 20px;
    display: block;
    color: #0068b7;
    opacity: 0.6;
  }
  .person_qa ul li dl dt::before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    display: block;
    height: 1px;
    width: 142px;
    background-color: #0068b7;
  }
  .person_qa ul li dl dd {
    font-size: 14px;
    line-height: 2;
  }

  .person_oneday {
    margin-top: 3em;
    background-color: #edf5f9;
    padding-bottom: 3em;
  }
  .person_oneday .ttl {
    font-size: 20px;
    padding: 2em 0 1em;
    text-align: center;
    color: #0068b7;
    font-weight: 900;
  }
  .person_oneday dl {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
    display: block;
    margin-top: 1em;
  }
  .person_oneday dl:first-of-type dt, .person_oneday dl:last-of-type dt {
    background-color: #0068b7;
  }
  .person_oneday dl dt {
    width: 80px;
    height: 30px;
    border-radius: 0;
    background-color: #80bce0;
    color: #fff;
    font-size: 16px;
    font-weight: 900;
    text-align: center;
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .person_oneday dl dt::before {
    display: none;
  }
  .person_oneday dl dd {
    width: 100%;
    font-size: 16px;
    background-color: #fff;
    color: #0068b7;
    border: 1px solid #0068b7;
    padding: 0.5em 1em;
    font-weight: 900;
  }

  /*ニュース*/
  .news_list_sec {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
  }
  .news_list_sec ul.news_list {
    padding: 3em 0 4em;
  }
  .news_list_sec ul.news_list li span, .news_list_sec ul.news_list li a {
    display: block;
    padding: 0.75em 0;
    border-bottom: 1px dashed #cccdce;
  }
  .news_list_sec ul.news_list li span time, .news_list_sec ul.news_list li a time {
    width: auto;
    color: #0068b7;
    font-size: 14px;
    font-weight: 900;
    text-align: left;
    padding: 0.5em 1em;
    display: inline-block;
  }
  .news_list_sec ul.news_list li span .ttl3, .news_list_sec ul.news_list li a .ttl3 {
    width: 100%;
    font-size: 14px;
    padding: 1em 1em 0.25em 1em;
  }

  /*代表メッセージ*/
  .msg1 {
    background: url(../img/msg.png) no-repeat center top;
    height: 190px;
    background-size: cover;
  }
  .msg1 .wrap {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
  }
  .msg1 .wrap .ttl3 {
    padding: 3.5em 0 0 30%;
    font-size: 16px;
    text-align: center;
    font-weight: 700;
  }
  .msg1 .wrap .ttl3 span {
    font-size: 10px;
    font-weight: 900;
    text-align: center;
    display: block;
    color: #939393;
    padding-top: 0.5em;
  }
  .msg1 .wrap .box {
    width: 70%;
    background-color: #fff;
    margin: 1em 0 0 auto;
    text-align: center;
    padding: 0.5em 1.75em;
    -webkit-box-shadow: 3px 3px 0 #b7b7b7;
            box-shadow: 3px 3px 0 #b7b7b7;
    font-size: 10px;
  }
  .msg1 .wrap .box .degree {
    text-align: center;
    padding-bottom: 0.5em;
    margin-bottom: 0.5em;
    color: #0068b7;
    font-weight: 900;
    border-bottom: 1px solid #bababa;
  }
  .msg1 .wrap .box .name {
    font-size: 12px;
  }
  .msg1 .wrap .box .name span {
    color: #a0a0a0;
    font-weight: 700;
    padding-left: 1em;
  }

  .msg2 .ttl3 {
    font-size: 18px;
    text-align: center;
    font-weight: 900;
    padding-top: 3em;
  }
  .msg2 .ttl3 span {
    color: #0068b7;
    font-weight: 900;
  }
  .msg2 ul li {
    display: block;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
    padding-top: 2em;
  }
  .msg2 ul li .txt {
    width: 100%;
  }
  .msg2 ul li .txt .rubik_i {
    font-size: 20px;
    opacity: 0.6;
    color: #0068b7;
  }
  .msg2 ul li .txt .q {
    font-size: 12px;
    font-weight: 700;
    position: relative;
    color: #44494c;
    margin-top: 0.5em;
    margin-bottom: 1em;
    padding-bottom: 1em;
  }
  .msg2 ul li .txt .q::before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    display: block;
    height: 1px;
    width: 46%;
    background-color: #0068b7;
  }
  .msg2 ul li .txt p {
    font-size: 12px;
    line-height: 2;
  }
  .msg2 ul img {
    margin: 1em auto 0 auto;
    display: block;
  }
  .msg2 ul li:nth-of-type(even) {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-flow: row-reverse;
            flex-flow: row-reverse;
  }

  /*取り扱いブランド一覧*/
  .brand_list {
    margin-top: 3em;
    background: url(../img/brand_bg.png) no-repeat center top #f2f6fb;
    background-size: 180% auto;
    padding-bottom: 2em;
  }
  .brand_list > .ttl {
    font-size: 20px;
    text-align: center;
    padding-top: 1.5em;
    padding-bottom: 0.25em;
    font-weight: 900;
  }
  .brand_list ul {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
  }
  .brand_list ul li {
    margin-top: 2em;
    width: 48%;
    background-color: #fff;
    -webkit-box-shadow: 6px 6px 0 #e4e8ea;
            box-shadow: 6px 6px 0 #e4e8ea;
    padding: 1em 1em 1.5em 1em;
  }
  .brand_list ul li .ttl {
    height: 4em;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    border-bottom: 4px solid #0068b7;
    font-size: 12px;
    font-weight: 700;
    color: #0068b7;
  }
  .brand_list ul li p {
    font-size: 10px;
    padding-top: 0.5em;
  }
  .brand_list ul li p .target {
    background-color: #0068b7;
    color: #fff;
    display: inline-block;
    border-radius: 15px;
    margin: 0.5em 0;
    padding: 0.15em 0.75em;
  }
  .brand_list ul li p .old {
    display: block;
  }

  /*インターン情報*/
  .intern1 {
    background: url(../img/intern_bg.png) no-repeat center top;
    background-size: cover;
    height: 360px;
    overflow-x: hidden;
  }
  .intern1 .wrap {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
    position: relative;
  }
  .intern1 .wrap .box {
    position: absolute;
    left: 0;
    top: 30px;
    width: 65%;
    background-color: #fff;
    -webkit-box-shadow: 3px 3px 0 #0068b7;
            box-shadow: 3px 3px 0 #0068b7;
    padding: 1em 1em 1.5em;
    z-index: 2;
  }
  .intern1 .wrap .box .rubik_i {
    font-size: 20px;
    color: #0068b7;
    opacity: 0.6;
    margin-top: -1.5em;
  }
  .intern1 .wrap .box .ttl3 {
    font-size: 16px;
    font-weight: 900;
    color: #0068b7;
    margin: 0.25em 0 0.5em;
    padding-bottom: 0.25em;
    border-bottom: 1px solid #bababa;
  }
  .intern1 .wrap .box p {
    font-size: 12px;
  }
  .intern1 .wrap img {
    position: absolute;
    right: -15px;
    top: 60px;
    z-index: 1;
  }

  section .ttl3cmn {
    font-size: 20px;
    text-align: center;
    color: #0068b7;
    padding: 1em 0 0.5em;
    font-weight: 900;
  }
  section .ttl3cmn span.intern2 {
    font-size: 12px;
    font-weight: 900;
    display: block;
    color: #000;
    padding-top: 0.5em;
  }

  .intern2 {
    padding-bottom: 20px;
  }
  .intern2 ul {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
  }
  .intern2 ul li {
    border: 2px solid #7fb3db;
    -webkit-box-shadow: 3px 3px 0 #e4e8ea;
            box-shadow: 3px 3px 0 #e4e8ea;
    padding: 1.5em;
    display: block;
    margin-bottom: 2em;
  }
  .intern2 ul li .txt {
    width: 290px;
  }
  .intern2 ul li .txt .rubik_i {
    font-size: 30px;
    margin-top: -1.4em;
    color: #0068b7;
    opacity: 0.6;
  }
  .intern2 ul li .txt .ttl {
    padding: 0.5em 0;
    font-size: 13px;
    font-weight: 900;
    color: #0068b7;
  }
  .intern2 ul li .txt p {
    font-size: 12px;
  }
  .intern2 ul li img {
    width: 181px;
    display: block;
    margin: 1em auto 0;
  }
  .intern2 .note {
    font-size: 12px;
    font-weight: 900;
    text-align: center;
    padding-top: 0.5em;
  }
  .intern2 .box {
    background-color: #f2f2f2;
    border-radius: 5px;
    width: 94%;
    margin: 2em auto 0 auto;
    text-align: center;
    padding: 0.5em 2em 1.25em;
  }
  .intern2 .box .ttl {
    font-size: 20px;
    font-weight: 900;
    color: #0068b7;
    padding: 0.1em 0 0.25em;
    border-bottom: 1px solid #bababa;
  }
  .intern2 .box p {
    font-size: 12px;
    margin-top: 1em;
  }

  .intern3 {
    background-color: #edf5f9;
    padding-bottom: 40px;
  }
  .intern3 ul {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
    display: block;
    margin: 1em auto 0 auto;
  }
  .intern3 ul li {
    width: 94%;
    max-width: 350px;
    margin: 0 auto 2em auto;
    background-color: #fff;
    position: relative;
    border: 1px solid #cecece;
  }
  .intern3 ul li .rubik_i {
    position: absolute;
    left: 0.5em;
    top: -0.75em;
    font-size: 15px;
    color: #0068b7;
    opacity: 0.6;
  }
  .intern3 ul li .ttl {
    font-size: 14px;
    font-weight: 900;
    padding: 0.75em 0.75em 0;
    color: #0068b7;
  }
  .intern3 ul li p {
    font-size: 12px;
    padding: 0.75em 0.75em 1.25em;
  }

  /*文系・理系特集*/
  .science1 {
    background: url(../img/science_bg1.png) no-repeat center top;
    background-size: cover;
    height: auto;
    position: relative;
    display: block;
    padding: 1em 0;
  }
  .science1 .ttl3 {
    position: relative;
    z-index: 2;
    text-align: center;
    font-size: 20px;
    color: #fff;
    font-weight: 900;
    width: 100%;
    padding-bottom: 1em;
  }
  .science1 .ttl3 .sub {
    display: inline-block;
    font-size: 10px;
    font-weight: 900;
    padding: 0.5em 1em;
    border-radius: 15px;
    margin-bottom: 0.5em;
  }
  .science1 .ttl3 .yellow {
    font-weight: 900;
  }
  .science1 .ttl3::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: auto;
    bottom: 0.25em;
    display: block;
    width: 114px;
    height: 1px;
    background-color: #fff;
    margin: 0 auto;
  }
  .science1 p {
    text-align: center;
    font-size: 12px;
    font-weight: 900;
    color: #fff;
    position: relative;
    z-index: 2;
  }

  .science2 {
    padding-bottom: 20px;
  }
  .science2 ul {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
  }
  .science2 ul li {
    display: block;
    margin-top: 20px;
  }
  .science2 ul li .txt {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
  }
  .science2 ul li .txt .ttl3 {
    font-size: 20px;
    font-weight: 900;
    color: #0068b7;
    position: relative;
    margin-bottom: 0.5em;
  }
  .science2 ul li .txt .ttl3 span {
    opacity: 0.1;
    font-size: 30px;
    color: #0068b7;
    display: block;
    margin-bottom: -0.8em;
  }
  .science2 ul li .txt .ttl3::before {
    content: "";
    position: absolute;
    left: 0;
    top: auto;
    bottom: -0.25em;
    display: block;
    width: 114px;
    height: 1px;
    margin: 0 auto;
  }
  .science2 ul li .txt p {
    font-size: 12px;
    padding-top: 0.25em;
    padding-bottom: 0.5em;
  }
  .science2 ul li img {
    width: 170px;
    margin: 10px auto 0 auto;
    display: block;
  }
  .science2 ul .dl_bg {
    width: 100%;
    display: block;
    background-color: #f0f1f2;
    padding: 0.75em 0.75em;
    margin-top: 2em;
  }
  .science2 ul .dl_bg dl {
    margin-bottom: 0.5em;
    padding-bottom: 0.5em;
    border-bottom: 1px solid #555;
  }
  .science2 ul .dl_bg dl dt {
    width: 60px;
    padding: 0.5em 0;
    text-align: center;
    color: #fff;
    font-size: 13px;
    font-weight: 900;
  }
  .science2 ul .dl_bg dl dd {
    width: calc(100% - 60px);
    color: #555;
    font-weight: 900;
    font-size: 12px;
    padding: 0 0.5em;
  }

  /*教育・研修*/
  .training1 {
    background: url(../img/training_bg.png) no-repeat center top;
    background-size: cover;
    height: auto;
    padding: 20px 0;
  }
  .training1 .box {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
    padding: 2em 3em;
    -webkit-box-shadow: 3px 3px 0 #e4e8ea;
            box-shadow: 3px 3px 0 #e4e8ea;
  }
  .training1 .box .rubik_i {
    position: absolute;
    right: 0.5em;
    top: -0.75em;
    font-size: 20px;
    opacity: 0.7;
  }
  .training1 .box .ttl3 {
    font-size: 20px;
    text-align: center;
    margin-bottom: 0.5em;
  }
  .training1 .box .ttl3 span {
    font-weight: 900;
  }
  .training1 .box p {
    font-size: 12px;
  }

  .training2 {
    background: url(../img/training_txtbg.png) no-repeat center 1em;
    padding-bottom: 20px;
  }
  .training2 > .ttl {
    text-align: center;
    font-size: 20px;
    padding: 1em 0;
  }
  .training2 > ul {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
  }
  .training2 > ul > li {
    position: relative;
    margin-top: 30px;
  }
  .training2 > ul > li .txt {
    background: url(../img/training_bg1.png) no-repeat center top;
    background-size: cover;
    padding: 2em;
    width: 100%;
    margin-left: 0;
  }
  .training2 > ul > li .txt .ttl3 {
    font-size: 16px;
    font-weight: 900;
    color: #fff;
    border-bottom: 1px solid #fff;
    padding-bottom: 0.25em;
  }
  .training2 > ul > li .txt .ttl3 .slug {
    font-size: 10px;
    display: block;
  }
  .training2 > ul > li .txt p {
    font-size: 12px;
    color: #fff;
    padding-top: 1em;
  }
  .training2 > ul > li .txt .voice_box {
    background-color: #fff;
    padding: 1.5em;
    margin-top: 1em;
  }
  .training2 > ul > li .txt .voice_box .ttl {
    font-size: 14px;
    font-weight: 900;
    color: #0068b7;
    padding-bottom: 0.5em;
  }
  .training2 > ul > li .txt .voice_box ul li {
    font-size: 12px;
    margin-left: 1em;
    text-indent: -1em;
    margin-bottom: 0.25em;
  }
  .training2 > ul > li .txt .voice_box ul li::before {
    content: "●";
    color: #0068b7;
  }
  .training2 > ul > li img {
    position: relative;
    top: 0;
    left: 0;
    display: block;
    margin: -1em auto 0;
    width: 90%;
  }
  .training2 > ul > li:nth-of-type(even) .txt {
    background: url(../img/training_bg1.png) no-repeat center top;
    background-size: cover;
    padding: 2em;
    margin-left: auto;
    margin-right: 0;
  }
  .training2 > ul > li:nth-of-type(even) img {
    position: relative;
    top: 0;
    left: 0;
    display: block;
    margin: -1em auto 0;
  }
  .training2 > ul > li:nth-of-type(3) .txt {
    background: url(../img/training_bg3.png) no-repeat center top;
    background-size: cover;
  }
  .training2 > ul > li:nth-of-type(4) .txt {
    background: url(../img/training_bg4.png) no-repeat center top;
    background-size: cover;
  }
  .training2 > ul > li:nth-of-type(5) .txt {
    background: url(../img/training_bg5.png) no-repeat center top;
    background-size: cover;
  }
  .training2 > ul > li:nth-of-type(6) .txt {
    background: url(../img/training_bg6.png) no-repeat center top;
    background-size: cover;
  }
  .training2 > ul > li:nth-of-type(7) .txt {
    background: url(../img/training_bg7.png) no-repeat center top;
    background-size: cover;
  }

  /*UIターン*/
  .turn1 {
    background: url(../img/turn_bg.png) no-repeat center top;
    background-size: cover;
    padding: 2em 0;
  }
  .turn1 .wrap {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
  }
  .turn1 .wrap .ttl3 {
    font-size: 20px;
    font-weight: 900;
    margin-bottom: 0.75em;
  }
  .turn1 .wrap .ttl3 span {
    display: inline-block;
    font-weight: 900;
    padding: 0.25em 0.25em;
    margin-bottom: 0.25em;
  }
  .turn1 .wrap p {
    font-size: 12px;
    padding: 1em;
    width: 100%;
  }

  .turn_u_bg {
    background: url(../img/turn_bg2.svg) no-repeat center 1em #f2f6fb;
    padding: 0 0 3em;
    background-size: auto 3em;
  }

  .turn_i_bg {
    background: url(../img/turn_bg3.svg) no-repeat center 1em;
    padding: 0;
    background-size: auto 3em;
  }

  .turn2 .ttl3 {
    text-align: center;
    font-size: 20px;
    font-weight: 900;
    color: #0068b7;
    padding: 1.5em 0 0;
  }
  .turn2 .ttl3 span {
    display: inline-block;
    padding: 0.25em 0.25em;
    color: #fff;
    font-weight: 900;
    background-color: #0068b7;
    margin-right: 0.25em;
  }
  .turn2 ul.list1 {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
    display: block;
  }
  .turn2 ul.list1 li {
    width: 100%;
    max-width: 300px;
    margin: 2em auto 0 auto;
    background-color: #fff;
  }
  .turn2 ul.list1 li .txt {
    font-size: 12px;
    font-weight: 900;
    color: #0068b7;
    padding: 1em 1em 0.25em 1em;
  }
  .turn2 ul.list1 li p {
    font-size: 12px;
    padding: 0 1 1em 1;
    word-break: break-all;
  }

  .turn3 {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
    width: 92%;
    margin-top: 2.5em;
    padding: 1.5em;
    background-color: #fff;
    -webkit-box-shadow: 0 0 2px rgba(81, 81, 81, .5);
            box-shadow: 0 0 2px rgba(81, 81, 81, .5);
  }
  .turn3 .ttl3 {
    text-align: center;
    font-size: 16px;
    font-weight: 900;
    padding-bottom: 1em;
    margin-bottom: 1em;
    position: relative;
  }
  .turn3 .ttl3 span {
    font-weight: 900;
    color: #0068b7;
  }
  .turn3 .ttl3::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: auto;
    bottom: 0;
    display: block;
    width: 127px;
    height: 1px;
    background-color: #9ac8e5;
    margin: 0 auto;
  }
  .turn3 ul li {
    border: 1px solid rgba(154, 200, 229, .4);
    background-color: rgba(242, 246, 251, .4);
    font-size: 12px;
    padding: 1em 1.25em;
    margin: 2em 0 0 auto;
    width: calc(100% - 30px);
    position: relative;
  }
  .turn3 ul li::before {
    content: "";
    position: absolute;
    left: -37px;
    top: calc(50% - 13px);
    display: block;
    width: 27px;
    height: 27px;
    background: url(../img/turn_ic.svg) no-repeat;
    background-size: contain;
  }

  .turn4 {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
    padding: 4em 0 2em;
  }
  .turn4 .ttl3 {
    text-align: center;
    font-size: 20px;
    font-weight: 900;
  }
  .turn4 .ttl3 .blue {
    font-weight: 900;
    font-size: 25px;
    color: #0068b7;
  }
  .turn4 .ttl3 .bg {
    font-size: 15px;
    font-weight: 900;
    padding: 0.75em;
    border-radius: 50%;
    margin-right: 1em;
  }
  .turn4 .rank_wrap {
    display: block;
    margin-top: 2em;
  }
  .turn4 .rank_wrap .box {
    width: 92%;
    margin: 2em auto 0 auto;
  }
  .turn4 .rank_wrap .box .ttl {
    background: url(../img/turn_ic2.svg) no-repeat 0.5em center #0068b7;
    font-size: 16px;
    text-align: center;
    font-weight: 900;
    color: #fff;
    padding: 0.25em;
    background-size: 1em;
  }
  .turn4 .rank_wrap .box:last-of-type .ttl {
    background-size: 1em;
  }
  .turn4 .rank_wrap .box .rank_list {
    padding: 1.25em;
  }
  .turn4 .rank_wrap .box .rank_list li {
    border-bottom: 1px solid #bababa;
    padding-bottom: 0.5em;
    font-size: 12px;
    font-weight: 700;
  }
  .turn4 .rank_wrap .box .rank_list li .rank span {
    font-weight: 900;
    font-size: 18px;
    color: #999999;
    padding-right: 0.25em;
    margin-bottom: -0.25em;
    display: inline-block;
  }

  /*事業内容*/
  .service1 {
    background: url(../img/service_bg1.png) no-repeat center top;
    background-size: cover;
    height: 400px;
    overflow-x: hidden;
  }
  .service1 .wrap {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
    position: relative;
  }
  .service1 .wrap .box {
    position: absolute;
    left: 0;
    top: 30px;
    width: 75%;
    background-color: #fff;
    -webkit-box-shadow: 3px 3px 0 #0068b7;
            box-shadow: 3px 3px 0 #0068b7;
    padding: 1em 1em 1.5em;
    z-index: 2;
  }
  .service1 .wrap .box .rubik_i {
    font-size: 20px;
    margin-top: -1.5em;
  }
  .service1 .wrap .box .ttl3 {
    font-size: 16px;
    font-weight: 900;
    margin: 0.25em 0 0.5em;
    padding-bottom: 0.25em;
    border-bottom: 1px solid #bababa;
  }
  .service1 .wrap .box .ttl {
    font-size: 13px;
  }
  .service1 .wrap .box p {
    font-size: 12px;
  }
  .service1 .wrap img {
    position: absolute;
    right: -15px;
    top: 60px;
    z-index: 1;
  }

  .service2 {
    background: url(../img/service_bg2.svg) no-repeat center;
    background-size: cover;
    padding: 3em 0;
  }
  .service2 .rubik_i {
    font-size: 30px;
    color: #0068b7;
    opacity: 0.7;
    text-align: center;
  }
  .service2 .youtube {
    position: relative;
    width: 94%;
    margin-left: 3%;
    padding-top: 52.25%;
  }
  .service2 .youtube iframe {
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
    margin-top: 1em;
  }

  .service3 {
    padding: 3em 0 0;
  }
  .service3 .ttl3 {
    font-size: 20px;
    text-align: center;
  }
  .service3 img {
    display: block;
    margin: 2em auto 0 auto;
    width: 94%;
  }

  #career .service1 .wrap .box {
    -webkit-box-shadow: 3px 3px 0 #123072;
            box-shadow: 3px 3px 0 #123072;
  }

  /*座談会*/
  .sympo1 {
    background: url(../img/sympo_bg1.svg) no-repeat center top 2em;
    background-size: 180% auto;
    padding: 3em 0 1.5em;
  }
  .sympo1 .desc {
    text-align: left;
    font-size: 14px;
    padding: 0 4%;
  }
  .sympo1 .ttl {
    text-align: center;
    font-size: 22px;
    font-weight: 900;
    color: #0068b7;
    margin-top: 1.5em;
    margin-bottom: 0.5em;
  }
  .sympo1 .member_list {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
    display: block;
  }
  .sympo1 .member_list li {
    width: 257px;
    text-align: center;
    margin: 2em auto 0 auto;
  }
  .sympo1 .member_list li .name {
    font-size: 12px;
    margin-top: 0.75em;
  }
  .sympo1 .member_list li .name span {
    font-size: 16px;
    font-weight: 900;
    padding: 0 0.25em;
  }
  .sympo1 .member_list li p {
    font-size: 12px;
    padding: 1em;
    width: 94%;
    margin: 1em auto 0 auto;
    text-align: left;
  }

  .sympo2 {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
    width: 85%;
    padding: 0;
    margin-top: 2.5em;
    -webkit-box-shadow: 0 0 2px rgba(81, 81, 81, .5);
            box-shadow: 0 0 2px rgba(81, 81, 81, .5);
  }
  .sympo2 .head {
    padding: 1.5em;
    text-align: center;
    position: relative;
  }
  .sympo2 .head .rubik_i {
    font-size: 50px;
    position: absolute;
    left: 10px;
    top: -35px;
  }
  .sympo2 .head .ttl3 {
    font-size: 16px;
    font-weight: 900;
    padding-bottom: 0.75em;
    margin-bottom: 0.5em;
    position: relative;
  }
  .sympo2 .head .ttl3::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: auto;
    bottom: 0;
    display: block;
    width: 127px;
    height: 1px;
    margin: 0 auto;
  }
  .sympo2 .head .ttl4 {
    font-size: 14px;
    font-weight: 900;
    color: #0068b7;
  }
  .sympo2 .box {
    padding: 1.5em 1em 1em;
  }
  .sympo2 .box img {
    float: none;
    margin: 0 auto 1.5em;
  }
  .sympo2 .box ul li {
    font-size: 13px;
    text-indent: -42px;
    margin-left: 42px;
    margin-bottom: 1em;
  }
  .sympo2 .box ul li span {
    font-size: 14px;
    font-weight: 900;
  }

  .sympo2.pt2 .head .rubik_i {
    left: 10px;
    right: auto;
  }

  .sympo2.pt2 .box img {
    float: none;
    margin: 1.5em;
  }

  /*働き方改革*/
  .wsr1 {
    background: url(../img/wsr_bg1.png) no-repeat center top;
    padding: 3em 0;
  }
  .wsr1 > .ttl3 {
    text-align: center;
    font-size: 20px;
    font-weight: 900;
    padding-bottom: 0.5em;
  }
  .wsr1 > .ttl3 span {
    font-weight: 900;
  }
  .wsr1 > p {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
    font-size: 12px;
  }

  .wsr2 {
    padding: 4em 0;
  }
  .wsr2 > .ttl3 {
    text-align: center;
    font-size: 20px;
    padding-bottom: 0.5em;
    margin-bottom: 0.5em;
    position: relative;
  }
  .wsr2 > .ttl3::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: auto;
    bottom: 0;
    display: block;
    width: 113px;
    height: 1px;
    margin: 0 auto;
  }
  .wsr2 > .sub {
    text-align: center;
    font-size: 15px;
  }
  .wsr2 > .desc {
    text-align: center;
    font-size: 12px;
    font-weight: 900;
    margin-top: 0.5em;
  }
  .wsr2 > .box {
    background-color: #fff;
    width: 92%;
    margin: 2em auto 0 auto;
    -webkit-box-shadow: 0 0 3px rgba(0, 0, 0, .3);
            box-shadow: 0 0 3px rgba(0, 0, 0, .3);
    padding: 1.5em;
  }
  .wsr2 > .box > .ttl4 {
    font-size: 20px;
    text-align: center;
    padding-top: 0.5em;
    padding-bottom: 0.5em;
  }
  .wsr2 > .box > .desc {
    font-size: 12px;
    text-align: center;
  }
  .wsr2 > .box .before_a {
    display: block;
    margin-top: 1em;
  }
  .wsr2 > .box .before_a li {
    background-color: #449dc1;
    padding: 1em;
    width: 100%;
  }
  .wsr2 > .box .before_a li .ttl {
    font-size: 15px;
    color: #fff;
    padding: 0.25em 0 0.5em;
  }
  .wsr2 > .box .before_a li .ttl span {
    font-size: 12px;
  }
  .wsr2 > .box .before_a li dl {
    background-color: #fff;
    border-radius: 10px;
    padding: 0.75em;
    min-height: auto;
  }
  .wsr2 > .box .before_a li dl dt {
    font-size: 12px;
    text-align: center;
    padding-bottom: 0.25em;
    margin-bottom: 0.5em;
  }
  .wsr2 > .box .before_a li dl dd {
    font-size: 12px;
    margin-top: 0.25em;
    text-indent: -1.25em;
    margin-left: 1.25em;
  }
  .wsr2 > .box .before_a li dl dd::before {
    content: "●";
    color: #0068b7;
    margin-right: 0.25em;
  }
  .wsr2 > .box > .ttl {
    width: 100%;
    font-size: 15px;
    text-align: center;
    padding: 0.5em 0;
    border-radius: 20px;
    color: #fff;
    margin-top: 1em;
    margin-bottom: 0.25em;
  }
  .wsr2 > .box .wsr_list1 li {
    margin-top: 0.5em;
    border: 1px solid #c1c1c1;
    background-color: #f4f7f9;
    width: 49%;
    padding: 1em;
    text-align: center;
    font-size: 12px;
  }
  .wsr2 > .box .wsr_list1 li img {
    margin: 1em auto 0 auto;
    display: block;
  }
  .wsr2 > .box .note {
    margin-top: 0.5em;
    font-size: 10px;
  }
  .wsr2 > .box .after {
    text-align: center;
    font-size: 14px;
    text-align: left;
    font-weight: 900;
    margin-top: 1.25em;
    padding-bottom: 1em;
  }
  .wsr2 .turn3 {
    -webkit-box-shadow: 0 0 3px rgba(0, 0, 0, .3);
            box-shadow: 0 0 3px rgba(0, 0, 0, .3);
    margin: 2em auto 0 auto;
  }
  .wsr2 .turn3 .ttl3 {
    font-size: 20px;
    color: #0068b7;
    position: static;
    padding-bottom: 0;
  }

  /*仕事を知る*/
  .work1 {
    padding: 3em 0;
  }
  .work1 .wrap {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
    background: url(../img/work1.png) right 3em no-repeat;
    position: relative;
    background-size: 47% auto;
  }
  .work1 .wrap .rubik_i {
    font-size: 30px;
    color: #0068b7;
    opacity: 0.7;
  }
  .work1 .wrap .ttl3 {
    font-size: 20px;
    font-weight: 900;
    margin-top: 0.5em;
    margin-bottom: 0.5em;
  }
  .work1 .wrap .ttl3 span {
    font-weight: 900;
  }
  .work1 .wrap p {
    font-size: 10px;
    width: 100%;
  }
  .work2 {
    padding: 3em 0;
  }
  .work2 .ttl3 {
    text-align: center;
    font-size: 20px;
    text-align: center;
    font-weight: 900;
    padding: 0 0 2em 0;
  }
  .work2 .ttl3 span {
    font-weight: 900;
  }
  .work2 .wrap {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
    position: static;
  }
  .work2 .wrap .box {
    background-color: #fff;
    padding: 1.5em;
    width: 100%;
    -webkit-box-shadow: 3px 3px 0 #e4e8ea;
            box-shadow: 3px 3px 0 #e4e8ea;
    border: 2px solid #ebf2fc;
    min-height: auto;
  }
  .work2 .wrap .box .rubik_i {
    font-size: 22px;
    opacity: 0.3;
  }
  .work2 .wrap .box .ttl4 {
    font-size: 17px;
    font-weight: 900;
    padding-bottom: 0.25em;
    padding-left: 1.75em;
    margin-top: 0.12em;
  }
  .work2 .wrap .box .ttl4.pt1, .work2 .wrap .box .ttl4.pt2, .work2 .wrap .box .ttl4.pt3, .work2 .wrap .box .ttl4.pt4 {
    background-size: 1.25em auto;
  }
  .work2 .wrap .box p {
    font-size: 12px;
    padding-top: 0.5em;
  }
  .work2 .wrap .box > .ttl {
    font-size: 14px;
    font-weight: 900;
    color: #fff;
    padding: 0.12em 0.5em;
    margin-top: 1em;
  }
  .work2 .wrap .box .img {
    position: relative;
    right: 0;
    top: 0;
    display: block;
    margin: 1em auto 0 auto;
  }
  .work2 .wrap .box .brand_box {
    width: 100%;
    background-color: #ebf2fc;
    padding: 1em 0.5em 1em 0.75em;
    margin-top: 0.5em;
  }
  .work2 .wrap .box .brand_box .ttl {
    font-size: 14px;
    font-weight: 900;
    border-width: 4px;
    padding-left: 0.25em;
  }
  .work2 .wrap .box .brand_box ul {
    margin-top: 0.5em;
  }
  .work2 .wrap .box .brand_box ul li {
    margin-right: 0.5em;
    margin-top: 0.5em;
    width: calc(50% - 0.5em);
  }
  .work2 .wrap .box .brand_box ul li:nth-of-type(even) {
    margin-right: 0;
  }

  .work2.pt1 {
    background-size: 4em auto;
  }

  .work2.pt2 .wrap .box {
    margin-left: auto;
    padding: 1.5em;
  }

  .work2.pt2 .wrap .box .img {
    position: relative;
    right: 0;
    left: 0;
    top: 0;
    display: block;
    margin: 1em auto 0 auto;
  }

  .work2.pt2 .wrap .box .rubik_i {
    margin: -1.7em 0 0 -1em;
    text-align: left;
  }

  /*福利厚生*/
  .welfare1 {
    padding: 3em 0 1.5em;
  }
  .welfare1 > ul {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .welfare1 > ul > li {
    width: 48%;
    margin-right: 0;
    margin-bottom: 25px;
    -webkit-box-shadow: 0 0 3px rgba(0, 0, 0, .3);
            box-shadow: 0 0 3px rgba(0, 0, 0, .3);
    position: relative;
  }
  .welfare1 > ul > li:nth-of-type(3n) {
    margin-right: 0;
  }
  .welfare1 > ul > li .rubik_i {
    position: absolute;
    right: 0;
    top: -0.75em;
    font-size: 16px;
    opacity: 0.6;
  }
  .welfare1 > ul > li .ttl3 {
    font-size: 14px;
    padding: 0.75em 0 0.5em;
    width: calc(100% - 20px);
    margin: 0 auto 0.6em;
  }
  .welfare1 > ul > li p {
    font-size: 12px;
    padding: 0 10px 15px 10px;
  }
  .welfare1 > ul > li ul {
    font-size: 12px;
    padding: 0 10px 15px 10px;
  }
  .welfare1 > ul > li ul li {
    text-indent: -1.25em;
    margin-left: 1.25em;
  }
  .welfare1 > ul > li ul li::before {
    content: "●";
    color: #0068b7;
    margin-right: 0.25em;
  }

  /*会社概要・沿革*/
  .about1 {
    padding: 3em 0;
  }
  .about1 .ttl3 {
    font-size: 20px;
    text-align: center;
    color: #0068b7;
    font-weight: 900;
    padding-bottom: 1em;
  }
  .about1 dl {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
    display: block;
  }
  .about1 dl dt {
    width: 100%;
    font-weight: 700;
    font-size: 14px;
    padding: 0.75em 1em;
    display: block;
    text-align: left;
    margin-top: -1px;
  }
  .about1 dl dd {
    width: 100%;
    font-size: 12px;
    padding: 1em;
    display: block;
    margin-top: -1px;
    border-left: 1px solid #bababa;
  }

  .about2 {
    padding: 3em 0;
  }
  .about2 .ttl3 {
    font-size: 20px;
    font-weight: 900;
    padding-bottom: 0.5em;
  }
  .about2 p {
    font-size: 12px;
    text-align: left;
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
    padding-bottom: 2em;
  }
  .about2 dl {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
  }
  .about2 dl dt {
    width: 70px;
    color: #fff;
    font-weight: 700;
    font-size: 10px;
    text-align: center;
    padding: 1em;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: baseline;
        -ms-flex-align: baseline;
            align-items: baseline;
    margin-top: 5px;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .about2 dl dt span {
    font-size: 14px;
    font-weight: 700;
  }
  .about2 dl dd {
    width: calc(100% - 70px);
    font-size: 12px;
    padding: 1em;
    margin-top: 5px;
    background-color: #fff;
  }

  /*キャリアプラン*/
  .plan1 {
    padding: 3em 0;
  }
  .plan1 .ttl3 {
    font-size: 20px;
    text-align: center;
    padding-bottom: 0.5em;
    position: relative;
    margin-bottom: 0.5em;
  }
  .plan1 .ttl3::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: auto;
    bottom: 0;
    display: block;
    width: 113px;
    height: 1px;
    margin: 0 auto;
  }
  .plan1 .ttl3 span {
    font-weight: 900;
  }
  .plan1 .wrap {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
    display: block;
    max-width: 570px;
  }
  .plan1 .wrap .txt {
    width: 100%;
  }
  .plan1 .wrap .txt p {
    font-size: 12px;
    line-height: 2.2;
  }
  .plan1 .wrap .txt .box {
    margin-top: 2em;
    width: 100%;
    background-color: #e6eef4;
    padding: 2em;
  }
  .plan1 .wrap .txt .box .ttl {
    font-size: 16px;
    font-weight: 900;
    position: relative;
    padding-bottom: 0.5em;
    margin-bottom: 0.5em;
  }
  .plan1 .wrap .txt .box .ttl::before {
    content: "";
    position: absolute;
    left: 0;
    top: auto;
    bottom: 0;
    display: block;
    width: 113px;
    height: 1px;
  }

  .plan2 {
    background: url(../img/plan_bg1.svg) no-repeat center 2em #f2f6fb;
    padding: 2.5em 0 0;
    background-size: auto 4em;
  }
  .plan2.pt2 {
    background-image: url(../img/plan_bg2.svg);
  }
  .plan2 .ttl3 {
    font-size: 20px;
    font-weight: 900;
    text-align: center;
    padding: 0.5em 0 1em;
  }
  .plan2 .desc {
    font-size: 12px;
    width: 92%;
    margin: 0 auto;
    padding-bottom: 2em;
    text-align: left;
  }
  .plan2 > ul {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .plan2 > ul > li {
    width: 48%;
    margin-right: 0;
    margin-bottom: 25px;
    -webkit-box-shadow: 0 0 3px rgba(0, 0, 0, .3);
            box-shadow: 0 0 3px rgba(0, 0, 0, .3);
    position: relative;
  }
  .plan2 > ul > li:nth-of-type(3n) {
    margin-right: 0;
  }
  .plan2 > ul > li .rubik_i {
    position: absolute;
    right: 0;
    top: -0.75em;
    font-size: 16px;
    opacity: 0.6;
  }
  .plan2 > ul > li .ttl3 {
    font-size: 14px;
    padding: 0.75em 0 0.5em;
    width: calc(100% - 20px);
    margin: 0 auto 0.6em;
  }
  .plan2 > ul > li p {
    font-size: 12px;
    padding: 0 10px 15px 10px;
  }
  .plan2 > ul > li ul {
    font-size: 12px;
    padding: 0 10px 15px 10px;
  }
  .plan2 > ul > li ul li {
    text-indent: -1.25em;
    margin-left: 1.25em;
  }
  .plan2 > ul > li ul li::before {
    content: "●";
    color: #0068b7;
    margin-right: 0.25em;
  }

  .plan3 {
    padding: 3em 0 2em;
    max-width: 410px;
    margin: 0 auto;
  }
  .plan3 .ttl3 {
    font-size: 20px;
    text-align: center;
    font-weight: 900;
    padding-bottom: 0.5em;
    position: relative;
    margin-bottom: 0.5em;
  }
  .plan3 .ttl3::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: auto;
    bottom: 0;
    display: block;
    width: 113px;
    height: 1px;
    margin: 0 auto;
  }
  .plan3 .ttl3 span {
    font-weight: 900;
  }
  .plan3 .desc {
    font-size: 12px;
    width: 92%;
    margin: 0 auto;
    padding-bottom: 1em;
  }
  .plan3 ul {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
  }
  .plan3 ul li {
    display: block;
    background-color: #e6ecf4;
    -webkit-box-shadow: 3px 3px 0 rgba(0, 104, 183, .4);
            box-shadow: 3px 3px 0 rgba(0, 104, 183, .4);
    margin: 2em auto 0 auto;
    width: 100%;
    position: relative;
  }
  .plan3 ul li:nth-of-type(odd) .rubik_i {
    left: 0.5em;
    right: auto;
  }
  .plan3 ul li .rubik_i {
    font-size: 16px;
    color: #0068b7;
    opacity: 0.3;
    position: absolute;
    left: 0.5em;
    top: -0.75em;
  }
  .plan3 ul li .txt {
    padding: 2em;
  }
  .plan3 ul li .txt .ttl {
    font-size: 14px;
    color: #0068b7;
    padding-bottom: 0.5em;
    margin-bottom: 0.5em;
    border-bottom: 1px solid #bababa;
    font-weight: 900;
  }
  .plan3 ul li .txt p {
    font-size: 12px;
  }

  /*数字で見る*/
  .data1 {
    padding: 3em 0 1.5em;
  }
  .data1 > ul {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .data1 > ul > li {
    width: 48%;
    margin-right: 0;
    margin-bottom: 15px;
    -webkit-box-shadow: 0 0 3px rgba(0, 0, 0, .3);
            box-shadow: 0 0 3px rgba(0, 0, 0, .3);
    position: relative;
  }
  .data1 > ul > li:nth-of-type(3n) {
    margin-right: 0;
  }
  .data1 > ul > li:last-of-type {
    width: 100%;
  }
  .data1 > ul > li p {
    font-size: 12px;
    padding: 0.5em 10px 15px 10px;
  }

  /*プライバシー*/
  .ttl2_privacy {
    font-size: 20px;
    text-align: center;
    padding: 1em 0 0.5em;
  }

  .privacy1 {
    padding: 0 4%;
    width: 100%;
    max-width: 100%;
    padding-bottom: 4em;
  }
  .privacy1 h3 {
    text-align: center;
    font-size: 15px;
    padding: 1em 0;
  }
  .privacy1 h4 {
    font-size: 15px;
    padding: 1.5em 0 0;
    position: relative;
    color: #0068b7;
  }
  .privacy1 h4::after {
    content: "";
    width: 20px;
    height: 1px;
    margin-top: 8px;
    display: block;
  }
  .privacy1 p {
    font-size: 12px;
    padding-top: 1em;
  }
}
/*# sourceMappingURL=maps/sp.css.map */
