@charset "UTF-8";

/*====================================================================

  =Global Layout

====================================================================*/

:root {
  --color-primary: #02328D;
  --color-secondary:#FFE037;
  --color-cv:#FFE037;
  --color-cv-hover:#eac200;
  --color-white: #fff;
  --color-black: #222;
  --bg-light-grey: #F2F4F5;
  --font-family-en: "Outfit", sans-serif;
  --border-radius: 2.4rem;
	--border-radius-md:1.6rem;
	--border-radius-sm: .8rem;
}
html {
  font-family: "Outfit","Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  font-size: 10px;
  color: var(--color-black);
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased !important;
  -webkit-tap-highlight-color: transparent;
}

body{
  background: #fff;
  width: 100%;
  font-size: 1.6rem;
  font-feature-settings: 'palt' 1;
  letter-spacing:.06em;
  line-height: 1.8;
}
@media only screen and ( max-width:960px) {
  body{
    font-size: 1.4rem;
  }
}
@media screen and (max-width: 768px){
  body {
    min-width: 320px;
  }
}


/*====================================================================

  =Common Layout

====================================================================*

/* ------------------------------------------
 =Frame Format
---------------------------------------------*/
#wrapper {
  width: 100%;
  position: relative;
  padding-top: 9rem;
}
#l-wrapper {
  width: 100%;
  position: relative;
  padding-top: 8rem;
}
.inner {
  max-width: 124rem;
  margin: 0px auto;
  padding: 0 2rem;
}
.wrap {
  padding: 8rem 0 9.6rem;
}
.content-row{
  display: grid;
  gap: 6.4rem;
  grid-template-columns: auto 30rem;
}
.radius-bg::before{
  content: "";
  position: absolute;
  top: -154px;
  left: 0;
  width: 100%;
  height: 155px;
  background: url(../img/common/bg-round_pc.svg) no-repeat top center / cover;
}
.main-body {
  padding: 8rem 0 12.6rem;
  position: relative;
}
#p-column-single.main-body {
  padding: 4rem 0 12.6rem;
}
@media screen and ( max-width:960px) {
  #wrapper {
    padding-top: 6rem;
  }
	#l-wrapper {
    padding-top: 6rem;
  }
  .wrap {
    padding:4.8rem 0 7.2rem;
  }
  .inner {
    padding: 0 2rem;
  }
  .content-row{
    display: block;
  }
  .main-body {
    padding: 3.2rem 0 6.4rem;
    position: relative;
  }
  .side-column {
      margin-top: 6.4rem;
  }
  #p-column-single.main-body {
  padding: 3.2rem 0 6.4rem;
}
}


/* ------------------------------------------
 =Font Formatt
---------------------------------------------*/
.section-heading{
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 2.4rem;
  margin-bottom: 4rem;
}
.section-heading .jp{
  color:#fff;
  font-size: 3.6rem;
  font-weight: 700;
  line-height: 1.4;
}
.section-heading .jp span {
  background: linear-gradient(to right, #02328D, #0058FF);
  padding: .8rem 1.6rem;
}
.section-heading .en{
  font-size: 1.4rem;
  font-weight: 700;
  color:var(--color-primary);
  opacity: .4;
}
.related-column .section-heading .jp{
  font-size: 3rem;
}
.tx-underline{
  background: linear-gradient(#FEF2AD, #FEF2AD) 0 100% / 100% 10px no-repeat;
  font-weight: 700;
}
.section-bg-heading{
  text-align: center;
  margin-bottom: 4.8rem;
  position: relative;
}
.section-bg-heading::before {
  content: attr(data-en);
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: rgba(2, 50, 140, .1);
  font-size: 14rem;
  font-weight: 700 !important;
  line-height: 1.44;
  letter-spacing: .04em;
  white-space: nowrap;
}
.section-bg-heading.non-txt{
  margin-bottom:6.4rem;
}
/* .section-bg-heading.non-txt::before {
  top: -70px;
} */
.bg-blue .section-bg-heading::before {
  color: rgba(255, 255, 255, 1);
}
.section-bg-heading .baloon{
  background-color: var(--color-primary);
  border-radius: 6rem;
  color:#fff;
  display: inline-block;
  font-size:1.6rem;
  font-weight: 700;
  line-height: 1.22;
  margin-bottom: 1.2rem;
  padding: 1rem 1.6rem ;
  position: relative;
}
.section-bg-heading .baloon::before {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -9px;
  border: 9px solid transparent;
  border-top: 9px solid var(--color-primary);
}
.section-bg-heading .jp{
  color:var(--color-primary);
  display: block;
  font-size: 4rem;
  font-weight: 700;
  line-height: 1.8;
  position: relative;
}
.section-bg-heading .jp span{
  background: linear-gradient(to right,#02328D, #0058FF) 0 100% / 100% 6px no-repeat;
  padding-bottom:.4rem;
}
.section-bg-heading .jp.txt-w{
  color:#fff;
}
.section-bg-heading .jp.txt-w span{
  background: linear-gradient(to right,#fff, #fff) 0 100% / 100% 6px no-repeat;
  padding-bottom:.4rem;
}
.tx-light-blue{
  color:#0CA7F4;
}

@media screen and ( max-width:960px) {
.section-heading{
  gap: 1.6rem;
  margin-bottom: 3.2rem;
}
.section-heading .jp{
  font-size: 2rem;
}
.section-heading .jp span {
  background: linear-gradient(to right, #02328D, #0058FF);
  padding: .8rem 1rem;
}
.section-heading .en{
  font-size: 1.1rem;
}
.related-column .section-heading .jp{
  font-size: 1.8rem;
}
.section-bg-heading{
  margin-bottom: 3rem;
}
.section-bg-heading.non-txt{
  margin-bottom:3.2rem;
}
.section-bg-heading::before {
  font-size: 7rem;
  letter-spacing: .02em;
}
/* .section-bg-heading.non-txt::before {
  top: -40px;
} */
.section-bg-heading .baloon{
  font-size:1.4rem;
  margin-bottom:.6rem;
}
  .section-bg-heading .baloon::before {
  margin-left: -6px;
  border: 6px solid transparent;
  border-top: 6px solid var(--color-primary);
  }
.section-bg-heading .jp{
  font-size: 2.2rem;
}
.section-bg-heading .jp span{
  background: linear-gradient(to right,#02328D, #0058FF) 0 100% / 100% 4px no-repeat;
}
.section-bg-heading .jp.txt-w span{
  background: linear-gradient(to right,#fff, #fff) 0 100% / 100% 4px no-repeat;
}


}


.page-header {
    border-radius: var(--border-radius-sm);
    color:#fff;
    height: 24rem;
    background-size: cover;
    background-position: 50% 50%;
    background-repeat: no-repeat;
    background-image: url(../img/mv-bg_pc.webp);
    position: relative;
    overflow: hidden;
    margin:0 1rem;
}
.page-header .page-header-inner {
    position: absolute;
    top: 50%;
    left: 0;
    width: 100%;
    transform: translateY(-50%);

}
.page-header .page-header-inner .pege-heading{
  font-size:4rem;
  font-weight: 700;
  line-height: 1.4;
  text-align: center;
}
@media screen and ( max-width:960px) {
  .page-header {
    height: 12rem;
}
  .page-header .page-header-inner .pege-heading{
    font-size:2.4rem;
  }
}



/* breadcrumbs
---------------------------------*/
.breadcrumbs{
  font-size: 1.2rem;
  line-height: 1.4;
  text-align: left;
  padding:1.6rem 0 2.4rem;
}
.breadcrumb-list{
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.breadcrumb-list li {
  position: relative;
  padding-left: 3rem;
}
.breadcrumb-list li:first-child {
  padding-left: 0;
}
.breadcrumb-list li:nth-child(1),
.breadcrumb-list li:nth-child(2) {
  -ms-flex-negative: 0;
  flex-shrink: 0;
}
.breadcrumb-list li a{
  color:inherit;
}
.breadcrumbs li:nth-child(n+2):before {
  position: absolute;
  top: 8px;
  left: 10px;
  display: block;
  width: 8px;
  height: 1px;
  content: "";
  background-color:rgba(0, 0, 0, .6);
}
.page-header .breadcrumbs li:nth-child(n+2):before {
  background-color: rgba(255, 255, 255, 0.5);
}
.breadcrumbs li a span{
  background-image: linear-gradient(#222, #222);
  background-position: 0% 100%;
  background-size: 100% 1px;
  background-repeat: no-repeat;
  transition: background-size 0.6s cubic-bezier(0.170, 0.935, 0.305, 1.000);
}
.page-header .breadcrumbs li a span{
  background-image: linear-gradient(#fff, #fff);
}
.breadcrumbs li a:hover span{
  background-position: 100% 100%;
  background-size: 0% 1px;
}
.breadcrumbs br{
  display: none;
}
@media screen and (max-width: 960px) {
  .breadcrumbs {
    display:none;
  }
}

/* Header
---------------------------------*/
#header{
  position: fixed;
  top: 0;
  right: 0;
  display: flex;
  align-items:center;
  justify-content: space-between;
  width: 100%;
  height: 90px;
  z-index: 3;
  padding: 0 30px;
  transition: all .3s ease;
  background: rgba(255, 255, 255, 1);
}
#header .logo {
  width: 220px;
  height: auto;
  z-index: 1;
}
@media screen and (min-width: 961px){
  #header.scroll{
    box-shadow: 0 1px 3px rgb(0 0 0 / 10%);
  }
}
@media screen and (max-width: 960px){
  #header{
    height: 60px;
    padding: 0 0 0 20px;
  }
  #header .logo {
    width: 160px;
  }
}

#nav-sp{
  display: none;
}
@media screen and (max-width: 960px){
  #g-nav{
    display:none;
  }
  /* Hum-nav*/
  #nav-sp{
    display: block;
  }
  #nav-sp .hum-nav {
    display: block;
    position: fixed;
    top: 0px;
    right: -999px;
    bottom: 0;
    width: 100%;
    background: #f5f5f5;
    overflow-x: hidden;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    transition: all .5s;
    z-index: 10;
    opacity: 0;
  }
  #nav-sp.open .hum-nav {
    right: 0;
    opacity: 1;
  }
  #nav-sp .nav-inner {
    background-color: #f5f5f5;
    padding:6rem 0;
  }
  #nav-sp .nav-category-list {
    border-top: rgba(0, 0, 0, .06) solid 1px;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
  }
  #nav-sp .nav-category-list li {
    position: relative;
    margin: 0;
    width: 100%;
    border-bottom: rgba(0, 0, 0, .06) solid 1px;
  }
  #nav-sp .nav-category-list li a {
    display: block;
    color: var(--color-black);;
    font-size: 1.4rem;
    font-weight: 700;
    padding: 1.6rem 1.6rem;
    position: relative;
  }
  #nav-sp .nav-widget{
    padding:0 2rem;
  }
  #nav-sp .nav-widget:nth-of-type(n+2) {
    margin-top: 3rem !important;
  }
  #nav-sp .arw{
    background-color: var(--color-primary);
    border-radius: 50%;
    content: "";
    display: block;
    margin-top: -12px;
    position: absolute;
    right: 1rem;
    top: 50%;
    transition: background-color .3s cubic-bezier(.43,.05,.17,1);
    width: 24px;
    height: 24px;
    overflow: hidden;
  }
  #nav-sp .arw svg {
    fill: #fff;
    width: 10px;
    height: 10px;
    transition: all .3s cubic-bezier(.43,.05,.17,1);
    vertical-align: top;
    position: absolute;
    top: calc(50% - 5px);
    left: calc(50% - 5px);
    display: inline-block;
    -webkit-transform: scale(1);
    transform: scale(1);
    z-index: 2;
  }
  #nav-sp li a:hover {
    color: var(--color-primary);
    background-color: #EDF6FF;
   }

  /* Hum-nav nav-search*/
  #nav-sp .searchform {
    position: relative;
  }
  #nav-sp .nav-search form input[type="text"] {
    padding: 1.2rem 4.5rem 1.2rem 1.5rem;
    border-radius: 1rem;
    border: 1px solid #dedede;
    background: #fff;
  }
  #nav-sp .nav-search form input[type="submit"] {
    position: relative;
    text-indent: -9999px;
    border: none;
    width: 20px;
    height: 20px;
    background: url(../img/icon/search.svg) center center / contain no-repeat;
    position: absolute;
    top: 12px;
    right: 15px;
  }
  /* toggle*/
  .toggle_btn {
    display: block;
    position: fixed;
    top: 10px;
    right: 20px;
    width: 40px;
    height: 40px;
    transition: all .4s;
    cursor: pointer;
    z-index: 10;
    border-radius: 10px;
    background-color: var(--color-primary);
  }
  .toggle_btn span {
    display: inline-block;
    position: absolute;
    left: 28px;
    width: 35%;
    height: 2px;
    margin-left: -15px;
    background-color: #fff;
    transition: all .4s;
  }
  .toggle_btn span:nth-child(1) {
    top: 13px;
  }
  .toggle_btn span:nth-child(2) {
    top: 19px;
  }
  .toggle_btn span:nth-child(3) {
    top: 25px;
  }
  .open .toggle_btn{
    background-color: #0058FF;
  }
  .open .toggle_btn span {
    background-color: #fff;;
  }
  .open .toggle_btn span:nth-child(1) {
    top: 13px;
    left: 28px;
    transform: translateY(6px) rotate(-45deg);
    width: 35%;
    background: #fff;
  }
  .open .toggle_btn span:nth-child(2) {
    opacity: 0;
  }
  .open .toggle_btn span:nth-child(3) {
    top: 25px;
    left: 28px;
    transform: translateY(-6px) rotate(45deg);
    width: 35%;
    background: #fff;
  }

  /* Mask*/
  #mask {
    display: none;
    transition: all .5s;
  }
  .open #mask {
    display: block;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #000;
    opacity: .8;
    z-index: 2;
    cursor: pointer;
  }
}

@media screen and (min-width: 960px){
  #g-nav{
    margin-right:4rem;
    display: flex;
    gap: .4rem;
    flex-direction: column;
    align-items: flex-end;
  }
  #g-nav .g-nav{
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  #g-nav .g-nav li{
    position: relative;
    padding:.8rem 2rem;
    font-size: 1.5rem;
    font-weight: 700;
  }
  #g-nav .g-nav li .g-nav-link{
    display: block;
    text-decoration: none;
    color: var(--color-black);;
    transition: .2s ease-in-out;
    position: relative;
    overflow: hidden;
    line-height: 1.1;
    padding: 0;
  }
  #g-nav .g-nav li .g-nav-link:hover{
    opacity: .6;
  }
  #g-nav li .g-nav-link::before {
    content: '';
    position: absolute;
    bottom: 0px;
    left: 0%;
    width: 100%;
    height: 1px;
    background: var(--color-black);
    transition: .4s ease-in-out;
    transform: scale(0, 1);
    transform-origin: left top;
  }
  #g-nav li .g-nav-link:hover::before {
    transform: scale(1, 1);
  }

}

/* Open Close Btn
--------------------------*/
.open-btn{
  position: absolute;
  top:24px;
  right:24px;
  background:url("../img/icon/search.svg") no-repeat;
  background-size: 40px 40px;
  width:40px;
  height:40px;
  cursor: pointer;
  z-index: 999;
}
@media only screen and (max-width: 960px) {
  .open-btn{
    top:10px;
    right:72px;
    background:url("../img/icon/search.svg") center;
    background-size: 40px 40px;
  }
}
.close-btn{
  position: absolute;
  top:20px;
  right:15px;
  z-index: 2;
  cursor: pointer;
  width: 50px;
  height:50px;
  background-color: var(--color-primary);
  border-radius: 10px;
}
.close-btn span{
  display: inline-block;
  position: absolute;
  left: 14px;
  height: 2px;
  background-color: #fff;
}
.close-btn span:nth-of-type(1) {
  top: 18px;
  left: 16px;
  transform: translateY(6px) rotate(-45deg);
  width: 35%;
}
.close-btn span:nth-of-type(2){
  top: 30px;
  left: 16px;
  transform: translateY(-6px) rotate(45deg);
  width: 35%;
}
#search-wrap.panelactive .close-btn{
  background-color: var(--color-primary);
}

@media only screen and (max-width: 960px) {
  .close-btn{
    position: absolute;
    top:10px;
    right:20px;
    width: 40px;
    height:40px;
    border-radius: 10px;
  }
  .close-btn span:nth-of-type(1) {
    top: 13px;
    left: 13px;
    transform: translateY(6px) rotate(-45deg);
    width: 35%;
  }

  .close-btn span:nth-of-type(2){
    top: 25px;
    left: 13px;
    transform: translateY(-6px) rotate(45deg);
    width: 35%;
  }
}

/* Search Wrap
--------------------------*/
#search-wrap{
  position:fixed;
  top: 0;
  left: 0;
  z-index: -1;
  opacity: 0;
  transition: all 0.4s;
  width:100%;
  height: 100vh;
}
#search-wrap.panelactive{
  opacity: 1;
  z-index: 9999;
  background:#f5f5f5;
  display: flex;
  justify-content: center;
  padding:80px 0;
}
#search-wrap .search-area{
  display: none;
}
#search-wrap.panelactive .search-area{
  display: block;
  max-width: 760px;
  width: 100%;
  padding: 0 20px;
  margin: 0 auto;
  position: relative;
}
#search-wrap form{
  position: relative;
  height: 66px;
}
#search-wrap input{
  -webkit-appearance:none;
	appearance:none;
  outline: none;
  cursor: pointer;
  color: var(--color-black);;
}
#search-wrap input[type="text"] {
  border: none;
  background-color: #fff;
  font-size: 1.6rem;
  line-height: 1.44;
  transition: all 0.5s;
  letter-spacing: 0.05em;
}
#search-wrap input[type="text"]:focus {
  background-color: #fff;
}
#search-wrap input[type="submit"] {
  background-image: url(../img/icon/search.svg);
  background-repeat: no-repeat;
  background-position: center center;
  background-color: #fff;
  position: absolute;
  cursor: pointer;
  right: 20px;
  top: 18px;
  width: 28px;
  height: 28px;
  border: none;
  text-indent: -9999px;
}
#search-wrap .entry-taglist{
  margin-top:60px;
  font-size: 1.4rem;
}
#search-wrap .entry-taglist li a {
  background-color: #fff;
  border:1px solid #fff;
}
#search-wrap .entry-taglist li a:hover {
  color:#06c755;
  border:1px solid #06c755;
}

/* Footer-CV
--------------------------*/
.footer-cv{
  background-color: var(--color-primary);
  border-radius: var(--border-radius-sm);
  color:#fff;
  margin:0 1rem;
  padding:8rem 0;
  text-align: center;
}
.footer-cv .heading{
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.44;
  margin-bottom:4rem;
}
.footer-cv .offer-list{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  column-gap: 4rem;
  row-gap: 1rem;
  max-width: 124rem;
  margin: 0px auto;
  padding: 0 2rem;
}
.footer-cv .offer-list a {
  display: block;
  padding: 3.2rem 2rem 4rem;
  border-radius: var(--border-radius-md);
  transition: 0.2s ease-in-out;
  text-align: center;
  position: relative;
  background: var(--color-cv);
  border: 2px solid var(--color-cv);
  color: var(--color-black);
}
.footer-cv .offer-list a:hover{
  background-color: var(--color-cv-hover);
  border: 2px solid var(--color-cv-hover);
  transform: translateY(-3px);
}
.footer-cv .offer-list .icon{
  width: 8rem;
  height: auto;
  margin:0 auto 1.6rem;
}
.footer-cv .offer-list .ttl{
  font-size: 3.6rem;
  font-weight: 700;
  line-height: 1.22;
  margin-bottom:1rem;
}
.footer-cv .offer-list .txt{
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.22;
}
@media screen and ( max-width:960px) {
  .footer-cv{
    padding:3.2rem 0;
  }
  .footer-cv .heading{
    font-size: 1.8rem;
    margin-bottom:2.4rem;
  }
  .footer-cv .offer-list{
    grid-template-columns: repeat(1, 1fr);
  }
  .footer-cv .offer-list a {
    border-radius: var(--border-radius-sm);
    padding: 2.4rem 2rem;
  }
  .footer-cv .offer-list .icon{
    width: 4.8rem;
  }
  .footer-cv .offer-list .ttl{
    font-size: 2.4rem;
    margin-bottom:1rem;
  }
  .footer-cv .offer-list .txt{
    font-size: 1.2rem;
  }
}

/* Footer-utiliry
--------------------------*/
.footer-utility{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 4rem;
  padding:8rem 0;
}
.footer-utility .logo{
  width: 24rem;
}
.footer-utility .f-nav{
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.footer-utility .f-nav li {
  position: relative;
  padding: 0 2rem;
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1.3;
}
.footer-utility .f-nav li a{
  display: block;
  text-decoration: none;
  color: var(--color-black);;
  transition: .2s ease-in-out;
  position: relative;
  overflow: hidden;
  line-height: 1.1;
  padding: .4rem 0;
}
.footer-utility .f-nav li a:hover{
  opacity: .6;
}
.footer-utility .f-nav li a::before {
  content: '';
  position: absolute;
  bottom: 0px;
  left: 0%;
  width: 100%;
  height: 1px;
  background: var(--color-black);
  transition: .4s ease-in-out;
  transform: scale(0, 1);
  transform-origin: left top;
}
.footer-utility .f-nav li a:hover::before {
  transform: scale(1, 1);
}
@media screen and ( max-width:960px) {
  .footer-utility{
    display: block;
    padding:2.4rem 0;
    text-align: center;
  }
  .footer-utility .logo{
    width: 20rem;
    margin: auto;
  }
  .footer-utility .f-nav{
    display: none;
  }
}

/* Footer-Group
--------------------------*/
.footer-group{
  border-bottom:1px solid #DDDDDD;
  border-top:1px solid #DDDDDD;
  padding:4rem 0;
  text-align: center;
}
.footer-group .heading {
  color:var(--color-primary);
  font-size: 1.8rem;
  font-weight: 700;
  background: linear-gradient(to right, var(--color-primary), var(--color-primary)) 0 100% / 100% 2px no-repeat;
  display: inline-block;
  line-height: 1.44;
}
.footer-group .footer-group-list{
  margin-top:1.6rem;
  column-gap: 2.4rem;
  row-gap: 2.4rem;
}
.footer-group .footer-group-list .pic{
  margin-bottom:1.6rem;
  border-radius: var(--border-radius-sm);
  overflow: hidden;
}
.footer-group .footer-group-list .txt{
  font-size:1.4rem;
  font-weight: 700;
  position: relative;
  padding-right:2.4rem;
   display: inline-block;
}
.footer-group .footer-group-list .txt::before {
  position: absolute;

  content: "";
  top: 50%;
  right: 0;
  width: 20px;
  height: 20px;
  background: url(../img/icon/link-arrow.svg) center / cover;
  transform: translateY(-50%);
}
.footer-group .footer-group-list li a:hover .txt{
  color:var(--color-primary);
}
@media screen and ( max-width:960px) {
  .footer-group{
    padding:2.4rem 0;
  }
  .footer-group .footer-group-list{
        /* grid-template-columns: repeat(1, 1fr); */
    column-gap: 1rem;
    row-gap: 1rem;
  }
  .footer-group .footer-group-list .pic{
    margin-bottom:1rem;
  }
  .footer-group .footer-group-list .txt{
    font-size:1.3rem;
  }
}

/* Footer-Bottom
--------------------------*/
.footer-bottom {
  padding: 2rem 0;
  font-size: 1.2rem;
}
.footer-bottom ul {
  align-items: center;
  display: flex;
}
.footer-bottom li {
  position: relative;
  margin-right:25px;
}
.footer-bottom li:last-child {
  margin:0px;
}
.footer-bottom li span {
  padding-right: 16px;
}
.footer-bottom li span::after {
  content: '';
  display: block;
  width: 11px;
  height: 11px;
  background: url(../img/icon/icon-blanklink.svg) 0 0 no-repeat;
  background-size: 100%;
  position: absolute;
  top: 6px;
  right: 0;
}
@media screen and (max-width:980px) {
  .footer-bottom{
    justify-content: center;
  }
  .footer-bottom ul {
    justify-content: center;
    width: 100%;
    margin-bottom:20px;
  }
}

/* Fix Cta
--------------------------*/
.fix-cta{
  display: none;
}
@media screen and ( max-width:960px) {
  #p-lp-footer, #footer{
    margin-bottom:60px;
  }
  #p-staffing #p-lp-footer{
    margin-bottom: 120px;
  }
  .fix-cta{
    display: block;
    position: fixed;
    bottom: -250px;
    left:0px;
    z-index: 4;
    transition: 0.3s ease all;
    text-align: center;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    box-shadow: rgba(0, 0, 0, .16) 0px 0px 16px;
    padding:1rem 1rem;
    background-color: var(--color-primary);
    width: 100%;
  }
  .fix-cta.show {
    bottom: 0px;
  }
  .fix-cta .fix-cta-list{
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    column-gap: .8rem;
    row-gap: .8rem;
  }
  .fix-cta .fix-cta-list li a {
    background-color: var(--color-cv);
    border:1px solid var(--color-cv);
    display: block;
    font-size: 1.1rem;
    font-weight: 700;
    letter-spacing: 0;
    border-radius: 8px;
    padding: 1.2rem 1rem 1.2rem 1rem;
    position: relative;
    transition: transform .2s;
  }
  .fix-cta .fix-cta-list li a::before{
    background-size: cover;
    content: "";
    display: block;
    width: 22px;
    height: 22px;
    position: absolute;
    top: calc(50% - 11px);
    left: 10px;
  }
  .fix-cta .fix-cta-list li.btn-tel a::before{
    background-image: url(../img/footer-tel-icon.svg);
  }
  .fix-cta .fix-cta-list li.btn-contact a::before{
    background-image: url(../img/footer-contact-icon.svg);
  }
}


/*
=======================================
= Entry
=======================================
*/

/* entry-list
---------------------------------*/
.column-list {
  column-gap: 4rem;
  row-gap: 4rem;
}
.column-list-item{
   position: relative;
}
.column-list-item > a{
  display: block;
}
.column-list-item .item-pic{
  overflow: hidden;
  margin-bottom:1.6rem;
}
.column-list-item .item-pic .thumb{
  aspect-ratio: 16 / 9;
  border-radius: var(--border-radius-sm);
  overflow: hidden;
}
.column-list-item .item-pic .thumb img{
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.entry-meta {
  display: flex;
  align-items: center;
  font-size: 1.1rem;
  line-height: 1.2;
  letter-spacing: 0;
  margin-bottom: 1rem;
}
.entry-meta .entry-date {
  margin-left: .8rem;
  letter-spacing: .04em;
}
.column-list-item .item-body .ttl{
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.6;
  margin-bottom:1.6rem;
  overflow: hidden;
}
.column-list-item .item-body .txt{
  font-size: 1.4rem;
  margin-top:2.4rem;
}
.p-top-recommend-list .column-list-item:not(:first-child) .item-body .txt{
  display: none;
}

@media screen and ( max-width:960px) {
  .column-list {
    grid-template-columns: repeat(1, 1fr);
    column-gap: 2.4rem;
    row-gap: 3.2rem;
  }
  .column-list .column-list-item a {
    display: grid;
    gap: 1.6rem;
    grid-template-columns: 14rem auto;
}
  .entry-meta {
    font-size: 1rem;
    margin-bottom: .6rem;
  }
  .column-list-item .item-pic{
    margin-bottom:1rem;
  }
  .column-list-item .item-body .ttl{
    font-size: 1.3rem;
    margin-bottom:1rem;
  }
  .p-top-recommend-list .column-list-item .item-body .txt{
    display: none;
  }
}

@media screen and (min-width: 961px) {
  .p-top-recommend-list .column-list-item:first-child{
    grid-column: 1 / 4;
  }
  .p-top-recommend-list .column-list-item:first-child a{
    display: flex;
    align-items: center;
  }
  .p-top-recommend-list .column-list-item:first-child .item-pic {
    width: 48%;
    flex-shrink: 0;
  }
  .p-top-recommend-list .column-list-item:first-child .item-body{
    padding: 0 0 0 4rem;
    flex-grow: 1;
  }
  .p-top-recommend-list .column-list-item:first-child .item-body .ttl{
    font-size: 2.2rem;
  }
}


/*
=======================================
= Top
=======================================
*/

/* Mv
--------------------------*/
#p-top-mv {
  background-image: url(../img/mv-bg_pc.webp);
  background-repeat: no-repeat;
  background-size: cover;
  border-radius:var(--border-radius-sm) ;
  color:#fff;
  overflow: hidden;
  position: relative;
  padding:4rem 0 6.4rem;
  margin:0 1rem 0;
}
#p-top-mv .mv-slider {
  max-width: 68rem;
  margin: auto;
  overflow: visible;
}
#p-top-mv .mv-slider .swiper-slide {
  max-width: 68rem;
  margin: 0 2rem;
  padding:0 0 2.4rem 0;
  height: auto;
}
#p-top-mv .swiper-button-prev,
#p-top-mv .swiper-button-next {
  position: absolute;
  z-index: 1;
  top: 35%;

}
#p-top-mv .swiper-button-prev {
  left: -30px;
}
#p-top-mv .swiper-button-next {
  right: -30px;
}
#p-top-mv .swiper-pagination {
  font-size: 1.4rem;
  font-weight: 700;
  color:#fff;
}
@media screen and (max-width: 960px) {
  #p-top-mv{
    padding:2.4rem 0 3.2rem;
  }
  #p-top-mv .mv-slider .swiper-slide{
    width: 90% !important;
    margin: 0 2rem 0;
    padding:0 0 1rem 0;
  }
  #p-top-mv .swiper-button-prev {
    left: 5px;
  }
  #p-top-mv .swiper-button-next {
    right: 5px;
  }
  #p-top-mv .swiper-pagination {
    font-size: 1.2rem;
  }
}

#p-top-mv .mv-slider .column-list-item{
  display: flex;
  flex-direction: column;
  height: 100%;
}
#p-top-mv .mv-slider .column-list-item a{
  color:#fff;
}
#p-top-mv .mv-slider .column-list-item .item-body{
  margin-top:2.4rem;
}
#p-top-mv .mv-slider .item-body .ttl{
  font-size: 2rem;
  line-height: 1.44;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
	line-clamp: 2;
  overflow: hidden;
}
@media screen and (max-width: 960px) {
  #p-top-mv .mv-slider .column-list-item .item-body{
    margin-top:1.6rem;
  }
  #p-top-mv .mv-slider .item-body .ttl{
    font-size: 1.6rem;
  }
}

/* Tagox
--------------------------*/
.tagbox{
  border:2px solid var(--color-primary);
  border-radius: var(--border-radius-sm);
  padding:4rem;
  display: grid;
  gap: 4rem;
  grid-template-columns: 20rem auto;
}
.p-top-tagbox.tagbox{
  margin-top:8rem;
}
.tagbox .heading{
  color:var(--color-primary);
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.2;
}
@media screen and (max-width: 960px) {
  .tagbox{
    padding:2.4rem;
    display: block;
  }
  .p-top-tagbox.tagbox{
    margin-top:4.8rem;
  }
  .tagbox .heading{
    font-size: 1.6rem;
    margin-bottom:2.4rem;
  }
}

/* Top-Recommend
--------------------------*/
#p-top-recommend{
  padding-top:9.6rem;
}
@media screen and (max-width: 960px) {
  #p-top-recommend{
    padding-top:6.4rem;
  }
}


/* Top New Arcile
--------------------------*/
#p-top-new-article{
  background-color: #F1F8FC;
  border-radius: var(--border-radius-sm);
  margin: 0 1rem 12.6rem;
}
@media screen and (max-width: 960px) {
  #p-top-new-article{
    margin: 0 1rem 8rem;
  }
}


/* Side
--------------------------*/
.side-column .nav-sticky {
  position: -webkit-sticky;
  position: sticky;
  top: 12rem;
}
.side-column aside .side-ttl {
  background-color: #F1F8FC;
  border-radius: .8rem;
  font-size: 1.8rem;
  font-weight: 700;
  padding: 1.6rem;
  position: relative;
  line-height: 1.44;
  margin-bottom: 2.4rem;
}
.side-column .side-entry-list{
  display: grid ;
  grid-template-columns: repeat(1, 1fr);
  row-gap: 1.6rem;
}
.side-column .side-entry-list .item{
  position: relative;
}
.side-column .side-entry-list .item a {
  display: grid;
  gap: 1.6rem;
  grid-template-columns: 10rem auto;
}
.side-column .side-entry-list .item .ttl{
  font-size: 1.4rem;
  line-height: 1.4;
  margin-top:.4rem;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
	line-clamp: 3;
  overflow: hidden;
}
.side-column .side-entry-list .item-pic .thumb {
  aspect-ratio: 16 / 9;
  border-radius: var(--border-radius-sm);
  overflow: hidden;
}
.side-column .side-entry-list .item-pic .thumb img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.side-column aside{
  margin-top:4rem;
}
.side-column .side-cv{
  background-color: var(--color-primary);
  border-radius: var(--border-radius-sm);
  padding:1.6rem 2.4rem 2.4rem;
  text-align: center;
}
.side-column .side-cv .heading{
  font-weight: 700;
  line-height: 1.44;
  color:#fff;
  margin-bottom:1.6rem;
}
.side-column .side-cv .side-cv-list {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  row-gap: 1rem;
}
.side-column .side-cv .item a {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  flex-direction: column;
  align-items: center;
  height: 6.4rem;
  padding: .8rem 2rem ;
  border-radius: var(--border-radius-sm);
  transition: 0.2s ease-in-out;
  text-align: center;
  position: relative;
  background: var(--color-cv);
  border: 2px solid var(--color-cv);
  color: var(--color-black);
}
.side-column .side-cv .item a:hover{
  background-color: var(--color-cv-hover);
  border: 2px solid var(--color-cv-hover);
}
.side-column .side-cv .item .ttl{
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1;
  position: relative;
  padding-left:2.8rem;
}
.side-column .side-cv .item.tel .ttl{
  font-size: 2.4rem;
}
.side-column .side-cv .item .ttl:before{
  background-size: cover;
  content: "";
  display: block;
  width: 24px;
  height: 24px;
  position: absolute;
  top: calc(50% - 12px);
  left: 0;
}
.side-column .side-cv .item.tel .ttl:before{
  background-image: url(../img/footer-tel-icon.svg);
}
.side-column .side-cv .item.contact .ttl:before{
  background-image: url(../img/footer-contact-icon.svg);
}
.side-column .side-cv .item .txt{
  font-size: 1.2rem;
  line-height: 1;
  margin-top:.6rem;
}
@media screen and (max-width: 960px) {
  .side-column .side-cv .item .ttl{
  font-size: 1.4rem;
  padding-left:2.4rem;
}
.side-column .side-cv .item.tel .ttl{
  font-size: 2rem;
}
.side-column .side-cv .item .ttl:before{
  width: 20px;
  height: 20px;
  top: calc(50% - 10px);
}
}




/* Single
---------------------------------*/
.single-article__header .entry-title {
  font-size: 2.8rem;
  font-weight: 700;
  line-height: 1.44;
  margin-bottom: 1.6rem;
}
@media screen and (max-width: 960px) {
  .single-article__header .entry-title{
    font-size: 2.4rem;
    margin-bottom: .8rem;
  }
}

.single-article{
  border-bottom:2px solid #222;
  padding-bottom:6.4rem;
}
.single-article__body{
  margin:6.4rem 0;
}
.single-article__body > *:first-child{
  margin-top: 0;
}
.single-article__body > *:last-child{
  margin-bottom: 0;
}
.single-article__body .article-mv {
  text-align: center;
}
.single-article__body > *{
  margin-top: 2.4rem;
}
.single-article__body a{
  color: var(--color-black);;
  text-decoration: underline;
}
.single-article__body a:focus,
.single-article__body a:active,
.single-article__body a:hover {
  color: var(--color-black);;
  text-decoration: none;
}
.single-article__body .wp-block-image,
.single-article__body img{
  border-radius: var(--border-radius-sm);
}
.single-article__body strong{
  font-weight: bold;
}
.single-article__body em{
  font-style: italic;
}
@media screen and (max-width: 960px) {
  .single-article{
    padding-bottom:4rem;
  }
  .single-article__body{
    margin:4rem 0;
  }
}

.single-article__body h2{
  background-image: radial-gradient(circle, #222 1px, transparent 1px);
  background-size: 6px 2px;
  background-repeat: repeat-x;
  background-position: left bottom;
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.44;
  margin-top: 6.4rem;
  margin-bottom: 2.4rem;
  padding-bottom: 1.6rem;
  position: relative;
}
.single-article__body  h3{
  border-radius: var(--border-radius-sm);
  background-color: #F1F8FC;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.44;
  padding: 1.4rem 2rem;
  margin-top: 4rem;
  margin-bottom: 2.4rem;
}
.single-article__body h4 {
  font-size: 1.8rem;
  line-height: 1.44;
  font-weight: 700;
  padding-left: 1.6rem;
  margin-top: 2.4rem;
  margin-bottom: 1.2rem;
  position: relative;
}
.single-article__body h4::before {
  content: "";
  display: block;
  position: absolute;
  border-left: 4px solid var(--color-primary);
  left: 0;
  height: 100%;
}
.single-article__body h5{
  color:var(--color-primary);
  font-weight: 700;
  line-height: 1.44;
  margin-top: 2.4rem;
  margin-bottom: 1.6rem;
}
.single-article__body h2 + *,
.single-article__body h3 + *,
.single-article__body h4 + *,
.single-article__body h5 + * {
  margin-top: 0;
}
@media screen and (max-width: 960px) {
  .single-article__body h2 {
      font-size: 2rem;
      margin-top: 4.8rem;
      margin-bottom: 1.6rem;
  }
  .single-article__body h3 {
      font-size: 1.8rem;
      margin-top: 4rem;
      margin-bottom: 1.6rem;
  }
  .single-article__body h4 {
      font-size: 1.6rem;
      margin-top: 3.2rem;
    }
}


/* Ul list */
.single-article__body ul:not(.toc_list) > li  {
  position: relative;
  padding-left: 15px;
  line-height: 1.66;
}
.single-article__body ul > li::after {
  content: '';
  display: block;
  position: absolute;
  top: 11px;
  left: 0;
  width: 3px;
  height: 3px;
  background: var(--color-primary);
}
/* Ol list */
.single-article__body ol {
  counter-reset: number;
}
.single-article__body ol > li {
  position: relative;
  padding-left: 20px;
  line-height: 1.66;
}
.single-article__body ol > li::after {
  color:var(--color-primary);
  position: absolute;
  top: 0;
  left: 0;
  counter-increment: number;
  display: inline-block;
  content: counter(number) '.';
}

/* wp-block-quote */
.single-article__body .wp-block-quote,
.single-article__body blockquote {
  padding: 3.2rem;
  background: #f5f5f5;
  border-radius: .8rem;
  font-size: 1.4rem;
  line-height: 1.44;
  border: none;
}
.single-article__body .wp-block-quote cite,
.single-article__body blockquote cite{
  opacity: .6;
  font-size: 1.2rem;
}
.single-article__body .wp-block-quote > :first-child,
.single-article__body blockquote > :first-child {
  margin-top: 0;
}
.single-article__body .wp-block-quote > :last-child,
.single-article__body blockquote > :last-child {
  margin-bottom: 0;
}

/* wp-element-caption */
.single-article__body .wp-element-caption {
  display: block;
  opacity: .6;
  margin-top: 1rem;
  font-size: 1.2rem;
  line-height: 1.6;
  text-align: center;
}

/* Iframe */
.single-article__body iframe{
  aspect-ratio: 16 / 9;
  width: 100%;
  height: auto;
}

@media screen and (max-width: 960px) {
  .single-article__body .wp-block-quote,
  .single-article__body blockquote {
    padding: 1.6rem;
  }
}

.single-article__body .wp-block-table {
 margin: 2.4rem 0 0;
}
.single-article__body table{
  width: 100%;
  border-top: 1px solid #ddd;
  border-left: 1px solid #ddd;
}
.single-article__body .wp-block-table thead {
    border-bottom: none;
}
.single-article__body  table th,
.single-article__body table td{
  vertical-align: middle;
  line-height: 1.6;
  font-size: 1.4rem;
  padding: 1.6rem;
  border-top: 1px solid #ddd;
  border-left: 1px solid #ddd;
  border-right: 1px solid #ddd;
  border-bottom: 1px solid #ddd;
}
.single-article__body table th > *:first-child,
.single-article__body table td > *:first-child{
  margin-top: 0;
}
.single-article__body table th > *:last-child,
.single-article__body table td > *:last-child {
  margin-bottom: 0;
}
.single-article__body table th{
  background: #efefef;
  font-weight: 500;
  text-align: left;
}
.single-article__body table td {
  background: #fff;
}
.single-article__body table thead th {
  background: #efefef;
}
.single-article__body table caption {
  text-align: left;
  font-size: 1.2rem;
  line-height: 1.8;
  margin-bottom: 1.6remx;
}
@media screen and (max-width: 768px) {
  .single-article__body table th,
  .single-article__body table td {
    font-size: 1.2rem;
    padding: 1.4rem;
  }
}

/* Writter Profile */
.writter-profile{
  width: 100%;
  background-color: #fff;
  border: 1px solid var(--color-primary);
  border-radius: .8rem;
  overflow: hidden;
}
.writter-profile .heading {
  background: var(--color-primary);
  color: #fff;
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1.2;
  font-weight: 700;
  text-transform: uppercase;
  padding: 1rem 2.4rem;
}
.writter-profile-row{
  display: grid;
  gap: 1.6rem;
  grid-template-columns: 9.6rem auto ;
  padding: 2.4rem 2.4rem;
}
.writter-profile .pic{
  width: 100px;
  height: 100px;
  border-radius: 50%;
  overflow: hidden;
  position: relative;
}
.writter-profile .pic img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.writter-profile__body {
  font-size: 1.4rem;
  line-height: 1.6;
}
.writter-profile__body .name {
  font-size:1.8rem;
  font-weight: 700;
  margin-bottom: 1rem;
}
@media screen and (max-width: 960px) {
   .writter-profile .heading{
    text-align: center;
   }
   .writter-profile-row{
    display: block;
    padding: 1.6rem;
  }
  .writter-profile .pic {
    width: 80px;
    height: 80px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom:15px;
   }
   .writter-profile__body .name {
    font-size:1.4rem;
    margin-bottom: 1rem;
  }
   .writter-profile__body {
    font-size: 1.2rem;
    line-height: 1.6;
  }
}


.related-column {
  background-color: #F1F8FC;
  border-radius: var(--border-radius-sm);
  margin-top: 6.4rem;
  padding: 4rem;
  overflow: hidden;
}
.related-column .column-list{
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  row-gap: 1.6rem;
}
.related-column .column-list .column-list-item a {
    display: grid;
    column-gap: 2.4rem;
    grid-template-columns: 24rem auto;
}
.related-column .column-list .column-list-item{
  border-bottom: 1px solid #C6D7EB;
  padding-bottom:1.6rem;
}
.related-column .column-list .column-list-item .item-pic {
    margin-bottom: 0;
}
@media screen and (max-width: 960px) {
  .related-column {
    padding: 2rem;
    margin-top: 4rem;
  }
  .related-column .column-list .column-list-item a {
      column-gap: 1.6rem;
      grid-template-columns: 12rem auto;
    }
}




/*====================================================================

  =LP PAGE

====================================================================*

/* Header
------------ */
#p-lp-header {
  background: rgba(255,255,255, 1);
  position: fixed;
  top: 0px;
  left: 0px;
  width: 100%;
  z-index: 9;
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: 80px;
  padding:0 3rem;
}
#p-lp-header .logo{
  width: 20rem;
  height: auto;
  transition: .5s;
}
#p-lp-header.scroll{
  box-shadow: 0 2px 3px rgba(0,0,0,0.1);
}
#p-lp-header #l-nav{
  display: block;
}
#p-lp-header #l-nav ul {
  display: flex;
  justify-content: center;
  align-items: center;
  column-gap: 2.4rem;
  font-size: 1.4rem;
}
#p-lp-header #l-nav .nav-item.tel{
  display: flex;
  flex-direction: column;
  justify-content: start;
}
#p-lp-header #l-nav .nav-item.tel .num{
  font-size: 2.8rem;
  font-weight: 700;
  line-height: 1;
  position: relative;
  padding-left:3rem;
  text-align: left;
  letter-spacing: .02em;
}
#p-lp-header #l-nav .nav-item.tel .num::before{
  content: "";
  width: 2.4rem;
  height: 2.4rem;
  -webkit-mask-image: url(../img/icon/icon-tel.svg);
  mask-image: url(../img/icon/icon-tel.svg);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  position: absolute;
  top: calc(50% - 1.2rem);
  transition: .3s ease-in-out;
  left: 0;
  background-color: #222;
}
#p-lp-header #l-nav .nav-item.tel .num span{
	font-size: 1.2rem;
	padding-right:.6rem;
}

#p-lp-header #l-nav .nav-item.tel .txt {
  font-size: 1rem;
  padding-top: .8rem;
  line-height: 1;
  letter-spacing:.02em;
}
#p-lp-header #l-nav .nav-item.contact a{
  background-color: var(--color-cv);
  border:2px solid var(--color-cv);
  color: #222;
  font-weight: 700;
  display: block;
  padding: 1rem 2rem;
  border-radius: 1.6rem;
  transition: 0.3s;
  width: 180px;
  text-align: center;
}
#p-lp-header #l-nav .nav-item.contact .txt{
  position: relative;
  padding-left:2.4rem;
}
#p-lp-header #l-nav .nav-item.contact .txt::before {
  content: "";
  width: 1.8rem;
  height: 1.8rem;
  -webkit-mask-image: url(../img/icon/icon-contact.svg);
  mask-image: url(../img/icon/icon-contact.svg);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  position: absolute;
  top: calc(50% - .9rem);
  transition: .3s ease-in-out;
  left: 0;
  background-color: #222;
}
#p-lp-header #l-nav .nav-item.contact a:hover{
  background-color: var(--color-cv-hover);
  border:2px solid  var(--color-cv-hover);
}
@media screen and (max-width: 960px) {
  #p-lp-header {
    height: 6rem;
    padding:0 2rem;
  }
  #p-lp-header .logo{
    width: 18rem;
    height: auto;
  }
  #p-lp-header #l-nav{
    display: none;
  }
}



/* Mv
------------ */
#p-lp_mv{
  aspect-ratio: 1920 / 740;
  background-size: cover;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  color:#fff;
  text-align: center;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding:4rem 2rem;
}
#p-processing #p-lp_mv{
  background-image: url(../img/processing/mv_pc.webp) ;
}
#p-staffing #p-lp_mv {
  background-image: url(../img/staffing/mv_pc.webp);
}
#p-transport #p-lp_mv {
	background-image: url(../img/transport/mv_pc.webp);
}
#p-warehouse #p-lp_mv {
  background-image: url(../img/warehouse/mv_pc.webp);
}
#p-lp_mv .catch{
  font-size: 4.8rem;
  font-weight: 700;
  line-height: 1.4;
  margin-bottom:3.6rem;
}
#p-lp_mv .catch .main-txt{
  background: linear-gradient(to right, #fff, #fff) 0 100% / 100% 6px no-repeat;
  padding-bottom: .4rem;
  font-size: 6rem;
}
#p-lp_mv .catch .main-txt .num{
  font-size: 6.8rem;
}
#p-lp_mv .lead-txt{
  font-size: 2.8rem;
  font-weight: 700;
  line-height: 1.5;
}
.mv-offer{
  background-color: #fff;
  border-radius: .8rem;
  padding:2.4rem 4rem;
  max-width: 72rem;
  margin:4rem auto 0;
  display: block;
}

.mv-offer .mv-offer__list{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  column-gap: 1.8rem;
  row-gap: 1.8rem;
}

.mv-offer .mv-offer__list .item a {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  height: 100%;
  transition: .4s;
  height: 7.2rem;
  border-radius: 1.6rem;
}
.mv-offer .mv-offer__list .item a{
  color:var(--color-black);
}
.mv-offer .mv-offer__list .item .txt{
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1;
  position: relative;
  padding-left:3rem;
}
.mv-offer .mv-offer__list .item.item-tel .txt{
  font-size: 2.8rem;
}
.mv-offer .mv-offer__list .item.item-tel .time{
  font-size: 1.1rem;
  margin-top:.3rem;
}
.mv-offer .mv-offer__list .item .txt::before {
    content: "";
    width: 2.4rem;
    height: 2.4rem;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    position: absolute;
    top: calc(50% - 1.2rem);
    left: 0;
}
.mv-offer .mv-offer__list .item.item-tel .txt::before {
    -webkit-mask-image: url(../img/icon/icon-tel.svg);
    mask-image: url(../img/icon/icon-tel.svg);
    background-color: #222;
}
.mv-offer .mv-offer__list .item.item-contact .txt::before {
    -webkit-mask-image: url(../img/icon/icon-contact.svg);
    mask-image: url(../img/icon/icon-contact.svg);
    background-color: #222;
}
.mv-offer .mv-offer__list .item.item-tel a{
  border:2px solid #ddd;
  background-color: #fff;
}
.mv-offer .mv-offer__list .item.item-tel a:hover{
  background-color: #ddd;
}
.mv-offer .mv-offer__list .item.item-contact a{
  border:2px solid #222;
  background-color: var(--color-cv);
}
.mv-offer .mv-offer__list .item.item-contact a:hover{
  background-color: var(--color-cv-hover);
}

#p-staffing .mv-offer {
  max-width: 94rem;
}

#p-staffing .mv-offer .mv-offer__list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: repeat(2, 1fr);
  column-gap: 1rem;
  row-gap: 1rem;
}

#p-staffing .mv-offer .mv-offer__list .item-contact {
  grid-area: 1 / 1 / 2 / 4;
}

#p-staffing .mv-offer .mv-offer__list .item-osaka {
  grid-area: 2 / 1 / 3 / 2;
}

#p-staffing .mv-offer .mv-offer__list .item-aichi {
  grid-area: 2 / 2 / 3 / 3;
}

#p-staffing .mv-offer .mv-offer__list .item-kanagawa {
  grid-area: 2 / 3 / 3 / 4;
}

#p-staffing .mv-offer .mv-offer__list .item .name {
  font-size: 1.2rem;
  font-weight: 700;
}

#p-staffing .mv-offer .mv-offer__list .item a {
  height: 8.2rem;
  padding: 0 .8rem;
}


@media screen and (max-width: 960px) {
  #p-lp_mv{
    aspect-ratio: 750 / 580;
  }
  #p-processing #p-lp_mv{
    background-image: url(../img/processing/mv_sp.webp) ;
  }
	#p-staffing #p-lp_mv {
		background-image: url(../img/staffing/mv_sp.webp);
	}
	#p-transport #p-lp_mv {
		background-image: url(../img/transport/mv_sp.webp);
	}
  #p-warehouse #p-lp_mv {
    background-image: url(../img/warehouse/mv_sp.webp);
  }
  .mv-offer{
    display: none;
  }
  #p-lp_mv .catch{
    font-size: 2rem;
    margin-bottom:2rem;
  }
  #p-lp_mv .catch .main-txt{
    background: linear-gradient(to right, #fff, #fff) 0 100% / 100% 4px no-repeat;
    font-size: 3.6rem;
  }
  #p-lp_mv .catch .main-txt .num{
    font-size: 4rem;
  }
  #p-lp_mv .lead-txt{
    font-size: 1.6rem;
  }
}


/* About
------------ */
#p-lp-about{
  padding:8rem 0 16rem;
}
#p-lp-about .lead-txt{
  text-align: center;
  line-height: 2;
}
#p-lp-about .movie-box{
  background: linear-gradient(120deg, #EDF3FF, #B5D0FF);
  border-radius: var(--border-radius-md);
  max-width: 80rem;
  margin:4.8rem auto 0;
  padding:0 2.4rem 2.4rem;
  text-align: center;
}
#p-lp-about .movie-box .heading{
  background-color: #fff;
  border:2px solid var(--color-primary);
  border-radius: 6rem;
  color:var(--color-primary);
  display: inline-block;
  font-size:2rem;
  font-weight: 700;
  line-height: 1.22;
  margin-bottom: 2rem;
  padding: 1rem 2.4rem ;
  position: relative;
  margin-top:-2.4rem;
}
#p-lp-about .movie-box .movie-item{
  width: 100%;
  aspect-ratio: 16 / 9;
  border-radius: var(--border-radius-sm);
  overflow: hidden;
}
#p-lp-about .movie-box .movie-item iframe{
   width: 100%;
  height: 100%;
}
@media screen and (max-width: 960px) {
  #p-lp-about{
    padding:5rem 0 10rem;
  }
  #p-lp-about .lead-txt{
    text-align: left;
  }
  #p-lp-about .movie-box{
    margin:4rem auto 0;
    padding:0 1rem 1rem;
  }
  #p-lp-about .movie-box .heading{
    font-size:1.6rem;
    margin-bottom: 2rem;
    padding: 1rem 1.6rem ;
    margin-top:-1.2rem;
  }
}


/* Reason
------------ */
#p-lp-reason{
  background-color: #EDF6FF;
  position: relative;
  padding:0 0 11.2rem;
  border-radius: 0 0 3.2rem 3.2rem;
}
#p-lp-reason .recommend-block{
  background-color: #fff;
  border:2px solid var(--color-primary);
  border-radius: var(--border-radius-md);
  padding: 3.2rem 4rem 4rem;
  text-align: center;
  position: relative;
  top:-10rem;
}
#p-lp-reason .recommend-block .heading{
  color:var(--color-primary);
  font-size: 2.8rem;
  font-weight: 700;
  margin-bottom:1.6rem;
}
#p-lp-reason .recommend-block .heading span{
  background: linear-gradient(#02328D, #02328D) 0 100% / 100% 4px no-repeat;
}
#p-lp-reason .recommend-block .recommend-list{
  gap: 1.6rem 3.2rem;
}
#p-lp-reason .recommend-block .recommend-list .item .img{
  border-radius: var(--border-radius-sm);
  overflow: hidden;
  margin-bottom:1.6rem;
}
#p-lp-reason .recommend-block .recommend-list .item .txt{
  font-size:1.8rem;
  font-weight: 700;
  line-height: 1.44;
}
#p-lp-reason .recommend-block .arrow-heading{
  font-size:2rem;
  font-weight: 700;
  line-height: 1.4;
  position: relative;
  padding-top:5rem;
  margin-bottom:1rem;
}
#p-lp-reason .recommend-block .arrow-heading::before {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    display: inline-block;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 30px 60px 0 60px;
    border-color: #EDF6FF transparent transparent transparent;
}
@media screen and (max-width: 960px) {
  #p-lp-reason{
    padding:0 0 6rem;
  }
  #p-lp-reason .recommend-block{
    padding: 2.4rem 1.6rem 2.44rem;
    top:-7rem;
  }
  #p-lp-reason .recommend-block .heading{
    font-size: 1.8rem;
    margin-bottom:1.6rem;
  }
  #p-lp-reason .recommend-block .recommend-list{
    grid-template-columns: repeat(1, 1fr);
  }
  #p-lp-reason .recommend-block .heading span{
    background: linear-gradient(#02328D, #02328D) 0 100% / 100% 2px no-repeat;
  }
  #p-lp-reason .recommend-block .recommend-list .item{
     width: 100%;
    display: grid;
    gap:  1rem 1.2rem;
    align-items: center;
    grid-template-columns: 11rem auto;
  }
  #p-lp-reason .recommend-block .recommend-list .item .img{
    margin:0;
  }
  #p-lp-reason .recommend-block .recommend-list .item .txt{
    font-size: 1.4rem;
    text-align: left;
  }
  #p-lp-reason .recommend-block .arrow-heading{
    font-size:1.8rem;
}
#p-lp-reason .recommend-block .arrow-heading::before {
  top:1rem;
}
}

/* Reason-List
------------ */
#p-lp-reason .reason-list .item{
  position: relative;
}
#p-lp-reason .reason-list .item:nth-of-type(n+2) {
  margin-top: 4.8rem;
}
#p-lp-reason .reason-list .item::before{
  background-size: 360px 360px;
  content: "";
  position: absolute;
  width: 360px;
  height: 360px;
}
#p-lp-reason .reason-list .item.bg-l-triangle::before{
  left: -1.4rem;
  top:-1.4rem;
  background: url(../img/common/bg-l-triangle.webp);
}
#p-lp-reason .reason-list .item.bg-r-triangle::before{
  right: -1.4rem;
  top:-1.4rem;
  background: url(../img/common/bg-r-triangle.webp);
}
#p-lp-reason .reason-list .item-row{
  background-color: #fff;
  padding:6.4rem 5.8rem;
  border-radius: var(--border-radius-md);
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  position: relative;
}
#p-lp-reason .reason-list .item .txt-row{
  position: relative;
  width: 50%;
}
/* #p-lp-reason .reason-list .item.bg-l-triangle .txt-row{
  padding:1.6rem 0 1.6rem 5.4rem;
}
#p-lp-reason .reason-list .item.bg-r-triangle .txt-row{
  padding:5.4rem;
} */
#p-lp-reason .reason-list .item .txt-row .catch{
  color:var(--color-primary);
  font-size: 3.2rem;
  font-weight: 700;
  line-height: 1.4;
  margin-bottom:2.4rem;
	position: relative;
	z-index: 1;
}
#p-lp-reason .reason-list .item .pic-row{
  width: 46%;
  aspect-ratio: 4 / 3;
  overflow: hidden;
}
#p-lp-reason .reason-list .item .pic-row img{
  border-radius: var(--border-radius-sm);
  overflow: hidden;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
#p-lp-reason .reason-list .item-row::after {
  content: "01";
  position: absolute;
  font-size: 8rem;
  font-weight: 700;
  line-height: 1;
  color:#93D7FB;
  opacity: .3;
}
#p-lp-reason .reason-list .item:nth-child(2) .item-row::after{
  content: "02";
}
#p-lp-reason .reason-list .item:nth-child(3) .item-row::after{
  content: "03";
}
#p-lp-reason .reason-list .item:nth-child(4) .item-row::after {
  content: "04";
}
#p-lp-reason .reason-list .item:nth-child(5) .item-row::after {
  content: "05";
}
#p-lp-reason .reason-list .item:nth-child(6) .item-row::after {
  content: "06";
}
#p-lp-reason .reason-list .item.bg-l-triangle .item-row::after{
  left: 1rem;
  top: 1rem;
}
#p-lp-reason .reason-list .item.bg-r-triangle .item-row::after{
  right: 1rem;
  top: 1rem;
}
#p-lp-reason .reason-list .item .reason-img{
  max-width: 8rem;
  margin-top:1.6rem
}
@media screen and (max-width: 960px) {
  #p-lp-reason .reason-list .item:nth-of-type(n+2) {
    margin-top: 3.2rem;
  }
	#p-lp-reason .reason-list .item-row{
  	padding:3.2rem 2rem;
	}
  #p-lp-reason .reason-list .item .txt-row{
    width: 100%;
		margin-bottom:2.4rem;
  }
  #p-lp-reason .reason-list .item .pic-row{
    width: 100%;
    aspect-ratio: 16 / 9;
  }
  #p-lp-reason .reason-list .item .txt-row .catch{
    font-size: 2rem;
    margin-bottom:1.6rem;
  }
  /* #p-lp-reason .reason-list .item.bg-l-triangle .txt-row{
    padding-left:1.4rem;
  }
  #p-lp-reason .reason-list .item.bg-r-triangle .txt-row{
    padding-right:1.4rem;
  } */
  #p-lp-reason .reason-list .item-row::after {
    font-size: 6.4rem;
  }
  #p-lp-reason .reason-list .item.bg-l-triangle .item-row::after{
    right: 1rem;
    left:auto;
  }
  #p-lp-reason .reason-list .item.bg-l-triangle::before{
    left: -.8rem;
    top:-.8rem;
  }
  #p-lp-reason .reason-list .item.bg-r-triangle::before{
    right: -.8rem;
    top:-.8rem;
  }
  #p-lp-reason .reason-list .item .reason-img{
    max-width: 7.2rem;
  }
}

/* Business
------------ */
#p-lp-business{
  padding:12rem 0;
}
#p-lp-business .business-list.grid-col-2{
  column-gap: 4.8rem;
  row-gap: 4.8rem;
}
#p-lp-business .business-list .img,
#p-lp-business .business-list .movie{
  position: relative;
  margin-bottom:2.4rem;
}
#p-lp-business .business-list .movie-item{
  aspect-ratio: 16 / 9;
  border-radius: var(--border-radius-sm);
  overflow: hidden;
}
#p-lp-business .business-list .movie-item .play-btn{
	display: block;
	width: 20%;
	position: absolute;
  top: 50%;
  left: 50%;
  cursor:pointer;
  transform: translateY(-50%) translateX(-50%);
  -webkit-transform: translateY(-50%) translateX(-50%);
}
#p-lp-business .business-list .movie-item .play-btn.playActive{display:none;}

#p-lp-business .business-list .img .thumb{
  position: relative;
  border-radius: var(--border-radius-sm);
  aspect-ratio: 16 / 9;
  overflow: hidden;
}
#p-lp-business .business-list .img .thumb::after{
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(to top, rgba(0, 0, 0, .4) 0%, rgba(0, 0, 0, 0) 25%);
}

#p-lp-business .business-list .img .ttl,
#p-lp-business .business-list .movie .ttl{
  position: absolute;
  left:-.8rem;
  bottom:3.2rem;
  font-size:2.4rem;
  font-weight: 700;
  color:#fff;
  z-index: 1;
}
#p-lp-business .business-list .item .ttl span{
  background: linear-gradient(to right, #02328D, #0058FF) ;
  padding:.8rem 1.6rem;
}
@media screen and (max-width: 960px) {
  #p-lp-business{
    padding:8rem 0;
  }
  #p-lp-business .business-list.grid-col-2{
    row-gap: 3.2rem;
  }
  #p-lp-business .business-list .img{
    margin-bottom:1.6rem;
  }
  #p-lp-business .business-list .img .ttl,
#p-lp-business .business-list .movie .ttl{
    bottom:2.4rem;
    font-size:1.6rem;
  }
}


/* Position
------------ */
#p-lp-position {
  padding: 0 0 12rem;
}
#p-lp-position .position-mv{
  border-radius: var(--border-radius-sm);
  overflow: hidden;
  margin-bottom:4rem;
}
#p-lp-position .position-list_header{
  display: grid;
  grid-template-columns: 16rem auto;
  align-items: center;
  column-gap: 2.4rem;
  row-gap: 2.4rem;
}
#p-lp-position .position-list_header .pic{
  border-radius: var(--border-radius-sm);
  overflow: hidden;
}
#p-lp-position .position-list_header .ttl{
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.4;
}
#p-lp-position .position-list_header .ttl .name {
  font-size: 1.4rem;
}
#p-lp-position .position-list_header .ttl .num {
  font-size: 3.2rem;
}
#p-lp-position .position-list_table {
  border-top: 1px solid #ddd;
  text-align: left;
  width: 100%;
  margin-top:2.4rem;
  font-size: 1.4rem;
}
#p-lp-position .position-list_table tr {
  border-bottom: 1px solid #ddd;
}
#p-lp-position .position-list_table th {
  padding: 1.6rem 0;
  font-weight: 700;
  text-align: left;
  width: 20%;
}
#p-lp-position .position-list_table td {
  padding: 1.6rem 0;
}
@media screen and (max-width: 960px) {
  #p-lp-position {
    padding: 0 0 8rem;
  }
  #p-lp-position .position-mv {
    margin-bottom: 3.2rem;
  }
  #p-lp-position .position-list_header {
    grid-template-columns: 12rem auto;
    row-gap: 3.2rem;
  }
  #p-lp-position .position-list_table {
    margin-top: 1.6rem;
    font-size: 1.4rem;
  }
  #p-lp-position .position-list_header .ttl {
    font-size: 1.6rem;
  }
  #p-lp-position .position-list_header .ttl .name {
    font-size: 1.3rem;
  }
  #p-lp-position .position-list_header .ttl .num {
    font-size: 2.4rem;
  }
  #p-lp-position .position-list_table th {
    padding: 1.2rem 0;
    width: 20%;
  }
  #p-lp-position .position-list_table td {
    padding: 1.2rem 0;
  }
}


/* Faq
------------ */
.faq_contents{
  text-align: left;
  padding: 2.4rem;
  background-color: #EDF6FF;
  border-radius: var(--border-radius-sm);
  border:2px solid #EDF6FF;
  transition: .3s;
}
.faq_contents:not(:first-child){
  margin-top: 1.6rem;
}
.faq_contents.selected{
  border:1px solid var(--color-primary);
}
.faq_contents .faq-head {
  position: relative;
  cursor: pointer;
}
.faq_contents .faq-head .ttl{
  font-size:1.8rem;
  font-weight: 700;
  line-height: 1.4;
  position: relative;
  padding-left:3rem;
}
.faq_contents .faq-head .ttl:before {
  content: "Q";
  position: absolute;
  left: 0;
  top: -5px;
  font-size: 2.4rem;
  color:var(--color-primary);
}
.faq_contents .toggle_icon {
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  display: block;
  width: 3rem;
  height: 3rem;
  background-color: var(--color-primary);
  padding: 1rem;
  text-indent: -9999px;
  white-space: nowrap;
  overflow: hidden;
  border-radius: var(--border-radius-sm);
}
.faq_contents .toggle_icon:before,
.faq_contents .toggle_icon:after {
  display: block;
  content: '';
  background-color: #fff;
  position: absolute;
  width: 1.5rem;
  height: .2rem;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.faq_contents .toggle_icon:before {
  width: .2rem;
  height: 1.5rem;
}
.faq_contents.selected .toggle_icon:before {
  content: normal;
}
.faq_contents dd {
  display: none;
}
.faq_contents .faq-body {
  background-color: #fff;
  margin-top: 1.6rem;
  border-radius: var(--border-radius-sm);
  padding: 2.4rem;
  line-height: 1.66;
}
.faq_contents .faq-body p span{
  display: block;
  font-size:1.2rem;
}
.faq_contents .faq-body a {
  text-decoration: underline;
}
.faq_contents .faq-body a:focus,
.faq_contents .faq-body a:active,
.faq_contents .faq-body a:hover {
  color: var(--color-primary);
  text-decoration: none;
}
@media screen and ( max-width:960px) {
  .faq_contents{
    padding: 1.6rem;
  }
  .faq_contents .faq-head {
    padding: 0 3rem 0 0;
  }
  .faq_contents .faq-head .ttl{
    font-size:1.5rem;
    padding-left:2.4rem;
  }
  .faq_contents .faq-head .ttl:before {
    top: 0px;
    font-size: 2rem;
  }
  .faq_contents .faq-body{
    margin-top:1rem;
    padding: 1.6rem
  }
  .faq_contents .toggle_icon {
    width: 2rem;
    height: 2rem;
    padding: 1rem;
  }
  .faq_contents .toggle_icon:before,
  .faq_contents .toggle_icon:after {
    width: 1rem;
    height: .2rem
  }
  .faq_contents .toggle_icon:before {
    width: .2rem;
    height: 1rem;
  }
}


/* Column
------------ */
#p-lp-column{
  border-top:1px solid #ddd;
  margin-top:12rem;
  padding:10rem 0 0;
}
@media screen and ( max-width:960px) {
  #p-lp-column{
    margin-top:6rem;
    padding:5rem 0 0;
  }
}


/* Footer
------------ */
#p-lp-footer{
  background-color: var(--color-primary);
  border-radius: 3.2rem 3.2rem 0 0;
  color:#fff;
  text-align: center;
  padding:10rem 0 6.4rem;
	margin-top:10rem;
}
#p-lp-footer .section-bg-heading::before {
  color: rgba(255, 255, 255, .1);
}
#p-lp-footer .lead-copy{
  font-size: 1.8rem;
}
#p-lp-footer .offer-list{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  column-gap: 4rem;
  row-gap: 1rem;
  margin-top:3.2rem;
}
#p-lp-footer .offer-list a {
  display: block;
  padding: 3.2rem 2rem;
  border-radius: var(--border-radius-md);
  transition: 0.2s ease-in-out;
  text-align: center;
  position: relative;
  background: var(--color-cv);
  border: 2px solid var(--color-cv);
  color: var(--color-black);
  height: 100%;
}
#p-lp-footer .offer-list a:hover{
  background-color: var(--color-cv-hover);
  border: 2px solid var(--color-cv-hover);
  transform: translateY(-3px);
}
#p-lp-footer .offer-list .icon{
  width: 8rem;
  height: auto;
  margin:0 auto 1.6rem;
}
#p-lp-footer .offer-list .ttl{
  font-size: 3.6rem;
  font-weight: 700;
  line-height: 1.22;
  margin-bottom:1rem;
}
#p-lp-footer .offer-list .txt{
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.22;
}
#p-lp-footer .offer-list .name{
  font-size: 1.8rem;
  font-weight: 700;
}
@media screen and (min-width:961px) {
  #p-staffing #p-lp-footer .offer-list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: repeat(2, 1fr);
    column-gap: 4rem;
    row-gap: 4rem;
  }
  #p-staffing #p-lp-footer .offer-list .item.tel {
    grid-area: 1 / 1 / 2 / 4;
  }

  #p-staffing #p-lp-footer .offer-list .item.osaka {
    grid-area: 2 / 1 / 3 / 2;
  }

  #p-staffing #p-lp-footer .offer-list .item.aichi {
    grid-area: 2 / 2 / 3 / 3;
  }

  #p-staffing #p-lp-footer .offer-list .item.kanagawa {
    grid-area: 2 / 3 / 3 / 4;
  }
}


@media screen and ( max-width:960px) {
  #p-lp-footer{
    border-radius: 1.6rem 1.6rem 0 0;
    padding:6.4rem 0 4rem;
		margin-top:8rem;
  }
  #p-lp-footer .lead-copy{
    font-size: 1.5rem;
  }
  #p-lp-footer .offer-list,
  #p-staffing #p-lp-footer .offer-list{
    grid-template-columns: repeat(1, 1fr);
    margin-top:2.4rem;
  }
  #p-lp-footer .offer-list a {
    border-radius: var(--border-radius-sm);
    padding: 2.4rem 2rem;
  }
  #p-lp-footer .offer-list .icon{
    width: 4.8rem;
  }
  #p-lp-footer .offer-list .ttl{
    font-size: 2.4rem;
    margin-bottom:1rem;
  }
  #p-lp-footer .offer-list .txt{
    font-size: 1.2rem;
  }
  #p-lp-footer .offer-list .name {
    font-size: 1.4rem;
    font-weight: 700;
  }
}

#p-lp-footer .footer-office{
  background-color: #032872;
  border-radius:var(--border-radius-md);
  margin:6.4rem 0;
  padding:2.4rem 3.2rem 3.2rem;
}
#p-lp-footer .footer-office .heading{
  font-size: 2.4rem;
  font-weight: 700;
  background: linear-gradient(to right, #fff, #fff) 0 100% / 100% 2px no-repeat;
  display: inline-block;
  line-height: 1.44;
}
#p-lp-footer .footer-office .heading span{
  font-size: 1.8rem;
}
#p-lp-footer .footer-office-list{
  font-size: 1.4rem;
  margin-top:2.4rem;
  text-align: left;
  column-gap: 4rem;
  row-gap: 3.2rem;
}
#p-lp-footer .footer-office-list .item{
  position: relative;
}
#p-lp-footer .footer-office-list .name{
  font-size:1.8rem;
  font-weight: 700;
  line-height: 1.4;
  margin-bottom:1rem;
  position: relative;
}
#p-lp-footer .footer-office-list .name span{
  font-size: 1.4rem;
  display: block;
}
#p-lp-footer .footer-office-list .address{
  letter-spacing: 0;
  line-height: 1.5;
}
#p-lp-footer .footer-office-list .btn-gmap {
  position: relative;
  display: inline-block;
  border:1px solid #fff;
  border-radius: .4rem;
  color: #fff;
  font-size: 1.3rem;
  padding: .6rem 2.4rem .8rem 1rem;
  line-height: 1;
  cursor: pointer;
  margin-top:1.2rem;
}
#p-lp-footer .footer-office-list .btn-gmap::after {
  content: "";
  -webkit-mask-image: url(../img/icon/blank-link.svg);
  mask-image: url(../img/icon/blank-link.svg);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  display: inline-block;
  width: 1.2rem;
  height: 1.2rem;
  position: absolute;
  top: calc(50% - .6rem);
  right: 8px;
  margin: auto;
  background-color: #fff;
}
#p-lp-footer .footer-office-list .btn-gmap:hover{
  background-color: #fff;
  color:var(--color-primary);
  }
#p-lp-footer .footer-office-list .btn-gmap:hover::after{
  background-color: var(--color-primary)
}
#p-lp-footer .footer-office-list .tel {
  font-size: 1.8rem;
  line-height: 1.22;
  margin-top: 1rem;
}
#p-lp-footer .footer-office-list .tel span{
  font-size: 1.4rem;
}

#p-lp-footer .copyright {
  font-size: 1.2rem;
  text-align: center;
}

@media screen and (min-width: 961px) {
  #p-lp-footer .footer-office-list .item:not(:first-child)::before{
    border-left: 2px dotted #405888;
    content: "";
    position: absolute;
    top: 0;
    left: -2rem;
    width: 1px;
    height: 100%;
  }
  #p-lp-footer .footer-office-list .item:nth-child(4)::before{
    content:none;
  }
  #p-staffing #p-lp-footer .footer-office-list .address{
    height: 4.5em;
  }
}
@media screen and ( max-width:960px) {
  #p-lp-footer .footer-office{
    border-radius: var(--border-radius-sm);
    margin:3.2rem 0;
    padding:2.4rem 1.6rem;
  }
  #p-lp-footer .footer-office .heading{
    font-size: 1.8rem;
    margin-bottom:.8rem;
  }
  #p-lp-footer .footer-office .heading span{
    font-size: 1.3rem;
  }
  #p-lp-footer .footer-office-list{
    font-size: 1.3rem;
    margin-top:1.6rem;
    grid-template-columns: repeat(1, 1fr);
    row-gap: 3.2rem;
  }
  #p-lp-footer .footer-office-list .name span {
    font-size: 1.3rem;
  }
  #p-lp-footer .footer-office-list .name{
    font-size:1.6rem;
  }
  #p-lp-footer .footer-office-list .btn-gmap {
    font-size: 1.2rem;
  }
  #p-lp-footer .footer-office-list .item:not(:first-child)::before {
    border-top: 2px dotted #405888;
    content: "";
    position: absolute;
    top: -1.6rem;
    left:0;
    width: 100%;
    height: 1px;
  }
  #p-lp-footer .footer-office-list .tel {
    font-size: 1.5rem;
  }
  #p-lp-footer .footer-office-list .tel span {
    font-size: 1.2rem;
  }
    #p-lp-footer .footer-office-list .tel .fax{
      padding-left:1rem;
    }
}
