@charset "utf-8";
/* CSS Document */
/*共通　-----------------------------*/
#dcms_layoutPageBlock {
  font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-optical-sizing: auto;
  color: #2d2d2d;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.6;
  background-color: #fff;
  letter-spacing: 0.08em;
}
#dcms_layoutPageBlock img {
  width: 100%;
  height: auto;
  max-width: 100%;
  aspect-ratio: auto;
}
#dcms_layoutPageBlock a {
  color: #2d2d2d !important;
}
#dcms_layoutPageBlock h1, #dcms_layoutPageBlock h2, #dcms_layoutPageBlock h3 {
  margin: 0;
}
#dcms_layoutPageBlock ul {
  list-style: none;
}
.u-visually-hidden {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  margin: -1px !important;
  padding: 0 !important;
  overflow: hidden !important;
  clip: rect(0 0 0 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}
section {
  width: 100%;
  padding: 0;
  margin: 0px;
  position: relative;
}
section:not(:last-child) {
  margin-bottom: 100px;
}
ruby rt {
  text-align: center;
  width: auto;
  min-width: 0;
}
.fw700 {
  font-weight: 700;
}
.fw900 {
  font-weight: 900;
}
.sp_only {
  display: none;
}
@media only screen and (max-width: 1000px) {
  section:not(:last-child) {
    margin-bottom: 60px;
  }
  .sp_only {
    display: block;
  }
}
/*---------------------------------------------

main

-----------------------------------------------*/
#sa-main {
  background-image: url("../image/sa_main-bg.jpg");
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  padding-top: 100px !important;
}

.sa-fv_inner {
  max-width: 1240px;
	width: 100%;
	margin: 0 auto;
	align-items:center;
  box-sizing: border-box;
  padding: 70px 20px;
}
/*h1*/
.sa-fv_title {
  width: 100%;
}
.sa-fv_title img {
  width: 100%;
  height: auto;
}
@media only screen and (max-width: 1150px) {
	#sa-main {padding-top: 60px !important;}
}
@media (max-width: 800px) {
  .sa-fv_inner {
	   padding: 50px 20px;
  }
  .sa-fv_title {
    text-align: center;
  }
}


/*------------------------

h2

---------------------------*/
.section_title {
  position: relative;
  padding-left: 60px;
  margin-bottom: clamp(28px, 9vw, 70px) !important;
  font-size: clamp(1.8rem, 0.0222rem + 3.7037vw, 2.8rem);
  letter-spacing: 0.17em;
  font-optical-sizing: auto;
  font-weight: 900;
}
.section_title::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  width: 30px;
  height: 3px;
  background-color: #000000;
  transform: translateY(-50%);
}
.section_title span {
  padding-right: 0.5em;
  letter-spacing: 0.52em;
	font-size: 2.8rem;
}
.sa_inner {
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0px 40px;
}
@media only screen and (max-width: 1900px) {
  .sa_inner {
    width: 100%;
  }
}
@media only screen and (max-width: 1200px) {
	.sa_inner {
  max-width: 1260px;
  padding: 0px 30px;
}
  .section_title {
    padding-left: 40px;
    line-height: 1.2;
  }
}
@media (max-width: 768px) {
	.section_title span{
		display: block;
	}
}
@media only screen and (max-width: 480px) {
  .section_title span {
    display: block;
  }
}

/*---------------------------------------------

lineup

-----------------------------------------------*/
.lineup-group {
  display: flex;
  width: 100%;
  gap: 60px;
  align-items: stretch;
}
.semiwhite {
  margin-bottom: clamp(60px, 10vw, 100px);
}
.lineup-title {
  width: clamp(240px, 26.7vw, 320px);
  margin-right: 30px;
}
.lineup-title img {
  width: 260px !important;
  height: auto !important;
}
.lineup-item {
  width: calc((100% - clamp(240px, 26.7vw, 320px)) / 3);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  text-align: center;
}
.lineup-item__body {
  text-align: left;
  margin: 30px 0px 10px;
}
.lineup-item__name {
  margin-bottom: 10px;
}
.lineup-item__name span {
  display: block;
}
a .lineup-item__name {
  text-decoration: underline;
}
a:hover .lineup-item__name {
  text-decoration: none;
}
.lineup-item__button {
  background-color: #333e48;
  color: #fff;
  border-radius: 30px;
  display: block;
  text-align: center;
  padding: 10px 0px;
}
.lineup-item__button:hover {
  background-color: #ff9900;
  color: #fff !important;
}
.lineup-item__button span {
  position: relative;
  font-size: 1.4rem !important;
  line-height: 1.4;
  color: #fff;
  display: inline-block;
  margin-right: 22px;
}
.lineup-item__button span br {
  display: none;
}
.lineup-item__button span:after {
  content: '';
  position: absolute;
  width: 12px;
  height: 12px;
  background-image: url("../image/sa_link_icon_white.png");
  background-size: 12px auto;
  background-position: center;
  background-repeat: no-repeat;
  top: calc(50% - 6px);
  right: -22px;
  transition: all .5s;
}
@media (max-width: 1200px) and (min-width: 769px) {
  .lineup-item__button span br {}
}
@media (max-width: 960px) {
  .lineup-group {
    display: flex;
    flex-wrap: wrap;
    column-gap: 20px;
  }
  .lineup-title {
    flex: 0 0 100%;
    text-align: center;
  }
  .lineup-title img {
    width: 60% !important;
    height: auto;
    display: inline-block;
  }
  .lineup-item {
    flex: 0 0 calc(50% - 10px);
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    text-align: center;
    margin-bottom: 20px;
  }
  .lineup-item:last-child {
    margin-bottom: 0px !important;
  }
  .lineup-item__body {
    margin: 30px 0px 10px;
  }
  .lineup-item__button {
    font-size: 1.4rem;
  }
}
/*---------------------------------------------

recommend

-----------------------------------------------*/
.reco_list li {
  display: flex;
  align-items: center;
  gap: 150px;
  margin-bottom: clamp(50px, 30px + 4.17vw, 80px);
}
.reco_list li:last-child {
  margin-bottom: 0;
}
.reco_image {
  width: 480px;
  border-radius: 15px;
  display: flex;
  overflow: hidden;
  position: relative;
}
.reco_image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block !important;
}
.reco_body {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.reco_body .midashi_txt {
  font-size: 2rem;
  margin-bottom: 20px;
}
.sub_txt {
  position: relative;
  padding-right: 70px;
}
.reco_list li:nth-child(odd) .reco_image {
  order: 2;
}
.reco_list li:nth-child(odd) .reco_body {
  order: 1;
  text-align: left;
}
@media (max-width: 1200px) and (min-width: 801px) {
  .reco_list li {
    margin-bottom: 60px;
    gap: clamp(50px, -201.504px + 25.13vw, 100px);
  }
  .reco_image {
    width: clamp(400px, 119.104px + 30.08vw, 480px);
  }
}
@media (max-width: 800px) {
  .reco_list li {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }
  .sub_txt {
    padding-right: 0px;
  }
  .reco_image {
    width: 100%;
    margin-bottom: 10px;
  }
  .reco_list li:nth-child(odd) .reco_image {
    order: 1;
  }
  .reco_list li:nth-child(odd) .reco_body {
    order: 2;
    text-align: left;
  }
}
/*---------------------------------------------

banner

-----------------------------------------------*/
.banner-list {
  display: flex;
  align-items: center;
  gap: 20px;
  margin-bottom: clamp(20px, 13.328px + 1.39vw, 30px);
  justify-content: center;
}
.banner-list li {
  width: calc(100% - 20px)/2;
  max-width: 590px;
}
.banner-list li a {
  padding: 0 !important;
}
.banner-list li a img {
  display: block;
}
#banner p {
  text-align: center;
  font-size: 1.2rem;
}
@media (max-width: 768px) {
  .banner-list {
    flex-direction: column;
    align-items: center;
    gap: 20px;
  }
  .banner-list li {
    width: 100%;
    max-width: none;
  }
  #banner p {
    text-align: left;
  }
}
/*-------------------------------------------

他おすすめ商品　RECOMMEND

--------------------------------------------*/
#other_recommend {
  background-color: #efefef;
  padding: 60px 0px;
}
#other_recommend .section_title {
  margin-bottom: 30px !important;
}
.other_slider_wrap {
  width: 100%;
  margin: 0 auto;
  padding: 0 40px; /* ← 矢印分の余白 */
  position: relative;
  box-sizing: border-box;
}
.other_slider_mask {
  margin: 0 auto;
  overflow: hidden;
}
/* ===== 横に流れる本体 ===== */
.other_recommend_list {
  width: 100% !important;
  display: flex;
	flex-wrap: nowrap !important;
  gap: 0px;
  padding: 0;
  margin: 0;
  align-items: stretch;
  will-change: transform;
  transition: transform 0.4s ease;
}
/* ===== 各カード（常に3つで割る） ===== */
.other_recommend_list li {
  list-style: none;
  flex: 0 0 auto;
  box-sizing: border-box;
  background-color: #fff;
  display: flex;
  flex-direction: column;
  padding: 30px;
  position: relative;
	margin-right: 20px;
}
.other_recommend_list li:last-child {
  margin-right: 0;
}
.other_recommend_new {
  color: #fff;
  background-color: #333e48;
  width: 75px;
  text-align: center;
  font-size: 1.2rem;
  line-height: 30px;
}

/* ===== 矢印 ===== */
.other_arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  border: none;
  width: 20px;
  height: 20px;
  cursor: pointer;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  background: transparent;
	z-index: 0;
}
.other_arrow::before {
  content: "";
  display: block;
  width: 15px;
  height: 15px;
  border-top: 2px solid #333;
  border-right: 2px solid #333;
}
.other_prev {
  left: -20px;
  transform: translate(0%, -50%);
}
.other_prev::before {
  transform: rotate(-135deg);
}
.other_next {
  right: -20px;
  transform: translate(0%, -50%);
}
.other_next::before {
  transform: rotate(45deg);
}
.other_reco-type {
  position: relative;
  padding-left: 30px;
}
.other_reco-type::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  width: 20px;
  height: 2px;
  background-color: #000000;
}
.other_reco--image {
 margin: 12px 40px;
}
.other_reco-name {
  margin-bottom: 50px !important;
  font-size: 2.2rem;
	line-height: 1.3;
	height: 3.5em;

}
.other_reco--body {
  flex: 1;
  display: flex;
  flex-direction: column;
  height: 100%;
}
.other_reco--text {
  margin-bottom: 20px;
}
.other_reco-more {
  position: relative;
  display: inline-block;
  align-items: center;
  border: 1px solid #000;
  text-align: center;
  margin-top: auto;
  align-self: flex-end;
  width: 110px;
  font-size: 1.3rem;
  line-height: 1;
  padding: 5px 0;
  align-items: center;
}
.other_reco-more span {
  display: inline-block;
  transform: translateY(-1px);
}
/* 矢印本体 */
.other_reco-more::after {
  content: "";
  position: absolute;
  right: 10px;
  top: 50%;
  width: 6px;
  height: 6px;
  border-top: 2px solid currentColor;
  border-right: 2px solid currentColor;
  transform: translateY(-50%) rotate(45deg);
}
 a:hover .other_reco-more {
  background-color: #efefef;
}
.other_arrow.is-disabled {
  opacity: 0.2;           /* 薄くする */
  pointer-events: none;   /* クリック無効 */
  cursor: default;
}
@media screen and (max-width: 1900px) {
  .other_slider_wrap {
    padding: 0px;
  }
  .other_slider_mask {
    width: 100%;
  }
}
@media screen and (max-width: 1000px) {
	.other_recommend_list li {
		padding: 15px;
	}
}
.other_recommend_list li {
  border: 1px solid transparent; /* ← 最初から枠を持たせる */
  box-sizing: border-box;
  transition: border-color 0.3s ease;
}
.other_recommend_list li > a {
  display: flex;
  flex-direction: column;
  height: 100%;
  text-decoration: none; /* 任意 */
}
.other_recommend_list li:has(> a:hover) {
  border-color: #666; /* 色だけ変える */
}
/*スワイプ用*/
.other_recommend_list {
  touch-action: pan-y;
}
/*---------------------------------------------

other_series

-----------------------------------------------*/
.other_series-title {
  position: relative;
  padding-left: 60px;
  margin-bottom: 30px !important;
  font-size: 1.8rem;
  letter-spacing: 0.17em; /* VA170 */
  font-optical-sizing: auto;
}
.other_series-title::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  width: 30px;
  height: 3px;
  background-color: #000000;
  transform: translateY(-50%);
}
.other_series-title span {
  padding-right: 0.5em;
  font-size: clamp(1.7rem, 0.4556rem + 2.5926vw, 2.4rem);
  letter-spacing: 0.52em; /* VA520 */
  font-optical-sizing: auto;
font-weight: 900;
}
.other_series-list {
  display: flex;
  width: 100%;
  gap: 20px;
  align-items: stretch;
  margin-bottom: clamp(25px, 9vw, 60px) !important;
}
.other_series-card {
  flex: 0 0 calc((100% - 40px) / 3);
  display: flex;
  border: 1px solid #000;
  overflow: hidden;
}
.other_series-card:hover {
  opacity: 0.6;
}
.other_series-content {
  background-color: #252e40;
  color: #fff;
  padding: 20px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  flex: 1;
}
.other_series-text{
	font-size: clamp(1.2rem, 0.4889rem + 1.4815vw, 1.6rem);
	font-weight: normal;
	letter-spacing: 0.17em;
	line-height: 1.2;
}
.other_series-text span {
  display: block;
  margin-bottom: 5px;
  font-size: clamp(1.4rem, 0.8667rem + 1.1111vw, 1.7rem);
	font-weight: 700;
	height: 2.5em;
	font-weight: 700;
}
.other_series-card-image {
  flex: 0 0 35%;
  max-width: 35%;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}
.other_series-card-image img {
  max-width: 100%;
  max-height: 100%;
  padding: 10px 15px;
}

@media (max-width: 1199px) and (min-width: 769px) {
  .other_series-title {
    padding-left: 40px;
  }
  #other_series .section_title span {
    display: block;
  }
  .other_series-list {
    flex-wrap: wrap;
  }
  .other_series-card {
    flex: 0 0 calc((100% - 20px) / 2);
    margin-bottom: 20px;
  }
}
@media (max-width: 768px) {
  .other_series-title {
    padding-left: 2em;
  }
  .other_series-title::before {
    width: 1.6em;
  }
  #other_series .section_title span {
    display: block;
  }
  .other_series-group:not(:first-of-type) .other_series-title span {
    display: block;
  }
  .other_series-list {
    flex-direction: column;
    gap: 20px;
  }
  .other_series-card {
    flex: 0 0 100%;
    margin-bottom: 0;
  }
}
/*---------------------------------------------

sa_sns

-----------------------------------------------*/
#sa_sns {
  background-color: #efefef;
  padding: clamp(50px, 30px + 4.17vw, 80px) 0px;
}
#sa_sns .section_title {
  font-size: clamp(1.4rem, 0.333rem + 3.56vw, 3rem);
  margin-bottom: clamp(30px, 16.672px + 2.78vw, 50px) !important;
  line-height: 1;
}
#sa_sns .section_title span {
  font-size: clamp(2rem, 0.022rem + 3.7vw, 3rem);
  display: inline-block;
}
.sa_sns-list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  list-style: none;
  gap: 10px;
}
.sa_sns-list li {
  width: 60px;
  height: 60px;
}
.sa_sns-list a {
  display: flex; /* 中央寄せ用 */
  align-items: center; /* 縦センター */
  justify-content: center;
  width: 100%;
  height: 100%;
}