@charset "UTF-8";

/* ========================================
   @media screen and (min-width: 768px), print
======================================== */
@media screen and (min-width: 768px), print {
  /* aboutus-cards：PC
  -------------------------------------*/
  #aboutus .aboutus-cards__list {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    align-items: start;
    column-gap: clamp(16px, 0px + 2.083vw, 40px); /* 768 ~ 1920px */
    row-gap: 60px;
    width: min(95%, 1100px);
    margin: 0 auto 120px;
    padding: 0;
    list-style: none;
  }

  #aboutus .aboutus-cards__item {
    min-width: 0;
  }

  #aboutus .aboutus-cards__link {
    display: block;
  }

  #aboutus .aboutus-cards__empty {
    width: 90%;
    margin-inline: auto;
    margin-bottom: 120px;
    padding-block: 120px;
    text-align: center;
    font-size: clamp(16px, 13.33px + 0.347vw, 20px); /* 768 ~ 1920px */
    font-weight: 500;
    line-height: 1.5;
    letter-spacing: 0.05em;
    color: #222;
    background-color: #eee;
  }

  #aboutus .aboutus-cards__img {
    display: block;
    width: 100%;
    margin-bottom: clamp(4px, -4px + 1.042vw, 16px); /* 768 ~ 1920px */
    aspect-ratio: 340 / 200;
    overflow: hidden;
  }

  #aboutus .aboutus-cards__img img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
  }

  #aboutus .aboutus-cards__title {
    margin-bottom: clamp(4px, -4px + 1.042vw, 16px); /* 768 ~ 1920px */
    font-size: clamp(16px, 13.33px + 0.347vw, 20px); /* 768 ~ 1920px */
    font-weight: 500;
    line-height: 1;
    letter-spacing: 0.05em;
    color: #222;
  }

  #aboutus .aboutus-cards__job {
    font-size: clamp(12px, 10px + 0.26vw, 15px); /* 768 ~ 1920px */
    font-weight: 400;
    line-height: 1;
    letter-spacing: 0.05em;
    color: #c8a160;
    text-align: left;
  }

  #aboutus .aboutus-cards__pagenavi {
    margin-top: 56px;
    text-align: center;
  }

  #aboutus .aboutus-cards__message {
    font-size: clamp(32px, 6.471px + 2.059vw, 46px); /* 768 ~ 1440px */
    font-weight: 500;
    line-height: 1;
    letter-spacing: 0.05em;
    text-align: center;
    color: #72b862;
  }

  /* archive-aboutus.php：PC
  -------------------------------------*/
  #aboutus .aboutus-archive .aboutus__inner {
    padding-block: 80px 37px;
  }

  /* FV */
  #aboutus .aboutus-archive .fv {
    position: relative;
    z-index: 0;
    isolation: isolate;
    overflow: hidden;
    width: min(95%, 1200px);
    margin-inline: auto;
    margin-bottom: 120px;
    aspect-ratio: 1200 / 400;
  }
  #aboutus .aboutus-archive .fv::after {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    right: 25px;
    bottom: 0;
    width: clamp(560px, 125.714px + 56.548vw, 940px); /* 768 ~ 1440px */
    background: url("../images/page-aboutus/aboutus-fv-img.jpg") no-repeat
      center center;
    background-size: cover;
    pointer-events: none;
  }
  #aboutus .aboutus-archive .fv__title-en {
    position: relative;
    width: clamp(154px, -6px + 20.833vw, 294px); /* 768 ~ 1440px */
    padding-top: 28px;
    aspect-ratio: 294.36 / 192.49;
    z-index: 1;
  }
  #aboutus .aboutus-archive .fv__title-en img {
    display: block;
    width: auto;
    height: auto;
    max-width: 100%;
  }
  #aboutus .aboutus-archive .fv__title {
    position: relative;
    padding-left: clamp(0px, -57.143px + 7.44vw, 50px); /* 768 ~ 1440px */
    z-index: 1;
  }
  #aboutus .aboutus-archive .fv__title span {
    display: inline-block;
    padding: 10px 20px 10px 0;
    font-size: clamp(24px, 5.714px + 2.381vw, 40px); /* 768 ~ 1440px */
    font-weight: 500;
    line-height: 1;
    letter-spacing: 0.05em;
    color: #222;
    background-color: #fff;
  }
  #aboutus .aboutus-archive .fv__title span:first-child {
    margin-bottom: 10px;
  }

  /* btm-block */
  #aboutus .aboutus-archive .btm-block {
    max-width: 1920px;
    margin-inline: auto;
    background-color: #eaeaca;
  }
  #aboutus .aboutus-archive .btm-block__inner {
    position: relative;
    width: min(95%, 1100px);
    margin-inline: auto;
    padding-top: 80px;
    padding-bottom: 116px;
  }
  #aboutus .aboutus-archive .btm-block__inner::before {
    content: "";
    position: absolute;
    top: -3%;
    right: 0;
    width: clamp(127px, 58.429px + 8.929vw, 187px); /* 768 ~ 1440px */
    height: auto;
    aspect-ratio: 1 / 1;
    background: url("../images/page-aboutus/aboutus-badge.svg") no-repeat center
      center;
    background-size: contain;
  }
  #aboutus .aboutus-archive .btm-block__inner::after {
    content: "";
    position: absolute;
    bottom: 0;
    right: clamp(0px, -108.571px + 14.137vw, 95px); /* 768 ~ 1440px */
    width: 159px;
    height: auto;
    aspect-ratio: 159 / 213;
    background: url("../images/page-aboutus/aboutus-person.png") no-repeat
      center center;
    background-size: contain;
  }

  #aboutus .aboutus-archive .btm-block__title {
    margin-bottom: 40px;
    font-size: clamp(28px, 23.429px + 0.595vw, 32px); /* 768 ~ 1440px */
    font-weight: 500;
    line-height: 1.75;
    letter-spacing: 0.05em;
    text-align: center;
    color: #222;
  }

  #aboutus .aboutus-archive .btm-block__content {
    position: relative;
    z-index: 1;
  }

  #aboutus .aboutus-archive .btm-block__img {
    position: absolute;
    top: 0;
    left: 0;
    width: clamp(390px, -180px + 74.219vw, 580px); /* 768 ~ 1024px */
    height: auto;
    aspect-ratio: 580 / 422;
    overflow: hidden;
  }
  #aboutus .aboutus-archive .btm-block__img img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: contain;
  }

  #aboutus .aboutus-archive .btm-block__list {
    max-width: clamp(390px, 113.39px + 36.017vw, 560px); /* 768 ~ 1240px */
    padding-top: clamp(16px, -23.051px + 5.085vw, 40px); /* 768 ~ 1240px */
    margin-bottom: 60px;
    margin-left: auto;
  }
  #aboutus .aboutus-archive .btm-block__item {
    position: relative;
    padding-block: clamp(18px, 3.356px + 1.907vw, 27px); /* 768 ~ 1240px */
    padding-left: clamp(54px, -43.627px + 12.712vw, 114px); /* 768 ~ 1240px */
    padding-right: 1em;
    font-size: clamp(14px, 10.746px + 0.424vw, 16px); /* 768 ~ 1240px */
    font-weight: 400;
    line-height: 1.555;
    letter-spacing: 0.05em;
    color: #222;
    background-color: #fff;
  }
  #aboutus .aboutus-archive .btm-block__item:not(:last-child) {
    margin-bottom: 8px;
  }
  #aboutus .aboutus-archive .btm-block__item::before {
    content: "";
    position: absolute;
    top: 50%;
    left: clamp(18px, -34.571px + 6.845vw, 64px); /* 768 ~ 1440px */
    transform: translateY(-50%);
    width: 26px;
    height: auto;
    aspect-ratio: 26.43 / 24.98;
    background: url("../images/page-aboutus/aboutus-check-icon.svg") no-repeat
      center center;
    background-size: contain;
  }

  #aboutus .aboutus-archive .btm-block__text {
    font-size: clamp(16px, 6.857px + 1.19vw, 24px); /* 768 ~ 1440px */
    font-weight: 700;
    line-height: 1.75;
    letter-spacing: 0.05em;
    text-align: center;
    color: #222;
  }
  #aboutus .aboutus-archive .btm-block__text span {
    font-size: clamp(28px, 18.857px + 1.19vw, 36px); /* 768 ~ 1440px */
  }

  /* single-aboutus.php：PC
  -------------------------------------*/
  #aboutus .aboutus-single .system-contents {
    width: 100%;
    background: #fff;
    padding: 40px;
    padding-bottom: 160px;
    padding-top: 80px;
  }

  #aboutus .aboutus-single .pagen {
    margin-top: 0;
    margin-bottom: 40px;
  }

  #aboutus .aboutus-single article {
    width: min(95%, 1200px);
    margin-inline: auto;
    margin-bottom: 40px;
    border: 10px solid #f3f1ef;
  }
  #aboutus .aboutus-single .article-inner {
    padding-block: clamp(60px, 46.667px + 1.736vw, 80px); /* 768 ~ 1920px */
    padding-inline: clamp(20px, 0px + 2.604vw, 50px); /* 768 ~ 1920px */
  }
  #aboutus .aboutus-single .article-header {
    display: grid;
    grid-template-columns: minmax(
        0,
        clamp(280px, 40px + 31.25vw, 640px)
      ) minmax(0, 1fr); /* 768 ~ 1920px */
    gap: clamp(16px, 0px + 2.083vw, 40px); /* 768 ~ 1920px */
    align-items: start;
    margin-bottom: clamp(20px, -20px + 5.208vw, 80px); /* 768 ~ 1920px */
  }
  #aboutus .aboutus-single .article-header .text-wrap {
    min-width: 0;
  }
  #aboutus .aboutus-single .wysiwyg p {
    font-size: clamp(12px, 9.333px + 0.347vw, 16px); /* 768 ~ 1920px */
  }

  #aboutus .aboutus-single .system-ttl {
    font-size: clamp(26px, 22px + 0.521vw, 32px);
    font-weight: 500;
    margin-bottom: 16px;
    line-height: 1;
    letter-spacing: 0.05em;
    text-align: left;
  }

  #aboutus .aboutus-single .system-category {
    margin: 0 0 clamp(14px, -3.333px + 2.257vw, 40px); /* 768 ~ 1920px */
  }

  #aboutus .aboutus-single .system-category > span {
    display: block;
    padding: 0;
    font-size: clamp(14px, 10px + 0.521vw, 20px); /* 768 ~ 1920px */
    line-height: 1;
    text-align: left;
    color: #c8a160;
    background-color: #fff;
  }

  /* アイキャッチ：元画像より拡大しない（解像度ボケ防止） */
  #aboutus .aboutus-single .system-i-pic {
    width: 100%;
    margin: 0;
    text-align: center;
  }

  #aboutus .aboutus-single .system-i-pic img {
    display: block;
    width: auto;
    max-width: 100%;
    height: auto;
    margin-inline: auto;
    object-fit: contain;
    object-position: center;
  }
  #aboutus .aboutus-single .text-wrap .wysiwyg p:first-child {
    margin-top: 0;
  }

  #aboutus .aboutus-single .system-gallery {
    padding: 0;
    background-color: #fff;
  }

  /* 他のスタッフも見てみる */
  #aboutus .aboutus-single .aboutus-related {
    margin-top: 100px;
  }
  #aboutus .aboutus-single .aboutus-related__title {
    width: fit-content;
    margin: 0 auto 80px;
    font-size: 32px;
    font-weight: 500;
    line-height: 1;
    letter-spacing: 0.05em;
    color: #222;
  }
  #aboutus .aboutus-single .aboutus-related .aboutus-cards__list {
    margin-bottom: 0;
  }

  #aboutus .system-gallery h3.system-ttl-02 {
    margin: 0 0 24px;
    text-align: center;
    font-size: clamp(18px, 14px + 0.52vw, 24px);
    font-weight: 700;
    line-height: 1.35;
    letter-spacing: 0.05em;
    color: #222;
    text-transform: uppercase;
  }

  #aboutus .system-gallery .theme-scf-gallery-list {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    align-items: start;
    column-gap: clamp(16px, 0px + 2.083vw, 40px); /* 768 ~ 1920px */
    row-gap: clamp(30px, 10px + 2.604vw, 60px);
    width: min(95%, 1100px);
    margin-inline: auto;
    margin-bottom: 0;
  }

  #aboutus .system-gallery .theme-scf-gallery-list .img-wrap {
    position: relative;
    aspect-ratio: 340 / 200;
    width: 100%;
    margin-bottom: clamp(4px, -4px + 1.042vw, 16px); /* 768 ~ 1920px */
    overflow: hidden;
    background: #e8e8e8;
  }
  #aboutus .system-gallery .theme-scf-gallery-list .img-wrap > a {
    position: absolute;
    inset: 0;
    display: block;
  }
  #aboutus .system-gallery .theme-scf-gallery-list .img-wrap img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
  }

  #aboutus .system-gallery .theme-scf-gallery-list > li > p {
    margin: 0;
    font-size: 12px;
    font-weight: 400;
    line-height: 1.6667;
    letter-spacing: 0.05em;
    color: #222;
    text-align: left;
  }
}

/* ========================================
   @media screen and (max-width: 767px)
======================================== */
@media screen and (max-width: 767px) {
  /* aboutus-cards：SP
  -------------------------------------*/
  #aboutus .aboutus-cards__list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: start;
    column-gap: 4.8vw;
    row-gap: 9.7vw;
    width: 91.8vw;
    margin: 0 auto 24.2vw;
    padding: 0;
    list-style: none;
  }

  #aboutus .aboutus-cards__item {
    min-width: 0;
  }

  #aboutus .aboutus-cards__link {
    display: block;
  }

  #aboutus .aboutus-cards__empty {
    width: 95%;
    margin-inline: auto;
    padding-block: 30vw;
    text-align: center;
    font-size: 3.9vw;
    font-weight: 500;
    line-height: 1.5;
    letter-spacing: 0.05em;
    color: #222;
    background-color: #eee;
  }

  #aboutus .aboutus-cards__img {
    display: block;
    width: 100%;
    margin-bottom: 3.4vw;
    aspect-ratio: 180 / 106;
  }

  #aboutus .aboutus-cards__img img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
  }

  #aboutus .aboutus-cards__title {
    margin-bottom: 1.9vw;
    font-size: 3.9vw;
    font-weight: 500;
    line-height: 1;
    letter-spacing: 0.05em;
    color: #222;
  }

  #aboutus .aboutus-cards__job {
    font-size: 2.9vw;
    font-weight: 400;
    line-height: 1;
    letter-spacing: 0.05em;
    color: #c8a160;
    text-align: left;
  }

  #aboutus .aboutus-cards__pagenavi {
    margin-top: 13.5vw;
    text-align: center;
  }

  #aboutus .aboutus-cards__message {
    margin-bottom: 18vw;
    font-size: 6.3vw;
    font-weight: 500;
    line-height: 1;
    letter-spacing: 0.05em;
    text-align: center;
    color: #72b862;
  }

  /* archive-aboutus.php：SP
  -------------------------------------*/
  #aboutus .aboutus-archive .aboutus__inner {
    padding-top: 14.01vw;
  }

  /* FV */
  #aboutus .aboutus-archive .fv {
    position: relative;
    z-index: 0;
    margin-bottom: 9.7vw;
  }
  #aboutus .aboutus-archive .fv::after {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    right: 0;
    width: 79.7vw;
    height: auto;
    aspect-ratio: 330 / 260;
    background: url("../images/page-aboutus/aboutus-fv-img_sp.jpg") no-repeat
      center center;
    background-size: cover;
    pointer-events: none;
  }
  #aboutus .aboutus-archive .fv__title-en {
    width: 34.5vw;
    padding-top: 24.2vw;
    padding-left: 2.2vw;
    height: auto;
    aspect-ratio: 143.33 / 93.73;
    z-index: 1;
  }
  #aboutus .aboutus-archive .fv__title-en img {
    display: block;
    width: auto;
    height: auto;
    max-width: 100%;
  }
  #aboutus .aboutus-archive .fv__title {
    position: relative;
    padding-left: 7.2vw;
    z-index: 1;
  }
  #aboutus .aboutus-archive .fv__title span {
    display: inline-block;
    padding: 1.4vw 2.9vw 1.4vw 0;
    font-size: 5.8vw;
    font-weight: 500;
    line-height: 1;
    letter-spacing: 0.05em;
    color: #222;
    background-color: #fff;
  }
  #aboutus .aboutus-archive .fv__title span:first-child {
    margin-bottom: 2.4vw;
  }

  /* btm-block */
  #aboutus .aboutus-archive .btm-block {
    background-color: #eaeaca;
  }
  #aboutus .aboutus-archive .btm-block__inner {
    position: relative;
    margin-inline: auto;
    padding-top: 17vw;
    padding-bottom: 14.5vw;
  }
  #aboutus .aboutus-archive .btm-block__inner::before {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 27.3vw;
    height: auto;
    aspect-ratio: 1 / 1;
    background: url("../images/page-aboutus/aboutus-badge_sp.svg") no-repeat
      center center;
    background-size: contain;
  }
  #aboutus .aboutus-archive .btm-block__inner::after {
    content: "";
    position: absolute;
    bottom: 0;
    right: 6.5vw;
    width: 18.6vw;
    height: auto;
    aspect-ratio: 77 / 113;
    background: url("../images/page-aboutus/aboutus-person_sp.png") no-repeat
      center center;
    background-size: contain;
  }

  #aboutus .aboutus-archive .btm-block__title {
    margin-bottom: 5.8vw;
    font-size: 5.3vw;
    font-weight: 500;
    line-height: 1.63636;
    letter-spacing: 0.05em;
    text-align: center;
    color: #222;
  }

  #aboutus .aboutus-archive .btm-block__content {
    position: relative;
    z-index: 1;
  }

  #aboutus .aboutus-archive .btm-block__img {
    position: relative;
    width: 100%;
    height: auto;
    aspect-ratio: 414 / 240;
  }
  #aboutus .aboutus-archive .btm-block__img img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  #aboutus .aboutus-archive .btm-block__list {
    width: 91.8vw;
    margin-inline: auto;
    margin-top: -4.8vw;
    margin-bottom: 9.7vw;
  }
  #aboutus .aboutus-archive .btm-block__item {
    position: relative;
    padding-block: 4.8vw;
    padding-left: 13vw;
    padding-right: 1em;
    font-size: 3.4vw;
    font-weight: 400;
    line-height: 2;
    letter-spacing: 0.05em;
    color: #222;
    background-color: #fff;
  }
  #aboutus .aboutus-archive .btm-block__item:not(:last-child) {
    margin-bottom: 1.9vw;
  }
  #aboutus .aboutus-archive .btm-block__item::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 5.8vw;
    transform: translateY(-50%);
    width: 4.3vw;
    height: auto;
    aspect-ratio: 18 / 17;
    background: url("../images/page-aboutus/aboutus-check-icon_sp.svg")
      no-repeat center center;
    background-size: contain;
  }

  #aboutus .aboutus-archive .btm-block__text {
    font-size: 4.3vw;
    font-weight: 700;
    line-height: 1.8888;
    letter-spacing: 0.05em;
    text-align: center;
    color: #222;
  }
  #aboutus .aboutus-archive .btm-block__text span {
    display: inline-block;
    margin-top: 5.8vw;
    font-size: 6.3vw;
  }

  /* single-aboutus.php：SP
  -------------------------------------*/
  #aboutus .aboutus-single .system-contents {
    width: 100%;
    margin-bottom: 0;
    padding-top: 9.7vw;
    padding-bottom: 28.98vw;
    padding-inline: 2.9vw;
    background: #fff;
  }

  #aboutus .aboutus-single .pagen {
    width: 100%;
    margin-bottom: 5.8vw;
  }

  #aboutus .aboutus-single article {
    margin-bottom: 5.8vw;
    border: 4px solid #f3f1ef;
  }

  #aboutus .aboutus-single .article-inner {
    padding: 4.8vw 4.8vw 9.7vw;
  }

  #aboutus .aboutus-single .article-header {
    display: block;
    margin-bottom: 9.7vw;
  }
  #aboutus .aboutus-single .article-header .text-wrap {
    min-width: 0;
  }

  #aboutus .aboutus-single .system-i-pic {
    width: 100%;
    margin: 0 0 3.9vw;
    text-align: center;
  }

  #aboutus .aboutus-single .system-i-pic img {
    display: block;
    width: auto;
    max-width: 100%;
    height: auto;
    margin-inline: auto;
    object-fit: contain;
    object-position: center;
  }

  #aboutus .aboutus-single .system-ttl {
    font-size: 5.8vw;
    font-weight: 500;
    margin-bottom: 1.9vw;
    line-height: 1;
    text-align: left;
  }

  #aboutus .aboutus-single .system-category {
    margin: 0 0 5.8vw;
    padding: 0;
  }

  #aboutus .aboutus-single .system-category > span {
    display: inline-block;
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    font-size: 3.9vw;
    font-weight: 400;
    line-height: 1;
    text-align: left;
    letter-spacing: 0.05em;
    color: #c8a160;
    background-color: #fff;
  }

  #aboutus .aboutus-single .text-wrap .wysiwyg p {
    font-size: 3.9vw;
    font-weight: 400;
    line-height: 1.875;
    letter-spacing: 0.05em;
    text-align: left;
    color: #222;
  }

  #aboutus .aboutus-single .text-wrap .wysiwyg p:first-child {
    margin-top: 0;
  }

  /* gallery */
  #aboutus .aboutus-single .system-gallery {
    padding: 0;
    background: #fff;
  }

  #aboutus .system-gallery .theme-scf-gallery-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 9.7vw 2.4vw;
    margin-bottom: 0;
  }

  #aboutus .system-gallery .theme-scf-gallery-list > li {
    min-width: 0;
    display: flex;
    flex-direction: column;
    align-items: stretch;
  }

  #aboutus .system-gallery .theme-scf-gallery-list > li > span.system-Frame {
    display: block;
    width: 100%;
  }

  #aboutus .system-gallery .theme-scf-gallery-list .img-wrap {
    position: relative;
    margin-bottom: 1.9vw;
    aspect-ratio: 170 / 117;
    overflow: hidden;
    background: #fff;
  }

  #aboutus .system-gallery .theme-scf-gallery-list .img-wrap > a {
    position: absolute;
    inset: 0;
    display: block;
  }

  #aboutus .system-gallery .theme-scf-gallery-list .img-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
  }

  #aboutus .system-gallery .theme-scf-gallery-list > li > p {
    font-size: 2.9vw;
    font-weight: 400;
    line-height: 1.666;
    letter-spacing: 0.05em;
    color: #222;
    text-align: left;
  }

  /* 他のスタッフも見てみる */
  #aboutus .aboutus-single .aboutus-related {
    margin-top: 19.3vw;
  }
  #aboutus .aboutus-single .aboutus-related__title {
    margin-bottom: 9.7vw;
    font-size: 5.8vw;
    font-weight: 500;
    line-height: 1;
    letter-spacing: 0.05em;
    text-align: center;
    color: #222;
  }
  #aboutus .aboutus-single .aboutus-related .aboutus-cards__list {
    margin-bottom: 0;
  }
}
