html {
  font-size: 10px;
}

#company-body {
  background: #F6F4F2;
}

#company.--new {
  width: 100%;
  background: #F6F4F2;
}

/* ===== メインタイトル ===== */
#company.--new .main-title {
  background: url("../images/new/main-title_bg.png");
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
  height: 328px;
}
@media (max-width: 768px) {
  #company.--new .main-title {
    height: auto;
    padding-block: 10%;
  }
}

#company.--new .main-title__wrap {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

#company.--new .main-title .en {
  display: block;
  color: #5C5C5C;
  font-family: Abel;
  font-size: 6.4rem;
  font-weight: 400;
  line-height: 1;
  text-transform: uppercase;
}
@media (max-width: 1024px) {
  #company.--new .main-title .en { font-size: 3.2rem; }
}
@media (max-width: 768px) {
  #company.--new .main-title .en { font-size: 2.4rem; }
}

#company.--new .main-title .jp {
  color: #8A7B7F;
  font-family: "Noto Sans JP";
  font-size: 1.2rem;
  font-weight: 500;
  line-height: 1.33;
  display: flex;
  align-items: center;
  gap: 8px;
}

#company.--new .main-title .jp::before {
  content: "";
  display: block;
  border-radius: 1px;
  background: #E85471;
  width: 4px;
  height: 4px;
}

/* ===== パンくず ===== */
#company.--new #panlistid {
  display: block !important;
  margin: 0;
  padding: 0;
  padding-bottom: 48px;
  background: transparent !important;
}
#company.--new #panlistid ul {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 4px;
  list-style: none;
  margin: 0;
  padding: 0;
  font-family: "Noto Sans JP";
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.71;
}
#company.--new #panlistid ul > span {
  color: #A19182 !important;
}
#company.--new #panlistid ul a,
#company.--new #panlistid ul a span {
  color: #A19182 !important;
  text-decoration: none;
}
#company.--new #panlistid ul .arrow {
  color: #A19182 !important;
}
@media (max-width: 767px) {
  #company.--new #panlistid {
    padding-bottom: 6%;
  }
}

/* ===== 共通セクション ===== */
.company-sec {
  padding-block: 80px;
}

/* 波形区切り（共通クラス）
   section上端にページ背景色(#F6F4F2)を波形マスクでオーバーレイ
   Figmaパス: M0 13.88 C622.355 113.818 827.645 -46.0825 1440 13.88
   → y値を+50シフトして負値を回避: M0 64 C622.355 164 827.645 4 1440 64 */
.--wave-bg {
  position: relative;
  padding-top: 0;
}

.company-profile,
.company-access {
  background: linear-gradient(180deg, #EEE9E4 0%, #F6F4F2 100%);
}

.company-history,
.company-sitemap {
  background: #FFF;
}

/* ::beforeをin-flowにして高さ自体が上余白になる
   波マスクはtop部分のみ。それ以下は透明→sectionの背景が透過して見える */
.--wave-bg::before {
  content: "";
  display: block;
  width: 100%;
  height: 160px;
  background: #F6F4F2;
  pointer-events: none;
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 -60 1440 180' preserveAspectRatio='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 -60 L1440 -60 L1440 13.88 C827.645 113.82 622.355 -46.08 0 13.88 Z' fill='white'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 -60 1440 180' preserveAspectRatio='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 -60 L1440 -60 L1440 13.88 C827.645 113.82 622.355 -46.08 0 13.88 Z' fill='white'/%3E%3C/svg%3E");
  mask-size: 100% 100%;
  mask-repeat: no-repeat;
}
@media (max-width: 767px) {
  .--wave-bg::before { height: 80px; }
}

.company-access.--wave-bg::before {
  background: #FFF;
}
@media (max-width: 767px) {
  .company-sec { padding-bottom: 12%; }
}

.company-sec:last-child {
  border-bottom: none;
  padding-bottom: 120px;
}
@media (max-width: 767px) {
  .company-sec:last-child { padding-bottom: 12%; }
}

.company-sec__ttl-wrap {
  margin-bottom: 48px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.company-sec__en {
  display: block;
  font-family: Abel;
  font-size: 4rem;
  font-weight: 400;
  color: #5C5C5C;
  text-transform: uppercase;
  line-height: 1;
}
@media (max-width: 768px) {
  .company-sec__en { font-size: 2.8rem; }
}

.company-sec__ttl {
  display: flex;
  align-items: center;
  gap: 8px;
  color: #8A7B7F;
  font-family: "Noto Sans JP";
  font-size: 1.2rem;
  font-weight: 500;
  line-height: 1;
}

.company-sec__ttl::before {
  content: "";
  display: block;
  width: 4px;
  height: 4px;
  border-radius: 1px;
  background: #E85471;
  flex-shrink: 0;
}


/* ===== メッセージ ===== */
.company-message__card {
  background: #FFF;
  border-radius: 10px;
  box-shadow: 0 0 20px rgba(0,0,0,0.05);
  padding: 80px 64px;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 32px;
}
@media (max-width: 768px) {
  .company-message__card { padding: 48px 24px; gap: 24px; }
}

.company-message__label {
  position: absolute;
  top: 40px;
  left: 50%;
  transform: translateX(-50%);
  font-family: Abel;
  font-size: 1.6rem;
  font-weight: 400;
  color: #D3C8BE;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  white-space: nowrap;
}
@media (max-width: 767px) {
  .company-message__label {
    top: 16px;
  }
}

.company-message__ttl {
  color: #5C5C5C;
  font-family: "Noto Sans JP";
  font-size: 2.8rem;
  font-weight: 500;
  line-height: 1.43;
  letter-spacing: 0.04em;
  text-align: center;
}
@media (max-width: 768px) {
  .company-message__ttl { font-size: 2.2rem; }
}

.company-message__ttl-pink {
  color: #E85471;
}
@media (max-width: 767px) {
  .company-message__ttl-pink {
    display: block;
  }
}

.company-message__txt p {
  color: #5C5C5C;
  font-family: "Noto Sans JP";
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 2;
  text-align: center;
  margin-bottom: 40px;
}
.company-message__txt p:last-child {
  margin-bottom: 0;
}
@media (max-width: 768px) {
  .company-message__txt p { font-size: 1.4rem; text-align: left; margin-bottom: 24px; }
}

.company-message__bottom {
  display: flex;
  gap: 40px;
  align-items: center;
}
@media (max-width: 768px) {
  .company-message__bottom { flex-direction: column; gap: 24px; }
}

.company-message__photo {
  flex-shrink: 0;
  width: 326px;
  height: 326px;
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 0 40px rgba(0,0,0,0.15);
}
@media (max-width: 768px) {
  .company-message__photo { width: 200px; height: 200px; }
}

.company-message__photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.company-message__sign {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.company-message__sign-dept-wrap {
  display: flex;
  gap: 8px;
  align-items: center;
}

.company-message__sign-dot {
  display: block;
  width: 4px;
  height: 4px;
  border-radius: 1px;
  background: #E85471;
  flex-shrink: 0;
}

.company-message__sign-dept {
  color: #8A7B7F;
  font-family: "Noto Sans JP";
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1;
}

.company-message__sign-name {
  color: #5C5C5C;
  font-family: "Noto Sans JP";
  font-size: 2rem;
  font-weight: 500;
  letter-spacing: 0.05em;
}

/* ===== 会社概要テーブル ===== */
.company-table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 48px;
  border-top: 1px solid #D3C8BE;
}

.company-table tr {
  border-bottom: 1px solid #D3C8BE;
}

.company-table th,
.company-table td {
  padding: 16px 0;
  font-family: "Noto Sans JP";
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.8;
  color: #463A3D;
  text-align: left;
  vertical-align: top;
}

.company-table th {
  vertical-align: middle;
}

.company-table th {
  width: 112px;
  color: #E85471;
  font-weight: 400;
  flex-shrink: 0;
}
@media (max-width: 767px) {
  .company-table,
  .company-table tbody,
  .company-table tr,
  .company-table th,
  .company-table td { display: block; width: 100%; }
  .company-table th { padding-bottom: 4px; border-bottom: none; font-size: 1.2rem; }
  .company-table td { padding-top: 4px; padding-bottom: 16px; }
}

/* YouTube */
.company-yt {
  display: flex;
  gap: 24px;
}
@media (max-width: 767px) {
  .company-yt { flex-direction: column; }
}

.company-yt__item {
  flex: 1;
  position: relative;
  aspect-ratio: 16 / 9;
  overflow: hidden;
}

.company-yt__item iframe {
  width: 100%;
  height: 100%;
  border: 0;
}

/* ===== 沿革テーブル ===== */
.company-table--history th {
  width: 120px;
  white-space: nowrap;
}

/* ===== アクセス ===== */
.company-access__grid {
  display: flex;
  flex-direction: column;
  gap: 64px;
}

.company-access__item {
  display: flex;
  gap: 56px;
  align-items: flex-start;
}
@media (max-width: 767px) {
  .company-access__item { flex-direction: column; gap: 24px; }
}

.company-access__info {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.company-access__name-wrap {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.company-access__store-ttl {
  color: #E85471;
  font-family: "Noto Sans JP";
  font-size: 2.4rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: 1.67;
}
@media (max-width: 767px) {
  .company-access__store-ttl { font-size: 2rem; }
}

.company-access__divider {
  height: 1px;
  background: #D3C8BE;
  width: 100%;
}

.company-access__addr-row {
  display: flex;
  gap: 24px;
  align-items: flex-start;
}

.company-access__addr-badge {
  flex-shrink: 0;
  width: 68px;
  border: 1px solid #D4CBCD;
  border-radius: 40px;
  padding: 10px 16px;
  color: #463A3D;
  font-family: "Noto Sans JP";
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 1;
  text-align: center;
  white-space: nowrap;
  box-sizing: border-box;
}

.company-access__addr {
  color: #5C5C5C;
  font-family: "Noto Sans JP";
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 2;
}
@media (max-width: 767px) {
  .company-access__addr { font-size: 1.4rem; }
}

.company-access__map {
  flex-shrink: 0;
  width: 48.5%;
  aspect-ratio: 466 / 312;
  overflow: hidden;
  border-radius: 15px;
}
@media (max-width: 767px) {
  .company-access__map { width: 100%; aspect-ratio: 16 / 9; }
}

.company-access__map iframe {
  width: 100%;
  height: 100%;
  border: 0;
}

/* ===== サイトマップ ===== */
.company-sitemap__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px 32px;
}
@media (max-width: 1024px) {
  .company-sitemap__list { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 767px) {
  .company-sitemap__list { grid-template-columns: 1fr; gap: 16px; }
}

.company-sitemap__card {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 16px;
  padding: 24px 16px;
  border-radius: 20px;
  overflow: hidden;
  text-decoration: none;
  background-size: cover;
  background-position: center;
  aspect-ratio: 298 / 153;
  transition: opacity 0.3s;
}

.company-sitemap__card:hover { opacity: 0.85; text-decoration: none; }
.company-sitemap__card:hover .company-sitemap__card-btn {
  background: #463A3D;
  color: #FFF;
  transition: all 0.3s;
}
.company-sitemap__card:hover .company-sitemap__card-btn-label { color: #FFF; }
.company-sitemap__card:hover .company-sitemap__card-btn-arrow { background: #5C5050; }

.company-sitemap__card-body {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.company-sitemap__card-txt {
  display: flex;
  flex-direction: column;
  gap: 12px;
  color: #FFF;
}

.company-sitemap__card-sub {
  font-family: "Noto Sans JP";
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1;
}

.company-sitemap__card-ttl {
  font-family: "Noto Sans JP";
  font-size: 2.0rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.04em;
}

.company-sitemap__card-btn {
  display: inline-flex;
  align-items: center;
  gap: 40px;
  background: #FCFCFC;
  border-radius: 5px;
  padding: 14px 20px;
  align-self: flex-start;
}

.company-sitemap__card-btn-inner {
  display: flex;
  align-items: center;
  gap: 8px;
}

.company-sitemap__card-btn-dot {
  width: 4px;
  height: 4px;
  border-radius: 1px;
  background: #E85471;
  flex-shrink: 0;
}

.company-sitemap__card-btn-label {
  color: #5C5C5C;
  font-family: "Noto Sans JP";
  font-size: 1.4rem;
  font-weight: 400;
  white-space: nowrap;
}

.company-sitemap__card-btn-arrow {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  background: #EAE5E0;
  border-radius: 5px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.company-sitemap__card-btn-arrow::after {
  content: "";
  display: block;
  width: 6px;
  height: 6px;
  border-top: 1.5px solid #463A3D;
  border-right: 1.5px solid #463A3D;
  transform: rotate(45deg) translate(-1px, 1px);
}
