/*--------------------------------------------
2025.10.17
---------------------------------------------*/
/*--------------------------------------------
TOP
---------------------------------------------*/
#top-banner{
  .cap{
    padding-top: 0;
    width: 100%;
    height: auto;
  }
  .slick-dots li.slick-active button {
    background: rgb(182, 0, 20);
    border-radius : 50%
  }
  @media screen and ( width < 768px ){
    .cap{
      aspect-ratio: 1;
    }
    figure.slider01 {
      background-image: url( "../images/slider/slider-img01_sp.png" ) !important;
    }
    figure.slider02 {
      background-image: url( "../images/slider/slider-house_sp.jpg" ) !important;
    }
    figure.slider03 {
      background-image: url( "../images/slider/slider-img03_sp-2026" .png) !important;
    }
    figure.slider04 {
      background-image: url( "../images/slider/slider-img04_sp.png" ) !important;
    }
    /* figure.slider05{
              background-image: url( "../images/slider/slider-img05_sp.png" ) !important;
          } */
    figure.slider06 {
      background-image: url( "../images/slider/slider-goodmeeting_sp.jpg" ) !important;
    }
    figure.slider07 {
      background-image: url( "../images/slider/slider-online_sp.jpg" ) !important;
    }
  }
  @media print,screen and ( width > 768px ){
    .cap{
      aspect-ratio: 1905 / 666.75;
    }
  }
}
/*--------------------------------------------
USER REGISTRATIONS
---------------------------------------------*/
@property --red01 {
  syntax: "<color>";
  inherits: false;
  initial-value: #DB0037;
}
@property --red02 {
  syntax: "<color>";
  inherits: false;
  initial-value: #E53754;
}
@property --gray01{
  syntax: "<color>";
  inherits: false;
  initial-value: #868686;
}
@property --orange01{
  syntax: "<color>";
  inherits: false;
  initial-value: #ed9623;
}
@property --borderColor01{
  syntax: "<color>";
  inherits: false;
  initial-value: #CECECE;
}
@property --filterWhite{
  syntax:"*";
  inherits: false;
  initial-value:invert(99%) sepia(28%) saturate(2%) hue-rotate(3deg) brightness(108%) contrast(100%);
}
@property --filterRed01{
  syntax:"*";
  inherits: false;
  initial-value:invert(45%) sepia(78%) saturate(6415%) hue-rotate(333deg) brightness(96%) contrast(87%);
}
@property --filterRed02{
  syntax:"*";
  inherits: false;
  initial-value:invert(100%) sepia(100%) saturate(0%) hue-rotate(307deg) brightness(103%) contrast(103%);
}
@property --filterGray01{
  syntax:"*";
  inherits: false;
  initial-value:invert(58%) sepia(0%) saturate(702%) hue-rotate(238deg) brightness(92%) contrast(86%);
}
@property --filterOrange01{
  syntax:"*";
  inherits: false;
  initial-value:invert(56%) sepia(98%) saturate(394%) hue-rotate(352deg) brightness(95%) contrast(95%);
}
.wpmem_msg{
  width: 100%!important;
}
@media screen and ( width < 768px ){
  .wpmem_msg{
    font-size: 16px!important;
    line-height: calc(32 / 16);
  }
}
@media print,screen and ( width > 768px ){
  .wpmem_msg{
    font-size: 18px!important;
    line-height: calc(32 / 18);
  }
}
:where( .page-user_registrations , .basic_information , #wpmem_login_form , .mypage , #singleEs , #singleCompany , #template_es-create , #template_es-edit , #template_interview-create , #template_interview-edit , #template_drafts ){
  .color-red01{
    color:var(--red01);
  }
  .color-red02{
    color:var(--red02);
  }
  .color-gray01{
    color:var(--gray01);
  }
  .link-text01{
    a{
      color:currentColor;
      width: fit-content;
    }
  }
  .ms-auto{
    margin-left: auto;
  }
  .me-auto{
    margin-right: auto;
  }
  a:where(.ms-auto , .me-auto){
    display: block;
    width: fit-content;
  }
  [data-before]{
    &:before{
      content : attr(data-before);
    }
  }
  span.error{
    color:var(--red02);
    font-weight: 400;
    line-height: 1.4;
  }
  @media screen and ( width < 768px ){
    &.wrap{
      padding-inline: 1rem;
    }
    .link-text01{
      a{
        font-size: 12px;
        line-height : calc( 24 / 12 );
      }
    }
  }
  @media print,screen and ( width > 768px ){
    &.wrap{
      padding-inline:calc( ( 100% - 1320px ) / 2 );
    }
    .link-text01{
      a{
        font-size: 15px;
        line-height : calc( 24 / 15 );
      }
    }
  }
}
.page-user_registrations{
  > .wp-block-group__inner-container{
    >h2{
      font-weight: 700;
    }
  }
  .box{
    background-color: white;
    padding-block: 24px;
    p{
      letter-spacing: -.06px;
    }
    ul{
      margin-top: 16px;
    }
    li{
      font-weight: 700;
      display: grid;
      align-items: start;
      justify-content: start;
      grid-template-columns: auto auto;
      &:before{
        content:"・";
      }
    }
  }
  #wpmem_reg{
    #wpmem_register_form{
      legend:empty{
        display: none;
      }
      fieldset{
        margin-block: 0;
        label:first-of-type{
          margin-top: 0;
        }
      }
      label{
        color:black;
        .req{
          display: none;
        }
      }
      .div_text{
        margin-bottom: 0;
      }
      :where( input[type="email"] , input[type="password"] , input[type="text"] ){
        border-color: var(--borderColor01);
        border-radius: 6px;
        &::placeholder{
          color:var(--gray01)!important;
        }
      }
    }
    + p{
      margin-top: 16px;
    }
  }
  #kiyaku1{
    margin-bottom: 0!important;
    p{
      color:var(--gray01);
    }
    a{
      color:var(--red01);
      -webkit-text-decoration: underline;
      text-decoration: underline;
    }
  }
  #wpmem_login{
    display: none;
  }
  #wpmem_login + p{
    display: none;
  }
  @media screen and ( width < 768px ){
    > .wp-block-group__inner-container{
      > h2{
        font-size: 24px;
        line-height : calc( 30 / 24 );
      }
      > p{
        font-size: 16px;
        line-height : calc( 32 / 16 );
      }
      > h2 + p{
        margin-top: 32px;
      }
    }
    .box{
      border-radius: 4px;
      padding-inline: 24px;
      margin-top: 32px;
      > p{
        font-size: 12px;
        line-height : calc( 24 / 12 );
      }
      li{
        font-size: 11px;
        line-height : calc( 20 / 11 );
      }
      .link-text01{
        margin-top: 12px;
      }
    }
    #wpmem_reg{
      margin-top: 40px;
      #wpmem_register_form{
        label{
          font-size: 16px;
          line-height : calc( 24 / 16 );
          &:not(:first-of-type){
            margin-top: 40px;
          }
        }
        .div_text{
          margin-top: 12px;
        }
        :where( input[type="email"] , input[type="password"] , input[type="text"] ){
          height: 48px;
          font-size: 13px;
          line-height : calc( 24 / 13 );
          padding-inline : 18px;
        }
        .button_div{
          margin-top: 40px;
        }
      }
    }
    #kiyaku1{
      margin-top: 40px;
      p{
        font-size: 12px!important;
        line-height : calc( 18 / 12 )!important;
      }
    }
  }
  @media print,screen and ( width > 768px ){
    > .wp-block-group__inner-container{
      > h2{
        font-size: 32px;
        line-height : calc( 38 / 32 );
      }
      > p{
        font-size: 18px;
        line-height : calc( 32 / 18 );
      }
      > h2 + p{
        margin-top: 32px;
      }
    }
    .box{
      border-radius: 10px;
      padding-inline: 40px;
      margin-top: 32px;
      > p{
        font-size: 15px;
        line-height : calc( 24 / 15 );
      }
      li{
        font-size: 13px;
        line-height : calc( 26 / 13 );
      }
      .link-text01{
        margin-top: 6px;
      }
    }
    #wpmem_reg{
      margin-top: 32px;
      #wpmem_register_form{
        label{
          font-size: 15px;
          line-height : calc( 24 / 15 );
          &:not(:first-of-type){
            margin-top: 32px;
          }
        }
        .div_text{
          margin-top: 6px;
        }
        :where( input[type="email"] , input[type="password"] , input[type="text"] ){
          height: 60px;
          font-size: 15px;
          line-height : calc( 24 / 15 );
          padding-inline : 19px;
        }
        .button_div{
          margin-top: 54px;
        }
      }
    }
    #kiyaku1{
      margin-top: 40px;
      p{
        font-size: 14px!important;
        line-height : calc( 24 / 14 )!important;
      }
    }
  }
}
.basic_information{
  legend:empty{
    display: none;
  }
  h2{
    font-weight: 700;
    &:not(:first-of-type){
      margin-top: 80px;
    }
  }
  fieldset{
    &:not(.is-current){
      display: none;
    }
    > label:has( .req ){
      display: flex!important;
      align-items: center;
      justify-content: start;
      color:black;
      .req{
        display: none;
      }
      &:before{
        content:"必須";
        background-color: var(--red01);
        color:white;
        display: grid;
        place-items: center;
        font-weight: 700;
      }
    }
  }
  :where( .div_text , .div_select){
    margin-bottom: 0 !important;
  }
  :where( input[type="text"] , input[type="email"] , input[type="tel"] , select ){
    background-color: white;
    border-color: var(--red01);
    padding-block: 0 !important;
    &::placeholder{
      color:var(--gray01)!important;
    }
  }
  .button_div{
    padding-block: 0!important;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    #btnFieldNext{
      color:white;
      &[disabled]{
        pointer-events: none;
        background-color: #C2C2C2;
        border-color:#c2c2c2;
      }
      &:not([disabled]){
        background-color: var(--red01);
        border-color : var(--red01);
      }
    }
    input[type="submit"]{
      background-color: var(--red01)!important;
      border-color : var(--red01)!important;
      color:white!important;
    }
  }

  #fieldset01.is-current ~ .button_div{
    input[type="submit"]{
      display: none;
    }
    #btnFieldPrev{
      display: none;
    }
  }
  #fieldset02.is-current ~ .button_div{
    #btnFieldNext{
      display: none;
    }
  }
  .div_checkbox{
    margin-bottom: 0 !important;
  }
  @media screen and ( width < 768px ){
    fieldset{
      margin-top: 48px;
    }
    h2{
      font-size: 24px;
      line-height : calc( 29 / 24 );
    }
    fieldset{
      > label{
        font-size: 16px;
        line-height : calc( 24 / 16 );
        &:has(.req){
          column-gap : 8px;
          &:before{
            width: 44px;
            height: 24px;
            font-size: 13px;
            line-height : calc( 19 / 13 );
            letter-spacing: -.06em;
            text-indent: -0.06em;
            border-radius: 6px;
          }
        }
        &:not(:first-of-type){
          margin-top: 32px!important;
        }
      }
    }
    :where( .div_text , .div_select){
      margin-top: 12px !important;
    }
    :where( input[type="text"] , input[type="email"] , input[type="tel"] , select ){
      border-radius: 6px!important;
      height: 48px!important;
      font-size: 13px;
      line-height : calc( 24 / 13 );
      padding-inline: 18px!important;
    }
    .div_select + a{
      margin-top: 4px;
      font-size: 12px;
      line-height : calc( 24 / 12 );
    }
    .div_checkbox{
      column-gap: 10px!important;
      justify-content: center!important;
      input[type="checkbox"]{
        width: 20px;
        height: 20px;
      }
      label{
        width: fit-content!important;
        font-size: 16px;
        line-height : calc( 24 / 16 );
      }
    }
    .button_div{
      margin-top: 40px;
      row-gap: 40px;
    }
  }
  @media print,screen and ( width > 768px ){
    fieldset{
      margin-top: 64px;
    }
    h2{
      font-size: 32px;
      line-height : calc( 36 / 32 );
    }
    h2 + label{
      margin-top: 40px;
    }
    fieldset{
      > label{
        font-size: 20px;
        line-height : calc( 24 / 20 );
        &:has(.req){
          column-gap : 16px;
          &:before{
            width: 48px;
            height: 28px;
            font-size: 15px;
            line-height : calc( 24 / 15 );
            letter-spacing: -.06em;
            text-indent: -0.06em;
            border-radius: 6px;
          }
        }
        &:not(:first-of-type){
          margin-top: 40px!important;
        }
      }
    }
    :where( .div_text , .div_select){
      margin-top: 14px !important;
    }
    :where( input[type="text"] , input[type="email"] , input[type="tel"] , select ){
      border-radius: 6px!important;
      height: 60px!important;
      font-size: 15px;
      line-height : calc( 24 / 15 );
      padding-inline: 18px!important;
    }
    .div_select + a{
      margin-top: 4px;
      font-size: 14px;
      line-height : calc( 24 / 14 );
    }
    .button_div{
      margin-top: 72px;
    }
    .div_checkbox{
      margin-top: 40px !important;
      gap:6px!important;
    }
  }
}
#serviceBegin{
  h2{
    font-weight: 700;
    color:var(--red01);
  }
  picture{
    display: block;
    font-size: 0;
    img{
      width: 100%;
      height: auto;
    }
  }
  p{
    color:black;
  }
  .links{
    a{
      color:var(--red01);
      &:before{
        content:"・";
      }
    }
  }
  .note{
    background-color: #F8F8F8;
    color:black;
    li{
      display: grid;
      align-items: start;
      justify-content: start;
      grid-auto-flow: column;
    }
  }
  @media screen and ( width < 768px ){
    h2{
      font-size: 24px;
      line-height : calc( 29 / 24 );
    }
    picture{
      margin-top: 24px;
    }
    p{
      margin-top: 24px;
      font-size: 16px;
      line-height : calc( 32 / 16 );
    }
    .links{
      margin-top: 34px;
      li{
        font-size: 14px;
        line-height : calc( 26 / 14 );
      }
    }
    .note{
      margin-top: 24px;
      padding-inline: 30px;
      padding-block: 24px;
      li{
        font-size: 13px;
        line-height : calc( 22 / 13 );
        + li{
          margin-top: 8px;
        }
      }
    }
  }
  @media print,screen and ( width > 768px ){
    h2{
      font-size: 32px;
      line-height : calc( 38 / 32 );
    }
    picture{
      margin-top: 32px;
    }
    p{
      margin-top: 40px;
      font-size: 18px;
      line-height : calc( 32 / 18 );
    }
    .links{
      margin-top: 32px;
      li{
        font-size: 16px;
        line-height : calc( 32 / 16 );
      }
    }
    .note{
      margin-top: 32px;
      padding-inline: 40px;
      padding-block: 24px;
      li{
        font-size: 15px;
        line-height : calc( 24 / 15 );
      }
    }
  }
}
/*--------------------------------------------
COLUMNS
---------------------------------------------*/
:is( #template_mypage , #template_es-create , #template_es-edit , #template_interview-create , #template_interview-edit , #template_drafts ){
  padding-top: 9.1875rem;
  padding-bottom: 5.3125rem;
  background-color: #f2f4f6;
  .names , .informations > li , .details-content > li{
    background-color: white;
  }
  .names{
    p{
      font-weight: 700;
    }
    h2{
      display: flex;
      align-items: center;
      justify-content: start;
      flex-wrap: wrap;
      img{
        width: auto;
        font-size: 0;
      }
      span{
        font-weight: 700;
      }
    }
  }
  :where( .informations , .details-content ){
    a{
      font-weight: 500;
    }
    a:not([data-count]){
      display: block;
    }
    a[data-count]{
      display: flex;
      align-items: center;
      justify-content: space-between;
      &:after{
        content:attr(data-count);
        display: grid;
        place-items: center;
        background-color: var(--red01);
        color:white;
        border-radius : 100vmax;
        font-weight: 700;
      }
    }
  }
  details{
    summary{
      background-color: #E5E9EF;
      font-weight: 700;
      display: block;
      list-style: none;
      font-weight: 700;
      &::-webkit-details-marker {
        display:none;
      }
    }
  }
  .column02{
    h3{
      font-weight: 700;
    }
    .box{
      background-color: white;
    }
    header{
      display: flex;
      align-items: center;
      justify-content: space-between;
    }
    h4{
      font-weight: 700;
    }
    dl{
      border-top-style: solid;
      border-top-color : #D9D9D9;
    }
  }
  @media screen and ( width < 768px ){
    .columns02{
      margin-top: 40px;
    }
    .names{
      padding-inline: 30px;
      border-radius : 12px 12px 0 0;
      padding-block: 24px;
      p{
        font-size: 14px;
        line-height : calc( 24 / 14 );
      }
      h2{
        column-gap: 4px;
        img{
          height: 21px;
        }
        span{
          font-size: 20px;
          line-height : calc( 24 / 20 );
        }
      }
    }
    :where( .informations , .details-content ){
      > li + li{
        margin-top: 4px;
      }
      a{
        padding-inline: 30px;
        font-size: 14px;
        line-height : calc( 24 / 14 );
      }
      > li:not(:has(ul)){
        > a{
          padding-block: 24px;
        }
      }
      > li:has(ul){
        padding-block: 16px;
        a{
          padding-block: 6px;
        }
      }
      a[data-count]:after{
        padding-inline: 11px;
        height: 26px;
        font-size: 13px;
        line-height : calc( 24 / 13 );
        letter-spacing: -0.06em;
        text-indent: -0.06em;
      }
    }
    .informations{
      margin-top: 4px;
    }
    details{
      margin-top: 4px;
      border-radius : 0 0 16px 16px;
      overflow: hidden;
      summary{
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding-inline: 30px;
        padding-block: 24px;
        font-size: 16px;
        line-height : calc( 24 / 16 );
        position: relative;
        &:after{
          content:"";
          font-size: 0;
          display: block;
          background: url( "../../../../wp-content/uploads/2025/07/Vector.png" ) center / contain no-repeat;
          aspect-ratio: 11.67 / 6.65;
          width: auto;
          height: 6.65px;
        }
      }
      &[open]{
        summary:after{
          rotate:0;
        }
      }
      &:not([open]){
        summary:after{
          rotate:-180deg;
        }
      }
    }
    .column02{
      margin-top : 60px;
    }
  }
  @media print,screen and ( width > 768px ){
    .columns02{
      margin-top: 80px;
      display: grid;
      grid-template-columns: 360px 904px;
      justify-content: space-between;
      align-items: start;
    }
    .column01{
      grid-column: 1;
      grid-row: 1;
    }
    .names{
      padding-inline: 30px;
      border-radius : 16px 16px 0 0;
      padding-top: 24px;
      padding-bottom: 30px;
      p{
        margin-bottom: 8px;
        font-size: 16px;
        line-height : calc( 24 / 16 );
      }
      h2{
        column-gap: 10px;
        img{
          height: 24px;
        }
        span{
          font-size: 22px;
          line-height : calc( 26 / 22 );
        }
      }
    }
    :where( .informations , .details-content ){
      > li + li{
        margin-top: 4px;
      }
      a{
        padding-inline: 32px;
        font-size: 18px;
        line-height : calc( 24 / 18 );
      }
      > li:not(:has(ul)){
        > a{
          padding-block: 28px;
        }
      }
      > li:has(ul){
        padding-block: 16px;
        a{
          padding-block: 12px;
        }
      }
      a[data-count]:after{
        padding-inline: 11px;
        height: 28px;
        font-size: 15px;
        line-height : calc( 24 / 15 );
        letter-spacing: -0.06em;
        text-indent: -0.06em;
      }
    }
    .informations{
      margin-top: 4px;
    }
    details{
      summary{
        padding-inline: 32px;
        padding-block: 20px;
        font-size: 18px;
        line-height : calc( 24 / 18 );
        pointer-events: none;
      }
      .details-content{
        border-radius : 0 0 16px 16px;
        overflow: hidden;
      }
    }
  }
}
/*--------------------------------------------
MYPAGE
---------------------------------------------*/
.mypage{
  .icon-upload-wrapper {
    width: 100%;
    position: relative;
    overflow: hidden;
    picture{
      width: 100%;
      height: 100%;
      display: block;
      img{
        object-fit: cover;
        max-width: inherit;
        max-height: inherit;
        width: 100%;
        height: 100%;
      }
    }
    .icon-upload-overlay {
      position: absolute;
      top: 10px;
      right: 10px;
      background: color-mix( in srgb , black 60% , transparent );
      color: white;
      padding: 6px;
      border-radius: 50%;
      cursor: pointer;
      display: flex;
      align-items: center;
      justify-content: center;
      transition: background 0.3s;
    }
    .icon-upload-overlay:hover {
      background: color-mix( in srgb , black 80% , transparent );
    }
    .icon-upload-overlay svg {
      width: 20px;
      height: 20px;
      fill: white;
    }
  }
  .icon-upload-input {
    display: none;
  }
  @media screen and ( width < 768px ){
    .icon-upload-wrapper {
      height: 166px;
      border-radius: 12px;
    }
    .columns02{
      margin-top: 40px;
    }
    .column02{
      margin-top: 60px;
      h3{
        font-size: 24px;
        line-height : calc( 29 / 24 );
      }
      .box{
        margin-top: 24px;
        border-radius : 16px;
       }
      header{
        padding-block: 32px;
        padding-inline : 30px;
        h4{
          font-size: 18px;
          line-height : calc( 24 / 18 );
        }
        a{
          font-size: 13px;
          line-height : calc( 24 / 13 );
        }
      }
      dl{
        border-top-width: 2px;
        padding-block: 32px;
        padding-inline: 30px;
        display: grid;
        align-items: start;
        grid-template-columns: 144px 1fr;
        row-gap : 24px;
      }
      :where( dt , dd ){
        font-size: 16px;
        line-height : calc( 24 / 16 );
      }
    }
  }
  @media print,screen and ( width > 768px ){
    .icon-upload-wrapper {
      height: 304px;
      border-radius: 16px;
    }
    .column02{
      grid-column: 2;
      grid-row: 1;
      h3{
        font-size: 32px;
        line-height : calc( 38 / 32 );
      }
      .box{
        margin-top: 32px;
        border-radius : 16px;
      }
      header{
        padding-block: 32px;
        padding-inline : 40px;
        h4{
          font-size: 20px;
          line-height : calc( 24 / 20 );
        }
        a{
          font-size: 15px;
          line-height : calc( 24 / 15 );
        }
      }
      dl{
        border-top-width: 2px;
        padding-block: 48px;
        padding-inline: 64px;
        display: grid;
        align-items: start;
        grid-template-columns: 216px 1fr;
        row-gap : 40px;
      }
      :where( dt , dd ){
        font-size: 18px;
        line-height : calc( 24 / 18 );
      }
    }
  }
}
#wpmem_login{
  background-color: white;
  border-radius : 16px;
  fieldset{
    margin-block: 0!important;
  }
  h2{
    color:black;
    font-weight: 700;
  }
  .div_text:not(:first-of-type){
    margin-top: 15px;
  }
  label:empty{
    display: none;
  }
  .div_text{
    margin-bottom: 0 !important;
    &:first-of-type{
      margin-top: 0;
    }
  }
  :where( input[type="email"] , input[type="text"] , input[type="password"] ){
    background-color: #F8F8F8!important;
    border : solid 1px #CECECE!important;
    padding-inline: 20px;
    font-size: 15px;
    line-height : calc( 24 / 15 );
    height: 47px;
    &::placeholder{
      color:var(--gray01)!important;
    }
  }
  .button_div{
    display: flex;
    align-items: center;
    justify-content: start !important;
    padding: 0!important;
    font-size: 0;
    margin-top: 15px;
    margin-bottom: 24px;
    row-gap: 0!important;
    input[type="checkbox"]{
      margin: 0;
    }
    label{
      color:var(--gray01);
      margin-bottom: 0;
      font-size: 13px;
      line-height : calc( 24 / 13 );
    }
    input[type="submit"]{
      margin-inline : auto;
      background-color: var(--red01)!important;
      color:white!important;
      display: grid;
      place-items: center;
      font-weight: 700;
      border-radius: 100vmax!important;
      width: 100%!important;
      height: 66px!important;
      font-size: 15px!important;
      line-height : calc( 24 / 15 )!important;
    }
  }
  .link-text{
    padding: 0!important;
  }
  .button_div + .link-text{
    margin-top: 0 !important;
  }
  .link-text-forgot > a{
    color:var(--red01);
    display: block;
    width: fit-content;
    margin-left: auto;
    -webkit-text-decoration: none!important;
    text-decoration: none!important;
  }
  .link-text .link-text-register{
    margin-top: 36px;
    > a{
      border-style: solid;
      border-color: var(--red01);
      background-color: white;
      color:var(--red01);
      border-radius: 100vmax;
      margin-inline : auto;
      display: grid;
      place-items: center;
      font-weight: 500;
      -webkit-text-decoration: none;
      text-decoration: none;
      width: 100%;
      height: 66px;
      border-width: 2px;
      font-size: 15px;
      line-height : calc( 24 / 15 );

    }
  }
  @media screen and ( width < 768px ){
    width: 100%;
    margin-top: 48px;
    padding-top: 32px;
    padding-bottom: 40px;
    padding-inline: 30px;
    h2{
      font-size: 20px;
      line-height : calc( 24 / 20 );
      margin-bottom: 29px;
    }
    :where( input[type="email"] , input[type="text"] , input[type="password"] ){
      border-radius: 6px;
    }
    .button_div{
      column-gap: calc( 8px / 2 );
      input[type="checkbox"]{
        width: 18px;
        height: 18px;
      }
      input[type="submit"]{
        margin-top: 32px;
      }
    }
    :where( .link-text-forgot > a , .link-text-register > a:first-of-type ){
      font-size: 12px;
      line-height : calc( 24 / 12 );
    }
    .link-text-register{
      > span{
        column-gap: 23px;
        margin-top: 32px;
        font-size: 14px;
        line-height : calc( 24 / 14 );
      }
      > a:nth-of-type(2){
        margin-top: 16px;
      }
    }
  }
  @media print,screen and ( width > 768px ){
    margin-top: 40px;
    max-width: 540px;
    margin-inline: auto;
    padding-top: 44px;
    padding-bottom: 60px;
    padding-inline: 51px;
    h2{
      font-size: 22px;
      line-height : calc( 26 / 22 );
      margin-bottom: 40px;
    }
    :where( input[type="email"] , input[type="text"] , input[type="password"] ){
      border-radius : 3px;
    }
    .button_div{
      column-gap: calc( 9px / 2 );
      input[type="checkbox"]{
        width: 16px;
        height: 16px;
      }
      input[type="submit"]{
        margin-top: 24px;
      }
    }
    :where( .link-text-forgot > a , .link-text-register > a:first-of-type ){
      font-size: 15px;
      line-height : calc( 24 / 15 );
    }
    .link-text-register{
      > span{
        column-gap: 8px;
        margin-top: 36px;
        font-size: 16px;
        line-height : calc( 24 / 16 );
      }
      > a:nth-of-type(2){
        margin-top: 12px;
      }
    }
  }
}
.page-resetPassword{
  #wpmem_login{
    fieldset{
      margin-block: 0;;
    }
    .button_div{
      margin-bottom: 0;
      margin-top: 24px;
      input[type="submit"]{
        margin-top: 0;
      }
    }
    .link-text:has( > span:empty ){
      display: none;
    }
  }
}
/*--------------------------------------------
ARCHIVE ES
---------------------------------------------*/
body.post-type-archive-es-info{
  #archive_esinfo{
    .es-left{
      > a{
        display: block;
        overflow: hidden;
        width: 100%;
        height: auto;
        img{
          object-fit: cover;
        }
      }
    }
    .es-right{
      .company-logo{
        overflow: hidden;
        border-radius: 8px;
      }
    }
    .swiper-controller{
      .es-swiper__pagination{
        position: relative;
        column-gap: 12px;
        bottom: 0;
        span{
          margin: 0;
        }
      }
      .es-slide__nav{
        position: relative;
        button{
          margin:0;
          top: 0;
          padding-inline: 0;
          bottom: 0;
          padding: 0;
        }
        img{
          height: 100%;
          width: auto;
        }
      }
    }
  }
  @media screen and ( width < 768px ){
    #archive_esinfo{
      .es-slider-wrapper{
        padding-inline: 0;
      }
      .es-slide-inner{
        row-gap: 17px;
      }
      .es-left{
        padding-inline: 20px;
        > a{
          border-radius: 12px;
        }
      }
      .es-right{
        column-gap: 20px;
        padding-inline: 20px;
        padding-bottom: 0;
        .company-name{
          font-size: 18px;
          margin-top: -2px;
          line-height : calc( 22 / 18 );
        }
        .es-title{
          font-size: 14px;
          line-height : calc( 22 / 14 );
          margin-top: 13px;
        }
      }
      .swiper-controller{
        margin-top: 40px;
        .es-slide__nav{
          height: 52px;
          margin-top: 32px;
          .es-swiper__prev{
            left: 112px;
          }
          .es-swiper__next{
            right: 112px;
          }
        }
      }
    }
  }
  @media print,screen and ( width > 768px ){
    #archive_esinfo{
      .es-slider-wrapper{
        max-width: calc( 1320px + 2rem );
      }
      .swiper{
        display: grid;
        grid-template-columns: 1fr 372px;
        grid-template-rows: 1fr 48px auto 16px;
        column-gap: calc( ( 1580 - 1160 - 372 ) * 100% / 1580 );
      }
      .swiper-wrapper{
        grid-column: 1 / -1;
        grid-row: 1/-1;
      }
      .swiper-controller{
        grid-column: 2;
        grid-row: 3;
      }
      .es-slide-inner{
        display: flex;
        align-items: flex-end;
        column-gap: calc( ( 1580 - 1160 - 372 ) * 100% / 1580 );
      }
      .es-left{
        flex-grow: 1;
        width: auto;
        > a{
          border-radius: 16px;
          aspect-ratio: 1160 / 652;
        }
      }
      .es-right{
        width: 372px;
        flex-shrink: 0;
        padding-bottom: 162px;
        .company-name{
          font-size: 20px;
          margin-top: 16px;
          line-height : calc( 24 / 20 );
        }
        .es-title{
          font-size: 18px;
          line-height : calc( 30 / 18 );
          margin-top: 40px;
        }
      }
      .swiper-controller{
        .es-slide__pagination{
          column-gap: 12px;
        }
        .es-slide__nav{
          margin-top: 32px;
          height: 52px;
          .es-swiper__prev{
            left: 108px;
          }
          .es-swiper__next{
            right: 108px;
          }
        }
      }
    }
  }
}
/*--------------------------------------------
SINGLE ES
---------------------------------------------*/
#singleEs{
  background-color: #F2F4F6;
  .breadcrumb{
    margin-block: 0;
  }
  .es{
    background-color: white;
    border-radius: 20px;
    overflow: hidden;
    header{
      h2{
        color:var(--red02);
        position: relative;
        font-weight: 700;
        &:before , &:after{
          content:"";
          display: block;
          font-size: 0;
          background-color: currentColor;
          top: 50%;
          translate: 0 -50%;
          position: absolute;
        }
        &:before{
          height: 6px;
        }
        &:after{
          border-radius: 50%;
          aspect-ratio: 1;
          width: auto;
          height: 14px;
        }
        a{
          color:var(--red02);
          -webkit-text-decoration: underline;
          text-decoration: underline;
          text-underline-offset: .2lh;
        }
      }
      p{
        color:black;
        font-weight: 700;
      }
    }
    .categories{
      margin-top: 8px;
      display: flex;
      flex-wrap: wrap;
      column-gap: 8px;
      p{
        display: grid;
        place-items: center;
        background-color: var(--red02);
        color:white;
        border-radius: 100vmax;
        font-weight: 700;
        padding-block:8px;
        padding-inline: 12px;
      }
      ul{
        outline:solid 1px var(--red02);
        outline-offset: -1px;
        border-radius: 100vmax;
        display: flex;
        align-items: center;
        justify-content: center;
        padding-inline: 4px;
        padding-block: 8px;
      }
      li{
        color:var(--red02);
        font-weight: 700;
        padding-inline: 12px;
        + li{
          border-left : solid 1px currentColor;
        }
      }
    }
  }
  .relation{
    h3{
      width: fit-content;
      border-bottom-style: solid;
      border-bottom-color: var(--red02);
      color:black;
      font-weight: 700;
    }
    > ul{
      > li{
        background-color: white;
        border-radius: 20px;
      }
    }
    section{
      display: grid;
      align-items: start;
      picture{
        display: block;
        img{
          width: auto;
        }
      }
      .categories{
        display: flex;
        flex-wrap: wrap;
        column-gap: 8px;
        p{
          display: grid;
          place-items: center;
          background-color: var(--red02);
          color:white;
          border-radius: 100vmax;
          font-weight: 700;
          padding-block:8px;
          padding-inline: 12px;
        }
        ul{
          outline:solid 1px var(--red02);
          outline-offset: -1px;
          border-radius: 100vmax;
          display: flex;
          align-items: center;
          justify-content: center;
          padding-inline: 4px;
          padding-block: 8px;
        }
        li{
          color:var(--red02);
          font-weight: 700;
          padding-inline: 12px;
          + li{
            border-left : solid 1px currentColor;
          }
        }
      }
    }
    h4{
      color:black;
      font-weight: 700;
    }
    .excerpt{
      color:black;
      background-color: #f8f8f8;
      overflow-y: hidden;
      letter-spacing: -0.06em;
      position: relative;
      &:after{
        content:"";
        display: block;
        position: absolute;
        left: 0;
        width: 100%;
        background-image: linear-gradient( to bottom , color-mix( in srgb , #f8f8f8 0% , transparent ) , color-mix( in srgb , #f8f8f8 100% , transparent ) );
      }
    }
    a{
      display: grid;
      place-items: center;
      background-color: var(--red02);
      color:white;
      border-radius :  100vmax;
      font-weight: 700;
    }
  }
  @media screen and ( width < 768px ){
    padding-inline: 20px;
    padding-top: 106px;
    padding-bottom: 88px;
    .es{
      padding-block: 32px;
      padding-inline: 20px;
      header{
        padding-inline: 20px;
        h2{
          font-size: 24px;
          line-height : calc( 30 / 24 );
          &:before{
            width: 25px;
            left: -40px;
          }
          &:after{
            left: -22px;
          }
        }
        p{
          margin-top: 8px;
          font-size: 14px;
          line-height : calc( 17 / 14 );
        }
      }
      .categories{
        padding-inline: 20px;
        margin-top: 16px;
        p{
          font-size: 12px;
          line-height : calc( 19 / 12 );
        }
        li{
          font-size: 12px;
          line-height : calc( 19 / 12 );
        }
      }
    }
    .relation{
      margin-top: 80px;
      h3{
        font-size: 18px;
        line-height: calc( 22 / 18 );
        padding-bottom: 8px;
        border-bottom-width: 4px;
      }
      > ul{
        margin-top: 32px;
        > li{
          padding-top: 20px;
          padding-bottom: 16px;
          padding-inline: 20px;
          + li{
            margin-top: 16px;
          }
        }
      }
      section{
        grid-template-columns: auto 16px auto 1fr;
        grid-template-rows: auto 16px auto 16px auto 8px auto;
      }
      .categories{
        grid-column: 1 / -1;
        grid-row: 1;
        p{
          font-size: 12px;
          line-height : calc( 19 / 12 );
        }
        li{
          font-size: 12px;
          line-height : calc( 19 / 12 );
        }
      }
      picture{
        grid-column: 1;
        grid-row: 3;
        align-self: center;
        img{
          height: 66px;
        }
      }
      h4{
        grid-column: 3;
        grid-row: 3;
        align-self: center;
        font-size: 16px;
        line-height : calc( 26 / 16 );
      }
      .excerpt{
        grid-column: 1 / 5;
        grid-row: 5;
        padding-inline: 16px;
        padding-block: 16px;
        font-size: 12px;
        line-height : calc( 21 / 12 );
        border-radius: 4px;
        max-height: 167px;
        &:after{
          height: 75px;
          top: 92px;
        }
      }
      a{
        grid-column: 1 / 5;
        grid-row: 7;
        padding-block:5px;
        width: 100%;
        padding-inline: 20px;
        font-size: 12px;
        line-height : calc( 19 / 12 );
      }
    }
    .sidebar{
      margin-top: 80px;
    }
  }
  @media print,screen and ( width > 768px ){
    padding-top: 203px;
    padding-bottom: 100px;
    padding-inline: calc( ( 100% - 1580px ) / 2 );
    .breadcrumb{
      padding-inline:130px;
    }
    .columns02{
      margin-top: 40px;
      display: grid;
      grid-template-columns: calc( 1160 * 100% / 1580 ) calc( 360 * 100% / 1580 );
      align-items: start;
      justify-content: space-between;
      row-gap: 120px;
    }
    .es{
      grid-column: 1;
      grid-row: 1;
      padding-block: 80px;
      padding-inline: 130px;
      header{
        h2{
          font-size: 35px;
          line-height : calc( 50 / 35 );
          &:before{
            width: 107px;
            left: -130px;
          }
          &:after{
            left: -32px;
          }
        }
        p{
          font-size: 18px;
          line-height : calc( 22 / 18 );
        }
      }
      .categories{
        margin-top: 24px;
        p{
          font-size: 14px;
          line-height : calc( 19 / 14 );
        }
         li{
          font-size: 14px;
          line-height : calc( 19 / 14 );
        }
      }
    }
    .relation{
      grid-column: 1;
      grid-row: 2/4;
      align-self: start;
      h3{
        font-size: 26px;
        line-height: calc( 31 / 26 );
        padding-bottom: 10px;
        border-bottom-width: 5px;
      }
      > ul{
        margin-top: 40px;
        > li{
          padding-top: 36px;
          padding-bottom: 24px;
          padding-inline: 40px;
          + li{
            margin-top: 40px;
          }
        }
      }
      section{
        grid-template-columns: auto 24px auto 1fr auto;
        grid-template-rows: 6px auto 10px auto auto 16px auto;
      }
      picture{
        grid-column: 1;
        grid-row: 1 / 6;
        img{
          height: 86px;
        }
      }
      .categories{
        grid-column: 3;
        grid-row: 2;
        p{
          font-size: 14px;
          line-height : calc( 19 / 14 );
        }
        li{
          font-size: 14px;
          line-height : calc( 19 / 14 );
        }
      }
      h4{
        grid-column: 3;
        grid-row: 4/6;
        align-self: start;
        font-size: 20px;
        line-height : calc( 28 / 20 );
      }
      a{
        grid-column: 5;
        grid-row: 4/6;
        padding-block:5px;
        padding-inline: 20px;
        font-size: 12px;
        line-height : calc( 19 / 12 );
        align-self: start;
      }
      .excerpt{
        grid-column: 1 / 6;
        grid-row: 7;
        padding-inline: 20px;
        padding-block: 16px;
        font-size: 15px;
        line-height : calc( 24 / 15 );
        border-radius: 4px;
        max-height: 256px;
        &:after{
          height: 108px;
          top: 148px;
        }
      }
    }
    .sidebar{
      grid-column: 2;
      grid-row: 1/3;
      align-self: start;
    }
  }
}
/*--------------------------------------------
TYPE
---------------------------------------------*/
#singleEs.type-es .content{
  color:black;
  h3{
    background-color: #F2F4F6;
    font-weight: 700;
  }
  p + h3{
    margin-top: 64px;
  }
  @media screen and ( width < 768px ){
    margin-top: 64px;
    h3{
      padding-inline: 16px;
      font-size: 17px;
      line-height : calc( 28 / 17 );
      padding-block : 10px;
    }
    p{
      font-size: 15px;
      line-height : calc( 28 / 15 );
    }
    h3 + p{
      margin-top: 24px;
    }
  }
  @media print,screen and ( width > 768px ){
    margin-top: 80px;
    h3{
      padding-inline: 24px;
      font-size: 20px;
      line-height : calc( 48 / 20 );
    }
    p{
      font-size: 15px;
      line-height : calc( 26 / 15 );
    }
    h3 + p{
      margin-top: 32px;
    }
  }
}
#singleEs.type-experience .content{
  h3{
    color:var(--red02);
    font-weight: 700;
    border-left-style: solid;
    border-left-color:currentColor;
    border-left-width: 5px;
  }
  h4{
    background-color: #F2F4F6;
    font-weight: 700;
    color:black;
  }
  h4 + table{
    margin-top: 8px;
  }
  table{
    overflow: visible;
  }
  table{
    width: 100%;
    th, td{
      color:black;
      border-left: 0;
      border-right: 0;
      border-top: 0;
      border-bottom : solid 1px #D9D9D9;
      vertical-align: middle;
    }
    th{
      position: relative;
      font-weight: 700;
      text-align: center;
      &:after{
        content:"";
        position: absolute;
        width: 100%;
        background-color: var(--red01);
        font-size: 0;
        left: 0;
        height: 3px;
        bottom: -1.5px;
      }
    }
  }
  table + h4{
    margin-top: 64px;
  }
  h5{
    border-left-style: solid;
    border-left-color:var(--red01);;
    font-weight: 700;
    color:black;
  }
  p{
    color:black;
  }
  p + h5 , p + h6{
    margin-top: 24px;
  }
  h6{
    display: flex;
    align-items: center;
    justify-content: start;
    flex-wrap: nowrap;
    &:before{
      content:"";
      display: block;
      font-size: 0;
      background-color: var(--red01);
      aspect-ratio: 1;
      width: auto;
    }
  }
  h6 + p{
    margin-top: 8px;
  }
  p + h4{
    margin-top: 64px;
  }
  @media screen and ( width < 768px ){
    margin-top: 64px;
    h3{
      font-size: 20px;
      line-height : calc( 24 / 20 );
      padding-left: 10px;
    }
    h3 + h4{
      margin-top: 40px;
    }
    h4{
      padding-inline: 16px;
      font-size: 17px;
      line-height : calc( 48 / 17 );
    }
    table{
      th{
        font-size: 14px;
        line-height : calc( 32 / 14 );
        padding-block: 16px;
        width: 120px;
      }
      td{
        padding-inline: 16px;
        font-size: 14px;
        line-height : calc( 26 / 14 );
        padding-block: 19px;
      }
    }
    h4 + h5{
      margin-top: 24px;
    }
    h5{
      border-left-width: 5px;
      padding-left: 13px;
      font-size: 18px;
      line-height : calc( 22 / 18 );
    }
    h5 + p{
      margin-top: 25px;
    }
    p{
      font-size: 15px;
      line-height : calc( 28 / 15 );
    }
    h6{
      column-gap: 6px;
      font-size: 15px;
      line-height : calc( 29 / 15 );
      &:before{
        height: 12px;
      }
    }
  }
  @media print,screen and ( width > 768px ){
    margin-top: 80px;
    h3{
      font-size: 30px;
      line-height : calc( 36 / 30 );
      padding-left: 20px;
    }
    h3 + h4{
      margin-top: 48px;
    }
    h4{
      padding-inline: 24px;
      font-size: 20px;
      line-height : calc( 48 / 20 );
    }
    table{
      th{
        font-size: 15px;
        line-height : calc( 32 / 15 );
        padding-block: 24px;
        width: 240px;
      }
      td{
        padding-inline: 24px;
        font-size: 15px;
        line-height : calc( 26 / 15 );
        padding-block: 27px;
      }
    }
    h4 + h5{
      margin-top: 31px;
    }
    h5{
      border-left-width: 6px;
      padding-left: 12px;
      font-size: 20px;
      line-height : calc( 24 / 20 );
    }
    h5 + p{
      margin-top: 32px;
    }
    p{
      font-size: 15px;
      line-height : calc( 26 / 15 );
    }
    h6{
      column-gap: 12px;
      font-size: 18px;
      line-height : calc( 32 / 18 );
      &:before{
        height: 16px;
      }
    }
  }
}
/*--------------------------------------------
COMPANY
---------------------------------------------*/
#singleCompany{
  background-color: #F2F4F6;
  .breadcrumb{
    margin-block: 0;
  }
  .company{
    background-color: white;
    border-radius: 20px;
    overflow: hidden;
    header{
      h2{
        color:var(--red02);
        position: relative;
        font-weight: 700;
        &:before , &:after{
          content:"";
          display: block;
          font-size: 0;
          background-color: currentColor;
          top: 50%;
          translate: 0 -50%;
          position: absolute;
        }
        &:before{
          height: 6px;
        }
        &:after{
          border-radius: 50%;
          aspect-ratio: 1;
          width: auto;
          height: 14px;
        }
      }
      p{
        color:black;
        font-weight: 700;
      }
    }
    dl{
      display: grid;
      color:black;
      dt , dd{
        align-self: center;
        border-bottom : solid 1px #D9D9D9;
      }
      dt{
        position: relative;
        font-weight: 700;
        text-align: center;
        &:after{
          content:"";
          position: absolute;
          width: 100%;
          background-color: var(--red01);
          font-size: 0;
          left: 0;
          height: 3px;
          bottom: -1.5px;
        }
      }
    }
  }
  .relation{
    h3{
      width: fit-content;
      border-bottom-style: solid;
      border-bottom-color: var(--red02);
      color:black;
      font-weight: 700;
    }
    > ul{
      > li{
        background-color: white;
        border-radius: 20px;
      }
    }
    section{
      display: grid;
      align-items: start;
      picture{
        display: block;
        img{
          width: auto;
        }
      }
      .categories{
        display: flex;
        flex-wrap: wrap;
        column-gap: 8px;
        p{
          display: grid;
          place-items: center;
          background-color: var(--red02);
          color:white;
          border-radius: 100vmax;
          font-weight: 700;
          padding-block:8px;
          padding-inline: 12px;
        }
        ul{
          outline:solid 1px var(--red02);
          outline-offset: -1px;
          border-radius: 100vmax;
          display: flex;
          align-items: center;
          justify-content: center;
          padding-inline: 4px;
          padding-block: 8px;
        }
        li{
          color:var(--red02);
          font-weight: 700;
          padding-inline: 12px;
          + li{
            border-left : solid 1px currentColor;
          }
        }
      }
    }
    h4{
      color:black;
      font-weight: 700;
    }
    .excerpt{
      color:black;
      background-color: #f8f8f8;
      overflow-y: hidden;
      letter-spacing: -0.06em;
      position: relative;
      &:after{
        content:"";
        display: block;
        position: absolute;
        left: 0;
        width: 100%;
        background-image: linear-gradient( to bottom , color-mix( in srgb , #f8f8f8 0% , transparent ) , color-mix( in srgb , #f8f8f8 100% , transparent ) );
      }
    }
    a{
      display: grid;
      place-items: center;
      background-color: var(--red02);
      color:white;
      border-radius :  100vmax;
      font-weight: 700;
    }
  }
  @media screen and ( width < 768px ){
    padding-inline: 20px;
    padding-top: 106px;
    padding-bottom: 88px;
    .company{
      padding-block: 32px;
      padding-inline: 20px;
      margin-top: 26px;
      header{
        padding-inline: 20px;
        h2{
          font-size: 24px;
          line-height : calc( 30 / 24 );
          &:before{
            width: 25px;
            left: -40px;
          }
          &:after{
            left: -22px;
          }
        }
        p{
          margin-top: 8px;
          font-size: 14px;
          line-height : calc( 17 / 14 );
        }
      }
      dl{
        grid-template-columns: 120px 1fr;
        dt{
          font-size: 14px;
          line-height : calc( 32 / 14 );
          padding-block: 16px;
        }
        dd{
          padding-inline: 16px;
          font-size: 14px;
          line-height : calc( 26 / 14 );
          padding-block: 19px;
        }
      }
    }
    .relation{
      margin-top: 80px;
      h3{
        font-size: 18px;
        line-height: calc( 22 / 18 );
        padding-bottom: 8px;
        border-bottom-width: 4px;
      }
      > ul{
        margin-top: 32px;
        > li{
          padding-top: 20px;
          padding-bottom: 16px;
          padding-inline: 20px;
          + li{
            margin-top: 16px;
          }
        }
      }
      section{
        grid-template-columns: auto 16px auto 1fr;
        grid-template-rows: auto 16px auto 16px auto 8px auto;
      }
      .categories{
        grid-column: 1 / -1;
        grid-row: 1;
        p{
          font-size: 12px;
          line-height : calc( 19 / 12 );
        }
        li{
          font-size: 12px;
          line-height : calc( 19 / 12 );
        }
      }
      picture{
        grid-column: 1;
        grid-row: 3;
        align-self: center;
        img{
          height: 66px;
        }
      }
      h4{
        grid-column: 3;
        grid-row: 3;
        align-self: center;
        font-size: 16px;
        line-height : calc( 26 / 16 );
      }
      .excerpt{
        grid-column: 1 / 5;
        grid-row: 5;
        padding-inline: 16px;
        padding-block: 16px;
        font-size: 12px;
        line-height : calc( 21 / 12 );
        border-radius: 4px;
        max-height: 167px;
        &:after{
          height: 75px;
          top: 92px;
        }
      }
      a{
        grid-column: 1 / 5;
        grid-row: 7;
        padding-block:5px;
        width: 100%;
        padding-inline: 20px;
        font-size: 12px;
        line-height : calc( 19 / 12 );
      }
    }
    .sidebar{
      margin-top: 80px;
    }
  }
  @media print,screen and ( width > 768px ){
    padding-top: 203px;
    padding-bottom: 100px;
    padding-inline: calc( ( 100% - 1580px ) / 2 );
    .breadcrumb{
      padding-inline:130px;
    }
    .columns02{
      margin-top: 40px;
      display: grid;
      grid-template-columns: 1160px 360px;
      align-items: start;
      justify-content: space-between;
      row-gap: 120px;
    }
    .company{
      grid-column: 1;
      grid-row: 1;
      padding-block: 80px;
      padding-inline: 130px;
      header{
        h2{
          font-size: 35px;
          line-height : calc( 50 / 35 );
          &:before{
            width: 107px;
            left: -130px;
          }
          &:after{
            left: -32px;
          }
        }
        p{
          font-size: 18px;
          line-height : calc( 22 / 18 );
        }
      }
      dl{
        grid-template-columns: 240px 1fr;
        dt{
          font-size: 15px;
          line-height : calc( 32 / 15 );
          padding-block: 24px;
        }
        dd{
          padding-inline: 24px;
          font-size: 15px;
          line-height : calc( 26 / 15 );
          padding-block: 27px;
        }
      }
    }
    .relation{
      grid-column: 1;
      grid-row: 2/4;
      align-self: start;
      h3{
        font-size: 26px;
        line-height: calc( 31 / 26 );
        padding-bottom: 10px;
        border-bottom-width: 5px;
      }
      > ul{
        margin-top: 40px;
        > li{
          padding-top: 36px;
          padding-bottom: 24px;
          padding-inline: 40px;
          + li{
            margin-top: 40px;
          }
        }
      }
      section{
        grid-template-columns: auto 24px auto 1fr auto;
        grid-template-rows: 6px auto 10px auto auto 16px auto;
      }
      picture{
        grid-column: 1;
        grid-row: 1 / 6;
        img{
          height: 86px;
        }
      }
      .categories{
        grid-column: 3;
        grid-row: 2;
        p{
          font-size: 14px;
          line-height : calc( 19 / 14 );
        }
        li{
          font-size: 14px;
          line-height : calc( 19 / 14 );
        }
      }
      h4{
        grid-column: 3;
        grid-row: 4/6;
        align-self: start;
        font-size: 20px;
        line-height : calc( 28 / 20 );
      }
      a{
        grid-column: 5;
        grid-row: 4/6;
        padding-block:5px;
        padding-inline: 20px;
        font-size: 12px;
        line-height : calc( 19 / 12 );
        align-self: start;
      }
      .excerpt{
        grid-column: 1 / 6;
        grid-row: 7;
        padding-inline: 20px;
        padding-block: 16px;
        font-size: 15px;
        line-height : calc( 24 / 15 );
        border-radius: 4px;
        max-height: 256px;
        &:after{
          height: 108px;
          top: 148px;
        }
      }
    }
    .sidebar{
      grid-column: 2;
      grid-row: 1/3;
      align-self: start;
    }
  }
}
/*--------------------------------------------
LOGIN POPUP
---------------------------------------------*/
body:has( #loginPopup[open] ){
  overflow: hidden;
}
#loginPopup{
  position: fixed;
  inset: 0;
  place-items: center;
  width: 100%;
  height: 100%;
  max-width: inherit;
  max-height: inherit;
  background-color: color-mix( in srgb , #3d3d3d 95% , transparent );
  &:not([open]){
    display: none;
  }
  &[open]{
    display: grid;
    z-index: 10;
  }
  .dialog-container{
    background-color: white;
    width: 100%;
    border-radius: 16px;
  }
  #wpmem_reg{
    background-color: white;
    width: 100%;
    legend{
      text-align: center;
      font-weight: 700;
      color:black;
      display: block;
    }
    label{
      display: flex;
      align-items: baseline;
      color:black;
      span{
        color:var(--gray01);
        display: flex;
        align-items:baseline;
        justify-content: start;
      }
      img{
        width: auto;
      }
      .req{
        display: none;
      }
    }
    .div_text{
      margin-bottom: 0;
    }
    :where( input[type="text"] , input[type="email"] , input[type="password"] ){
      border : solid 1px #cecece;
      background-color: #F8F8F8;
      &::placeholder{
        color:var(--gray01)!important;
      }
    }
    fieldset{
      margin: 0;
      > p{
        color:var(--gray01);
        a{
          color:var(--red01);
        }
      }
    }
    input[type="submit"]{
      border-radius : 100vmax;
      background-color: var(--red01);
      color:white;
      border : solid 1px var(--red01);
      display: grid;
      width: 100%;
      place-items: center;
      font-weight: 700;
      height: 66px;
      font-size: 15px;
      line-height : calc( 24 / 15 );
    }
    fieldset{
      > a{
        margin-top: 24px;
        border-radius : 100vmax;
        background-color: white;
        color:var(--red01);
        border-style : solid;
        border-width: 1px;
        border-color : var(--red01);
        display: grid;
        width: 100%;
        place-items: center;
        font-weight: 700;
        height: 66px;
        font-size: 15px;
        line-height : calc( 24 / 15 );
      }
    }
    .button_div{
      padding-block: 0;
    }
  }
  @media screen and ( width < 768px ){
    .dialog-container{
      max-width: 360px;
      padding-block: 40px;
      padding-inline: 30px;
    }
    #wpmem_reg{
      legend{
        font-size: 20px;
        line-height : calc( 24 / 20 );
        margin-bottom: 37px;
      }
      label{
        font-size: 16px;
        line-height : calc( 24 / 16 );
        column-gap: 10px;
        span{
          font-size: 11px;
          line-height : calc( 24 / 11 );
          column-gap: 4px;
          img{
            height: 12px;
          }
        }
      }
      .div_text{
        margin-top: 12px;
      }
      :where( input[type="text"] , input[type="email"] , input[type="password"] ){
        height: 47px;
        border-radius: 6px;
        font-size: 15px;
        line-height : calc( 24 / 15 );
      }
      fieldset{
        > label:not(:first-of-type){
          margin-top: 24px;
        }
        > p{
          &:nth-of-type(1){
            font-size: 14px;
            line-height : calc( 24 / 14 );
            margin-top: 32px;
          }
          &:nth-of-type(2){
            font-size: 11px;
            line-height : calc( 18 / 11 );
            margin-top: 24px;
          }
        }
      }
      .button_div{
        margin-top: 32px;
      }
    }
  }
  @media print,screen and ( width > 768px ){
    .dialog-container{
      max-width: 500px;
      padding-top: 48px;
      padding-bottom: 48px;
      padding-inline: 60px;
    }
    #wpmem_reg{
      legend{
        font-size: 22px;
        line-height : calc( 26 / 22 );
        margin-bottom: 40px;
      }
      label{
        font-size: 18px;
        line-height : calc( 24 / 18 );
        column-gap: 10px;
        span{
          font-size: 13px;
          line-height : calc( 24 / 13 );
          column-gap: 3px;
          img{
            height: 12px;
          }
        }
      }
      .div_text{
        margin-top: 10px;
      }
      :where( input[type="text"] , input[type="email"] , input[type="password"] ){
        height: 47px;
        border-radius: 3px;
        font-size: 15px;
        line-height : calc( 24 / 15 );
      }
      fieldset{
        > label:not(:first-of-type){
          margin-top: 32px;
        }
        > p{
          &:nth-of-type(1){
            font-size: 16px;
            line-height : calc( 24 / 16 );
            margin-top: 40px;
          }
          &:nth-of-type(2){
            font-size: 13px;
            line-height : calc( 18 / 13 );
            margin-top: 24px;
          }
        }
      }
      .button_div{
        margin-top: 40px;
      }
    }
  }
}
/*--------------------------------------------

---------------------------------------------*/
.popup_wrap.popup_view{
  z-index: calc(infinity);
}
body.single-type_campus{
  @media screen and ( width < 768px ){
    --headerHeight : 72px;
    main{
      padding-top: var(--headerHeight);
    }
  }
  @media print,screen and ( width > 768px ){
    --headerHeight : 147px;
    .all_container{
      overflow-x: clip;
    }
    main{
      padding-top: var(--headerHeight);
    }
    .campus_sidebar_container{
      padding-top: 0;
    }
  }
}
/*--------------------------------------------
VIDEOS
---------------------------------------------*/
.post-type-archive-videos {
  #archive__videos{
    .video-left{
      > a{
        display: block;
        overflow: hidden;
      }
    }
    .video-right{
      .company-logo{
        overflow: hidden;
        border-radius: 8px;
      }
    }
    .swiper-controller{
      .video-swiper__pagination{
        position: relative;
        column-gap: 12px;
        bottom: 0;
        span{
          margin: 0;
        }
      }
      .video-slide__nav{
        position: relative;
        button{
          margin:0;
          top: 0;
          padding-inline: 0;
          bottom: 0;
          padding: 0;
        }
        img{
          height: 100%;
          width: auto;
        }
      }
    }
  }
  @media screen and ( width < 768px ){
    #archive__videos{
      .video-slider-wrapper{
        padding-inline: 0;
      }
      .video-slide-inner{
        row-gap: 17px;
      }
      .video-left{
        padding-inline: 20px;
        > a{
          border-radius: 12px;
        }
      }
      .video-right{
        column-gap: 20px;
        padding-inline: 20px;
        padding-bottom: 0;
        .company-name{
          font-size: 18px;
          margin-top: -2px;
          line-height : calc( 22 / 18 );
        }
        .video-title{
          font-size: 14px;
          line-height : calc( 22 / 14 );
          margin-top: 13px;
        }
      }
      .swiper-controller{
        margin-top: 40px;
        .video-slide__nav{
          height: 52px;
          margin-top: 32px;
          .video-swiper__prev{
            left: 112px;
          }
          .video-swiper__next{
            right: 112px;
          }
        }
      }
    }
  }
  @media print,screen and ( width > 768px ){
    #archive__videos{
      .video-slider-wrapper{
        max-width: calc( 1320px + 2rem );
      }
      .swiper{
        display: grid;
        grid-template-columns: 1fr 372px;
        grid-template-rows: 1fr 48px auto 16px;
        column-gap: calc( ( 1580 - 1160 - 372 ) * 100% / 1580 );
      }
      .swiper-wrapper{
        grid-column: 1 / -1;
        grid-row: 1/-1;
      }
      .swiper-controller{
        grid-column: 2;
        grid-row: 3;
      }
      .video-left{
        flex-grow: 1;
        flex-shrink: 0;
        width: auto;
        > a{
          border-radius: 16px;
        }
      }
      .video-right{
        width: 372px;
        flex-shrink: 0;
        padding-bottom: 162px;
        .company-name{
          font-size: 20px;
          margin-top: 16px;
          line-height : calc( 24 / 20 );
        }
        .video-title{
          font-size: 18px;
          line-height : calc( 30 / 18 );
          margin-top: 40px;
        }
      }
      .swiper-controller{
        .video-slide__pagination{
          column-gap: 12px;
        }
        .video-slide__nav{
          margin-top: 32px;
          height: 52px;
          .video-swiper__prev{
            left: 108px;
          }
          .video-swiper__next{
            right: 108px;
          }
        }
      }
    }
  }
}
/*--------------------------------------------
SP MENUBOX
---------------------------------------------*/
#sp-menubox{
  @media ( 768px <= width < 1560px ){
    padding-inline: calc( 32 * 100% / 1560 );
    .global_navigation{
      padding-inline : 0;
    }
    .menu-content-wrapper{
      column-gap : calc( 32 * 100% / 1496 );
    }
  }
}
/*--------------------------------------------
HEADER
---------------------------------------------*/
#header{
  #header-nav{
    .wrap-box{
      > div{
        >span{
          display: block;
          color:#b60014;
          font-weight: 500;
          font-size: 1rem;
          margin-top : 4px;
          text-align: center;
          width: 1.875rem ! important;
          white-space: pre;
          position: relative;
          > span{
            position: absolute;
            left: 50%;
            translate: -50% 0;
          }
        }
      }
    }
  }
  @media screen and ( width < 768px ){
    &.has-scrolled.is-view{
      translate: 0 0;
    }
    &.has-scrolled:not(.is-view){
      translate: 0 -100%;
    }
    #header-nav{
      .wrap-box{
        > div{
          >span{
            margin-left: 10px;
          }
        }
      }
    }
  }
  @media print,screen and ( width > 768px ){
    #header-nav{
      .wrap-box{
        > div{
          >span{
            margin-left: 20px;
          }
        }
      }
    }
  }
}
/*--------------------------------------------
FOOTER
---------------------------------------------*/
@media screen and ( width < 768px ){
  .global_navigation .g{
    align-items: end;
  }
}
footer#footer{
  .footer_inner{
    position: relative;
  }
  .topbutton.is-absolute{
    position: absolute;
    top: 12px;
  }
  @media print,screen and ( width > 768px ){
    .g{
      align-items: end;
    }
  }
}
/*--------------------------------------------
CAMPUS
---------------------------------------------*/
body.post-type-archive-type_campus{
  .post_co_inner{
    .post_co__label:not(.only_icon):not(.post_co__label__limited ){
      outline: solid 1px var(--red02);
      outline-offset: -1px;
    }
  }
  .post_co_inner{
    .post_co__label:not(.only_icon).post_co__label__limited {
      outline: solid 1px var(--orange01);
      outline-offset: -1px;
      img{
        filter: var(--filterWhite);
      }
    }
  }
  .stepguide_item__title{
    font-feature-settings: "palt" on;
  }
}
@media ( hover : hover ){
  body.post-type-archive-type_campus{
    .post_co_inner:hover{
      .post_co__label:not(.only_icon):not(.post_co__label__limited ){
        background-color: color-mix( in srgb , white 80% , transparent );
        .text{
          color:var(--red02);
        }
      }
    }
    .post_co_inner:hover{
      .post_co__label:not(.only_icon).post_co__label__limited{
        background-color: color-mix( in srgb , white 80% , transparent );
        .text{
          color:var(--orange01);
        }
        img{
          filter: var(--filterOrange01);
        }
      }
    }
    .btn_red_border:hover{
      background-color: var(--red02);
      color:white;
    }
    .btn_red_fill:hover{
      background-color: white;
      color:var(--red02);
    }
    .btn_black_border:hover{
      background-color: black;
      color:white;
    }
    #campus-stepguide button:hover{
      background-color: var(--red02);
      color:white;
      span{
        background-color: white;
        color:var(--red02)
      }
    }
  }
}
/*--------------------------------------------
SINGLE CAMPUS
---------------------------------------------*/
.single-curner-box .contents-box .single-sns-box li.x {
  background: black;
}
/*--------------------------------------------
SIDEBAR
---------------------------------------------*/
.campus_sidebar_container{
  @media print,screen and ( width > 768px ){
    .sidebar{
      > div:first-of-type{
        margin-top: 0;
      }
    }
  }
}
/*--------------------------------------------
FORM PARTS
---------------------------------------------*/
#single_materials{
  .form-dl{
    select{
      flex-shrink: 0;
      font-size: 1.125rem;
      line-height: 1.3333333333;
      border: 1px solid #cecece;
    }
  }
  input::placeholder{
    color:#868686!important;
  }
  .materials-wysiwyg{
    li span{
      color:var(--red02);
    }
  }
  @media screen and ( width < 768px ){
    .form-dl{
      select{
        width: 100%;
      }
    }
  }
  @media print,screen and ( width > 768px ){
    .form-dl{
      select{
        width: 24.4375rem;
      }
    }
  }
}
/*--------------------------------------------
ARCHIVE VIDEO
---------------------------------------------*/
.video-search{
  @media screen and ( width < 768px ){
    .video-search-fields{
      display: block;
    }
    .video-search-form{
      .video-search-fields{
        .search-taxonomy{
          width: 100%;
          margin-top: 10px;
        }
        .search-button{
          margin-top: 24px;
          width: 100%;
        }
      }
    }

  }
}
/*--------------------------------------------
SINGLE VIDEO
---------------------------------------------*/
#single_videos{
  .video-category-tabs-scroll{
    width: 100%;
    max-width: inherit;
    overflow: visible;
    padding-right: 0;
  }
  .video-category-tabs{
    flex-wrap: wrap;
    inline-size: inherit;
  }
  @media print,screen and ( width > 768px ){
    .single_videos__head{
      display: block;
    }
    .video-search-fields{
      justify-content: end;
    }
    .search-box{
      width: auto;
    }
  }
}
/*--------------------------------------------
ARCHIVE ES INFO
---------------------------------------------*/
#archive_esinfo{
  .user-message{
    padding: 0;
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: calc( 1rem + 3lh ) 1fr;
    > p{
      grid-column: 1;
      grid-row: 1/-1;
      padding : 1rem 1.25rem
    }
    .user-message-blur , .user-message-fade{
      position: relative;
      grid-column: 1;
      grid-row: 2;
    }
    .user-message-fade{
      height: auto;
    }
  }
  @media screen and ( width < 768px ){
    .user-message{
      font-size: 0.75rem;
      line-height: 1.75;
    }
  }
  @media print,screen and ( width > 768px ){
    .user-message{
      line-height: 1.6;
      font-size: 0.9375rem;
    }
  }
}
/*--------------------------------------------
SIDEBAR
---------------------------------------------*/
.sidebar{
  .app-promo-icon{
    flex-shrink: 0;
    img{
      width: auto;
      height: 90px;
    }
  }
}
/*--------------------------------------------
CTA
---------------------------------------------*/
.top_cta {
	margin-top: 50px;
	padding: 32px 24px;
	line-height: 1.2;
	background: #F7F7F7;
	border: 3px solid #BD0E10;
  .cta_tit {
    margin-bottom: 1em;
    padding: 10px 0 10px 45px;
    color: #383838;
    font-size: 19px;
    font-weight: 700;
    background:  url(../images/campus/common/icon_ranking_crown.png) no-repeat left center / 38px auto;
  }

  .cta_tit span {
    display: inline-block;
    margin-left: 0.5em;
    padding: 0.2em 0.5em;
    font-size: 16px;
    font-weight: 600;
    background: #fff;
    border-radius: 1em;
    border: 2px solid #BD0E10;
  }

  ol {
    list-style: none;
  }

  li {
    margin-bottom: 1em;
    padding-bottom: 1em;
    border-bottom: 2px dashed #CBCBCB;
  }

  li:last-child {
    margin-bottom: 0;
    padding-bottom: 0;
    border-bottom: none;
  }

  li::before {
    content: none;
  }

  li span {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    width: 35px;
    height: 35px;
    margin-right: 15px;
    color: #fff;
    font-size: 22px;
    font-weight: 500;
    line-height: 1;
    background: #BD0E10;
    border-radius: 50%;
    box-sizing: border-box;
  }

  li:nth-child(4) span,
  li:nth-child(5) span {
    background: #4A4A4A;
  }

  li a {
    color: #2085D9 !important;
    font-size: 22px;
    font-weight: 600;
    -webkit-text-decoration: underline;
    text-decoration: underline;
  }

  li a:hover {
    -webkit-text-decoration: none;
    text-decoration: none;
  }

  li p {
    margin-bottom: 0 !important;
    padding-left: 50px;
    color: #383838;
    font-size: 16px !important;
    font-weight: 600;
    line-height: 1.4 !important;
  }
  @media screen and ( width < 768px ){
    .cta_tit {
      background:  url("../images/campus/common/icon_ranking_crown.png") no-repeat left top 0.5em / 38px auto;
    }

    .cta_tit span {
      margin: 0.5em 0 0;
    }
  }
}
.btn_cta {
	margin: 30px 0;
	text-align: center;
  p {
    margin-bottom: 0 !important;
    color: #676767;
  }
  p span {
    display: inline-block;
    padding: 0 1em;
    position: relative;
    font-size: 18px;
    font-weight: 600;
  }
  p span::before,
  p span::after {
    content: "";
    position: absolute;
    top: 0;
    display: block;
    width: 2px;
    height: 1em;
    background: #676767;
  }
  p span::before {
    left: 0;
    transform: rotate(-30deg);
  }
  p span::after {
    right: 0;
    transform: rotate(30deg);
  }
  .red {
    color: #BD0E10;
  }
  .note {
    font-size: 14px !important;
  }
  .mockup_img {
    width: 80%;
  }
  a {
    position: relative;
    display: block;
    margin: 0.5em 2em;
    padding: 1em 3em 1em 1em;
    color: #fff !important;
    font-size: 22px;
    font-weight: 600;
    border-radius: 2em;
    box-shadow: 0px 2px 2px 0px rgba(0, 0, 0, 0.5), inset 0px -3px 6px -2px rgba(0, 0, 0, 0.3);
  }
  a:hover {
    opacity: 0.7;
  }
  a::before {
    content: "";
    position: absolute;
    right: 40px;
    top: 0;
    bottom: 0;
    margin: auto;
    display: block;
    width: 24px;
    height: 24px;
    background: #fff;
    border-radius: 50%;
  }
  a::after {
    content: "";
    position: absolute;
    right: 44px;
    top: 0;
    bottom: 0;
    margin: auto;
    display: block;
    width:0;
    height:0;
    border-style:solid;
    border-width: 7px 0 7px 12.1px;
  }
  .img_link {
    position: relative;
    display: block;
    margin: 0;
    padding: 0;
    border-radius: 0;
    box-shadow: none;
  }

  .img_link:hover {
    opacity: 1;
  }

  .img_link::before {
    content: none;
  }

  .img_link::after {
    content: none;
  }

  .btn_line {
    background: #06C755;
  }

  .btn_line::after {
    border-color: transparent transparent transparent #06C755;
  }

  .btn_01 {
    background: #ED9623;
  }

  .btn_01::after {
    border-color: transparent transparent transparent #ED9623;
  }

  .btn_02 {
    background: #BD0E10;
  }

  .btn_02::after {
    border-color: transparent transparent transparent #BD0E10;
  }
}
/*--------------------------------------------
SINGLE CAMPUS
---------------------------------------------*/
body.single-type_campus{
  .conte-box{
    div[style*="text-align: center"]{
      > a{
        display: block;
        width: fit-content;
        margin-inline : auto;
      }
    }
  }
}