@charset "UTF-8";
/*-----------------------------------------

※このスタイルシートはSCSSで生成されています。
cssへの直記入はなさらないようにしてください。

-----------------------------------------*/
/* 変数の定義
--------------------------------------------------*/
/*-----------------------------------------

※このスタイルシートはSCSSで生成されています。
cssへの直記入はなさらないようにしてください。

-----------------------------------------*/
/*-----------------------------------------

※このスタイルシートはSCSSで生成されています。
cssへの直記入はなさらないようにしてください。

-----------------------------------------*/
/* 色の定義
--------------------------------------------------*/
/* 色のクラス
--------------------------------------------------*/
.white {
  color: #fff;
}

.black {
  color: #000;
}

.blue {
  color: #2953ED;
}

.orange {
  color: #D56300;
}

/* フォントの定義
--------------------------------------------------*/
html,
body,
ul,
ol,
dl,
li,
dt,
dd,
p,
div,
img,
svg,
table,
tr,
th,
td,
a,
figure {
  font-family: "Noto Sans JP", serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 400;
  letter-spacing: 0.05em;
  line-height: 1.6;
  color: #000;
}

body,
ul,
ol,
dl,
li,
dt,
dd,
p,
div,
img,
svg,
a,
table,
tr,
th,
td,
figure {
  font-size: 1.6rem;
}
@media screen and (max-width: 999px) {
  body,
  ul,
  ol,
  dl,
  li,
  dt,
  dd,
  p,
  div,
  img,
  svg,
  a,
  table,
  tr,
  th,
  td,
  figure {
    font-size: 1.4rem;
  }
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: "Noto Sans JP", serif;
  font-optical-sizing: auto;
  font-style: normal;
  letter-spacing: 0.05em;
  line-height: 1.4;
  font-weight: 700;
  color: #000;
}

/*-----------------------------------------

※このスタイルシートはSCSSで生成されています。
cssへの直記入はなさらないようにしてください。

-----------------------------------------*/
/*-----------------------------------------

※このスタイルシートはSCSSで生成されています。
cssへの直記入はなさらないようにしてください。

-----------------------------------------*/
/* 共通
--------------------------------------------------*/
body {
  word-break: break-word;
}

a {
  transition-duration: 0.3s;
  animation-timing-function: cubic-bezier(0.83, 0, 0.17, 1);
}

span {
  color: inherit;
  font-size: inherit;
  font-family: inherit;
  font-weight: inherit;
  letter-spacing: inherit;
  line-height: inherit;
}

section {
  position: relative;
  z-index: 1;
}

span.word {
  display: inline-block;
}

/* 404
--------------------------------------------------*/
/* ---------- Greeting ---------- */
.greeting {
  background: #fff;
  padding: 100px 0 80px;
  /* 日本語キャッチまでの見出し高さぶんを画像側にオフセット */
  --greeting-catch-offset: clamp(60px, 7vw, 100px);
}
@media screen and (max-width: 768px) {
  .greeting {
    padding: 60px 0;
  }
}
.greeting .greeting-inner {
  margin-inline: auto;
  display: grid;
  grid-template-columns: 3fr 2fr; /* 左テキスト:右画像 ≒ 60:40 */
  gap: clamp(16px, 7.1428vw, 100px);
}
@media screen and (max-width: 768px) {
  .greeting .greeting-inner {
    width: 90%;
    grid-template-columns: 1fr;
  }
}
.greeting .greeting-col.media {
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-self: end;
  margin-right: 0;
  margin-top: var(--greeting-catch-offset);
}
.greeting .greeting-col.media img {
  width: 100%;
  object-fit: cover;
}
.greeting .greeting-col.media .sign {
  padding-right: 7.14vw;
  margin-top: 16px;
  text-align: right;
}
@media screen and (max-width: 768px) {
  .greeting .greeting-col.media .sign {
    padding-right: 0;
  }
}
.greeting .greeting-col.media .sign .corp {
  font-family: "Shippori Mincho B1", serif;
  font-size: clamp(12px, 1.1429vw, 16px);
  font-weight: 600;
}
@media screen and (max-width: 768px) {
  .greeting .greeting-col.media .sign .corp {
    font-size: 14px;
  }
}
.greeting .greeting-col.media .sign .name {
  font-family: "Shippori Mincho B1", serif;
  font-size: clamp(14px, 1.6429vw, 23px);
  font-weight: 600;
}
@media screen and (max-width: 768px) {
  .greeting .greeting-col.media .sign .name {
    font-size: 20px;
  }
}
@media screen and (max-width: 768px) {
  .greeting .greeting-col.media {
    margin-top: 20px;
    margin-right: 0; /* SPでは通常の余白に戻す */
  }
}
.greeting .greeting-col.content {
  align-content: center;
  padding-left: 7.14vw;
}
@media screen and (max-width: 768px) {
  .greeting .greeting-col.content {
    padding-left: 0;
  }
}
.greeting .greeting-col.content .title-en {
  font-size: 14px;
  letter-spacing: 0.05em;
  color: #D56300;
  font-family: "EB Garamond", serif;
  font-weight: 700;
  margin-bottom: 4px;
}
.greeting .greeting-col.content .title-ja {
  font-size: 26px;
  font-family: "Shippori Mincho B1", serif;
  font-weight: 800;
  letter-spacing: 0.05em;
  margin-bottom: 24px;
}
.greeting .greeting-col.content .catch-ja {
  font-family: "Shippori Mincho B1", serif;
  font-weight: 800;
  font-size: clamp(18px, 2.1vw, 31px);
  margin-bottom: 30px;
  white-space: nowrap;
  overflow-wrap: normal;
  word-break: keep-all;
}
@media screen and (max-width: 768px) {
  .greeting .greeting-col.content .catch-ja {
    font-size: 20px;
  }
}
@media screen and (max-width: 375px) {
  .greeting .greeting-col.content .catch-ja {
    font-size: 16px;
  }
}
.greeting .greeting-col.content .catch-ja.catch-en {
  font-family: "EB Garamond", serif;
  font-size: clamp(20px, 2.5vw, 35px);
  white-space: break-spaces;
  word-break: break-word;
}
.greeting .greeting-col.content .catch-ja .catch-ja-br {
  display: none;
}
@media screen and (max-width: 500px) {
  .greeting .greeting-col.content .catch-ja .catch-ja-br {
    display: block;
  }
}

/* ---------- Company Info ---------- */
.company-info .info-grid {
  display: grid;
  grid-template-columns: 42vw 1fr; /* Figma: map 600 / outline 800 */
  grid-template-areas: "map outline";
  align-items: start;
}
@media screen and (max-width: 768px) {
  .company-info .info-grid {
    grid-template-columns: 1fr;
    grid-template-areas: "outline" "map";
  }
}
.company-info .info-grid .map {
  grid-area: map;
  width: 100%;
  height: 100%;
  border: 0;
  display: grid;
  place-items: stretch;
}
.company-info .info-grid .map iframe {
  width: 100%;
  height: 100%;
  border: 0;
}
@media screen and (max-width: 768px) {
  .company-info .info-grid .map {
    height: 400px;
  }
}
.company-info .outline {
  grid-area: outline;
  background: #F5F6F9;
  padding: 80px 7.14vw;
}
@media screen and (max-width: 768px) {
  .company-info .outline {
    padding: 60px 7.14vw;
  }
}
@media screen and (max-width: 768px) {
  .company-info .outline .title-ja {
    margin-bottom: 0;
  }
}
.company-info .company-table {
  margin-top: 24px;
  display: grid;
  gap: 0;
  border-bottom: 1px solid #2953ED;
}
.company-info .company-table .row {
  display: grid;
  grid-template-columns: 107px 1fr;
  border-top: 1px solid #2953ED;
}
.company-info .company-table .row:first-child {
  border-top: none;
}
@media screen and (max-width: 768px) {
  .company-info .company-table .row {
    grid-template-columns: 1fr;
  }
}
.company-info .company-table .th {
  color: #041C2B;
  font-weight: 700;
  padding: 20px 0;
}
@media screen and (max-width: 768px) {
  .company-info .company-table .th {
    padding-bottom: 10px;
  }
}
.company-info .company-table .td {
  padding: 20px 0;
}
@media screen and (max-width: 768px) {
  .company-info .company-table .td {
    padding-top: 0;
  }
}
.company-info .company-table .td a:hover {
  color: #2953ED;
}
.company-info .company-table .td .map-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: transform 0.15s ease;
  vertical-align: middle;
}
.company-info .company-table .td .map-link:hover {
  transform: translateY(-1px);
}/*# sourceMappingURL=company.css.map */