/* ==========================================================================
	基本リセット & グローバル設定
========================================================================== */
@import url('https://fonts.googleapis.com/css2?family=Jost:ital,wght@0,100..900;1,100..900&family=Shippori+Mincho:wght@400;500&family=Zen+Kaku+Gothic+New:wght@400;500;700&display=swap');
@import url(public/css/products.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: "Zen Kaku Gothic New", 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: "Zen Kaku Gothic New", sans-serif;
  --font-mincho: "Shippori Mincho", serif;
  --font-en: "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;}

.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-mincho { font-family: var(--font-mincho) !important; }
.font-en { font-family: var(--font-en) !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-48{ font-size: var(--font-48) !important;}

.text-red{ color: var(--color-red);}
.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: scroll;
  }
  .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;
    &::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 .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;
    }
  }
  .sub-links{
    width: max-content;
    padding: var(--sp-20) var(--sp-60);    
    position: absolute;
    top: 2.1rem;
    left: -9rem;
    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;
  }
  .sub-links ul{
    display: grid !important;
    grid-template-columns: repeat(2, 1fr);
    align-items: center;
    gap: 12px var(--sp-60);
  }
  .sub-links ul li{
    width: calc(50% - 6px);
    margin-top: 0 !important;
    margin-right: 0 !important;
  }
  .sub-links a{
    font-size: var(--font-14);
    color: var(--color-red);
  }
  .sub-links ul li img{
    width: 90px;
    height: 65px;
    object-fit: cover;
    border-radius: 5px;
    vertical-align: middle;
    margin-right: 1rem;
  }
  .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;
  }
  .sub-links::before {
    content: "";
    position: absolute;
    display: block;
    width: 8.5rem;
    height: 2.5rem;
    top: -1rem;
    left: 9rem;
    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 !important;
    flex-direction: column !important;
    align-items: center;
    padding-right: 0 !important;
    padding-left: 0 !important;
  }
  .sub-links{
    width: 100%;
  }
  .sub-links ul{
    width: 100%;
    display: flex !important;
    flex-direction: column !important;
    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/en/common/ico_global.svg);
    mask-image: url(public/images/en/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: 5rem;
  }
  .global-link a{
    width: 100%;
    height: 100%;
    flex-direction: column;
    gap: .3rem;
    font-size: 1rem !important;
    &::before{
      margin-right: 0;
    }
  }
}

/* 検索窓 */
.search-bar {
  position: absolute;
  top: calc(100% + 2px); /* ヘッダーの高さ分、下に出る */
  right: 0;
  width: 50%;
  padding: var(--sp-30);
  background: linear-gradient(-64deg, rgba(0, 23, 87, 255) 0%, rgba(97, 133, 234, 255) 100%);
  /* アニメーション用 */
  opacity: 0;
  visibility: hidden;
  transform: translateY(-10px);
  transition: all 0.3s ease;
}
.search-bar.is-active {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.search-bar-inner {
  max-width: 1000px;
  margin: 0 auto;
  display: flex;
  align-items: flex-start;
  gap: 20px;
  color: #fff;
}
.search-form {
  flex: 1;
}
.search-bar--title{
  margin-top: 1rem;
}
.search-input-wrapper {
  position: relative;
  width: 100%;
}
.search-input-wrapper label{
  color: #fff !important;
  font-size: var(--font-16) !important;
}

/* 虫眼鏡アイコン */
.search-icon {
  content: "";
  width: 16px;
  height: 16px;
  background: #000;
  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;
    position: absolute;
    right: 15px;
    top: 50%;
    transform: translateY(20%);
}

/* 入力欄のスタイル調整 */
.search-input {
  width: 100%;
  padding: 12px 45px 12px 45px;
  border: 1px solid #ccc;
  outline: none;
  font-size: 16px;
  transition: border-color 0.3s;
  border-radius: 30px !important;
}
/* 閉じるボタン */
.search-close {
  background: none;
  border: none;
  font-size: var(--font-12);
  line-height: 1;
  cursor: pointer;
}

.search-bar--sp{
  display: none;
}
@media (max-width: 1080px) {
  .search-bar,
  .search-bar--pc{
    display: none;
  }
  .search-bar--sp{
    display: inline;
    width: 100%;
  }
}
/* 検索窓 SP */
.search-bar--sp .search-bar-inner {
  width: 100%;
  padding: 2rem 0;
  background: linear-gradient(-64deg, rgba(0, 23, 87, 255) 0%, rgba(97, 133, 234, 255) 100%);
  display: block;
  font-size: var(--font-18) !important;
  margin: 2rem auto 0;
}
.search-bar--sp .search-bar--title{
  margin-top: 0;
  margin-bottom: 1rem;
  text-align: center;
}
.search-bar--sp .search-input-wrapper{
  max-width: 25rem;
  width: 96%;
  margin: 0 auto;
}
.search-bar--sp .search-input {
  padding: 1.35rem;
  font-size: var(--font-18) !important;
}
.search-bar--sp .search-icon {
  width: 1.5rem;
  height: 1.5rem;
}
.search-bar--sp .search-input-wrapper label {
  font-size: var(--font-18) !important;
}
.search-bar--sp .flex{
  flex-direction: row !important;
  justify-content: center;
}
.search-bar--sp .flex label{
  color: #fff !important;
  font-size: var(--font-18) !important;
}


/* ==========================================================================
	セクション共通
========================================================================== */
.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) !important;}
.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;
  -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);
}

/* 見出し ============================================================== */
/* 見出し＋英文＋アイコン */
.heading-1,
.heading-2,
.title-container h1{
  font-size: var(--font-18);
  font-weight: 500;
  color: var(--color-red);
  line-height: 1.6;
  position: relative;
  display: inline-block;
}
.heading-1::after,
.title-container h1::after{
  content: "";
  width: 35px;
  height: 37px;
  background: #F8D1D1;
  mask-image: url(public/images/common/ico_h3.svg);
  mask-size: contain;
  mask-repeat: no-repeat;
  -webkit-mask-image: url(public/images/common/ico_h3.svg);
  display: block;
  position: absolute;
  right: -45px;
  top: 0;
}
.heading-1 span,
.heading-2 span,
.title-container h1 span{
  display: block;
  font-size: 12px;
  font-family: var(--font-en);
  color: var(--color-pink);
}
/* 見出し＋英文 */
.heading-2{
  font-weight: 500;
  line-height: 1.6;
}
/* 見出し＋上下罫線 */
.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: var(--font-14);
  font-weight: 500;
  margin-bottom: var(--sp-30);
  padding-left: 20px;
  position: relative;
}
.heading-4::before{
  content: "";
  width: 11px;
  height: 2px;
  border-radius: 2px;
  background-color: var(--color-pink);
  display: block;
  position: absolute;
  top: .75rem;
  left: 0;
}
/* 見出し（font:18px） */
.heading-5{
  font-size: var(--font-18);
  font-weight: 500;
}
/* 見出し（font:16px） */
.heading-6{
  font-size: var(--font-16);
  color: var(--color-red);
  font-weight: 500;
  margin-top: 25px;
}
/* 見出し（font:16px、下線つき） */
.heading-7{
  font-size: 1rem;
  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-16);
  /* 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% - 40px);
  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: 5px;
}
.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%;
  }
}

.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 .narrow-container {
  display: flex;
  justify-content: center;
}
.title-container h1,.title-container h1 span,.title-container h2,.title-container h2 span {
  text-align: center !important;
  color: #fff;
}

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;
  }

  .tbl-scroll {
    overflow: scroll;
}
    .tbl-scroll table.table-container td {
        width: auto;
        display: revert;
    }

	  .tbl-scroll table.table-container th{
        width: auto;
        display: revert;
	  }
	  .tbl-scroll table.table-container.products-container--table1 {
    min-width: 36rem;
}
  
}

/* パンくず ============================================================== */
.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-en);
  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-color: #b51a25;
  /* background: var(--bg-grade-red); */
  position: relative;
}
.mv-container {
  width: 100%;
  height: 100%;
  /* background: url('../images/top/mv.png') no-repeat center bottom 45px; */
  /* background-size: cover; */
  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{
  color: var(--color-white);
  max-width: 1180px;
  width: 94%;
  margin: 0 auto;
  padding-bottom: 190px;
}
.mv-container--text h2{
  font-family: var(--font-mincho);
  font-size: var(--font-48);
  font-weight: 400;
  line-height: 1.2;
  margin-bottom: 5px;
}
@media (max-width: 768px) {
  .hero{
    height: 50rem;
  }
  .mv-container--text{
    /* bottom: 3rem;
    left: 0; */
    padding: 0 1rem 3rem;
  }
  .mv-container--text h2{
    font-size: var(--font-32);
  }
}

/* About Us ============================================================== */
.about-container {
  display: grid;
  grid-template-columns: 1fr 1fr; /* 1:1の2カラム */
  gap: 40px;
  max-width: 1440px;
  margin: 0 auto;
  align-items: center;
}

#top .about-container .l-container{
  position: relative;
  width: 100%;
  max-width: 670px; 
  aspect-ratio: 670 / 555; /* 全体の高さ(220+230+α)に合わせて調整 */
}
#top .about-container .photo-top-about--1{
  width: 68.6%; /* 460 / 670 */
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  margin: 0;
  border-radius: 0 10px 10px 0;
  overflow: hidden;
}
#top .about-container .photo-top-about--2{
  width: 47.7%; /* 320 / 670 */
  position: absolute;
  /* 座標計算: 220px / 555px ≒ 39% | 350px / 670px ≒ 52% */
  top: 40%;
  left: 52%; 
  z-index: 2;
  margin: 0;
  border-radius: 10px;
  overflow: hidden;
}
#top .about-container .l-container figure img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}
@media (min-width: 1441px) {
  #top .about-container .photo-top-about--1{
    border-radius: 10px;
  }
}
@media (max-width: 1440px) {
  #top .about-container .r-container{
    padding-right: var(--sp-20);
  }
}
@media (max-width: 768px) {
  #top .about-container .l-container{
    max-width: 100%;
    aspect-ratio: 4 / 3; /* スマホで見やすい比率に */
  }
  .photo-top-about--1{
    width: 80% !important;
  }
  .photo-top-about--2{
    width: 60% !important;
    left: auto;
    right: 0; /* スマホでは右端に寄せるなど */
    border-radius: 10px 0 0 10px !important;
  }
  #top .about-container .r-container{
    padding: 0 3%;
  }
}

/* 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;
  clip-path: path("M1440 98.04 V0 s -369.23 69.78 -729.23 69.78 S 0 0 0 0 v98.04 h1440 Z");
  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,
#top .top-products-container h3 span {
  color: var(--color-white) !important;
}
#top .top-products-container h3::after {
  background: var(--color-white);
}
.products-container .products-container--wrapper{
  display: grid;
  grid-template-columns: 363px 1fr;
  margin-top: var(--sp-40);
  padding-bottom: 1.5rem;
  position: relative;
  z-index: 10;
}
.products-container .products-container--wrapper figure{
  max-width: 363px;
  width: 100%;
  aspect-ratio: 9 / 6;
  border-radius: 10px;
  position: relative;
  z-index: 10;
  overflow: hidden;
}
.products-container .products-container--wrapper figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.products-container .products-container--wrapper .products-container--content{
  height: 100%;
  margin-left: -90px;
  margin-top: 1.5rem;
  padding-right: var(--sp-50);
  padding-left: var(--sp-140);
  padding-top: 1.5rem;
  padding-bottom: 1.5rem;
  color: #2C2C2C;
  display: flex;
  flex-direction: column;
  justify-content: center;
  border-radius: 10px;
  background-color: #fff;
}
@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;
  }
  .products-container .products-container--wrapper figure{
    margin-bottom: -8.2rem;
  }
  .products-container .products-container--wrapper .products-container--content{
    margin-left: 1.5rem;
    padding: var(--sp-130) var(--sp-20) var(--sp-20);
  }
}
@media (max-width: 375px) {
  #top .top-products-container{
    padding-top: var(--sp-90);
    padding-bottom: var(--sp-90);
  }
}

/* News ============================================================== */
#top .top-news-container--wrapper {
  padding: var(--sp-60) 3%;
}
#news .news-detail .news-detail--content .news-detail--content-text a {
    color: #840E08;
}
#top .top-news-container {
  margin-top: var(--sp-40);
}
#top .top-news-container li{
  padding-bottom: .5rem;
  margin-bottom: 1rem;
  border-bottom: 1px solid var(--color-pink);
}
#top .top-news-container li p{
  margin-bottom: .3rem;
}
#top .top-news-container li .date{
  font-size: 12px;
  font-family: var(--font-en);
}
#top .top-news-container li .ico{
  font-size: 12px;
  color: var(--color-pink);
  border: 1px solid var(--color-pink);
  border-radius: 30px;
  padding: .1rem .5rem;
  margin-left: 1rem;
}

@media (max-width: 768px) {
  #top .bg-palepink .narrow-container{
    padding-left: 3%;
    padding-right: 3%;
  }
}

/* Company ============================================================== */
#top .top-company-container{
  width: 880px;
  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,
#top .top-company-container .l-container h3 span{
  color: #fff;
}
#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: 865px) {
  #top .top-company-container .l-container{
    width: 43%;
  }
  #top .top-company-container .r-container iframe{
    width: 50%;
  }
}
@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{
    padding-bottom: 0;
  }
  #top .top-company-container .r-container iframe{
    width: 100%;
    border-radius: 10px;
    position: relative;
  }
}

/* ==========================================================================
	2. 会社概要 / Company
========================================================================== */
#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;
  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;
}

#company .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-en);
  font-size: var(--font-32);
  font-weight: 500;
  line-height: 1;
}
.history-container .year span{
  display: block;
  font-size: var(--font-14);
  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) {
  #company .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. ニュース / News
========================================================================== */
#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-tags-container{
  color: #A2A2A2;
  font-size: var(--font-12);
  margin-top: 35px;
}
#news .news-tags-list{
  display: flex;
  align-items: center;
    flex-wrap: wrap;
    gap: 1rem;
    margin-top: .5rem;
}
#news .news-tags-list li,
#news .news-list-card .news-list-card--icon .news-icon,
#news .news-detail--heading .news-detail--icon .news-icon{
  width: 100%;
      max-width: 13rem;
  line-height: 1;
  font-size: var(--font-14);
  color: var(--color-pink);
  text-align: center;
  padding: 8px;
  border-radius: 1.6rem;
  border: 1px solid var(--color-pink);
  cursor: pointer;
  transition: all .3s;
}
#news .news-tags-list li.current{
  color: #fff;
  background: var(--color-pink);
}
#news .news-tags-list li:hover{
  color: #fff;
  background: var(--color-pink);
}

#news .news-tags-search{
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: var(--sp-30);
}
#news .news-tags-search .news-tags-search--clear{
  display: flex;
  align-items: center;
  cursor: pointer;
  position: relative;
}
#news .news-tags-search .news-tags-search--clear::before{
  content: "";
  width: 16px;
  height: 16px;
  background: #7E7E7E;
  mask-image: url(public/images/common/ico_close.svg);
  mask-size: contain;
  mask-repeat: no-repeat;
  -webkit-mask-image: url(public/images/common/ico_close.svg);
  margin-right: .5rem;
}

/* ニュース一覧・記事一覧 */
#news .news-list-container{
  margin-top: var(--sp-50);
}
#news .news-list-card{
  padding-bottom: .5rem;
  border-bottom: 1px solid var(--color-pink);
  margin-bottom: 1.25rem;
}
#news .news-list-card .news-list-card--icon,
#news .news-detail--heading .news-detail--icon{
  display: flex;
  align-items: center;
  gap: 1rem;
}
#news .news-list-card .news-list-card--icon time{
  font-size: var(--font-12);
  font-family: var(--font-en);
}
#news .news-list-card .news-list-card--icon .news-icon,
#news .news-detail--heading .news-detail--icon .news-icon{
  width: auto;
  font-size: var(--font-12);
  padding: .3rem 1rem;
}
#news .news-list-card .news-list-card--content{
  margin-top: .6rem;
  line-height: 1.4;
}

/* ニュース一覧・ページ送り */
.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-en);
  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-section{
    display: block;
  }
  #news .news-tags-list{
    flex-wrap: wrap;
    justify-content: flex-start;
    gap: .5rem;
  }
  #news .news-tags-list li{
    width: auto !important;
  }
  .news-container{
    margin-top: 1.5rem;
  }
}

/* ニュース記事 */
.news-detail-container{
  margin-top: var(--sp-90);
}
#news .news-detail--heading{
  padding-bottom: .5rem;
  border-bottom: 1px solid var(--color-pink);
}
#news .news-detail--heading .news-detail--icon time{
  font-size: var(--font-14);
  font-family: var(--font-en);
}
#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;
  /* 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) {

}

/* ==========================================================================
	4. わたしたちについて / 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-partner-container{
  max-width: 660px;
  width: 100%;
  margin: var(--sp-20) auto 0;
  display: grid;
  grid-template-columns: minmax(150px, 240px) 1fr;
  gap: var(--sp-20);
  align-items: center;
}
#aboutus .aboutus-partner-container figure{
  text-align: center;
}
#aboutus .aboutus-partner-container figure img{
  padding: 18px 25px;
  border: 1px solid #E3E3E3;
  border-radius: 5px;
  text-align: center;
}
#aboutus .aboutus-partner-container .tags{
  display: flex;
  gap: 10px;
  margin-top: var(--sp-30);
}
#aboutus .aboutus-partner-container .tags li{
  border-radius: 30px;
  background-color: var(--color-red);
  padding: .3rem 1rem;
  font-size: var(--font-12);
  color: #fff;
  line-height: 1;
}
#aboutus .aboutus-partner-container .tags li.out{
  background-color: #D9D9D9;
}

#aboutus .aboutus-business-container{
  padding: var(--sp-90) 0 var(--sp-100);
}
#aboutus .aboutus-business-container h2,
#aboutus .aboutus-business-container h2 span{
  color: #fff;
  text-align: center;
}
#aboutus .aboutus-business-container--wrapper{
  max-width: 1180px;
  width: 96%;
  margin: 0 auto;
  background-color: #fff;
  border-radius: 10px;
  padding-top: var(--sp-30);
  padding-bottom: var(--sp-50);
  padding-left: 3.4%;
  padding-right: 3.4%;
}
#aboutus .aboutus-business-container--wrapper h3{
  text-align: center;
  font-size: var(--font-24);
  font-weight: 500;
  color: var(--color-red);
}
#aboutus .aboutus-business-container--wrapper h3 span{
  display: block;
  height: 64px;
  width: 64px;
  color: #fff;
  border-radius: 50%;
  background: var(--bg-grade-red2);
  margin: 0 auto 10px;
  line-height: 64px;
}
#aboutus .aboutus-business-container--wrapper .list-grid{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
}
#aboutus .aboutus-business-container--wrapper h4{
  font-size: 1rem;
  font-weight: 500;
  border-bottom: 1px solid #D0D0D0;
  padding-bottom: .3rem;
  margin-bottom: 8px;
  margin-top: var(--sp-30);
}
.grid-min {
  display: grid;
  grid-template-columns: 1fr .65fr; 
}

@media (max-width: 768px) {
  #aboutus .aboutus-partner-container,
  #aboutus .aboutus-business-container--wrapper .list-grid{
    grid-template-columns: 1fr;
  }
}

/* ==========================================================================
	5. お問い合わせ / Inquiry
========================================================================== */
#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 .form-group.line{
  padding: var(--sp-40) 0;
  border-top: 1px solid var(--color-palepink);
  margin-bottom: 0;
}
#inquiry .form-group.line-last{
  border-bottom: 1px solid var(--color-palepink);
}

#inquiry label,.label-title {
  display: block;
  font-size: var(--font-14);
  color: var(--color-red);
  position: relative;
}

#inquiry label span{
  display: inline-block;
  font-size: var(--font-14);
  line-height: 1;
  width: 41px;
  padding: 0.4rem 0; /* 25px */
  text-align: center;
  margin-left: 1rem;
  border-radius: 4px;
  color: #fff;
  background: var(--color-red);
  position: absolute;
  right: 0;
}

#inquiry .checkbox-group {
  display: flex;
  align-items: flex-start;
  flex-wrap: wrap;
}
#inquiry .checkbox-group div{
  display: flex;
  align-items: flex-start;
}
#inquiry .checkbox-group input{
  margin-top: .28rem;
}
#inquiry .checkbox-group label{
  margin-left: .5rem;
  margin-right: 2rem;
}

#inquiry .grid-inquiry {
  display: grid;
  grid-template-columns: 1fr 2fr;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1rem;
}

/* 入力フィールドのスタイル */
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;
  }
}


/* ==========================================================================
   Inquiry / Contact Form 7 調整
   静的デザインをベースに、CF7のラッパー要素だけ吸収する
========================================================================== */

/* ----------------------------------
   CF7全体
---------------------------------- */
#inquiry .form-container .wpcf7 {
  width: 100%;
}

#inquiry .form-container .wpcf7 form {
  margin: 0;
}

#inquiry .form-container .wpcf7 form.invalid .wpcf7-response-output,
#inquiry .form-container .wpcf7 form.sent .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 {
  margin: var(--sp-30) 0 0;
  padding: 1rem 1.25rem;
  border-radius: 6px;
  font-size: var(--font-14);
  line-height: 1.7;
}

#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;
}

#inquiry .form-container .wpcf7 form.sent .wpcf7-response-output {
  color: #2C2C2C;
  border: 1px solid #D9D9D9;
  background-color: #F8F8F8;
}

/* ----------------------------------
   CF7の自動ラッパーを無害化
---------------------------------- */
#inquiry .form-container .wpcf7-form-control-wrap {
  display: block;
  width: 100%;
}

#inquiry .form-container .wpcf7-form-control-wrap[data-name="mailmagazine"],
#inquiry .form-container .wpcf7-form-control-wrap[data-name="acceptance-privacy"] {
  width: 100%;
}

/* text / email / tel / textarea が横幅100%になるよう補強 */
#inquiry .form-container .wpcf7-form-control-wrap > input[type="text"],
#inquiry .form-container .wpcf7-form-control-wrap > input[type="email"],
#inquiry .form-container .wpcf7-form-control-wrap > input[type="tel"],
#inquiry .form-container .wpcf7-form-control-wrap > textarea {
  width: 100%;
}

/* hidden は表示しない */
#inquiry .form-container input[type="hidden"] {
  display: none;
}

/* ----------------------------------
   入力UI
   ※ 既存style.cssの見た目を前提に微調整
---------------------------------- */
#inquiry .form-container .wpcf7 input[type="text"],
#inquiry .form-container .wpcf7 input[type="email"],
#inquiry .form-container .wpcf7 input[type="tel"],
#inquiry .form-container .wpcf7 textarea {
  width: 100%;
  min-width: 0;
}

#inquiry .form-container .wpcf7 textarea {
  resize: vertical;
  min-height: 14rem;
}

/* placeholder */
#inquiry .form-container .wpcf7 input::placeholder,
#inquiry .form-container .wpcf7 textarea::placeholder {
  color: #d9d9d9;
  opacity: 1;
}

/* focus */
#inquiry .form-container .wpcf7 input:focus,
#inquiry .form-container .wpcf7 textarea:focus {
  outline: none;
}

/* error時 */
#inquiry .form-container .wpcf7 input.wpcf7-not-valid,
#inquiry .form-container .wpcf7 textarea.wpcf7-not-valid {
  border: 1px solid #D32D26;
  background-color: #FFF8F8;
}

/* 各項目下のエラーメッセージ */
#inquiry .form-container .wpcf7-not-valid-tip {
  display: block;
  margin-top: .5rem;
  font-size: var(--font-12);
  line-height: 1.6;
  color: var(--color-red);
}

/* ----------------------------------
   住所ブロック
---------------------------------- */
#inquiry .form-container .form-group.align-start > div {
  width: 100%;
}

#inquiry .form-container .form-group.align-start .grid {
  grid-template-columns: 1fr 2fr;
  gap: 1rem;
  align-items: center;
  margin-bottom: 1rem;
}

.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);
}

#inquiry .form-container .form-group.align-start .grid:last-child {
  margin-bottom: 0;
}

#inquiry .form-container .form-group.align-start .grid label {
  margin-bottom: 0;
}

/* ----------------------------------
   チェックボックス（メールマガジン）
---------------------------------- */
#inquiry .form-container .checkbox-group .wpcf7-checkbox {
  display: block;
}

#inquiry .form-container .checkbox-group .wpcf7-list-item {
  display: block;
  margin: 0;
}

#inquiry .form-container .checkbox-group .wpcf7-list-item label {
  display: flex;
  align-items: flex-start;
  gap: .5rem;
  margin-left: 0;
  margin-right: 0;
  color: #2C2C2C;
}

#inquiry .form-container .checkbox-group .wpcf7-list-item input[type="checkbox"] {
  margin-top: .28rem;
  flex: 0 0 auto;
}

#inquiry .form-container .checkbox-group .wpcf7-list-item-label {
  display: block;
  color: #2C2C2C;
  font-size: var(--font-16);
  line-height: 1.8;
}

/* ----------------------------------
   同意チェック（プライバシー）
---------------------------------- */
#inquiry .form-container .policy-group .wpcf7-acceptance {
  display: block;
}

#inquiry .form-container .policy-group .wpcf7-list-item {
  display: block;
  margin: 0;
}

#inquiry .form-container .policy-group .wpcf7-list-item label {
  display: flex;
  align-items: flex-start;
  gap: .625rem;
  cursor: pointer;
  line-height: 1.4;
      margin-right: 10px;
}

#inquiry .form-container .policy-group .wpcf7-list-item input[type="checkbox"] {
  margin-top: 0.45rem;
  flex: 0 0 auto;
}

#inquiry .form-container .policy-group .wpcf7-list-item-label {
    background: none;
    width: auto;
	color: #2C2C2C;
}

/* acceptance のエラーメッセージ位置 */
#inquiry .form-container .policy-group .wpcf7-not-valid-tip {
  text-align: center;
  margin-top: .75rem;
}

/* ----------------------------------
   送信ボタン
---------------------------------- */
#inquiry .form-container .btn-container {
  position: relative;
}

#inquiry .form-container .wpcf7-submit.btn.btn-arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 320px;
  height: 60px;
  line-height: 1;
  text-align: center;
  border-radius: 40px;
  color: #fff !important;
  background: var(--bg-grade-red);
  border: 1px solid #fff;
  position: relative;
  overflow: hidden;
  padding: 0 53px 0 0;
  z-index: 1;
}

#inquiry .form-container .wpcf7-submit.btn.btn-arrow::before {
  content: "";
  width: 53px;
  height: 60px;
  background-color: var(--color-pink);
  position: absolute;
  right: 0;
  top: 0;
  transition: all .5s;
}

#inquiry .form-container .wpcf7-submit.btn.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;
  top: 50%;
  transform: translateY(-50%);
}

#inquiry .form-container .wpcf7-submit.btn.btn-arrow:hover::before {
  width: 100%;
}

#inquiry .form-container .wpcf7-submit.btn.btn-arrow:hover {
  color: #fff !important;
}

#inquiry .form-container .wpcf7-submit.btn.btn-arrow:disabled {
  opacity: .6;
  cursor: not-allowed;
}

#inquiry .form-container .wpcf7-spinner {
  display: inline-block;
  vertical-align: middle;
  margin: 0 0 0 .75rem;
  display: none;
}

/* ----------------------------------
   戻るリンクや説明文との余白調整
---------------------------------- */
#inquiry .form-container + .wpcf7-response-output {
  margin-top: var(--sp-20);
}

/* =========================================
   CF7 submit button wrapper
========================================= */

#inquiry .btn-submit-wrap {
  width: 320px;
  height: 60px;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  overflow: hidden;
}

/* 元のbtnデザインを活かす */
#inquiry .btn-submit-wrap.btn.btn-arrow {
  padding: 0;
}

/* テキスト */
#inquiry .btn-submit-wrap span {
  position: relative;
  z-index: 2;
  width: calc(100% - 53px);
  text-align: center;
  color: #fff;
}

/* 実際のsubmit（透明で上に被せる） */
#inquiry .btn-submit-wrap .btn-submit {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  cursor: pointer;
  z-index: 3;
}

/* 右の赤いバー */
#inquiry .btn-submit-wrap::before {
  content: "";
  width: 53px;
  height: 100%;
  background-color: var(--color-pink);
  position: absolute;
  right: 0;
  top: 0;
  transition: all .5s;
  z-index: 1;
}

/* 矢印 */
#inquiry .btn-submit-wrap::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;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
}

/* hover */
#inquiry .btn-submit-wrap:hover::before {
  width: 100%;
}

/* disabled時 */
#inquiry .btn-submit-wrap .btn-submit:disabled {
  cursor: not-allowed;
}

#inquiry .btn-submit-wrap .btn-submit:disabled + span,
#inquiry .btn-submit-wrap .btn-submit:disabled ~ span {
  opacity: 0;
  display: none;
}

input.wpcf7-form-control.wpcf7-submit.has-spinner.btn-submit {
    color: transparent;
}

span.wpcf7-spinner {
    position: absolute;
}

#inquiry .form-container .policy-group span.wpcf7-form-control-wrap span.wpcf7-form-control.wpcf7-acceptance {
    max-width: 28rem;
    width: 100%;
}

#inquiry .form-container .policy-group .wpcf7-list-item-label a.color-red {
	    color: var(--color-pink);
}

/* ----------------------------------
   SP
---------------------------------- */
@media (max-width: 768px) {
  #inquiry .form-container {
    margin-top: var(--sp-40);
  }

  #inquiry .form-container .form-group.align-start .grid {
    grid-template-columns: 1fr;
    gap: .5rem;
  }

  #inquiry .form-container .checkbox-group .wpcf7-list-item-label,
  #inquiry .form-container .policy-group .wpcf7-list-item-label {
    font-size: var(--font-14);
	line-height: 1.4;
        text-align: left;
  }

  #inquiry .form-container .policy-group .wpcf7-list-item input[type="checkbox"] {
    margin-top: 1rem;
}

#inquiry .form-container .policy-group span.wpcf7-form-control-wrap span.wpcf7-form-control.wpcf7-acceptance {
    max-width: 17rem;
}

  #inquiry .form-container .wpcf7-submit.btn.btn-arrow {
    width: 100%;
    max-width: 320px;
  }

  #inquiry .form-container .wpcf7-spinner {
    display: block;
    margin: .75rem auto 0;
  }
}


#inquiry .form-container .checkbox-group span.wpcf7-list-item-label {
    display: contents;
}

#inquiry .form-container .checkbox-group .wpcf7-list-item input[type="checkbox"] {
    margin-top: 0.5rem;
}

#inquiry .checkbox-group div span.wpcf7-form-control-wrap {
    display: contents;
}

#inquiry .checkbox-group div span.wpcf7-form-control-wrap label span.wpcf7-list-item-label {
    display: none;
}

#inquiry .form-container .policy-group span.wpcf7-form-control-wrap {
    display: flex;
    justify-content: center;
    align-items: center;
}



/* ==========================================================================
	6. プライバシーポリシー / Privacy
========================================================================== */
#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. 利用規約 / Agreement
========================================================================== */
#agreement .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;
}

#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: #fff;
  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-link {
  display: flex;
  flex-wrap: wrap;
  gap: clamp(2rem, 4.2vw, 2.8125rem); /* 45px */
  font-weight: 500;
}

.btn-search--footer{
  background: linear-gradient(-64deg, rgba(0, 23, 87, 255) 0%, rgba(97, 133, 234, 255) 100%) !important;
}
.btn-search--footer.btn-arrow span,
.btn-contact--footer.btn-arrow span,
.btn-global--footer.btn-arrow span{
  position: relative;
  display: flex;
  align-items: center;
  padding-left: 50px;
}
.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: 5px;
}
.btn-search--footer span::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-search--footer.btn-arrow::before{
  background-color: #3B57A2 !important;
}
.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-global--footer span::before{
  content: "";
  width: 20px;
  height: 16px;
  background: var(--color-red);
  mask-image: url(public/images/en/common/ico_global.svg);
  mask-size: contain;
  mask-repeat: no-repeat;
  -webkit-mask-image: url(public/images/en/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-copyright{

}
.footer-copyright small{
  font-family: var(--font-en);
  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-en);
  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: 768px) {
  .footer-logo{
    text-align: center;
  }
  .footer-link {
    justify-content: center;
    padding: 0 1rem;
  }
  .footer-bottom{
    margin-top: 2rem;
    text-align: center;
  }
  .footer-container .box-center--sp{
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-top: 0 !important;
  }
  .footer-copyright{
    text-align: center;
  }
}
/* ==========================================================================
	スマートフォン向け調整 (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;
}

/* --- スマホ版のスタイル --- */
@media (max-width: 1080px) {
  .hamburger {
    display: block;
    margin-left: auto;
  }
}


/* ==========================================================================
	検索画面 / cosmetics
========================================================================== */
.post-type-archive-cosmetics main{
  background-color: #F9F9F9;
}
.cosmetics-archive-pagehead,
.cosmetics-search__module,
.cosmetics-archive-main,
.cosmetics-archive-list{
  width: 96%;
  max-width: 1180px;
  margin: var(--sp-120) auto 0;
  position: relative;
  line-height: 1.6;
  letter-spacing: .5px;
  text-align: center;
}
.cosmetics-archive-pagehead__title,
.cosmetics-search__module h2 {
  font-size: var(--font-24);
  font-weight: 500;
  color: var(--color-red);
  margin-bottom: var(--sp-20);
}

.food-archive-pagehead__flex {
    display: flex;
    align-items: center;
    gap: 1rem;
    justify-content: center;
    background: #ffffff;
    max-width: 34rem;
    margin: 0 auto;
    margin-top: 2rem;
    margin-bottom: 4rem;
	    padding: 1rem;
}

.food-archive-pagehead__flex figure {
    margin: 0;
    min-width: 5rem;
}

/* キーワード検索 */
.cosmetics-search__keyword{
  width: 96%;
  max-width: 880px;
  margin: var(--sp-40) auto;
  display: flex;
  gap: 1rem;
  align-items: center;
  justify-content: stretch;
  line-height: 1.6;
  letter-spacing: .5px;
  position: relative;
}
@media (max-width: 768px) {
  .cosmetics-search__keyword{
    flex-direction: column;
  }
}
.cosmetics-search__keyword input{
  flex: 1;
  display: flex;
  position: relative;
  border-radius: 30px;
  border: 1px solid var(--color-red) !important;
  background-color: #fff;
  overflow: hidden;
}
.cosmetics-search__keyword button {
  width: 24px;
  height: 24px;
  border: none;
  cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%23840E08' stroke-width='2.5'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M21 21l-6-6m2-5a7 7 0 11-14 0 7 7 0 0114 0z' /%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 20px;
  background-color: #fff;
  text-indent: -9999px;
  position: absolute;
  right: 1rem;
  bottom: .7rem;
}

/* 製品検索 */
.cosmetics-search__module{
  background-color: #fff;
  border-radius: 10px;
  border: 1px solid var(--color-red);
  margin-top: var(--sp-30);
  padding: var(--sp-50);
}
@media (max-width: 768px) {
  .cosmetics-search__module{
    padding: 1rem;
  }
}
.cosmetics-search__module h2 {
  font-size: var(--font-18);
}
.cosmetics-search__accordion{
  background-color: #f9f9f9;
  border-radius: 10px;
  border: 1px solid var(--color-red);
  margin-top: var(--sp-30);
  padding: var(--sp-20) var(--sp-30);
}
@media (max-width: 768px) {
  .cosmetics-search__accordion{
    padding: 1rem;
  }
}
.cosmetics-search__toggle{
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-right: 2rem;
  position: relative;
  &:after{
    content: '';
    width: 8px;
    height: 8px;
    border: 0;
    border-top: solid 2px var(--color-red);
    border-right: solid 2px var(--color-red);
    transform: rotate(135deg);
    position: absolute;
    top: 8px;
    right: 5px;
    margin: auto;
    transition: all .3s;
  }
}
.cosmetics-search__accordion.is-open .cosmetics-search__toggle{
  &:after{
    transform: rotate(-45deg);
  }
}
.cosmetics-search__toggle-label{
  font-size: var(--font-18);
  color: var(--color-red);
}
.cosmetics-search__toggle-count{
  color: #B4B4B4;
  font-size: var(--font-12);
}
.cosmetics-search__panel{
  border-top: 1px solid var(--color-red);
  padding-top: 25px;
  margin-top: 1rem;
}
.cosmetics-search__panel h3{
  font-size: var(--font-14);
  text-align: left;
  margin-bottom: .5rem;
}
.cosmetics-search__checks{
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  font-size: var(--font-16);
  margin-bottom: 1rem;
}
.cosmetics-search__checks label{
  display: flex;
  gap: .5rem;
  align-items: center;
}
.cosmetics-search__footer{
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 1.5rem;
}
@media (max-width: 960px) {
  .cosmetics-search__footer{
    display: flex;
    flex-direction: column;
  }
}
.cosmetics-search__conditions,
.cosmetics-archive-active-conditions{
  display: grid;
  grid-template-columns: 4.6rem 1fr;
  font-size: var(--font-14);
}
@media (max-width: 768px) {
  /* .cosmetics-search__conditions{
    grid-template-columns: 1fr;
  } */
  .cosmetics-search__conditions p{
    margin-bottom: .5rem;
  }
}
.cosmetics-search__chips,
.cosmetics-archive-active-conditions__chips,
.cosmetics-card__selected{
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: .5rem;
  margin-top: .2rem;
  margin-right: 1rem;
}
.cosmetics-search__chips button,
.cosmetics-archive-active-conditions__chips button,
.cosmetics-card__selected button{
  font-size: var(--font-12);
  color: #818181;
  background-color: #E5E5E5;
  border-radius: 20px;
  padding: 0 1rem;
}
.cosmetics-search__chips button span,
.cosmetics-archive-active-conditions__chips button span,
.cosmetics-card__selected button span{
  margin: 0 .1rem;
}

.cosmetics-search__actions{
  display: flex;
  gap: 1rem;
  align-items: center;
}
@media (max-width: 960px) {
  .cosmetics-search__actions{
    margin-top: 1rem;
  }
}
@media (max-width: 768px) {
  .cosmetics-search__actions{
    width: 100%;
  }
}
.cosmetics-search__clear{
  width: 200px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: .5rem;
  background-color: #F0F0F0;
  border: 1px solid #F0F0F0;
  font-size: var(--font-14);
  color: #747474;
  padding: 1rem 0;
  border-radius: 30px;
  position: relative;
  &:after{
    content: "";
    display: block;
    box-sizing: border-box;
    width: 5px;
    height: 5px;
    border: 5px solid transparent;
    border-left: 5px solid #747474;
    position: relative;
  }
  &:hover{
    color: #747474;
    background-color: #fff;
    border: 1px solid #747474;
  }
}
.cosmetics-search__submit{
  width: 250px;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: var(--color-red);
  border: 1px solid var(--color-red);
  font-size: var(--font-16);
  color: #fff;
  padding: 1rem 0;
  border-radius: 30px;
  position: relative;
  transition: all .5s;
  &:after{
    content: "";
    display: block;
    box-sizing: border-box;
    width: 5px;
    height: 5px;
    border: 5px solid transparent;
    border-left: 5px solid #fff;
    position: absolute;
    right: 20px;
    transition: all .5s;
  }
  &:hover{
    background-color: #fff;
    color: var(--color-red);
    &:after{
      border-left: 5px solid var(--color-red);
    }
  }
}
@media (max-width: 768px) {
  .cosmetics-search__clear,
  .cosmetics-search__submit{
    width: 50%;
  }
}

/* 検索結果 */
.cosmetics-archive-main{
  margin-top: var(--sp-30);
}
.cosmetics-archive-toolbar{
  display: flex;
  justify-content: space-between;
  align-items: center;
}
@media (max-width: 489px) {
  .cosmetics-archive-toolbar{
    flex-direction: column;
    align-items: center;
  }
  .cosmetics-archive-toolbar__count{
    margin-bottom: .5rem;
  }
}
.cosmetics-archive-toolbar__count{
  font-size: var(--font-14);
}
.cosmetics-archive-toolbar__sort{
  font-size: var(--font-14);
}
.cosmetics-archive-toolbar__sort label{
  margin-right: .5rem;
}
.cosmetics-archive-toolbar__sort select{
  border: 1px solid #D5D5D5;
  padding: .5rem 1rem .5rem .5rem;
  font-size: var(--font-14);

  /* デフォルトの矢印を消す */
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;

  /* 背景としてSVGをセット */
  background-image: url('data:image/svg+xml;charset=utf8,<svg xmlns="http://www.w3.org/2000/svg" width="10" height="6.069" viewBox="0 0 10 6.069"><path d="M10.268,123.655l-4.45,4.45a.55.55,0,0,0,0,.777l.519.519a.55.55,0,0,0,.776,0l3.544-3.527L14.2,129.4a.55.55,0,0,0,.776,0l.519-.519a.55.55,0,0,0,0-.777l-4.45-4.45a.55.55,0,0,0-.777,0Z" transform="translate(15.656 129.563) rotate(180)" fill="%23747474"/></svg>');
  background-repeat: no-repeat;
  
  /* --- 矢印の移動・サイズ調整 --- */
  background-size: 10px 6px; /* SVGのサイズに合わせて指定 */
  background-position: calc(100% - 15px) center; /* 右端から15pxの位置 */

  /* 文字と矢印が重ならないように右側に余白を作る */
  padding-right: 35px;

  padding-top: 10px;
  padding-bottom: 10px;
  padding-left: 15px;
  border: 1px solid #ccc;
  border-radius: 4px;
  background-color: #fff;
  cursor: pointer;
}

.cosmetics-archive-toolbar__sort select::-ms-expand {
  display: none;
}

.cosmetics-archive-active-conditions{
  margin-top: .8rem;
  margin-right: 0;
}


/* 検索結果 一覧 */
.cosmetics-archive-list{
  width: 100%;
  background-color: #fff;
  border-radius: 10px;
  margin-top: var(--sp-20);
  padding: var(--sp-60) var(--sp-50);
}
@media (max-width: 768px) {
  .cosmetics-archive-list{
    padding: 2rem 1rem 3rem;
  }
}
.cosmetics-card{
  background-color: #F9F9F9;
  border-radius: 10px;
  margin-bottom: var(--sp-30);
  padding: var(--sp-20);
}
.cosmetics-card__toggle{
  width: 100%;
  display: flex;
  justify-content: space-between;
  padding-right: 2rem;
  position: relative;
  &:after{
    content: '';
    width: 8px;
    height: 8px;
    border: 0;
    border-top: solid 2px var(--color-red);
    border-right: solid 2px var(--color-red);
    transform: rotate(135deg);
    position: absolute;
    top: 8px;
    right: 5px;
    margin: auto;
    transition: all .3s;
  }
}
.cosmetics-card.is-open .cosmetics-card__toggle{
  &:after{
    transform: rotate(-45deg);
  }
}
@media (max-width: 768px) {
  .cosmetics-card__toggle{
    flex-direction: column;
    align-items: flex-start;
  }
  .cosmetics-card__selected{
    margin-top: .5rem;
  }
}
.cosmetics-card__icon{ display: none;}
.cosmetics-card__title {
  color: var(--color-red);
  font-size: var(--font-18);
}
.cosmetics-card__body{
  background-color: #fff;
  border-radius: 6px;
  margin-right: var(--sp-40);
  margin-top: var(--sp-20);
  padding: var(--sp-20);
  text-align: left;
  font-size: var(--font-16);
  position: relative;
  width: 100%;
}
@media (max-width: 768px) {
  .cosmetics-card__body{
    margin-right: 0;
    padding: 1rem;
  }
}
.cosmetics-card__en{
  font-size: var(--font-16);
  margin-bottom: .5rem;
  font-weight: 500;
}
.cosmetics-card__inci{
  color: #747474;
  margin-top: .5rem;
}
.cosmetics-card__actions{
  display: flex;
  justify-content: flex-end;
}
.cosmetics-card__checks{
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .8rem;
  border: 1px solid var(--color-red);
  background-color: #fff;
  border-radius: 30px;
  padding: var(--sp-10) var(--sp-30);
  margin-top: 1rem;
  font-size: var(--font-12);
  width: fit-content;
}
@media (max-width: 768px) {
  .cosmetics-card__checks{
    padding-left: 1rem;
    padding-right: 1rem;
  }
}
@media (max-width: 443px) {
  .cosmetics-card__checks{
    border-radius: 6px;
  }
}
.cosmetics-card__checks label{
  display: flex;
  align-items: center;
  gap: .5rem;
}
.cosmetics-card__checks span{
  font-size: var(--font-14);
}
.cosmetics-card__links a{
  display: flex;
  align-items: center;
  gap: .5rem;
  position: absolute;
  right: var(--sp-20);
  top: 1rem;
  color: var(--color-red);
  font-size: .95rem;
  font-weight: 500;
  &:after{
    content: "";
    display: block;
    box-sizing: border-box;
    width: 4px;
    height: 4px;
    border: 4px solid transparent;
    border-left: 4px solid var(--color-red);
  }
}
.cosmetics-archive-bulk,
.cosmetics-single-bottom__cta{
  width: 320px;
  height: 60px;
  display: flex;
  align-items: center;
  border-radius: 40px;
  font-size: var(--font-16);
  /* font-weight: 500; */
  color: var(--color-white) !important;
  background: var(--bg-grade-red);
  border: 1px solid #fff;
  position: relative;
  z-index: 1;
  overflow: hidden;
  margin: 0 auto;
  cursor: pointer;
  &::before{
    content: "";
    width: 53px;
    height: 60px;
    background-color: var(--color-pink);
    position: absolute;
    right: 0;
    top: 0;
    transition: all .5s;
  }
  &::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;
  }
}

.cosmetics-archive-bulk:hover::before{
  width: 100%;
}
.cosmetics-archive-bulk button {
  position: relative;
  z-index: 10;
  width: calc(100% - 40px);
  text-align: center;
}



/* ==========================================================================
	検索 - 詳細画面 / cosmetics
========================================================================== */
.cosmetics-template-default main{
  background-color: #F9F9F9;
}
.cosmetics-single-pagehead,
.cosmetics-single-main{
  width: 96%;
  max-width: 1180px;
  margin: var(--sp-120) auto 0;
  position: relative;
  line-height: 1.6;
  letter-spacing: .5px;
  text-align: center;
}
.cosmetics-single-pagehead__title {
  font-size: var(--font-24);
  font-weight: 500;
  color: var(--color-red);
  margin-bottom: var(--sp-20);
}

.heading-2.line.cosmetics-single-pagehead__title {
    display: block;
    padding-bottom: .5rem;
    border-bottom: 1px solid #E2E2E2;
}

.cosmetics-single-main{
  background-color: #fff;
  border-radius: 10px;
  padding: var(--sp-60) var(--sp-50);
  text-align: left;
}
@media (max-width: 768px) {
  .cosmetics-single-main{
    padding-left: 1rem;
    padding-right: 1rem;
  }
}
.cosmetics-single-section h2 {
  color: var(--color-red);
  font-size: var(--font-18);
  font-weight: 500;
  border-top: 1px solid #E3E3E3;
  border-bottom: 1px solid #E3E3E3;
  padding: .4rem 0;
  margin-top: var(--sp-50);
  margin-bottom: 2rem;
}

.cosmetics-single-media{
  display: grid;
  grid-template-columns: minmax(250px, 360px) 1fr;
  /* grid-template-columns: 360px 1fr; */
  margin-top: var(--sp-40);
  padding-bottom: 1.5rem;
  position: relative;
  z-index: 10;
}

.cosmetics-single-media.cosmetics-single-media--full {
    display: block;
}

.cosmetics-single-media.cosmetics-single-media--full .cosmetics-single-media__body {
    margin-left: 0;
    padding-left: var(--sp-50);
}

.cosmetics-single-media figure{
  max-width: 360px;
  width: 100%;
  aspect-ratio: 9 / 6;
  border-radius: 10px;
  position: relative;
  z-index: 10;
  overflow: hidden;
}
.cosmetics-single-media img {
    object-fit: cover;
    display: block;
    max-width: 100%;
    height: auto;
    margin: 1rem auto;
	margin-bottom: 2rem;
}

.cosmetics-single-media__text h3,.cosmetics-single-media__text h4 {
    margin-bottom: 1rem;
}

.cosmetics-single-media__text p {
    margin-bottom: 1rem;
}

.cosmetics-single-media__body{
  height: 100%;
  margin-left: -90px;
  margin-top: 1.5rem;
  padding-right: var(--sp-50);
  padding-left: var(--sp-140);
  padding-top: 1.5rem;
  padding-bottom: 1.5rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  border-radius: 10px;
  background-color: #F9F9F9;  
}
.cosmetics-single-media__body h2{
  border-top: none !important;
  border-bottom: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
.cosmetics-single-media__text {
  /* font-size: var(--font-14); */
  margin-top: 15px;
}
.cosmetics-single-media.cosmetics-single-media--reverse{
  grid-template-columns: 1fr 360px;
}
.cosmetics-single-media.cosmetics-single-media--reverse .cosmetics-single-media__body{
  margin-right: -90px;
  margin-left: 0;
  padding-left: var(--sp-50);
  padding-right: var(--sp-140);
}
@media (max-width: 768px) {
  .cosmetics-single-media,
  .cosmetics-single-media.cosmetics-single-media--reverse{
    grid-template-columns: 1fr !important;
  }
  .cosmetics-single-media figure{
    margin-bottom: -8.2rem;
  }
  .cosmetics-single-media__body{
    margin-left: 1.5rem !important;
    padding: var(--sp-130) var(--sp-20) var(--sp-20);
  }
  .cosmetics-single-media.cosmetics-single-media--reverse figure{
    order: 1;
  }
  .cosmetics-single-media.cosmetics-single-media--reverse .cosmetics-single-media__body{
    order: 2;
    margin-right: 0;
    padding: var(--sp-130) var(--sp-20) var(--sp-20);
  }
}

.product-effect-list li{
  list-style-type: disc;
  margin-left: 1rem;
  margin-bottom: .3rem;
  &::marker {
    color: var(--color-red);
  }
}
.cosmetics-single-movie {
  max-width: 640px;
  width: 100%;
  margin: 0 auto;
  text-align: center;
}
.cosmetics-single-movie iframe{
  width: 100%;
}
.cosmetics-single-movie__caption {
  color: var(--color-red);
  font-size: var(--font-14);
}
.product-detail-table table{
  width: 100%;
  border-collapse: separate;
  border-spacing: 2px;
  border-top: 1px solid #E2E2E2;
  font-size: var(--font-16);
}

section.cosmetics-single-section.tbl .product-detail-table table tr:first-of-type{
display: none;
}

th.col-black {
    color: #2C2C2C !important;
}

.product-detail-table table th {
  color: var(--color-red);
  vertical-align: middle;
  text-align: left;
  font-weight: 400;
  padding: 0.9375rem var(--sp-20);
  background-color: var(--color-palepink);
  border-bottom: 1px solid #E2E2E2;
  border-right: 1px solid #fff;
}
.product-detail-table table td {
  width: auto !important;
  padding: 0.9375rem var(--sp-30);
  border-top: 1px solid #fff;
  border-bottom: 1px solid #E2E2E2;
  background-color: #fff;
  text-align: left;
}
@media (max-width: 580px) {
  .product-detail-table table th {
    width: 100% !important;
    border-right: 0;
    border-bottom: 1px solid var(--color-palepink);
  }
  .product-detail-table table td {
        width: 100% !important;
        min-width: 17rem;
        padding: 1rem;
  }
  .product-detail-table table {
    min-width: 30rem;
    overflow: scroll;
}
  .product-detail-table {
    overflow: scroll;
}
.product-detail-table table th.col-black {
    font-weight: 500;
}
}

.cosmetics-single-function__inner{
  display: flex;
  justify-content: space-between;
  align-items: center;
      gap: 1rem;
}
@media (max-width: 768px) {
  .cosmetics-single-function__inner{
    flex-direction: column;
    gap: 1rem;
  }
}
.cosmetics-single-function__btn{
  width: 320px;
  height: 60px;
  display: flex;
  align-items: center;
  border-radius: 40px;
  font-size: var(--font-16);
  /* font-weight: 500; */
  color: var(--color-white) !important;
  background: linear-gradient(-64deg, rgba(0, 23, 87, 255) 0%, rgba(97, 133, 234, 255) 100%);
  border: 1px solid #fff;
  position: relative;
  z-index: 1;
  overflow: hidden;
  cursor: pointer;
  &:before {
    content: "";
    width: 53px;
    height: 60px;
    background-color: #3B57A2;
    position: absolute;
    right: 0;
    top: 0;
    transition: all .5s;
  }
  &: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;
  }
  &:hover::before{
    width: 100%;
  }
}
.cosmetics-single-function__btn a{
  width: calc(100% - 40px);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10;
  &: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;
  }
}

section.cosmetics-single-manufacture.is-full {
    display: block;
}

.cosmetics-single-related__body {
    margin-top: 2rem;
}

.cosmetics-single-bottom__cta-area {
    display: flex;
    justify-content: center;
    margin-top: 5rem;
    gap: 1.5rem;
    flex-wrap: wrap;
}

.cosmetics-single-bottom__cta.--blue {
    background: linear-gradient(-64deg, rgba(0, 23, 87, 255) 0%, rgba(97, 133, 234, 255) 100%) !important;
}

.cosmetics-single-bottom__cta.--blue::before {
    background-color: #3B57A2 !important;
}

.cosmetics-single-bottom__cta-area .cosmetics-single-bottom__cta {
    margin: 0;
}

#inquiry .checkbox-group div {
    gap: 1rem;
}

h3.heading-4.related-heading-title {
    margin-bottom: 0.5rem;
	font-size: var(--font-16);
}

.cosmetics-single-bottom__cta-area.middle-btn .cosmetics-single-bottom__cta,.cosmetics-single-bottom__cta.middle-btn {
    width: 24rem;
    height: 5rem;
}

.cosmetics-single-bottom__cta-area.middle-btn .cosmetics-single-bottom__cta::before ,.cosmetics-single-bottom__cta.middle-btn::before{
    height: 5rem;
}

.cosmetics-single-bottom__cta-area.middle-btn .cosmetics-single-bottom__cta a ,.cosmetics-single-bottom__cta.middle-btn a{
    font-size: 1.125rem;
    font-weight: 500;
	    padding-right: 2.5rem;
}

.cosmetics-single-manufacture{
  display: grid;
  grid-template-columns: 243px 1fr;
  gap: 20px;
}
.cosmetics-single-manufacture__logo {
  padding: 18px 25px;
  border: 1px solid #E3E3E3;
  border-radius: 5px;
}
.cosmetics-single-manufacture__logo img {
  width: 193px;
}
.cosmetics-single-manufacture__body h3{
  font-size: var(--font-18);
  font-weight: 500;
}
.cosmetics-single-manufacture__text{
  margin-top: 10px;
  font-size: var(--font-14);
}
@media (max-width: 768px) {
  .cosmetics-single-manufacture{
    grid-template-columns: 1fr;
  }
  .cosmetics-single-manufacture__logo {
    margin: 0 auto;
  }
}

.cosmetics-single-bottom__note{
  width: 96%;
  max-width: 880px;
  margin: var(--sp-70) auto 0;
  font-size: var(--font-14);
  line-height: 1.6;
  letter-spacing: .5px;
  position: relative;
}
.cosmetics-pagination {
  margin-top: 3rem;
}

.cosmetics-pagination .page-numbers {
  display: flex;
  align-items: center;
  justify-content: center;
flex-wrap: wrap;
    gap: 1.5rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.cosmetics-single-function__inner .cosmetics-single-function__text {
    max-width: 50rem;
}

.cosmetics-pagination .page-numbers li {
  margin: 0;
  padding: 0;
}

.cosmetics-pagination .page-numbers a,
.cosmetics-pagination .page-numbers span {
  display: grid;
  place-items: center;
  min-width: 2.5rem;
  height: 2.5rem;
  color: #4a4a4a;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1;
  text-decoration: none;
}

/* 現在ページ */
.cosmetics-pagination .page-numbers .current {
  width: 2.5rem;
  min-width: 2.5rem;
  height: 2.5rem;
  color: #fff;
  background: #D32D26;
  border-radius: 50%;
}



/* 次へ・前へ */
.cosmetics-pagination .page-numbers .next,
.cosmetics-pagination .page-numbers .prev {
  position: relative;
  width: 2.5rem;
  min-width: 2.5rem;
  height: 2.5rem;
  overflow: hidden;
  color: transparent;
  font-size: 0;
}

/* 矢印本体 */
.cosmetics-pagination .page-numbers .next::before,
.cosmetics-pagination .page-numbers .prev::before {
  content: "";
  position: absolute;
  top: 50%;
  width: 0.6rem;
  height: 0.6rem;
  border-top: 0.1rem solid #D32D26;
  border-right: 0.1rem solid #D32D26;
}

/* next > */
.cosmetics-pagination .page-numbers .next::before {
  left: 50%;
  transform: translate(-60%, -50%) rotate(45deg);
}

/* prev < */
.cosmetics-pagination .page-numbers .prev::before {
  left: 50%;
  transform: translate(-40%, -50%) rotate(-135deg);
}

/* ホバー */
.cosmetics-pagination .page-numbers a:not(.next):not(.prev):hover {
  color: #840E08;
}

.cosmetics-pagination .page-numbers .next:hover::before,
.cosmetics-pagination .page-numbers .prev:hover::before {
  border-color: #840E08;
}
.cosmetics-single-bottom__cta{
  margin-top: var(--sp-70);
  cursor: pointer;
  &:hover::before{
    width: 100%;
  }
}
.cosmetics-single-bottom__cta a{
  width: 100%;
  padding-right: 53px;
  color: #fff;
  display: flex;
  justify-content: center;
  z-index: 10;
}





#news .news-tags-list li.current a ,#news .news-tags-list li:hover a{
    color: #ffffff;
}




.cosmetics-card.is-open .cosmetics-card__title {
  text-decoration: underline;
  margin-right: 1rem;
}
.cosmetics-card.is-open .cosmetics-card__title:hover{
	text-decoration: none;
}

.cosmetics-search__panel[hidden] {

  display: none !important;

}

.cosmetics-card__toggle-button {
    margin-left: auto;
    padding: 0;
    border: 0;
    background: none;
    cursor: pointer;
    margin-left: auto;
    position: relative;
    left: 2rem;
    width: 1.5rem;
	    z-index: 9;
}









 /* ポップアップ本体のスタイル */
    dialog {
      border: none;
      border-radius: 20px;
      padding: 70px 100px;
      width: 90%;
      max-width: 880px;
      text-align: center;
      margin: auto auto;
    }
    @media (max-width: 880px) {
      dialog {
        padding: 10% 5%;
      }
    }
    /* 背景のグレーアウト */
    dialog::backdrop {
      background: rgba(0, 0, 0, 0.6);
      backdrop-filter: blur(4px); /* 背景を少しぼかす（おしゃれになります） */
    }
    dialog .flex{
      max-width: 420px;
      margin: auto auto;
      justify-content: center;
    }
    @media (max-width: 768px) {
    dialog .flex{
        flex-direction: row !important;
      }
    }
    /* 説明文 */
    dialog p {
      color: #2C2C2C;
      font-size: 1rem;
      line-height: 1.6;
    }
    .btn-no{
      filter: grayscale(1);
      opacity: .6;
    }