/* ==========================================================================
	基本リセット & グローバル設定
========================================================================== */
@import url('https://fonts.googleapis.com/css2?family=Baskervville:ital,wght@0,400..700;1,400..700&family=Jost:ital,wght@0,100..900;1,100..900&family=Noto+Sans:ital,wght@0,100..900;1,100..900&display=swap');
@import url("https://use.typekit.net/riv1hkc.css");
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
html {
  scroll-behavior: smooth;
  scroll-padding-top: 80px;
  overflow: visible;
  font-size: 14px;
}
@media (min-width: 768px) { html { font-size: 15px; } } /* タブレット */
@media (min-width: 1024px) { html { font-size: 16px; } } /* PC */

body {
  font-family: "Noto Sans", sans-serif;
  font-weight: 400;
  font-style: normal;
	line-height: 1.6;
  color: #2C2C2C;
  background: #fff;
}

a{
  color: #2C2C2C;
  text-decoration: none;
  transition: all 0.3s;
}

a:hover{
  color: var(--color-red);
}

img{
  max-width: 100%;
}

ul,li{
  list-style: none;
}

button,
input[type="submit"],
input[type="reset"],
input[type="button"] {
  -webkit-appearance: none;
  appearance: none;  
  background: none;
  border: none;
  padding: 0;
  color: inherit;
  font: inherit;
  cursor: pointer;
}


/* ==========================================================================
	共通レイアウトクラス
========================================================================== */
:root {
  --sp-0: 0;
  --sp-5: 0.375rem;
  --sp-10: 0.75rem;
  --sp-20: 1.25rem;
  --sp-30: 1.875rem;
  --sp-40: 2.5rem;
  --sp-50: 3.125rem;
  --sp-60: 3.75rem;
  --sp-70: 4.375rem;
  --sp-80: 5rem;
  --sp-90: 5.625rem;
  --sp-100: 6.25rem;
  --sp-110: 6.875rem;
  --sp-120: 7.5rem;
  --sp-130: 8.125rem;
  --sp-140: 8.75rem;

  --font-initial: "Noto Sans", sans-serif;
  --font-serif: "futura-pt", serif;
  --font-jost: "Jost", sans-serif;
  --font-12: .75rem;
  --font-14: .875rem;
  --font-16: 1rem;
  --font-18: 1.125rem;
  --font-20: 1.25rem;
  --font-24: 1.5rem;
  --font-26: 1.625rem;
  --font-32: 2rem;
  --font-40: 2.5rem;
  --font-48: 3rem;
  --color-red: #840E08;
  --color-pink: #D32D26;
  --color-palepink: #FCECEC;
  --color-white: #fff;
  --bg-grade-red: linear-gradient(70deg, rgba(211, 45, 38, 255) 0%, rgba(87, 0, 0, 255) 100%);
  --bg-grade-red2: linear-gradient(157deg, rgba(211, 45, 38, 255) 0%, rgba(87, 0, 0, 255) 100%);
}


/* --- Margin Top --- */
.mt-0 { margin-top: var(--sp-0) !important; }
.mt-5 { margin-top: var(--sp-5) !important; }
.mt-10 { margin-top: var(--sp-10) !important; }
.mt-20 { margin-top: var(--sp-20) !important; }
.mt-30 { margin-top: var(--sp-30) !important; }
.mt-40 { margin-top: var(--sp-40) !important; }
.mt-50 { margin-top: var(--sp-50) !important; }
.mt-55 { margin-top: var(--sp-55) !important; }
.mt-60 { margin-top: var(--sp-60) !important; }
.mt-70 { margin-top: var(--sp-70) !important; }
.mt-80 { margin-top: var(--sp-80) !important; }
.mt-90 { margin-top: var(--sp-90) !important; }
.mt-100 { margin-top: var(--sp-100) !important; }
.mt-110 { margin-top: var(--sp-110) !important; }
.mt-120 { margin-top: var(--sp-120) !important; }
.mt-130 { margin-top: var(--sp-130) !important; }

/* --- Margin Bottom --- */
.mb-0 { margin-bottom: var(--sp-0) !important; }
.mb-5 { margin-bottom: var(--sp-5) !important; }
.mb-10 { margin-bottom: var(--sp-10) !important; }
.mb-20 { margin-bottom: var(--sp-20) !important; }
.mb-30 { margin-bottom: var(--sp-30) !important; }
.mb-40 { margin-bottom: var(--sp-40) !important; }
.mb-50 { margin-bottom: var(--sp-50) !important; }
.mb-55 { margin-bottom: var(--sp-55) !important; }
.mb-60 { margin-bottom: var(--sp-60) !important; }
.mb-70 { margin-bottom: var(--sp-70) !important; }
.mb-80 { margin-bottom: var(--sp-80) !important; }
.mb-90 { margin-bottom: var(--sp-90) !important; }
.mb-100 { margin-bottom: var(--sp-100) !important; }
.mb-110 { margin-bottom: var(--sp-110) !important; }
.mb-120 { margin-bottom: var(--sp-120) !important; }
.mb-130 { margin-bottom: var(--sp-130) !important; }

/* --- Margin Left --- */
.ml-0 { margin-left: var(--sp-0) !important; }
.ml-5 { margin-left: var(--sp-5) !important; }
.ml-10 { margin-left: var(--sp-10) !important; }
.ml-20 { margin-left: var(--sp-20) !important; }
.ml-30 { margin-left: var(--sp-30) !important; }
.ml-40 { margin-left: var(--sp-40) !important; }
.ml-50 { margin-left: var(--sp-50) !important; }
.ml-55 { margin-left: var(--sp-55) !important; }
.ml-60 { margin-left: var(--sp-60) !important; }
.ml-70 { margin-left: var(--sp-70) !important; }
.ml-80 { margin-left: var(--sp-80) !important; }
.ml-90 { margin-left: var(--sp-90) !important; }
.ml-100 { margin-left: var(--sp-100) !important; }
.ml-110 { margin-left: var(--sp-110) !important; }
.ml-120 { margin-left: var(--sp-120) !important; }
.ml-130 { margin-left: var(--sp-130) !important; }

/* --- Margin Right --- */
.mr-0 { margin-right: var(--sp-0) !important; }
.mr-5 { margin-right: var(--sp-5) !important; }
.mr-10 { margin-right: var(--sp-10) !important; }
.mr-20 { margin-right: var(--sp-20) !important; }
.mr-30 { margin-right: var(--sp-30) !important; }
.mr-40 { margin-right: var(--sp-40) !important; }
.mr-50 { margin-right: var(--sp-50) !important; }
.mr-55 { margin-right: var(--sp-55) !important; }
.mr-60 { margin-right: var(--sp-60) !important; }
.mr-70 { margin-right: var(--sp-70) !important; }
.mr-80 { margin-right: var(--sp-80) !important; }
.mr-90 { margin-right: var(--sp-90) !important; }
.mr-100 { margin-right: var(--sp-100) !important; }
.mr-110 { margin-right: var(--sp-110) !important; }
.mr-120 { margin-right: var(--sp-120) !important; }
.mr-130 { margin-right: var(--sp-130) !important; }

.pt-50{ padding-top: var(--sp-50) !important;}
.pb-50{ padding-bottom: var(--sp-50) !important;}
.pt-60{ padding-top: var(--sp-60) !important;}
.pb-60{ padding-bottom: var(--sp-60) !important;}
.pt-90{ padding-top: var(--sp-90) !important;}
.pb-90{ padding-bottom: var(--sp-90) !important;}
.pt-100{ padding-top: var(--sp-100) !important;}
.pb-100{ padding-bottom: var(--sp-100) !important;}
.pt-120{ padding-top: var(--sp-120) !important;}
.pb-120{ padding-bottom: var(--sp-120) !important;}
.pt-130{ padding-top: var(--sp-130) !important;}
.pb-130{ padding-bottom: var(--sp-130) !important;}
.pt-140{ padding-top: var(--sp-140) !important;}
.pb-140{ padding-bottom: var(--sp-140) !important;}

.text-center { text-align: center !important; }
.text-left { text-align: left !important; }
.text-right { text-align: right !important; }

.font-bold { font-weight: 500 !important; }
.font-normal{ font-weight: 400 !important;}
.font-serif { font-family: var(--font-serif) !important; }
.font-jost { font-family: var(--font-jost) !important; }
.font-initial { font-family: var(--font-initial) !important; }

.font-12{ font-size: var(--font-12) !important;}
.font-14{ font-size: var(--font-14) !important;}
.font-16{ font-size: var(--font-16) !important;}
.font-18{ font-size: var(--font-18) !important;}
.font-20{ font-size: var(--font-20) !important;}
.font-24{ font-size: var(--font-24) !important;}
.font-26{ font-size: var(--font-26) !important;}
.font-32{ font-size: var(--font-32) !important;}
.font-40{ font-size: var(--sp-40) !important;}
.font-48{ font-size: var(--font-48) !important;}

.text-red{ color: var(--color-red) !important;}
.text-pink{ color: var(--color-pink);}
.text-white{ color: var(--color-white);}

.align-start{ align-items: flex-start !important; }
.align-center{ align-items: center !important; }
.align-end{ align-items: flex-end !important; }
.justify-end{ justify-content: flex-end !important;}
.justify-between{ justify-content: space-between !important;}


/* 改行設定 */
.nobr {
  display: inline-block;
  white-space: nowrap;
}
.sp-only { display: none; }
@media (max-width: 768px) {
  .pc-only { display: none; }
  .sp-only { display: inline; }
  .font-48{ font-size: var(--font-32);}
}

ul.list-disc li{
  list-style-type: disc;
  margin-left: 1rem;
  margin-bottom: .3rem;
}
ul.list-disc li::marker{
  color: var(--color-red);
}
.list-decimal li{
  list-style-type: decimal;
  margin-left: 1rem;
  margin-bottom: .3rem;
}

main{
  padding-bottom: var(--sp-120);
}
/* フェードインアニメーション */
/* 1. アニメーションさせたい要素の初期状態 */
.js-fade-in {
  opacity: 0;
  transform: translateY(30px); /* 30px下に下げておく */
  transition: opacity 0.8s ease, transform 0.8s ease;
}

/* 2. 表示領域に入った時に付与するクラス */
.js-fade-in.is-visible {
  opacity: 1;
  transform: translateY(0); /* 元の位置に戻る */
}

/* ==========================================================================
	ヘッダー & ナビゲーション
========================================================================== */
.header {
  width: 100%;
  height: var(--sp-90);
  padding-left: 2%;
  position: fixed;
  background-color: #840E08;
  box-shadow: 0 0 0 1px var(--color-pink), 0 0 0 2px var(--color-palepink);
  /* transition: box-shadow 0.3s ease; */
  z-index: 1000;
}
/* スクロールした時にJSで付与するクラス */
header.scrolled {
  /* box-shadow: 0 3px 6px rgba(0, 0, 0, 0.3); */
}

.header .header-container{
  max-width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0;
}
.header a{
  color: var(--color-white);
  line-height: 1;
}
.header a:hover{
  opacity: .7;
}
.logo a{
  display: block;
  width: 170px;
  height: 30px;
  background: #fff;
  mask-image: url(./public/images/common/logo.svg);
  mask-size: contain;
  mask-repeat: no-repeat;
  -webkit-mask-image: url(./public/images/common/logo.svg);
  text-indent: -9999px;
}
.logo a:hover{
  opacity: 1;
}

.header .nav {
	display: flex;
	justify-content: flex-end;
  margin-left: 2rem;
}
.header .nav .logo{
	display: none;
}
.header .nav .main-links--wrapper{
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-end;
}
.header .nav .main-links {
  display: flex;
  align-items: center;
	flex-wrap: nowrap;
  margin-top: .8rem;
}
.header .nav ul.main-links li {
  display: flex;
  align-items: center;
  font-size: var(--font-16);
  font-weight: 500;
	letter-spacing: 0.8px;
	white-space: nowrap;
  margin-right: var(--sp-30);
  line-height: 1;
}
.header .nav ul.main-links li a{
  position: relative;
}
@media (min-width: 1080px) {
    .header .nav ul.main-links li a.is-active::after{
    /* content: "";
    width: 6px;
    height: 6px;
    background-color: #fff;
    border-radius: 50%;
    position: absolute;
    bottom: -1.1rem;
    left: calc(50% - 3px); */
    content: "";
    position: absolute;
    width: 100%;
    height: 1px;
    background-color: #fff;
    bottom: -8px;
    left: 0;
  }
}
.header .nav ul.btn-links {
  display: flex;
  align-items: center;
}
.header .btn-contact, 
.header .btn-search {
  width: clamp(145px, 11vw, 160px);
  height: var(--sp-90);
  font-weight: 500;
  border-radius: 0;
  border: none;
  justify-content: center;
}
.header .btn-contact {
  border-right: 1px solid #fff;
}
.header .btn-contact.is-active {
  background: var(--color-pink);
}

/* --- スマホ版のスタイル --- */
@media (max-width: 1080px) {
  .header{
    width: 100%;
    height: 4.5rem;
    /* padding-right: 2%; */
  }
  .header .nav{
    margin-left: 0;
  }
  .header .nav .logo{
    display: block;
    margin-top: 1.25rem;
    margin-left: 2%;
  }
  .header .nav .logo a{
    background-color: #fff;
  }
  .header .container {
    width: 100% !important;
  }

  .nav {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    background: rgba(132, 14, 8, .95);
    backdrop-filter: blur(2px);
    flex-direction: column;
    justify-content: flex-start !important;
    transform: translateX(100%);
    transition: transform 0.4s ease;
    z-index: 999;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 3rem;
  }

  .nav.is-active {
    transform: translateX(0);
  }
  .header .nav .main-links--wrapper{
    align-items: center;
    margin-top: 2rem;
  }
  .nav ul.main-links {
    width: 100%;
    padding: 0 2%;
    flex-direction: column;
    align-items: flex-start !important;
  }
    .nav ul.main-links li{
    width: 100% !important;
    margin-top: 0 !important;
    margin-right: 0 !important;
    border-bottom: 1px solid #fff;
  }
  .nav ul.main-links li a{
    width: 100%;
    padding: 2rem .5rem .7rem;
    font-size: var(--font-18);
    &::after{
      content: "";
      position: absolute;
      right: 0 ;
      top: calc(50% - 5px);
      width: 6px;
      height: 10px;
      background: #fff;
      mask-image: url(./public/images/common/ico_arrow.svg);
      mask-size: contain;
      mask-repeat: no-repeat;
      -webkit-mask-image: url(./public/images/common/ico_arrow.svg);
    }
  }
  .nav ul.main-links li a.border-btm{
    border-bottom: 1px solid #fff;
    position: relative;
    pointer-events: none;
    &::after{
      display: none;
    }
  }
  .nav .btn-container{
    margin-top: 3rem;
    margin-left: 0;
  }
  .btn-links{
    flex-direction: column;
    margin-top: 2rem;
  }
  .btn-links li{
    width: 100%;
  }
  .header .btn-search, .header .btn-contact {
    width: 96%;
    max-width: 25rem !important;
    height: 4.15rem;
    margin: 0 auto;
    padding: 1.7rem 5rem !important;
    font-size: var(--font-18) !important;
    color: #fff;
    border: 1px solid #fff;
    border-radius: 30px;
  }
}
/* ドロップダウンメニュー PC用設定 */
@media screen and (min-width: 1080px) {
  .dropdown {
    position: relative;
    z-index: 10;
    padding-right: 1rem;
    cursor: pointer;
    &::after{
      content: "";
      position: absolute;
      right: 0;
      width: 0;
      height: 0;
      border-left: 4px solid transparent;
      border-right: 4px solid transparent;
      border-top: 4px solid #fff;
      transition: all .3s;
    }
  }
  .dropdown .sub-links{
    width: max-content;
    padding: var(--sp-20) var(--sp-60);    
    position: absolute;
    top: 2.1rem;
    left: -28.3rem;
    background: var(--color-palepink);
    /* アニメーションの初期状態 */
    opacity: 0;
    visibility: hidden;
    transform: translateY(-10px);
    transition: opacity 0.3s ease, transform 0.3s ease, visibility 0.3s;
    /* 隠れている間はクリックできないようにする */
    pointer-events: none;
    z-index: 1;
  }
  .dropdown .sub-links ul{
    display: grid !important;
    grid-template-columns: repeat(2, 1fr);
    align-items: center;
    gap: 12px var(--sp-60);
  }
  .dropdown .sub-links ul li{
    margin-top: 0 !important;
    margin-right: 0 !important;
  }
  .dropdown .sub-links a{
    font-size: var(--font-14);
    color: var(--color-red);
    line-height: 1.4;
    display: flex;
    align-items: center;
    gap: 1rem;
  }
  .dropdown .sub-links ul li img{
    width: 90px;
    height: 65px;
    object-fit: cover;
    border-radius: 5px;
  }
  .dropdown .sub-links p{
    font-size: var(--font-12);
    color: var(--color-red);
    border-bottom: 1px solid var(--color-pink);
    margin-bottom: 12px;
    line-height: 1.4;
  }
  .dropdown .sub-links::before {
    content: "";
    position: absolute;
    display: block;
    width: 13.5rem;
    height: 2.5rem;
    top: -1rem;
    left: 28.5rem;
    background: transparent;
    pointer-events: auto;
  }

  /* ホバー時の状態 */
  .dropdown:hover .sub-links {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    pointer-events: auto; /* マウス操作を有効化 */
  }
  .dropdown:hover::after {
    transform: rotate(180deg);
  }
}

/* ドロップダウンメニュー SP用設定 */
@media (max-width: 1080px) {
  .dropdown{
    display: flex;
    flex-direction: column;
    align-items: center;
    padding-right: 0 !important;
    padding-left: 0 !important;
  }
  .sub-links{
    width: 100%;
  }
  .sub-links ul{
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0;
  }
  .sub-links ul li{
    width: 100%;
  }
  .sub-links ul li:last-child{
    border-bottom: none;
  }
  .sub-links ul li a{
    padding-left: 2rem !important;
    font-size: var(--font-16) !important;
  }
  .sub-links p,
  .sub-links a img{
    display: none;
  }
}

/* Englishボタン */
.global-link{
  width: 120px;
  height: 28px;
  line-height: 1;
  border-radius: 30px;
  background-color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-right: 2rem;
  position: relative;
  top: -.3rem;
}
.global-link a{
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--font-14);
  color: var(--color-pink);
  font-weight: 500;
  &::before{
    content: "";
    width: 16px;
    height: 16px;
    background-color: var(--color-pink);
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
    -webkit-mask-image: url(./public/images/common/ico_global.svg);
    mask-image: url(./public/images/common/ico_global.svg);
    margin-right: .5rem;
  }
}

@media (max-width: 1080px) {
  .global-link{
    width: 4.5rem !important;
    height: 4.5rem;
    margin-right: 0;
    border-radius: 0;
    position: absolute;
    top: 0;
    right: 4.8rem;
  }
  .global-link a{
    width: 100%;
    height: 100%;
    flex-direction: column;
    gap: .3rem;
    /* font-size: var(--font-12); */
    &::before{
      margin-right: 0;
    }
  }
}

/* ==========================================================================
	セクション共通
========================================================================== */
.section{
	position: relative;
	overflow: hidden;
}
.wide-container{
  width: 100%;
  margin: var(--sp-120) auto 0;
  position: relative;
  line-height: 1.6;
  letter-spacing: .5px;
}
.container{
  width: 96%;
  max-width: 1180px;
  margin: var(--sp-120) auto 0;
  position: relative;
  line-height: 1.6;
  letter-spacing: .5px;
}
.narrow-container{
  width: 96%;
  max-width: 880px;
  margin: 0 auto;
  position: relative;
  line-height: 1.6;
  letter-spacing: .5px;
}
.container .narrow-container{
  width: 100%;
}

.anchor-scroll{
  scroll-margin-top: 100px;
}

/* グリッドレイアウト */
.grid {
  display: grid;
  grid-template-columns: 1fr auto;
  /* grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); */
  gap: var(--sp-80);
}
.grid-reverse {
  grid-template-columns: auto 1fr; 
}
.grid-1fr {
  grid-template-columns: 1fr 1fr; 
}
.grid-2fr {
  grid-template-columns: 1.6fr 1fr; 
}
.grid-2fr-reverse {
  grid-template-columns: 1fr 1.3fr; 
}

.grid img{
  display: block;
  width: 100%;
  max-width: 100%; 
  height: auto;
  object-fit: cover;
}
.gap-0{ gap: 0;}
.gap-10{ gap: var(--sp-10);}
.gap-20{ gap: var(--sp-20);}
.gap-30{ gap: var(--sp-30);}
.gap-40{ gap: var(--sp-40);}

/* フレックスレイアウト */
.flex {
  display: flex;
	flex-shrink: 1;
  gap: 1rem;
}
.flex .l-container,
.flex .r-container{
  width: 50%;
}

.br-10{ border-radius: var(--sp-10);}
.br-20{ border-radius: var(--sp-20);}
.br-30{ border-radius: var(--sp-30);}
.br-40{ border-radius: var(--sp-40);}

.bg-palepink{ background-color: var(--color-palepink);}
.bg-white{ background-color: #fff;}
.bg-gray{ background-color: #F9F9F9;}
.bg-grade-red{ background: var(--bg-grade-red);}
.bg-grade-red2{ background: var(--bg-grade-red2);}

.bg-mask::before,
.bg-mask::after{
  content: "";
  position: absolute;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  background-color: #fff;
  mask-image: url(./public/images/common/bg_mask-path.svg);
  mask-size: 100%;
  mask-repeat: no-repeat;
  mask-position: center top;
  -webkit-mask-image: url(./public/images/common/bg_mask-path.svg);  
  z-index: 0;
}
.bg-mask.bg-mask--top::before{
  top: 0;
}
.bg-mask.bg-mask--btm::before{
  bottom: 0;
  transform: rotate(180deg);
}
.bg-mask.bg-gray::before,
.bg-mask.bg-gray::after{
  background-color: #F9F9F9;
}

/* 見出し ============================================================== */
/* 見出し＋英文＋アイコン */
.heading-1,
.heading-2{
  font-size: var(--font-18);
  font-weight: 500;
  font-family: var(--font-jost);
  color: var(--color-red);
  line-height: 1.6;
  position: relative;
  display: flex;
  align-items: center;
}
.heading-2{
  font-size: var(--font-16);
}
.heading-1::before,
.heading-2::before{
  content: "";
  width: 66px;
  height: 1px;
  background-color: var(--color-red);
  display: block;
  margin-right: 8px;
}

/* 見出し＋小見出し */
.heading-3{
  font-size: var(--font-18);
  font-weight: 500;
  border-top: 1px solid #E3E3E3;
  border-bottom: 1px solid #E3E3E3;
  padding: .4rem 0;
  margin-bottom: var(--sp-30);
}

.heading-4{
	    font-size: 1.125rem;
    font-weight: 500;
    border-bottom: 1px solid #D0D0D0;
    padding-bottom: .3rem;
    margin-bottom: 8px;
    margin-top: var(--sp-30);
    color: #2C2C2C !important;
}

hr {
  height: 1px; margin: 0; padding: 0; border: none;
  background-color: #2C2C2C;
}

/* ボタン基本設定 */
.btn{
  width: 320px;
  height: 60px;
  display: flex;
  /* justify-content: center; */
  align-items: center;
  border-radius: 40px;
  font-size: var(--font-14);
  font-family: var(--font-jost);
  font-weight: 500;
  color: var(--color-white) !important;
  background: var(--bg-grade-red);
  border: 1px solid #fff;
  position: relative;
  z-index: 1;
  overflow: hidden;
}
.btn-arrow::before{
  content: "";
  width: 53px;
  height: 60px;
  background-color: var(--color-pink);
  position: absolute;
  right: 0;
  top: 0;
  transition: all .5s;
}
.btn-arrow::after{
  content: "";
  width: 6px;
  height: 10px;
  background: #fff;
  mask-image: url(./public/images/common/ico_arrow.svg);
  mask-size: contain;
  mask-repeat: no-repeat;
  -webkit-mask-image: url(./public/images/common/ico_arrow.svg);
  position: absolute;
  right: 23px;
}
.btn-arrow:hover::before{
  width: 100%;
}
.btn-arrow span{
  position: relative;
  z-index: 10;
  width: calc(100% - 53px);
  text-align: center;
}
.btn-arrow--back::before{
  left: 0;
}
.btn-arrow--back::after{
  left: 23px;
  transform: rotate(180deg);
}
.btn-arrow--back span{
  margin-left: auto;
}

.btn-contact{
  color: var(--color-white) !important;
  background: var(--bg-grade-red);
}
.btn-contact::before{
  content: "";
  width: 20px;
  height: 15px;
  background: #fff;
  mask-image: url(./public/images/common/ico_letter.svg);
  mask-size: contain;
  mask-repeat: no-repeat;
  -webkit-mask-image: url(./public/images/common/ico_letter.svg);
  margin-right: 10px;
}
.btn-search{
  color: var(--color-white) !important;
  background: linear-gradient(-64deg, rgba(0, 23, 87, 255) 0%, rgba(97, 133, 234, 255) 100%);
}
.btn-search::before{
  content: "";
  width: 16px;
  height: 16px;
  background: #fff;
  mask-image: url(./public/images/common/ico_search.svg);
  mask-size: contain;
  mask-repeat: no-repeat;
  -webkit-mask-image: url(./public/images/common/ico_search.svg);
  margin-right: 5px;
}

.btn-container{
  margin-top: var(--sp-40);
}
.btn-container.box-center{
  display: flex;
  align-items: center;
  justify-content: center;
}

.btn-white{
  background: #fff;
  color: var(--color-red) !important;
  &::before{
    display: none;
  }
  &::after{
    background-color: var(--color-red);
  }
  span{
    width: 100%;
  }
}

@media (max-width: 768px) {
  .btn{
    font-size: 1rem !important;
  }
}

.link-text{
  color: var(--color-red);
  font-size: var(--font-14);
  font-weight: 500;
  padding-left: .8rem;
  position: relative;
  transition: all .5s;
}
.link-text::after{
  content: "";
  width: 6px;
  height: 10px;
  background: var(--color-red);
  mask-image: url(./public/images/common/ico_arrow.svg);
  mask-size: contain;
  mask-repeat: no-repeat;
  -webkit-mask-image: url(./public/images/common/ico_arrow.svg);
  display: block;
  position: absolute;
  left: 0;
  top: .4rem;
}
.link-text:hover{
  opacity: .7;
}
.link-text--arrow{
  font-weight: 400;
  padding-left: 1.3rem;
}
.link-text--arrow::after{
  width: 10px;
  height: 10px;
  background: var(--color-pink);
  mask-image: url(./public/images/common/ico_arrow-left.svg);
  -webkit-mask-image: url(./public/images/common/ico_arrow-left.svg);
}

/* 下層タイトル ============================================================== */
.head-container{
  padding-top: 4.5rem;
}
.title-container{
  width: 100%;
  min-height: 220px;
  overflow: hidden;
  display: flex;
  justify-content: center;
  align-items: center;
  mask-image: url(./public/images/common/bg_mask-path_header.svg);
  mask-size: cover;
  mask-repeat: no-repeat;
  -webkit-mask-image: url(./public/images/common/bg_mask-path_header.svg);
  mask-position: center bottom;
  position: relative;
}
.title-container h1,.title-container h2{
  font-size: var(--font-24);
  font-weight: 400;
  font-family: var(--font-jost);
  line-height: 1.6;
  position: relative;
  display: flex;
  align-items: center;
  text-align: center !important;
  color: #fff;
}
.title-container .narrow-container {
  display: flex;
  justify-content: center;
}




table.table-container{
  width: 100%;
  border-collapse: separate;
  border-spacing: 0 5px;
}
table.table-container th{
  width: 25%;
  color: var(--color-red);
  vertical-align: middle;
  text-align: left;
  font-weight: 400;
  padding: var(--sp-20) var(--sp-30);
  background-color: #fff;
  border-right: 1px solid var(--color-palepink);
  overflow: hidden;
}
table.table-container td{
  text-align: left;
  padding: var(--sp-20) var(--sp-30);
  background-color: #fff;
}
@media (max-width: 580px) {
  table.table-container th{
    width: 100% !important;
    border-right: 0;
    border-bottom: 1px solid var(--color-palepink);
    display: block;
  }
  table.table-container td{
    width: 100% !important;
    display: block;
  }
}

/* パンくず ============================================================== */
.breadcrumb-container{
  width: 100%;
  display: flex;
  align-items: center;
  padding: 10px 0;
  background-color: var(--color-palepink);
}
.breadcrumb{
  width: 96%;
  max-width: 1180px;
  margin: 0 auto;
}
.breadcrumb-list {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  list-style: none;
  padding: 0;
  margin: 0;
}
.breadcrumb-item {
  display: flex;
  align-items: center;
  font-size: var(--font-14);
  line-height: 1.4;
}
.breadcrumb-item[aria-current="page"] {
  flex: 1 1 auto;
  min-width: 0;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  overflow: hidden;
  text-overflow: ellipsis;
}
.breadcrumb-item:not(:last-child)::after {
  content: "";
  width: 10px;
  height: 6px;
  background-color: var(--color-red);
  mask-image: url(./public/images/common/ico_anchor.svg);
  mask-size: contain;
  mask-repeat: no-repeat;
  -webkit-mask-image: url(./public/images/common/ico_anchor.svg);
  transform: rotate(-90deg);
  margin: 0 15px;
}

/* ページ内リンク ============================================================== */
.anchorlink-container .anchorlink-list{
  max-width: 640px;
  width: 96%;
  margin: var(--sp-50) auto 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(calc(100% / 4), 1fr));
  /* grid-template-columns: repeat(4, 1fr); */
}
.anchorlink-container .anchorlink-list li{
  display: flex;
  align-items: end;
  justify-content: center;
  text-align: center;
  border-left: 1px solid var(--color-pink);
}
.anchorlink-container .anchorlink-list li:last-child{
  border-right: 1px solid var(--color-pink) ;
}
.anchorlink-container .anchorlink-list li a{
  display: block;
  font-size: var(--font-18);
  font-weight: 500;
  color: var(--color-red);
  position: relative;
}
.anchorlink-container .anchorlink-list span{
  display: block;
  font-size: var(--font-12);
  font-family: var(--font-jost);
  color: var(--color-pink);
}
.anchorlink-container .anchorlink-list a::after{
  content: "";
  width: 16px;
  height: 9px;
  background: var(--color-pink);
  mask-image: url(./public/images/common/ico_anchor.svg);
  mask-size: contain;
  mask-repeat: no-repeat;
  -webkit-mask-image: url(./public/images/common/ico_anchor.svg);
  display: block;
  margin: var(--sp-20) auto 0;
  transition: all .3s;
}
.anchorlink-container .anchorlink-list a:hover{
  opacity: .7;
}

@media (max-width: 1180px) {
  .grid {
    /* grid-template-columns: 1fr 1fr; */
  }
}
@media (max-width: 768px) {
  .grid {
    grid-template-columns: 1fr !important;
  }
  .flex {
    flex-direction: column !important;
  }
  .grid .l-container{
    padding: 0;
    margin: 0;
  }
  .grid .r-container{
    margin: 0;
    padding: 0;
  }
  .grid.switch {
    gap: var(--sp-30);
  } 
  .grid.switch .l-container {
    order: 2; /* 2番目へ */
  } 
  .grid.switch .r-container {
    order: 1; /* 1番前へ */
  }
  .btn-container.box-center--sp a{
    margin: 0 auto;
  }
  .block-center--sp{
    margin: auto auto !important;
  }
  .title-container{
    min-height: auto;
    padding: 3rem 1rem;
  }
  .anchorlink-container .anchorlink-list {
    grid-template-columns: repeat(2, 1fr);
  }
  .anchorlink-container .anchorlink-list li:nth-last-child(-n+2) {
    margin-top: 1rem;
  }
  .anchorlink-container .anchorlink-list li:nth-of-type(2n){
    border-right: 1px solid var(--color-pink) ;
  }
}

/* ==========================================================================
	1.TOP
========================================================================== */
/* Main Visual ============================================================== */
.hero {
  width: 100%;
  height: 880px;
  margin: 0 auto;
  /* background: var(--bg-grade-red); */
  background-color: #b51a25;
  position: relative;
}
.mv-container {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: flex-end;
  position: absolute;
  left: 0;
  top: 0;
  &::after {
    content: "";
    position: absolute;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(-60deg, rgba(179, 33, 28, 255) 0%, rgba(87, 0, 0, 255) 100%);
    mask-image: url(./public/images/common/bg_mask-path.svg);
    mask-size: contain;
    mask-repeat: no-repeat;
    -webkit-mask-image: url(./public/images/common/bg_mask-path.svg);
    bottom: -1px;
    transform: rotate(180deg);
  }
}
.mv-container--text{
  max-width: 1180px;
  width: 94%;
  margin: 0 auto;
  padding-bottom: 190px;
  color: var(--color-white);
}
.mv-container--text h2{
  font-family: var(--font-serif);
  font-size: var(--font-48);
  font-weight: 400;
  line-height: 1.4;
  margin-bottom: 5px;
}
@media (max-width: 768px) {
  .hero {
    height: 50rem;
  }
  .mv-container--text{
    padding: 0 1rem 3rem;
  }
  .mv-container--text h2{
    font-size: var(--font-32);
  }
}

/* About Us ============================================================== */
#top .about-container .grid{
  gap: var(--sp-70);
}
#top .about-container .l-container{
  min-width: 345px;
  max-width: 445px;
  aspect-ratio: 445 / 525;
  margin: 0;
  position: relative;
}
#top .about-container .photo-top-about--1{
  position: absolute;
  top: 0;
  left: 0;
  width: 83.1%; /* 370 / 445 */
  aspect-ratio: 370 / 480;
  z-index: 1;
  border-radius: 10px;
  overflow: hidden;
}
#top .about-container .photo-top-about--2{
  position: absolute;
  top: 53.3%;   /* 280 / 525 */
  left: 50.5%;  /* 225 / 445 */
  width: 49.4%; /* 220 / 445 */
  aspect-ratio: 220 / 245;
  z-index: 2;
  border-radius: 10px;
  overflow: hidden;
}
#top .about-container .l-container figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

@media (max-width: 768px) {
  #top .about-container .l-container{
    max-width: 100%;
    padding-bottom: 2rem;
  }
  .photo-top-about--1{
    width: 90% !important;
  }
  .photo-top-about--2{
    width: 60% !important;
  }
  #top .about-container .r-container{
    padding: 0 3%;
    margin-right: 0 !important;
  }
}

/* Our Products ============================================================== */
#top .top-products-container{
  width: 100%;
  background: url(./public/images/top/bg_shape.svg) center top 57% no-repeat,
              linear-gradient(136deg, rgba(211, 45, 38, 255) 0%, rgba(87, 0, 0, 255) 100%);
  background-size: 104%;
  margin-top: var(--sp-100);
  padding: var(--sp-130) 0 10rem;
  color: var(--color-white) !important;
  overflow: hidden;
  position: relative;
  clip-path: ellipse(calc(100% + 500px) 50% at 50% 50%);
  -webkit-clip-path: ellipse(calc(100% + 500px) 50% at 50% 50%);
}
/* #top .top-products-container::before,
#top .top-products-container::after {
  content: "";
  position: absolute;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #fff;
  mask-image: url(./public/images/common/bg_mask-path.svg);
  mask-size: contain;
  mask-repeat: no-repeat;
  -webkit-mask-image: url(./public/images/common/bg_mask-path.svg);
}
#top .top-products-container::before {
  top: 0;
}
#top .top-products-container::after {
  bottom: -1px;
  transform: rotate(180deg);
} */

#top .top-products-container h3 {
  color: var(--color-white) !important;
}
#top .top-products-container h3::before {
  background: var(--color-white);
}
.products-container .products-container--outer{
  border-radius: 10px;
  background-color: #fff;
  margin-top: var(--sp-40);
}
.products-container .products-container--wrapper{
  width: 880px;
  max-width: 96%;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 363px 1fr;
  padding: var(--sp-60) 0;
  gap: var(--sp-40);
  position: relative;
  z-index: 10;
  color: #2C2C2C;
}
.products-container .products-container--wrapper figure{
  max-width: 363px;
  width: 100%;
  aspect-ratio: 9 / 6;
  border-radius: 10px;
  overflow: hidden;
  margin: 0 auto;
}
.products-container .products-container--wrapper figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

@media (max-width: 768px) {
  #top .top-products-container{
    background-image: linear-gradient(136deg, rgba(211, 45, 38, 255) 0%, rgba(87, 0, 0, 255) 100%);
    clip-path: ellipse(calc(100% + 700px) 50% at 50% 50%);
    -webkit-clip-path: ellipse(calc(100% + 700px) 50% at 50% 50%);
  }
  .products-container .products-container--wrapper{
    grid-template-columns: 1fr;
  }
}
@media (max-width: 375px) {
  #top .top-products-container{
    padding-top: var(--sp-90);
    padding-bottom: var(--sp-90);
  }
}

/* News ============================================================== */


.news-list-card > .news-list-card--no-link {
    display: grid;
    grid-template-columns: 165px 1fr;
    gap: 15px;
}

.top-news-container > li > .top-news-container--nolink {

    display: grid;
    grid-template-columns: 165px 1fr;
    gap: 15px;

}
#top .top-news-container {
  margin-top: var(--sp-40);
}
#news .news-detail .news-detail--content .news-detail--content-text a {
    color: #840E08;
}
#top .top-news-container li{
  padding-bottom: .5rem;
  margin-bottom: 1rem;
  border-bottom: 1px solid var(--color-palepink);
}
#top .top-news-container li a{
  display: grid;
  grid-template-columns: 165px 1fr;
  gap: 15px;
}
#top .top-news-container li a .top-news-container--img{
  width: 165px;
}
#top .top-news-container li a img{
  width: 165px;
  height: 120px;
  object-fit: cover;
  border-radius: 10px;
}
#top .top-news-container li p{
  margin-bottom: .3rem;
}
#top .top-news-container li .date{
  font-size: 12px;
  font-family: var(--font-jost);
}

@media (max-width: 768px) {
  #top .narrow-container{
    padding: 0 3%;
  }
}
@media (max-width: 496px) {
  #top .top-news-container li a{
    grid-template-columns: 1fr;
  }
}

/* Company ============================================================== */
#top .top-company-container{
  width: 1180px;
  min-height: 600px;
  margin: 0 auto;
  grid-template-columns: 1fr auto;
  gap: 0;
}
#top .top-company-container::before{
  content: "";
  width: 80%;
  height: 100%;
  background: url(./public/images/top/bg_company.jpg) left bottom no-repeat;
  background-size: cover;
  background-color: rgba(44, 44, 44, 0.7);
  background-blend-mode:darken;
  border-radius: 0 10px 10px 0;
  display: block;
  position: absolute;
  left: 0;
  top: 0;
}
#top .top-company-container .l-container{
  height: 100%;
  padding-left: 2%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  color: #fff;
  line-height: 1.8;
  z-index: 1;
}
#top .top-company-container .l-container h3{
  color: #fff;
}
#top .top-company-container .l-container h3::before{
  background-color: #fff;
}
#top .top-company-container .l-container .top-company-container--detail div{
  max-width: 650px;
  width: 100%;
  display: grid;
  grid-template-columns: .4fr 1fr;
  border-bottom: 1px solid #fff;
  font-size: var(--font-14);
  margin-top: var(--sp-20);
}
#top .top-company-container .l-container .top-company-container--detail div dt{
  font-family: var(--font-jost);
  font-weight: 500;
}
#top .top-company-container .l-container .top-company-container--detail div dd{
  font-size: var(--font-16);
  font-weight: 300;
}

#top .top-company-container .r-container{
  margin-top: var(--sp-100);
  padding-bottom: var(--sp-100);
  z-index: 1;
}
#top .top-company-container .r-container iframe{
  width: 42%;
  position: absolute;
  right: 0;
  border-radius: 10px 0 0 10px;
}

@media (max-width: 1180px) {
  #top .top-company-container .l-container{
    width: 49%;
  }
}
@media (max-width: 880px) {
  #top .top-company-container .l-container{
    width: 41%;
  }
}
@media (max-width: 800px) {
  #top .top-company-container .l-container{
    width: 38%;
  }
}

@media (max-width: 768px) {
  #top .top-company-container::before{
    width: 100%;
    border-radius: 0;
  }
  #top .top-company-container{
    width: 96%;
    padding: var(--sp-100) 0;
    min-height: auto;
  }
  #top .top-company-container .l-container{
    width: 100%;
  }
  #top .top-company-container .r-container{
    margin-top: var(--sp-50);
    padding-bottom: 0;
  }
  #top .top-company-container .r-container iframe{
    width: 100%;
    border-radius: 10px;
    position: relative;
  }
  #top .top-company-container .l-container .top-company-container--detail div{
    width: 100%;
    max-width: 100%;
  }
}

/* ==========================================================================
	2. わたしたちについて / About Us
========================================================================== */
#aboutus .title-container{
  background: url(./public/images/aboutus/header.jpg) no-repeat center center;
  background-size: cover;
  background-color: rgba(44, 44, 44, 0.7);
  background-blend-mode:darken;
}
#aboutus main{
  /* padding-bottom: 0; */
}
#aboutus .aboutus-logo{
  width: 170px;
  height: 30px;
  margin: var(--sp-70) auto 0;
  background-color: var(--color-pink);
  mask-image: url(./public/images/common/logo.svg);
  mask-size: contain;
  mask-repeat: no-repeat;
  -webkit-mask-image: url(./public/images/common/logo.svg);
}

#aboutus .bg-mask--aboutus::before{
  background: #fff;
  mask-image: url(./public/images/common/bg_mask-path.svg);
  -webkit-mask-image: url(./public/images/common/bg_mask-path.svg);
}

#aboutus .bg-mask--aboutus::after{
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  background: #fff;
  mask-image: url(./public/images/common/bg_mask-path.svg);
  -webkit-mask-image: url(./public/images/common/bg_mask-path.svg);
  mask-size: 100%;
  mask-repeat: no-repeat;
  z-index: 0;
  transform: rotate(180deg);
}


#aboutus .aboutus-mission-container{
  grid-template-columns: minmax(150px, 260px) 1fr;
  gap: var(--sp-30);
  align-items: center;
}
#aboutus .aboutus-mission-container .l-container img{
  /* width: 260px; */
  height: 345px;
  width: 100%;
  max-height: 100%;
  object-fit: cover;
  border-radius: 10px;
}

#aboutus .aboutus-team-contianer{
  background: #fff !important;
  border-radius: 10px !important;
  padding: var(--sp-70) 0;
}

#aboutus .aboutus-team-container--sub{
  grid-template-columns: minmax(120px, 190px) 1fr;
  gap: var(--sp-30);
  align-items: flex-start;
  margin-top: 20px;
}
#aboutus .aboutus-team-container--sub .l-container img{
  /* width: 190px; */
  height: 245px;
  width: 100%;
  max-height: 100%;
  object-fit: cover;
  border-radius: 10px;
}
#aboutus .aboutus-team-container--sub .r-container{
  margin-top: var(--sp-20);
}

@media (max-width: 768px) {
  #aboutus .aboutus-team-contianer{
    padding: 6% 3%;
  }
  #aboutus .aboutus-team-container--sub{
    grid-template-columns: 1fr !important;
    margin-bottom: 3rem;
  }
  #aboutus .aboutus-team-container--sub:last-of-type{
    margin-bottom: 0;
  }
  #aboutus .aboutus-team-container--sub .l-container img{
    height: 100%;
  }
  #aboutus .aboutus-team-container--sub .r-container{
    margin-top: 0;
  }
} 

/* 歴史年表 */
.history-container {
  list-style: none;
  padding: var(--sp-30) 0;
  margin-top: var(--sp-50);
  position: relative;
  &::before {
    content: "";
    width: 10px;
    height: 100%;
    background: url(./public/images/company/history_line.svg) left top no-repeat;
    background-size: auto 100%;
    display: block;
    position: absolute;
    left: 110px;
    top: 0;
  }
}
.history-item {
  display: grid;
  grid-template-columns: 75px 82px 1fr;
  align-items: center;
  gap: 0;
  margin-bottom: var(--sp-40);
  position: relative;
}
.mb-200{
  margin-bottom: 12.5rem;
}
.history-container .year {
  color: var(--color-red);
  font-family: var(--font-jost);
  font-size: var(--font-32);
  font-weight: 500;
  line-height: 1;
}
.history-container .year span{
  display: block;
  font-size: var(--font-14);
  text-align: center;
  margin: .3rem 0;
}

.history-container .point {
  position: relative;
  &::after {
    content: "";
    position: absolute;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background-color: var(--color-pink);
    left: calc(50% - 7px);
    top: calc(50% - 6px);
  }
}

.history-item .content{
  line-height: 1.4;
  text-align: left;
  position: relative;
}
.history-item figure{
  position: absolute;
  right: 0;
  top: 0;
}
.history-item figcaption{
  color: var(--color-red);
  font-size: var(--font-12);
}

@media (max-width: 835px) {
  .history-container::before {
    left: 6.56rem;
  }
  .history-item {
    align-items: flex-start;
    grid-template-columns: 5rem 4rem 1fr;
  }
  .history-item:first-child {
    padding-top: var(--sp-50);
  }
  .mb-200{
    margin-bottom: var(--sp-40);
  }
  .history-container .point::after {
    top: .5rem
  }
  .history-item figure{
    position: relative;
    margin-top: var(--sp-20);
  }
}

/* ==========================================================================
	3. 製品情報 / Our Products & Services
========================================================================== */
#products .head-container{
  margin-bottom: var(--sp-100);
}

#products.cosmetic .title-container{
  background: url(./public/images/cosmetics/header.jpg) no-repeat center center;
  background-size: cover;
  background-color: rgba(44, 44, 44, 0.7);
  background-blend-mode:darken;
}
#products.food .title-container{
  background: url(./public/images/food/header.jpg) no-repeat center center;
  background-size: cover;
  background-color: rgba(44, 44, 44, 0.7);
  background-blend-mode:darken;
}
#products.api_pharma .title-container{
  background: url(./public/images/api_pharma/header.jpg) no-repeat center center;
  background-size: cover;
  background-color: rgba(44, 44, 44, 0.7);
  background-blend-mode:darken;
}
#products.pharma_c .title-container{
  background: url(./public/images/pharma_c/header.jpg) no-repeat center 70%;
  background-size: cover;
  background-color: rgba(44, 44, 44, 0.7);
  background-blend-mode:darken;
}

#products .grid-products{
  grid-template-columns: minmax(200px, 360px) 1fr;
  gap: var(--sp-50);
  margin-top: var(--sp-90);
}
#products .grid-products .l-container{
  /* width: 360px;
  height: 260px; */
}
#products .grid-products .l-container img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 10px;
}
#products .grid-products .r-container h2{
  font-size: var(--font-32);
  font-family: var(--font-serif);
  font-weight: 400;
  line-height: 1.2;
  margin-bottom: 15px;
}

#products .gray-box--wrapper{
  background: #F9F9F9;
  border-radius: 10px;
  padding: var(--sp-40);
  margin-top: var(--sp-30);
}

@media (max-width: 768px) {
  #products .gray-box--wrapper{
    padding: var(--sp-20);
  }
}

/* ==========================================================================
	2. 会社概要 / Company
========================================================================== */
/* #company .head-container{
  margin-bottom: var(--sp-100);
}

#company .title-container{
  background: url(./public/images/company/header.jpg) no-repeat center bottom;
  background-size: cover;
  background-color: rgba(44, 44, 44, 0.7);
  background-blend-mode:darken;
}

#company .company-prof-container{
  padding: var(--sp-90) 0 12.5rem;
  color: #fff;
  text-align: center;
}
#company .company-prof-container .heading-2,
#company .company-prof-container .heading-2 span{
  color: #fff;
}

#company .bg-mask.bg-mask--company_prof::before{
  top: 0;
}
#company .bg-mask.bg-mask--company_prof::after{
  background: var(--color-palepink);
  mask-image: url(./public/images/common/bg_mask-path2.svg);
  -webkit-mask-image: url(./public/images/common/bg_mask-path2.svg);
  mask-position: center bottom;
  bottom: -1px;
}

#company .company-container--map{
  width: 96%;
  max-width: 680px;
  margin: 0 auto;
}
#company .company-container--map iframe{
  width: 100%;
}

#company .company-container--map .grid {
  grid-template-columns: 5rem 1fr;
  gap: 1rem;
} */


/* ==========================================================================
	3. ニュース / News
========================================================================== */
#news .head-container{
  margin-bottom: var(--sp-100);
}

#news .title-container{
  background: url(./public/images/news/header.jpg) no-repeat center center;
  background-size: cover;
  background-color: rgba(44, 44, 44, 0.7);
  background-blend-mode:darken;
}

/* ニュース一覧・記事一覧 */
#news .news-list-card{
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--color-palepink);
  margin-bottom: 1.25rem;
}
#news .news-list-card a{
  display: grid;
  grid-template-columns: 165px 1fr;
  gap: 1rem;
  cursor: pointer;
}
#news .news-list-card img{
  border-radius: 10px;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
#news .news-list-card .news-list-card--content{
  line-height: 1.4;
}

#news .news-list-card .news-list-card--content time{
  font-size: var(--font-12);
  font-family: var(--font-jost);
  display: block;
  margin-bottom: 10px;
}


/* ニュース一覧・ページ送り */
.pagination-container {
  display: flex;
  justify-content: center;
  margin: 5rem 0 0;
  position: relative;
}
.pagination-container .pagination {
  display: flex;
  list-style: none;
  padding: 0;
  gap: 10px;
  align-items: center;
}
.pagination-container .pagination li{
  font-family: var(--font-jost);
  column-gap: 0;
  border-bottom: 0;
  padding: 0;
}
.pagination-container .pagination li a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  text-decoration: none;
  border-radius: 50%;
  transition: all 0.3s;
}
.pagination-container .pagination li a:hover {
}
.pagination-container .pagination li.active a {
  color: #fff;
  background: var(--color-pink);
}
.pagination-container .pagination li.dots {
  padding: 0 5px;
}
.pagination-container .pagination li.prev a,.pagination-container .pagination li.next a{
  width: 4rem !important;
  text-indent: -9999px;
  position: relative;
}
.pagination-container .pagination li.prev a::before,
.pagination-container .pagination li.next a::after {
  content: "";
  display: block;
  width: 16px;
  height: 10px;
  background-color: var(--color-pink);
  mask-image: url("../images/common/ico_anchor.svg");
  mask-size: contain;
  mask-repeat: no-repeat;
  -webkit-mask-image: url("../images/common/ico_anchor.svg");
  position: absolute;
}
.pagination-container .pagination li.prev a::before {
  transform: rotate(90deg);
  left: 0;
}
.pagination-container .pagination li.next a::after {
  transform: rotate(-90deg);
  right: 0;
}

@media (max-width: 768px) {
  .news-container{
    margin-top: 1.5rem;
  }
}

/* ニュース記事 */
#news .news-detail--heading{
  padding-bottom: .5rem;
  border-bottom: 1px solid var(--color-palepink);
}
#news .news-detail--heading .news-detail--time time{
  font-size: var(--font-14);
  font-family: var(--font-jost);
}
#news .news-detail--heading .news-detail--title{
  font-size: var(--font-24);
  font-weight: 500;
  margin-top: .5rem;
}
#news .news-detail .news-detail--content{
  margin-top: var(--sp-50);
}
#news .news-detail .news-detail--content .news-detail--content-photo{
  display: flex;
  flex-direction: column;
  width: fit-content;
  max-width: 100%;
  margin: 0 auto;
}
#news .news-detail .news-detail--content figure{
  max-width: 780px;
  width: 100%;
}
#news .news-detail .news-detail--content figure img{
  width: auto;
  max-width: 100%;
  height: auto;
  border-radius: 10px;
  /* object-fit: cover;
  aspect-ratio: 2 / 1; */
}

#news .news-detail .news-detail--content figcaption{
  font-size: var(--font-12);
  color: var(--color-red);
}
#news .news-detail .news-detail--content .news-detail--content-text{
  margin-top: var(--sp-50);
}

@media (max-width: 768px) {

}


/* ==========================================================================
	5. お問い合わせ / Inquiry
========================================================================== */
#inquiry .head-container{
  margin-bottom: var(--sp-100);
}

#inquiry .title-container{
  background: url(./public/images/inquiry/header.jpg) no-repeat center center;
  background-size: cover;
  background-color: rgba(44, 44, 44, 0.7);
  background-blend-mode:darken;
}

#inquiry .form-container {
  width: 100%;
  max-width: 1000px;
  margin: var(--sp-50) auto;
}
/* 各入力項目の間隔 */
#inquiry .form-group {
  display: grid;
  grid-template-columns: 1.2fr 3fr;
  gap: var(--sp-20);
  align-items: center;
  margin-bottom: var(--sp-20);
}

#inquiry label,.label-title {
  display: block;
  font-family: var(--font-jost);
  font-size: var(--font-14);
 /* color: var(--color-red);*/
  position: relative;
}
#inquiry label span{
  color: var(--color-pink);
}

/* 入力フィールドのスタイル */
input[type="text"],
input[type="email"],
input[type="tel"],
textarea {
  width: 100%;
  padding: 15px 10px 15px 20px;
  border: none;
  background-color: #F8F8F8;
  border-radius: 6px;
  box-sizing: border-box;
  transition: border-color 0.3s, box-shadow 0.3s;
}
input::placeholder,
textarea::placeholder {
  color: #d9d9d9 !important;
  font-family: var(--font-initial);
  font-size: var(--font-14);
}

input:focus,
textarea:focus {
  outline: none;
  border-color: #414141;
  box-shadow: 0 0 0 3px rgba(74, 144, 226, 0.1);
}

/* チェックボックス部分 */
#inquiry .policy-group {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: 10px;
  line-height: 1;
  margin-top: var(--sp-40);
}
#inquiry .checkbox-group label,
#inquiry .checkbox-group input,
#inquiry .policy-group input,
#inquiry .policy-group label{
  cursor: pointer;
}

@media (max-width: 768px) {
  #inquiry .form-group {
    grid-template-columns: 1fr;
  }
}

/* お問い合わせ画面 */
#inquiry .products-inquiry-container{
  margin-top: var(--sp-50);
  margin-bottom: var(--sp-70);
}
#inquiry .products-inquiry-container--table{
  width: 100%;
  margin: 1rem auto 0;
  border-collapse: collapse;
}
#inquiry .products-inquiry-container--table th{
  width: 50%;
  background-color: #F9F9F9;
  text-align: left;
  font-size: var(--font-14);
  font-weight: 400;
  border-right: 1.5px solid #fff;
  border-bottom: 1.5px solid var(--color-palepink);
  padding: 15px 20px;
}
#inquiry .products-inquiry-container--table td{
  width: 50%;
  border-right: 1px solid #fff;
  border-bottom: 1.5px solid var(--color-palepink);
  padding: 15px 20px;
}
#inquiry .products-inquiry-container--table tr:nth-last-of-type(odd) td{
  background-color: #FFFAFA;
}
#inquiry .products-inquiry-container--table td:nth-last-of-type(odd){
  color: var(--color-red);
}
@media (max-width: 768px) {
  #inquiry .products-inquiry-container--table th,
  #inquiry .products-inquiry-container--table td{
    font-size: var(--font-14);
    padding: 10px;
  }
}

/* ==========================================================================
	6. プライバシーポリシー / Privacy
========================================================================== */
#privacy .head-container{
  margin-bottom: var(--sp-100);
}

#privacy .title-container{
  background: url(./public/images/company/header.jpg) no-repeat center bottom;
  background-size: cover;
  background-color: rgba(44, 44, 44, 0.7);
  background-blend-mode:darken;
}

/* ==========================================================================
	7. 利用規約 / Terms of Use 
========================================================================== */
#terms .head-container{
  margin-bottom: var(--sp-100);
}

#terms .title-container{
  background: url(./public/images/company/header.jpg) no-repeat center bottom;
  background-size: cover;
  background-color: rgba(44, 44, 44, 0.7);
  background-blend-mode:darken;
}

/* ==========================================================================
	フッター
========================================================================== */
.footer{
  width: 100%;
  padding-top: var(--sp-140); /* 140px */
  padding-bottom: var(--sp-40);
  background-color: #f9f9f9;
  position: relative;
}
.footer::before{
  content: "";
  width: 100%;
  height: 100%;
  background: var(--bg-grade-red);
  mask-image: url(./public/images/common/bg_mask-path.svg);
  mask-size: 100%;
  mask-repeat: no-repeat;
  -webkit-mask-image: url(./public/images/common/bg_mask-path.svg);
  mask-position: center top;
  position: absolute;
  top: 0;
}
.footer-container .logo a{
  width: 200px;
  height: 34px;
  background-color: var(--color-pink);
}
.footer h4 {
  font-size: var(--font-18);
  margin-top: var(--sp-30);
}
.footer-bottom{
  margin-top: 3rem;
}
.footer-link {
  display: flex;
  flex-wrap: wrap;
  gap: clamp(2rem, 4.2vw, 2.8125rem); /* 45px */
  font-weight: 500;
}
.footer-link li{
  text-align: left;
}
.footer-link a{
  color: var(--color-red);
}
.footer-link a:hover{
  opacity: .7;
}
.footer-link .footer-sub-links{
  margin-top: 1rem;
  margin-left: 1.5rem;
}
.footer-link .footer-sub-links li{
  font-size: var(--font-14);
  list-style: disc;
  color: var(--color-red);
  text-align: left;
}

.footer-bottom .box-center--sp ul{
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: 0 !important;
  gap: 1.5rem;
}
.btn-global--footer{
  color: var(--color-red) !important;
  background: #fff !important;
  border: 1px solid var(--color-pink);
}
.btn-global--footer.btn-arrow span,
.btn-contact--footer.btn-arrow span{
  position: relative;
  display: flex;
  align-items: center;
  padding-left: var(--sp-40);
  margin-right: 10px;
}
.btn-contact--footer span::before{
  content: "";
  width: 20px;
  height: 15px;
  background: #fff;
  mask-image: url(./public/images/common/ico_letter.svg);
  mask-size: contain;
  mask-repeat: no-repeat;
  -webkit-mask-image: url(./public/images/common/ico_letter.svg);
  margin-right: 10px;
}
.btn-global--footer span::before{
  content: "";
  width: 20px;
  height: 16px;
  background: var(--color-red);
  mask-image: url(./public/images/common/ico_global.svg);
  mask-size: contain;
  mask-repeat: no-repeat;
  -webkit-mask-image: url(./public/images/common/ico_global.svg);
  margin-right: 5px;
}
.btn-global--footer.btn-arrow::before{
  background-color: var(--color-red) !important;
}
.btn-global--footer:hover span{
  color: #fff !important;
}
.btn-global--footer:hover span::before{
  background-color: #fff !important;
}

.footer-bottom{
  margin-top: var(--sp-90);
  display: flex;
  justify-content: space-between;
}
.footer-bottom .footer-bottom-link{
  display: flex;
  gap: 2rem;
  font-size: var(--font-12);
}
.footer-bottom .footer-bottom-link a{
  color: var(--color-red);
}
.footer-bottom .footer-bottom-link a:hover{
  opacity: .8;
}

.footer-copyright{
  /* margin-top: var(--sp-90); */
}
.footer-copyright small{
  font-family: var(--font-jost);
  font-size: var(--font-12);
}

a.pagetop{
  display: block;
  width: 54px;
  height: 54px;
  border-radius: 50%;
  background: var(--bg-grade-red);
  color: #fff;
  border: 1px solid #fff;
  font-size: var(--font-12);
  font-family: var(--font-jost);
  letter-spacing: 1.2px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  right: var(--sp-130);
  top: -1.7rem;
  transition: all 0.5s;
}
a.pagetop:hover{
  color: #fff;
  transform: scale(1.2);
}
@media (max-width: 1180px) {
  a.pagetop{
    width: 4rem;
    height: 4rem;
    font-size: var(--font-18);
    right: 1rem;
  }
}
@media (max-width: 980px) {
  .footer-container .grid{
    grid-template-columns: 1fr !important;
    gap: 0;
  }
  .footer-container .box-center--sp ul{
    display: flex;
    flex-direction: row;
    align-items: flex-end;
    justify-content: center;
    gap: 2rem;
  }
}
@media (max-width: 768px) {
  .footer-logo{
    text-align: center;
  }
  .footer-link {
    justify-content: center;
    padding: 0 1rem;
  }
  .footer-bottom{
    flex-direction: column-reverse;
    align-items: center;
    margin-top: 3rem;
  }
  .footer-container .box-center--sp ul{
    display: block;
  }
  .footer-copyright{
    text-align: center;
    margin-top: 2rem;
  }
}
@media (max-width: 515px) {
  .footer-link {
    flex-direction: column;
    justify-content: center;
    gap: 1rem;
    padding: 0 1rem;
  }
}
/* ==========================================================================
	スマートフォン向け調整 (768px以下)
========================================================================== */
/* --- ハンバーガーボタン（PCでは隠す） --- */
.hamburger {
  display: none;
  min-width: 4.5rem;
  height: 100%;
  /* border: 1px solid #D9D9D9;
  border-radius: 5px; */
  background: var(--color-pink);
  position: relative;
  z-index: 1001; /* ナビ背景より常に上 */
  cursor: pointer;
}

.hamburger span {
  display: block;
  position: absolute;
  width: 30px;
  height: 2px;
  background: #fff;
  left: calc(50% - 15px);
  transition: 0.3s;
}
.hamburger span:nth-child(1) { top: 1.7rem; }
.hamburger span:nth-child(2) { top: calc(50% - 1px); }
.hamburger span:nth-child(3) { bottom: 1.7rem; }

/* 展開時のアニメーション */
.hamburger.is-active span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.hamburger.is-active span:nth-child(2) { opacity: 0; }
.hamburger.is-active span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

.is-resize .nav {
  transition: none !important;
}
/* --- スマホ版（768px以下）のスタイル --- */
@media (max-width: 1080px) {
  .hamburger {
    display: block;
    margin-left: auto;
  }
}

#inquiry .policy-group span.wpcf7-list-item-label {
    color: #2c2c2c;
}

#inquiry .policy-group span.wpcf7-list-item-label a {
    color: var(--color-pink);
    margin-left: 0.25rem;
    margin-right: 0.25rem;
}

input.wpcf7-form-control.wpcf7-submit.has-spinner.btn-submit {
    color: transparent;
    position: absolute;
    z-index: 99;
    width: 100%;
    height: 100%;
}

.wpcf7-spinner {
    background-color: transparent!important;
    position: absolute !important;
}


#inquiry .form-container .wpcf7 form.invalid .wpcf7-response-output, #inquiry .form-container .wpcf7 form.failed .wpcf7-response-output, #inquiry .form-container .wpcf7 form.aborted .wpcf7-response-output, #inquiry .form-container .wpcf7 form.spam .wpcf7-response-output, #inquiry .form-container .wpcf7 form.unaccepted .wpcf7-response-output {
    color: var(--color-red);
    border: 1px solid #E7B5B3;
    background-color: #FFF7F7;
}