@charset "UTF-8";
.-pc {
  display: block;
}
.FadeSlideUp {
  opacity: 0;
  transform: translate3d(0, 20px, 0);
}
.FadeSlideUp.-active {
  opacity: 1;
  transform: translate3d(0, 0, 0);
}
.ZoomOut {
  opacity: 0;
  transform: scale(1.25) rotate(2deg);
}
.ZoomOut.-active {
  opacity: 1;
  transform: scale(1);
}
[data-scroll-hook].-active {
  transition: opacity 1.2s, transform 1.2s;
}
.Banner {
  padding: 70px 0 80px;
}
.Banner.-yellow {
  background-color: #fefef0;
}
.Banner.-gray {
  background-color: #f5f5f5;
}
.Banner_title {
  text-align: center;
  font-family: "Noto Serif JP", serif;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.7;
}
.Banner_title > span {
  display: block;
  font-family: "Noto Sans JP", sans-serif;
  margin-top: 5px;
}
.Banner_link {
  display: table;
  margin: auto;
}
.Banner_img {
  display: block;
  width: 725px !important;
  margin: 30px auto 0;
}
.Banner .Button {
  width: 400px;
  margin: 40px auto 0;
}
@media (any-hover: hover) {
  .Banner .Button:hover {
    opacity: 1;
  }
  .Banner a {
    transition: opacity 0.4s, background-color 0.4s;
  }
  .Banner a:hover {
    opacity: 0.7;
  }
}
.Brand {
  padding-top: 90px;
}
.Brand:first-child, .Brand:last-child {
  padding-bottom: 100px;
}
.Brand_firstView {
  display: flex;
  justify-content: space-between;
}
.Brand_firstViewItem:nth-child(1) {
  width: 472px;
}
.Brand_firstViewItem:nth-child(2) {
  display: flex;
  flex-direction: column;
  justify-content: center;
  width: 450px;
}
.Brand_title {
  text-align: center;
  font-family: "Palatino Linotype", "Noto Serif JP", serif;
  font-size: 30px;
  margin-bottom: 50px;
}
.Brand_slider {
  position: relative;
}
.Brand_slider .swiper-pagination {
  display: flex;
  right: 14px;
  bottom: 20px;
}
.Brand_slider .swiper-pagination-bullet {
  width: 12px;
  height: 12px;
  margin: 0 6px;
  opacity: 1;
  background-color: #bbb;
}
.Brand_slider .swiper-pagination-bullet-active {
  background-color: #f2aac2;
}
.Brand_slideImg {
  aspect-ratio: 800/1066;
}
.Brand_nonIronmaxImg {
  display: block;
  width: 133px !important;
  margin: auto;
  aspect-ratio: 266/340;
}
.Brand_nonIronmaxText {
  font-size: 24px;
  margin-top: 20px;
}
.Brand_nonIronmaxText > em {
  display: block;
  font-weight: 700;
}
.Brand_nonIronmaxText > span {
  display: block;
}
.Brand_strong {
  text-align: center;
  font-family: "Noto Serif JP", serif;
  padding: 7px 1em;
}
.Brand_strong.-persons {
  color: #fff;
  background-color: #b8c0e6;
}
.Brand_strong.-imgn {
  color: #fff;
  background-color: #b4e0bb;
}
.Brand_catch {
  text-align: center;
  margin-top: 15px;
}
.Brand_catch > em {
  display: block;
  font-size: 24px;
  font-weight: 700;
}
.Brand_buttonGroup {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 60px;
}
.Brand_buttonGroup .Button {
  width: 400px;
  margin: 0 20px;
}
.Brand_buttonGroup .Button:nth-child(3) {
  margin-top: 100px;
}
.Brand .List {
  display: flex;
  justify-content: center;
  margin: 60px 0;
}
.BrandVoice {
  margin-top: 40px;
}
.BrandVoice_title {
  text-align: center;
  font-family: "Noto Serif JP", serif;
  font-size: 24px;
  font-weight: 700;
}
.BrandVoice_body {
  display: flex;
  align-items: flex-start;
  margin-top: 10px;
}
.BrandVoice_avatar {
  width: 80px !important;
  aspect-ratio: 1/1;
  flex-shrink: 0;
}
.BrandVoice_text {
  width: 100%;
  position: relative;
  font-size: size(12);
  line-height: 2;
  background-color: #f5f5f5;
  border-radius: 10px;
  padding: 20px 30px;
  margin-top: 5px;
  margin-left: 38px;
}
.BrandVoice_balloon {
  width: 30px;
  height: 32.5px;
  position: absolute;
  top: 35px;
  right: 100%;
  fill: #f5f5f5;
}
.BrandFeature {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin: 80px -30px;
}
.BrandFeature_item {
  width: 280px;
  margin: 0 30px;
  flex-grow: 0;
}
.BrandFeature_img {
  aspect-ratio: 560/372;
}
.BrandFeature_caption {
  text-align: center;
  margin-top: 10px;
}
.BrandSize {
  border-color: #333;
  border-style: solid;
  border-width: 1px 0;
  margin-top: 35px;
}
.BrandSize.-active .BrandSize_state {
  transform: rotate(180deg);
}
.BrandSize.-active .BrandSize_state::after {
  opacity: 0;
}
.BrandSize_title {
  position: relative;
  text-align: center;
  padding: 13px 0;
  margin: 5px 0;
  background-color: #f5f5f5;
  cursor: pointer;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}
.BrandSize_body {
  overflow: hidden;
  height: 0;
}
.BrandSize_state {
  display: block;
  width: 15px;
  height: 15px;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 30px;
  margin: auto;
  transition: transform 0.6s;
}
.BrandSize_state::before, .BrandSize_state::after {
  content: "";
  position: absolute;
  background-color: #333;
}
.BrandSize_state::before {
  width: 100%;
  height: 1px;
  top: 7px;
  left: 0;
}
.BrandSize_state::after {
  width: 1px;
  height: 100%;
  top: 0;
  left: 7px;
  transition: opacity 0.6s;
}
.BrandSize_table {
  width: 100%;
  table-layout: fixed;
  border-collapse: separate;
  border-spacing: 1px;
  font-size: 13px;
  background-color: #dcdcdc;
  margin-top: 25px;
  margin-bottom: 30px;
}
.BrandSize_table th,
.BrandSize_table td {
  vertical-align: middle;
  text-align: center;
  padding: 0.5em 0;
}
.BrandSize_table th {
  background-color: #eee;
}
.BrandSize_table td {
  background-color: #fff;
}
.Button {
  display: table;
  width: 100%;
  position: relative;
  background-color: #fff;
  text-align: center;
  line-height: 1;
  padding: 21px 15px 22px;
  box-sizing: border-box;
  cursor: pointer;
}
@media (any-hover: hover) {
  .Button {
    transition: opacity 0.4s, background-color 0.4s, color 0.4s;
  }
}
.Button_icon {
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
}
.Button_icon.-arrowDown {
  width: 14px;
  height: 7px;
  right: 15px;
}
.Button_icon.-arrowNext {
  width: 7px;
  height: 14px;
  right: 15px;
}
.Button.-square {
  border: 1px solid #333;
}
@media (any-hover: hover) {
  .Button.-square:hover {
    background-color: #f5f5f5;
  }
}
.Button.-round {
  border-radius: 8px;
  padding: 21px 1em 22px;
}
.Button.-round.-sm {
  border-radius: 10px;
  padding: 16px 1em 18px;
}
.Button.-round.-xs {
  max-width: 100px;
  font-size: 12px;
  border-radius: 5px;
  padding: 7px 1em 9px;
  margin: auto;
}
.Button.-nonIronmax {
  color: #fff;
  background-color: #c7b8e6;
}
@media (any-hover: hover) {
  .Button.-nonIronmax:hover {
    background-color: #a992d9;
  }
}
.Button.-persons {
  color: #fff;
  background-color: #b8c0e6;
}
@media (any-hover: hover) {
  .Button.-persons:hover {
    background-color: #929fd9;
  }
}
.Button.-imgn {
  color: #fff;
  background-color: #b4e0bb;
}
@media (any-hover: hover) {
  .Button.-imgn:hover {
    background-color: #90d19a;
  }
}
.Button.-coordinate {
  width: 100%;
  font-size: 12px;
  padding: 6px 1em 8px;
}
.Button.-coordinate .Button_icon.-arrowNext {
  width: 5.4px;
  height: 10px;
  right: 8px;
}
.Collection {
  padding: 90px 0 100px;
}
.Collection + .Collection {
  margin-top: -100px;
}
.Collection_title {
  text-align: center;
  margin-bottom: 50px;
}
.Collection_title > em {
  display: block;
  font-family: "Noto Serif JP", serif;
  font-size: 24px;
  font-weight: 700;
  line-height: 1.7;
}
.Collection_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin: -10px;
}
.Collection_item {
  width: 236px;
  margin: 10px;
}
.Collection_img {
  aspect-ratio: 440/560;
}
.Collection_img.-hasBorder {
  border: 1px solid #e0e0e0;
}
@media (any-hover: hover) {
  .Collection a {
    transition: opacity 0.4s;
  }
  .Collection a:hover {
    opacity: 0.7;
  }
}
.Coordinate {
  max-width: 920px;
  margin: 100px auto 0;
}
.Coordinate_firstView {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.Coordinate_firstViewItem:nth-child(1) {
  width: 412px;
}
.Coordinate_firstViewItem:nth-child(2) {
  width: 450px;
}
.Coordinate_mainImg {
  aspect-ratio: 590/786;
  margin-bottom: size(40);
}
.Coordinate_list {
  display: flex;
  justify-content: center;
  margin: 80px -30px 0;
}
.Coordinate_item {
  width: 200px;
  position: relative;
  padding-bottom: 70px;
  margin: 0 30px;
}
.Coordinate_img {
  aspect-ratio: 157/167;
}
.Coordinate_name {
  display: flex;
  justify-content: center;
  font-size: 14px;
  line-height: 1.5;
  margin-top: 10px;
}
.Coordinate_price {
  width: 100%;
  position: absolute;
  left: 0;
  bottom: 40px;
  text-align: center;
  font-size: 16px;
}
.Coordinate_soldOut {
  width: 100%;
  position: absolute;
  left: 0;
  bottom: 0;
  text-align: center;
  font-size: 12px;
  line-height: 30px;
  color: #f00;
}
.Coordinate .Button {
  position: absolute;
  left: 0;
  bottom: 0;
}
.CoordinateGroup {
  padding-top: 90px;
}
.CoordinateGroup_title {
  text-align: center;
  font-family: "Noto Serif JP", serif;
  font-size: 24px;
  font-weight: 700;
  line-height: 1.7;
  margin-bottom: -50px;
}
.CoordinateGroup_buttonGroup {
  display: flex;
  justify-content: center;
  margin: 100px -20px 0;
}
.CoordinateGroup_buttonGroup .Button {
  width: 400px;
  margin: 0 20px;
}
.Inner {
  width: 980px;
  position: relative;
  padding-right: 30px;
  padding-left: 30px;
  margin-right: auto;
  margin-left: auto;
}
.KV {
  position: relative;
  z-index: 1;
  overflow: hidden;
}
.KV::before, .KV::after {
  content: "";
  width: 50%;
  height: 100%;
  position: absolute;
  top: 0;
  z-index: -1;
  opacity: 0;
}
.KV::before {
  left: 0;
  background-image: url(/user_data/packages/store/images/pj/white_shirt/kv_bg_left.png);
}
.KV::after {
  right: 0;
  background-image: url(/user_data/packages/store/images/pj/white_shirt/kv_bg_right.png);
}
.KV_img {
  display: block;
  max-width: 1920px !important;
  aspect-ratio: 1920/660;
  -o-object-fit: contain;
     object-fit: contain;
  margin: auto;
}
.KV_img:nth-child(n+2) {
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  opacity: 0;
}
.KV_img:nth-child(2) {
  transform: translate3d(0, 20px, 0);
}
.KV_img:nth-child(3) {
  transform: translate3d(0, 20px, 0);
}
.KV_img:nth-child(4) {
  transform: scale(0);
  transform-origin: 30% 55%;
}
.KV_img:nth-child(5) {
  transform: translate3d(0, 20px, 0);
}
.KV_img:nth-child(6) {
  transform: scale(0) rotate(-45deg);
  transform-origin: 60% 40%;
}
.KV_img:nth-child(7) {
  transform: translate3d(0, 50px, 0);
}
.KV.-active::before, .KV.-active::after {
  opacity: 1;
}
.KV.-active .KV_img:nth-child(n+2) {
  opacity: 1;
  transition: 0.6s;
}
.KV.-active .KV_img:nth-child(2) {
  transform: translate3d(0, 0, 0);
  transition-delay: 0.2s;
}
.KV.-active .KV_img:nth-child(3) {
  transform: translate3d(0, 0, 0);
  transition-delay: 0.4s;
}
.KV.-active .KV_img:nth-child(4) {
  transform: scale(1);
  transition-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1.275);
  transition-delay: 0.6s;
}
.KV.-active .KV_img:nth-child(5) {
  transform: translate3d(0, 0, 0);
  transition-delay: 0.8s;
}
.KV.-active .KV_img:nth-child(6) {
  transform: scale(1);
  transition-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1.275);
  transition-delay: 1s;
}
.KV.-active .KV_img:nth-child(7) {
  transform: translate3d(0, 0, 0);
}
.Lineup {
  padding: 90px 0;
}
.Lineup_title {
  position: relative;
  text-align: center;
  line-height: 2;
  padding-bottom: 30px;
  margin-bottom: 75px;
}
.Lineup_title > em {
  display: block;
  font-family: "Noto Serif JP", serif;
  font-size: 24px;
  font-weight: 700;
  margin-top: 7px;
}
.Lineup_title::after {
  content: "";
  width: 60px;
  height: 2px;
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  background-color: #333;
}
.Lineup_list {
  display: flex;
  margin: 0 -12.5px;
}
.Lineup_item {
  width: 310px;
  margin: 0 12.5px;
}
.Lineup_item .Button {
  margin-top: 18px;
}
.Lineup_table {
  width: 100%;
  text-align: center;
  font-size: 14px;
  background-color: #dcdcdc;
  border-collapse: separate;
  border-spacing: 1px;
  margin: 20px 0 30px;
}
.Lineup_table th,
.Lineup_table td {
  vertical-align: middle;
  text-align: center;
  padding: 12px 0;
  box-sizing: border-box;
}
.Lineup_table th {
  background-color: #eee;
}
.Lineup_table th:nth-child(1) {
  width: 90px;
}
.Lineup_table td {
  background-color: #fff;
}
.Lineup_table td.-material {
  height: 80px;
  padding: 0;
}
.Lineup_name {
  text-align: center;
  margin-bottom: 10px;
}
.Lineup_name > em {
  display: block;
  font-weight: 700;
}
.Lineup_name > span {
  display: block;
  font-size: 24px;
  font-family: "Palatino Linotype", "Noto Serif JP", serif;
}
.Lineup_img {
  aspect-ratio: 800/1066;
}
.Lineup_price {
  margin: size(5) 0;
}
.Lineup_text {
  margin: size(5) 0;
}
.Lineup_iconGroup {
  display: flex;
  justify-content: center;
}
.Lineup_icon {
  width: 30px;
  height: 49px;
  fill: #808080;
  margin: 0 5px;
}
.Lineup_buttonGroup {
  display: flex;
  margin: 100px -12.5px 0;
}
.Lineup_buttonGroup .Button {
  width: 100%;
  margin: 0 12.5px;
}
.List {
  margin: 10px 0;
  list-style: none;
}
.List.-notice li::before {
  content: "※";
}
.List li {
  font-size: 14px;
  line-height: 1.25;
  padding-left: 1em;
  text-indent: -1em;
  margin-top: 0.5em;
}
.Mask {
  overflow: hidden;
}
.Mask.-roundSm {
  border-radius: 10px;
}
.Mask.-round {
  border-radius: 20px;
}
.Point {
  padding: 90px 0;
  background-color: #f5f5f5;
}
.Point_title {
  text-align: center;
  font-family: "Noto Serif JP", serif;
  font-size: 24px;
  font-weight: 700;
  line-height: 2;
  margin-bottom: 70px;
}
.Point_list {
  display: flex;
  margin: 0 -12.5px;
}
.Point_item {
  width: 310px;
  margin: 0 12.5px;
  background-color: #fff;
}
.PointDetail {
  font-size: 16px;
  padding: 40px 30px;
}
.PointDetail_title {
  text-align: center;
}
.PointDetail_title > em {
  display: block;
  font-family: "Noto Serif JP", serif;
  font-size: 18px;
  font-weight: 700;
  margin-top: 5px;
}
.PointDetail_body {
  margin-top: 15px;
}
.PointDetail_body :last-child {
  margin-bottom: 0;
}
.PointDetail_text {
  font-size: 15px;
  line-height: 1.75;
  margin: 20px 0;
}
.PointDetail_img {
  display: block;
  margin: 30px 0;
}
.PointDetail_img.-unisize {
  aspect-ratio: 600/262;
}
.PointDetail_img.-function {
  aspect-ratio: 500/324;
}
.PointDetail_table {
  width: 100%;
  table-layout: fixed;
  border-collapse: separate;
  border-spacing: 1px;
  font-size: 16px;
  background-color: #dcdcdc;
  margin: 15px 0;
}
.PointDetail_table th,
.PointDetail_table td {
  padding: 10px 0;
}
.PointDetail_table th {
  text-align: center;
  font-size: 14px;
  background-color: #eee;
}
.PointDetail_table th.-pink {
  color: #fff;
  background-color: #f2aac2;
}
.PointDetail_table td {
  text-align: center;
  background-color: #fff;
}
.Product {
  display: flex;
  justify-content: space-between;
  margin-top: 100px;
}
.Product:nth-child(even) {
  flex-direction: row-reverse;
}
.Product:nth-child(even) .Product_subImgHolder {
  margin-right: auto;
  margin-left: 0;
}
.Product_title {
  text-align: center;
  font-size: 24px;
  font-weight: 700;
  margin-top: 40px;
}
.Product_mainImgHolder {
  width: 472px;
}
.Product_data {
  width: 448px;
}
.Product_mainImg {
  aspect-ratio: 944/1260;
}
.Product_subImgHolder {
  width: 378px;
  margin: 40px 0 0 auto;
}
.Product_subImg {
  display: block;
  width: size(137.5);
  margin: size(20) 0 0 auto;
  aspect-ratio: 756/504;
}
.Product_text {
  line-height: 2;
  margin-top: 40px;
}
.Product_price {
  font-size: 20px;
  font-weight: 700;
  margin-top: 5px;
}
.Product .Button {
  margin-top: 43px;
}
.Reason {
  padding: 90px 0;
  background-color: #fefef0;
}
.Reason_title {
  text-align: center;
  font-family: "Noto Serif JP", serif;
  font-size: 24px;
  font-weight: 700;
  line-height: 2;
}
.Reason_list {
  display: flex;
  justify-content: center;
  margin: 70px -30px 0;
  counter-reset: reason;
}
.Reason_item {
  width: 280px;
  position: relative;
  margin: 0 30px;
}
.Reason_item::before {
  counter-increment: reason;
  content: counter(reason, decimal-leading-zero);
  position: absolute;
  top: -23px;
  left: 14px;
  z-index: 2;
  color: #f2aac2;
  font-family: "Palatino Linotype", "Noto Serif JP", serif;
  font-size: 46px;
  line-height: 1;
}
.Reason_img {
  aspect-ratio: 560/372;
}
.Reason_caption {
  text-align: center;
  margin-top: 10px;
}
.Recommend {
  max-width: 750px;
  position: relative;
  padding: 50px 20px;
  margin: auto;
  background-color: #fefef0;
  box-sizing: border-box;
}
.Recommend_title {
  position: absolute;
  top: -0.6em;
  right: 0;
  left: 0;
  text-align: center;
  font-family: "Noto Serif JP", serif;
  font-size: 24px;
  font-weight: 700;
  line-height: 1;
}
.Recommend_list {
  display: table;
  margin: auto;
}
.Recommend_list.-inline {
  display: flex;
  justify-content: center;
  margin: -10px;
}
.Recommend_list.-inline .Recommend_item {
  margin: 10px;
}
.Recommend_item {
  position: relative;
  line-height: 1.5;
  padding-left: 30px;
}
.Recommend_item:nth-child(n+2) {
  margin-top: 10px;
}
.Recommend_check {
  width: 23px;
  height: 16.5px;
  position: absolute;
  top: 5px;
  left: 0;
  fill: #f2aac2;
}
.StarGroup {
  display: flex;
  justify-content: center;
  margin: 5px 0;
}
.Star {
  width: 18px;
  height: 17.5px;
  fill: #eee;
  margin: 0 1.5px;
}
.Star.-active {
  fill: #eab15e;
}
.Summary {
  padding: 75px 0;
}
.Summary_text {
  text-align: center;
  line-height: 1.5;
}
.Summary_text.-n2 {
  font-family: "Noto Serif JP", serif;
  font-size: 24px;
  font-weight: 700;
  margin-top: 30px;
}
.Summary_text.-n3 {
  display: table;
  font-size: 24px;
  font-weight: 700;
  padding: 0 30px;
  margin: 0 auto 55px;
  background: linear-gradient(transparent 70%, #f8d4e0 70%, #f8d4e0 90%, transparent 90%);
}
.Summary_text.-n3 > em {
  color: #e57373;
  font-size: 54px;
  font-weight: 700;
  vertical-align: baseline;
}
.Summary .List {
  text-align: center;
}
.theme-combination-ladies .Title {
  text-align: center;
  font-weight: 900;
}
.theme-combination-ladies .Title.-main {
  position: relative;
  font-size: 30px;
  line-height: 1.25;
  padding-bottom: 25px;
  margin: 0 auto 40px;
}
.theme-combination-ladies .Title.-main::after {
  content: "";
  width: 50px;
  height: 5px;
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  background-color: #db2828;
}
.theme-combination-mens .Title {
  text-align: center;
  font-weight: 900;
}
.theme-combination-mens .Title.-main {
  position: relative;
  font-size: 30px;
  line-height: 1.25;
  padding-bottom: 25px;
  margin: 0 auto 40px;
}
.theme-combination-mens .Title.-main::after {
  content: "";
  width: 50px;
  height: 5px;
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  background-color: #0080c3;
}
.theme-white-shirt {
  min-width: 1040px;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 18px;
  line-height: 1.75;
  color: #333;
  background-color: #fff;
}
.theme-white-shirt img {
  width: 100%;
  max-width: 100%;
  height: auto;
}
.hidden {
  display: none;
}
[data-lazy] {
  opacity: 0;
}
[data-lazy].-loaded {
  opacity: 1;
  transition: opacity 0.5s;
}

/* -------------------------------- 20230421追加 -- */
p.catch {
  text-align: center;
  line-height: 1.4;
}
.catch_nonIronmax {
  background: linear-gradient(transparent 60%, #e7dcff 20%);
  display: inline-table;
}
.catch_persons {
  background: linear-gradient(transparent 60%, #d6e0ff 20%);
  display: inline-table;
}
.catch_imgn {
  background: linear-gradient(transparent 60%, #d4ffdb 20%);
  display: inline-table;
}