@charset "UTF-8";
/* ------------------------------------ */
/* --------- page-company.php --------- */
/* ----------------------------------- */
/* page内共通 */
section.advantage,
section.outline {
  background-color: var(--base-lgray);
}
/* ページカバー */
.cover {
  background-image: url(../images/company/company__cover.jpg);
}
.cover__menu {
  display: flex;
  flex-wrap: wrap;
  margin: 160px 0 80px;
}
.cover__menu--list {
  min-width: calc(100% / 3);
  padding-right: 56px;
  padding-bottom: 40px;
}
.cover__menu--link {
  display: flex;
  flex-direction: column;
  position: relative;
}
.cover__menu--list {
  position: relative;
}
.cover__menu--link {
  z-index: 2;
}
/* 円形リンクボタン 下向き仕様*/
.cover__menu--link .arrow-area {
  position: absolute;
  top: 20%;
  left: 25%;
  bottom: inherit;
  transform: rotate(90deg);
}
.cover__menu--link .link__circle--width {
  border-color: var(--base-white);
  position: absolute;
  top: 25%;
  left: 50%;
  z-index: -1;
}
.cover__menu--link .link__arrow,
.cover__menu--link .link__arrow:before {
  background-color: var(--base-white);
}
/* PCデバイス用の「:hover」用のスタイル */
@media (hover: hover) {
  .cover__menu--link:hover .link__circle--width .arrow-area {
    top: 32%;
    left: 25%;
    transition: 0.3s ease-in-out;
  }
  .cover__menu--link:hover .link__circle--width {
    border-color: var(--corporate-red);
    transition: 0.3s ease-in-out;
  }
  .cover__menu--link:hover .link__arrow,
  .cover__menu--link:hover .link__arrow:before {
    background-color: var(--corporate-red);
    transition: 0.3s ease-in-out;
  }
}
/* タッチデバイス用 */
.cover__menu--link.touchstart .link__circle--width .arrow-area {
  top: 32%;
  left: 25%;
  transition: 0.3s ease-in-out;
}
.cover__menu--link.touchstart .link__circle--width {
  border-color: var(--corporate-red);
  transition: 0.3s ease-in-out;
}
.cover__menu--link.touchstart .link__arrow,
.cover__menu--link.touchstart .link__arrow:before {
  background-color: var(--corporate-red);
  transition: 0.3s ease-in-out;
}
/* ----- section 共通 ----- */
.p-company__container {
  padding: 120px 0;
  max-width: 1600px;
  margin: 0 auto;
}
.p-company__title {
  display: flex;
  flex-direction: column;
}
.p-company__title .title--jp {
  padding-bottom: 4px;
}
.p-company__title::after {
  content: "";
  display: block;
  width: 32px;
  height: 2px;
  background-color: var(--corporate-red);
  margin: 12px 0;
}
.p-company__subtitle {
  color: var(--corporate-red);
}
.p-company__box {
  display: flex;
  justify-content: space-between;
  padding-top: var(--px-48);
}
.p-company__heading {
  padding-bottom: 40px;
}
.p-company__textbox {
  display: flex;
  flex-direction: column;
  padding-right: 3.5rem;
  width: 48%;
}
.p-company__text {
  margin-bottom: 2.5rem;
}

/* section 代表挨拶 */
#message .p-company__ceo--name {
  align-items: baseline;
  align-self: flex-end;
  display: flex;
  font-family: "a-otf-ryumin-pr6n", serif;
  justify-self: flex-end;
}
.ceo__signature {
  margin-left: 1.5rem;
}
.ceo__signature p {
  font-weight: 500;
  letter-spacing: 0.25em;
}
.ceo__signature span {
  padding-left: 0.25rem;
}
.p-company__img.ceo__img {
  background-image: url(../images/company/company__ceo.jpg);
  background-position: right;
  background-size: cover;
  width: calc(100% - 54%);
}
.p-company__img.ceo__img::before {
  content: "";
  display: block;
}
#message .p-company__text p,
#advantage .p-company__text p {
  line-height: 1.7;
  margin-bottom: 1.5rem;
  text-indent: 1em;
}
/* section OPの強み */
.advntg__img img {
  max-width: 720px;
}
.p-company__box.advntg__list {
  margin-block-start: 80px;
}
.advntg__list--container {
  position: relative;
}
.advntg__list--container::before {
  content: "";
  width: 88%;
  margin-inline: calc(50% - 50vw);
  height: 100%;
  background-color: #d8d2d2;
  position: absolute;
}
.advntg__list--container.advntg__02::before {
  transform: translate(-50%, 0);
  left: 50%;
  margin-inline: unset;
  background-color: #b7afaf;
}
.advntg__list--container.advntg__03::before {
  margin-inline-start: calc(50vw - 50% + 9.6% + 30px);
}
.advntg__list--item {
  justify-content: space-between;
  align-items: center;
  position: relative;
  z-index: 2;
  margin-block: 40px;
}
.advntg__list--item .advntg__textbox {
  padding-inline-start: 56px;
}
.advntg__02 .advntg__list--item .advntg__textbox {
  padding-inline-start: unset;
  padding-inline-end: 56px;
}
.advntg__list--item .advntg__img img {
  max-width: 720px;
}
.advntg__textbox h3 {
  color: var(--base-white);
}
.advntg__text {
  margin-block: 40px;
}
/* section 会社概要 */
.outline {
  position: relative;
}
.outline .p-company__wrap {
  position: relative;
  z-index: 2;
}
.p-company__bg {
  position: absolute;
  bottom: 0;
  left: 0;
  height: 100%;
  width: 100%;
  background-image: url(../images/company/company__outline.png);
  background-size: cover;
  background-blend-mode: lighten;
  z-index: 1;
}
.p-company__container.flex__row {
  justify-content: space-between;
}
.outline__box--left {
  width: 38.5%;
}
.outline__box--right {
  width: 55.5%;
}
.outline__content {
  border-bottom: dotted 2.4px rgba(197, 190, 190, 0.32);
  padding: 1.5rem 0;
}
.outline__content:first-child {
  padding: 0 0 1.5rem;
}
.outline__content--tag {
  color: var(--base-gray);
  margin-bottom: var(--px-8);
}

/* ------ LOCATION ------ */
#location .p-company__container {
  display: flex;
  margin-bottom: 80px;
}
#location .p-company__title {
  width: 16%;
  min-width: 210px;
}
#location .p-company__box {
  padding-top: 0;
  width: calc(100% - 16%);
}
.p-company__gmap--container {
  width: 100%;
  margin: 0 auto var(--px-80);
}
.p-company__gmap {
  overflow: hidden;
  position: relative;
  height: 0;
  padding-bottom: 38.22%;
}
.p-company__gmap iframe {
  position: absolute;
  inset: -150px;
  height: calc(100% + 300px);
  width: calc(100% + 300px);
}
.p-company__address {
  display: flex;
  justify-content: space-between;
}
.p-company__address--title {
  margin-bottom: var(--px-24);
}
.p-company__address--text {
  line-height: 1.8;
}
.p-company__address--text.last-child {
  margin-top: 1rem;
}
.p-company__address--img {
  background-image: url(../images/company/company__location.jpg);
  background-position: center;
  background-size: cover;
  width: 40%;
  height: 100%;
  aspect-ratio: 1.618 / 1;
}
.p-company__address .fas.fa-map-marker-alt {
  color: var(--corporate-red);
}
#topics .p-company__textbox {
  width: auto;
}
ul.p-company__topics--list {
  max-width: 56%;
}
.p-company__topics--item {
  margin-bottom: var(--px-40);
}
#topics .p-company__wrap {
  background-image: url(../images/company/topics_202410.jpg);
  background-position: center;
  background-size: cover;
  position: relative;
}
.p-company__img.topics__img {
  left: 0;
  background: linear-gradient(to bottom, transparent 0%, transparent 60%, #fff 100%), url(../images/company/topics_202406-img.jpg);
  background-position: right top;
  height: 100%;
  width: clamp(18rem, 8.5rem + 47.5vw, 56rem);
  max-width: 1080px;
}
.p-company__img.topics__img::before {
  content: "";
  display: block;
  padding-top: 64%;
  background-image: linear-gradient(180deg, transparent 0 50%, #fff 100%);
}
.p-company__t--link.link__arrow span,
.p-company__t--link.link__arrow span::before,
.p-company__t--link.link__arrow span::after {
  background-color: var(--corporate-red);
}
.p-company__t--link {
  color: var(--base-gray);
  letter-spacing: 0.1em;
  margin-top: var(--px-16);
}
.p-company__t--link a {
  color: var(--base-gray);
}
a:visited.p-company__t--link.link__cases {
  color: var(--base-gray);
}
/* overft__wrapper */
.overft__nav--box.overft__nav--next {
  background-image: url(../images/common/illust__bg--office.jpg);
}
/* --------------------------------------- */
/* ------------ メディアクエリ ------------ */
/* --------------------------------------- */
@media screen and (width > 1600px) {
  .cover__menu--link .link__circle--width {
    left: 45%;
  }
  #topics .p-company__wrap {
    background-image: unset;
  }
  #topics .p-company__container {
    background-image: url(../images/company/topics_202410.jpg);
    background-size: cover;
  }
  .p-company__img.topics__img {
    position: static;
    width: 100%;
    height: 500px;
    margin: 0 auto;
  }
}
/* ---- max ---- */
@media screen and (width <= 1920px) {
  .cover__menu {
    max-width: 100%;
  }
  .p-company__container {
    padding: var(--px-160) 9.6%;
  }
  .advntg__img img,
  .advntg__list--item .advntg__img img {
    max-width: 640px;
  }
}
@media screen and (width <= 1600px) {
  .advntg__img img {
    max-width: 400px;
  }
  .advntg__list--item .advntg__img img {
    max-width: 480px;
  }
}
@media screen and (width <= 1024px) {
  .cover__menu {
    width: 100%;
  }
  .p-company__box {
    flex-direction: column;
  }
  #message .p-company__box {
    flex-direction: column-reverse;
  }
  .p-company__textbox {
    margin-bottom: var(--px-24);
    padding-right: 0;
    width: 100%;
  }
  .p-company__img.ceo__img::before {
    aspect-ratio: 16 / 9;
    padding-top: inherit;
  }
  .p-company__img.ceo__img {
    width: 100%;
    margin-bottom: var(--px-40);
  }
  .p-company__container.flex__row {
    justify-content: flex-start;
  }
  .advntg__list--item.flex__row {
    flex-direction: column;
  }
  .advntg__01 .advntg__list--item.flex__row,
  .advntg__03 .advntg__list--item.flex__row {
    flex-direction: column-reverse;
  }
  .advntg__list--item .advntg__textbox {
    padding-inline-start: 0;
  }
  .advntg__02 .advntg__list--item .advntg__textbox {
    padding-inline-end: 0;
  }
  .advntg__img img,
  .advntg__list--item .advntg__img img {
    max-width: 100%;
  }
  #topics .p-company__wrap {
    background-image: url(../images/company/topics_202410-SP.jpg);
    background-position: center;
    background-size: cover;
    position: relative;
  }
  ul.p-company__topics--list {
    max-width: 72%;
  }
  /* outline */
  .outline__box--left {
    min-width: 210px;
    width: 16%;
  }
  .outline__box--right {
    width: 100%;
  }
  .p-company__gmap {
    padding-bottom: 56.25%;
  }
  .p-company__address {
    flex-direction: column;
  }
  .p-company__address--img {
    margin-top: var(--px-24);
    width: 54%;
    min-width: 324px;
  }
}
@media screen and (width <= 768px) {
  .cover__menu {
    margin: 160px 0 0;
  }
  .cover__container h1 {
    margin-bottom: var(--px-56);
  }
  .cover__menu--list {
    min-width: calc(100% / 2);
    width: calc(100% / 2);
    white-space: nowrap;
  }
  .p-company__container {
    padding: var(--px-120) 9.6%;
    flex-direction: column;
  }
  #topics .p-company__wrap {
    background-position: bottom;
    background-size: contain;
  }
  .p-company__img.topics__img {
    background: linear-gradient(to bottom, transparent 0%, transparent 80%, #fff 100%), url(../images/company/topics_202406-img.jpg);
    background-position: right top;
    width: 88%;
  }

  #location .p-company__box {
    width: 100%;
  }
  .outline__box--right {
    margin-top: var(--px-56);
    width: 100%;
  }
  .p-company__gmap--container {
    margin: var(--px-56) 0;
  }
  .p-company__address--img {
    margin-top: var(--px-24);
    width: 100%;
    min-width: auto;
  }
}

@media screen and (width <= 500px) {
  .cover__menu {
    margin: 80px 0;
  }
  .p-company__ceo--name {
    flex-direction: column;
  }
  .p-company__img.topics__img {
    background-repeat: no-repeat;
    background-size: auto;
    width: 96%;
  }
}
@media screen and (width <= 425px) {
  .cover__menu--list {
    min-width: auto;
    width: 44%;
  }
  .cover__menu li.cover__menu--list:nth-child(2n) {
    width: 48%;
    margin-left: 8%;
  }
  .cover__menu--link .title--en {
    font-size: 20px;
  }
  .cover__menu--link .link__circle--width {
    left: initial;
    right: -24%;
  }
  .cover__menu li.cover__menu--list:nth-child(1) .cover__menu--link .link__circle--width,
  .cover__menu li.cover__menu--list:nth-child(2n + 1) .cover__menu--link .link__circle--width {
    right: -48%;
  }
  .p-company__container {
    padding: var(--px-120) 9.6% var(--px-40);
  }
  ul.p-company__topics--list {
    max-width: 80%;
  }
  .p-company__img.topics__img {
    background-size: cover;
    margin-bottom: -16%;
    margin-left: -16%;
  }
}
