@charset "Shift_JIS";
/* --------------------------------------------------------------------
【予告】お中元　CSS（PC・SP） / .yokoku
--------------------------------------------------------------------- */
/* ボタン 右矢印（＞） */
.yokoku .btn_basic a {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  color: #fff;
  width: 100%;
  max-width: 380px;
  height: 70px;
  margin: 0 auto;
  background: #222;
  border-radius: 60px;
  box-shadow: 0px 2px 3px 0px rgba(61, 61, 61, 0.15);
  font-size: 1.6rem;
  line-height: 1.4;
}

.yokoku .btn_basic a::after {
  content: '';
  position: absolute;
  top: 50%;
  right: 20px;
  width: 10px;
  height: 10px;
  border-right: solid 1px #fff;
  border-bottom: solid 1px #fff;
  transform: translateY(-50%) rotate(-45deg);
}

/* 改行切り替え */
.mainframe_ .yokoku .sp_only { display: none; }
.wrapper_:not(:has(.mainframe_)) .yokoku .pc_only { display: none; }

/* 基本カラー */
.yokoku {
  color: #333;
  --color-main: #0B4380; /* 青 */
  --color-sub: #de8b04; /* 黄 */
  --title-color-bg: #1785c2; /* 青 */
  --title-color-txt: #2b2723; /* 茶 */
  --cp-color: #aa8d34; /* cp文字 */
  --cp-btn-color: #de8b04; /* cpボタン */
  --btn-color-hover: #0B4380; /* ボタン */
}

/* ---------------------- PC ----------------------------- */
/* MV・キャッチコピー
================================================== */
/* キャッチコピー */
.mainframe_ .yokoku .catch_copy {
  font-size: 1.8rem;
  text-align: center;
  padding: 15px 0;
}

.mainframe_ .yokoku .catch_copy > span {
  font-size: 2.0rem;
  font-weight: bold;
}

/* 共通：コンテンツタイトル（.title_box）
================================================== */
.mainframe_ .yokoku .title_box {
  text-align: center;
}

.mainframe_ .yokoku .title_box .title .title_sub {
  position: relative;
  display: inline-block;
  color: #fff;
  line-height: 1;
  background: var(--title-color-bg);
  margin-bottom: 10px;
  padding: 5px 15px;
  border-radius: 60px;
}

.mainframe_ .yokoku .title_box .title .title_sub::after {
  content: '';
  position: absolute;
  bottom: -10px;
  left: calc(50% - 3px);
  border-left: 6px solid transparent;
  border-right: 6px solid transparent;
  border-top: 10px solid var(--title-color-bg);
}

.mainframe_ .yokoku .title_box .title .title_main {
  display: block;
  color: var(--title-color-txt);
  font-size: 2.8rem;
  font-weight: bold;
  line-height: 1;
  margin: 10px 0 0 0;
}

.mainframe_ .yokoku .title_box .lead_txt {
  margin: 10px 0 0 0;
}

/* サービス情報
================================================== */
.mainframe_ #yokoku_service {
  margin-top: 40px;
}

/* ボタンリスト */
.mainframe_ #yokoku_service ul.btn_list {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 10px;
}

.mainframe_ #yokoku_service ul.btn_list li {
  width: calc(100% / 3);
  border: 1px solid #ccc;
}
.mainframe_ #yokoku_service ul.btn_list li:not(:nth-of-type(1)) { border-left: none; }

.mainframe_ #yokoku_service ul.btn_list li a {
  position: relative;
  display: flex;
  align-items: center;
  font-size: 1.5rem;
  width: 100%;
  height: 80px;
  padding: 0 0 0 10px;
  background: #fff;
  border: 2px solid #fff;
}
.mainframe_ #yokoku_service ul.btn_list li:nth-of-type(1) a { letter-spacing: -0.08rem; }

.mainframe_ #yokoku_service ul.btn_list li a::after {
  content: '';
  position: absolute;
  top: 50%;
  right: 10px;
  width: 10px;
  height: 10px;
  border-right: solid 1px #111;
  border-bottom: solid 1px #111;
  transform: translateY(-50%) rotate(-45deg);
}

.mainframe_ #yokoku_service ul.btn_list li a span {
  position: relative;
  padding: 0 0 0 45px;
}

.mainframe_ #yokoku_service ul.btn_list li a span::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 0;
  width: 40px;
  height: auto;
  aspect-ratio: 1;
  transform: translateY(-50%);
}
.mainframe_ #yokoku_service ul.btn_list li.icon_beginner a span::before { background: url("/contents/siblings/cgen/yokoku/img/icon_beginner.png") center center / contain no-repeat; }
.mainframe_ #yokoku_service ul.btn_list li.icon_delivery a span::before { background: url("/contents/siblings/cgen/yokoku/img/icon_delivery.png") center center / contain no-repeat; }
.mainframe_ #yokoku_service ul.btn_list li.icon_pc a span::before { background: url("/contents/siblings/cgen/yokoku/img/icon_pc.png") center center / contain no-repeat; }


/* マウスオーバー */
.mainframe_ #yokoku_service ul.btn_list li a:hover {
  opacity: 1;
  border-color: var(--btn-color-hover);
}

.mainframe_ #yokoku_service ul.btn_list li a:hover::after {
  border-color: var(--btn-color-hover);
}

/* 注釈 */
.mainframe_ #yokoku_service p.att {
  text-align: center;
  margin-top: 10px;
}

/* キャンペーン情報
================================================== */
.mainframe_ #yokoku_campaign {
  margin-top: 50px;
  position: relative;
  overflow: hidden;
  background: #eaf9fe;
}

/* 背景設定 */
.mainframe_ #yokoku_campaign::before {
  content: '';
  position: absolute;
  top: -16px;
  left: -20px;
  width: 230px;
  height: auto;
  aspect-ratio: 300 / 170;
  background: url("/contents/siblings/cgen/yokoku/img/campaign_bg01.png") left top / contain no-repeat;
}
.mainframe_ #yokoku_campaign::after {
  content: '';
  position: absolute;
  bottom: 0;
  right: 0;
  width: 260px;
  height: auto;
  aspect-ratio: 430 / 170;
  background: url("/contents/siblings/cgen/yokoku/img/campaign_bg02.png") left top / contain no-repeat;
}

.mainframe_ #yokoku_campaign_inner {
  padding: 50px 0;
  border-top: 6px solid #cff1fc;
  border-bottom: 6px solid #cff1fc;
}

/* リンク：会員登録 */
.mainframe_ #yokoku_campaign .title_box .lead_txt a {
  display: inline-block;
  color: #1a0dab;
  font-weight: bold;
}
.mainframe_ #yokoku_campaign .title_box .lead_txt a::before,
.mainframe_ #yokoku_campaign .title_box .lead_txt a::after {
  display: inline;
}
.mainframe_ #yokoku_campaign .title_box .lead_txt a::before { content: '>>'; }
.mainframe_ #yokoku_campaign .title_box .lead_txt a::after { content: '<<'; }

/* マウスオーバー */
.mainframe_ #yokoku_campaign .title_box .lead_txt a:hover {
  opacity: 1;
  text-decoration: underline;
}

/* 特典 */
.mainframe_ #yokoku_campaign ul.list {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 20px;
  width: 100%;
  max-width: 760px;
  margin: 20px auto;
}

.mainframe_ #yokoku_campaign ul.list li {
  text-align: center;
  width: calc((100% - (20px * 2)) / 3);
  padding: 20px 0;
  background: #fff;
  border-radius: 3px;
  box-shadow: 0px 2px 3px 0px rgba(61, 61, 61, 0.15);
}

.mainframe_ #yokoku_campaign ul.list li .icon {
  color: var(--cp-color);
  font-family: '游明朝', YuMincho, 'Hiragino Mincho ProN', 'Hiragino Mincho Pro', 'ＭＳ 明朝', serif;
  font-weight: 500; /* 機種による文字のかすれ防止 */
  font-size: 2.2rem;
}

.mainframe_ #yokoku_campaign ul.list li .icon > span {
  position: relative;
  display:inline-block;
  margin: 0 0 3px 0;
  padding: 0 10px;
}
.mainframe_ #yokoku_campaign ul.list li .icon > span::before,
.mainframe_ #yokoku_campaign ul.list li .icon > span::after {
  content: '';
  position: absolute;
  height: 1px;
  background: var(--cp-color);
}
.mainframe_ #yokoku_campaign ul.list li .icon > span::before {
  left: 0;
  bottom: 0;
  width: 50%;
}
.mainframe_ #yokoku_campaign ul.list li .icon > span::after {
  right: 0;
  bottom: -3px;
  width: 80%;
}

.mainframe_ #yokoku_campaign ul.list li .desc::before {
  content: '';
  display: block;
  width: 100px;
  height: auto;
  aspect-ratio: 1;
  margin: 10px auto;
}
.mainframe_ #yokoku_campaign ul.list li.cont_coupon .desc::before {
  background: url("/contents/siblings/cgen/yokoku/img/icon_coupon.png") center bottom / contain no-repeat;
}
.mainframe_ #yokoku_campaign ul.list li.cont_shipping .desc::before {
  background: url("/contents/siblings/cgen/yokoku/img/icon_track.png") center bottom / contain no-repeat;
}
.mainframe_ #yokoku_campaign ul.list li.cont_20off .desc::before {
  background: url("/contents/siblings/cgen/yokoku/img/icon_20off.png") center bottom / contain no-repeat;
}

.mainframe_ #yokoku_campaign ul.list li .catch {
  color: #333;
  font-weight: bold;
}

.mainframe_ #yokoku_campaign ul.list li .title {
  color: #d02626;
  font-size: 2.4rem;
  font-weight: bold;
  padding-top: 5px;
}

.mainframe_ #yokoku_campaign ul.list li .link {
  margin: 5px 0 0 0;
}

.mainframe_ #yokoku_campaign ul.list li .link a {
  color: #111;
  font-size: 1.4rem;
}

/* マウスオーバー */
.mainframe_ #yokoku_campaign ul.list li .link a:hover {
  opacity: 1;
  color: var(--btn-color-hover);
  text-decoration: underline;
}

/* ボタン */
.mainframe_ #yokoku_campaign .btn_list {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 20px;
  margin: 0 auto;
  width: 660px;
}

.mainframe_ #yokoku_campaign .btn_list .btn_topic {
  width: 100%;
}

.mainframe_ #yokoku_campaign .btn_list .btn_topic a {
  max-width: 330px;
  height: 60px;
  background: var(--cp-btn-color);
  box-shadow: none;
}

/* カタログ情報
================================================== */
.mainframe_ #yokoku_catalog {
  margin-top: 50px;
}

.mainframe_ #yokoku_catalog .box {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  padding: 20px 0 0 0;
}

.mainframe_ #yokoku_catalog .box .img {
  width: 180px;
  margin: 0 20px 0 0;
}

.mainframe_ #yokoku_catalog .box .img img {
  width: 100%;
  height: auto;
}

/* ボタンリスト */
.mainframe_ #yokoku_catalog ul.btn_list {
  width: 280px;
}

.mainframe_ #yokoku_catalog ul.btn_list li {
  width: 100%;
  border: 1px solid #ccc;
}
.mainframe_ #yokoku_catalog ul.btn_list li + li { margin-top: 10px; }

.mainframe_ #yokoku_catalog ul.btn_list li a {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
  height: 70px;
  padding: 0 0 0 15px;
  background: #fff;
  border: 2px solid #fff;
}

.mainframe_ #yokoku_catalog ul.btn_list li a::after {
  content: '';
  position: absolute;
  top: 50%;
  right: 10px;
  width: 10px;
  height: 10px;
  border-right: solid 1px #111;
  border-bottom: solid 1px #111;
  transform: translateY(-50%) rotate(-45deg);
}

/* マウスオーバー */
.mainframe_ #yokoku_catalog ul.btn_list li a:hover { opacity: 1; border-color: var(--btn-color-hover); }
.mainframe_ #yokoku_catalog ul.btn_list li a:hover::after { border-color: var(--btn-color-hover); }


/* ---------------------- SP ----------------------------- */
/* MV・キャッチコピー
================================================== */
/* キャッチコピー */
.wrapper_:not(:has(.mainframe_)) .yokoku .catch_copy {
  font-size: 1.8rem;
  text-align: center;
  padding: 15px 0;
}

.wrapper_:not(:has(.mainframe_)) .yokoku .catch_copy > span {
  font-size: 2.0rem;
  font-weight: bold;
}


/* 共通：コンテンツタイトル（.title_box）
================================================== */
.wrapper_:not(:has(.mainframe_)) .yokoku .title_box {
  text-align: center;
  padding: 0 3%;
}

.wrapper_:not(:has(.mainframe_)) .yokoku .title_box .title .title_sub {
  position: relative;
  display: inline-block;
  color: #fff;
  line-height: 1;
  background: var(--title-color-bg);
  margin-bottom: 10px;
  padding: 5px 15px;
  border-radius: 60px;
}

.wrapper_:not(:has(.mainframe_)) .yokoku .title_box .title .title_sub::after {
  content: '';
  position: absolute;
  bottom: -10px;
  left: calc(50% - 3px);
  border-left: 6px solid transparent;
  border-right: 6px solid transparent;
  border-top: 10px solid var(--title-color-bg);
}

.wrapper_:not(:has(.mainframe_)) .yokoku .title_box .title .title_main {
  display: block;
  color: var(--title-color-txt);
  font-size: 2.6rem;
  font-weight: bold;
  line-height: 1.2;
  margin: 10px 0 0 0;
}

.wrapper_:not(:has(.mainframe_)) .yokoku .title_box .lead_txt {
  font-size: 1.4rem;
  margin: 10px 0 0 0;
}

/* サービス情報
================================================== */
.wrapper_:not(:has(.mainframe_)) #yokoku_service {
  padding: 0 3%;
  margin-top: 50px;
}

/* ボタンリスト */
.wrapper_:not(:has(.mainframe_)) #yokoku_service ul.btn_list {
  margin-top: 10px;
}

.wrapper_:not(:has(.mainframe_)) #yokoku_service ul.btn_list li {
  width:100%;
  border: 1px solid #ccc;
}
.wrapper_:not(:has(.mainframe_)) #yokoku_service ul.btn_list li + li { border-top: none; }

.wrapper_:not(:has(.mainframe_)) #yokoku_service ul.btn_list li a {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
  height: 80px;
  padding: 0 0 0 10px;
  background: #fff;
  border: 2px solid #fff;
}

.wrapper_:not(:has(.mainframe_)) #yokoku_service ul.btn_list li a::after {
  content: '';
  position: absolute;
  top: 50%;
  right: 10px;
  width: 10px;
  height: 10px;
  border-right: solid 1px #111;
  border-bottom: solid 1px #111;
  transform: translateY(-50%) rotate(-45deg);
}

.wrapper_:not(:has(.mainframe_)) #yokoku_service ul.btn_list li a span {
  position: relative;
  padding: 0 0 0 50px;
}

.wrapper_:not(:has(.mainframe_)) #yokoku_service ul.btn_list li a span::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 0;
  width: 40px;
  height: auto;
  aspect-ratio: 1;
  transform: translateY(-50%);
}
.wrapper_:not(:has(.mainframe_)) #yokoku_service ul.btn_list li.icon_beginner a span::before { background: url("/contents/siblings/cgen/yokoku/img/icon_beginner.png") center center / contain no-repeat; }
.wrapper_:not(:has(.mainframe_)) #yokoku_service ul.btn_list li.icon_delivery a span::before { background: url("/contents/siblings/cgen/yokoku/img/icon_delivery.png") center center / contain no-repeat; }
.wrapper_:not(:has(.mainframe_)) #yokoku_service ul.btn_list li.icon_pc a span::before { background: url("/contents/siblings/cgen/yokoku/img/icon_pc.png") center center / contain no-repeat; }


/* 注釈 */
.wrapper_:not(:has(.mainframe_)) #yokoku_service p.att {
  text-align: center;
  margin-top: 10px;
}

/* キャンペーン情報
================================================== */
.wrapper_:not(:has(.mainframe_)) #yokoku_campaign {
  margin-top: 50px;
  position: relative;
  overflow: hidden;
  background: #eaf9fe;
}

/* 背景設定 */
.wrapper_:not(:has(.mainframe_)) #yokoku_campaign::before {
  content: '';
  position: absolute;
  top: -16px;
  left: -20px;
  width: 200px;
  height: auto;
  aspect-ratio: 300 / 170;
  background: url("/contents/siblings/cgen/yokoku/img/campaign_bg01.png") left top / contain no-repeat;
}
.wrapper_:not(:has(.mainframe_)) #yokoku_campaign::after {
  content: '';
  position: absolute;
  bottom: 0;
  right: 0;
  width: 200px;
  height: auto;
  aspect-ratio: 430 / 170;
  background: url("/contents/siblings/cgen/yokoku/img/campaign_bg02.png") left top / contain no-repeat;
}

.wrapper_:not(:has(.mainframe_)) #yokoku_campaign_inner {
  padding: 40px 0;
  border-top: 6px solid #cff1fc;
  border-bottom: 6px solid #cff1fc;
}

.wrapper_:not(:has(.mainframe_)) #yokoku_campaign_inner > * {
  position: relative;
  z-index: 1;
}

/* リンク：会員登録 */
.wrapper_:not(:has(.mainframe_)) #yokoku_campaign .title_box .lead_txt a {
  display: inline-block;
  color: #1a0dab;
  font-weight: bold;
}
.wrapper_:not(:has(.mainframe_)) #yokoku_campaign .title_box .lead_txt a::before,
.wrapper_:not(:has(.mainframe_)) #yokoku_campaign .title_box .lead_txt a::after {
  display: inline;
}
.wrapper_:not(:has(.mainframe_)) #yokoku_campaign .title_box .lead_txt a::before { content: '>>'; }
.wrapper_:not(:has(.mainframe_)) #yokoku_campaign .title_box .lead_txt a::after { content: '<<'; }


/* 特典 */
.wrapper_:not(:has(.mainframe_)) #yokoku_campaign ul.list {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  width: 100%;
  max-width: 600px;
  margin: 20px auto;
  padding: 0 3%;
}

.wrapper_:not(:has(.mainframe_)) #yokoku_campaign ul.list li {
  width: 100%;
  padding: 14px 3%;
  background: #fff;
  border-radius: 3px;
  box-shadow: 0px 2px 3px 0px rgba(61, 61, 61, 0.15);
}

.wrapper_:not(:has(.mainframe_)) #yokoku_campaign ul.list li .icon {
  display: inline-block;
  color: var(--cp-color);
  font-size: 1.8rem;
  line-height: 1;
  font-family: '游明朝', YuMincho, 'Hiragino Mincho ProN', 'Hiragino Mincho Pro', 'ＭＳ 明朝', serif;
  font-weight: 500; /* 機種による文字のかすれ防止 */
  font-weight: bold;
  padding: 3px 7px;
  margin: 0 0 8px 0;
  border-bottom: 2px solid var(--cp-color);
}

.wrapper_:not(:has(.mainframe_)) #yokoku_campaign ul.list li .desc {
  position: relative;
  padding: 0 80px 0 0;
}

.wrapper_:not(:has(.mainframe_)) #yokoku_campaign ul.list li .desc::before {
  content: '';
  position: absolute;
  bottom: 0;
  right: 0;
  width: 80px;
  height: auto;
  aspect-ratio: 1;
}
.wrapper_:not(:has(.mainframe_)) #yokoku_campaign ul.list li.cont_coupon .desc::before {
  background: url("/contents/siblings/cgen/yokoku/img/icon_coupon.png") center bottom / contain no-repeat;
}
.wrapper_:not(:has(.mainframe_)) #yokoku_campaign ul.list li.cont_shipping .desc::before {
  background: url("/contents/siblings/cgen/yokoku/img/icon_track.png") center bottom / contain no-repeat;
}
.wrapper_:not(:has(.mainframe_)) #yokoku_campaign ul.list li.cont_20off .desc::before {
  background: url("/contents/siblings/cgen/yokoku/img/icon_20off.png") center bottom / contain no-repeat;
}

.wrapper_:not(:has(.mainframe_)) #yokoku_campaign ul.list li .catch {
  color: #333;
  font-weight: bold;
}

.wrapper_:not(:has(.mainframe_)) #yokoku_campaign ul.list li .title {
  color: #d02626;
  font-feature-settings: "palt";
  font-size: 2.4rem;
  font-weight: bold;
  line-height: 1.2;
  margin-top: 5px;
  
}

.wrapper_:not(:has(.mainframe_)) #yokoku_campaign ul.list li .link {
  text-align: right;
  margin: 5px 0 0 0;
}

.wrapper_:not(:has(.mainframe_)) #yokoku_campaign ul.list li .link a {
  color: #1a0dab;
  font-size: 1.3rem;
  font-weight: 500;
}

/* ボタン */
.wrapper_:not(:has(.mainframe_)) #yokoku_campaign .btn_list {
  display: grid;
  gap: 10px;
  width: 380px;
  max-width: 100%;
  margin: 0 auto;
  padding: 0 3%;
}

.wrapper_:not(:has(.mainframe_)) #yokoku_campaign .btn_list .btn_topic {
  width: 90%;
  margin: 0 auto;
}

.wrapper_:not(:has(.mainframe_)) #yokoku_campaign .btn_list .btn_topic a {
  text-align: center;
  background: var(--cp-btn-color);
  box-shadow: none;
}

/* カタログ情報
================================================== */
.wrapper_:not(:has(.mainframe_)) #yokoku_catalog {
  margin-top: 50px;
}

.wrapper_:not(:has(.mainframe_)) #yokoku_catalog .box {
  width: 100%;
  padding: 20px 0 0 0;
}

.wrapper_:not(:has(.mainframe_)) #yokoku_catalog .box .img {
  width: 180px;
  margin: 0 auto;
}

.wrapper_:not(:has(.mainframe_)) #yokoku_catalog .box .img img {
  width: 100%;
  height: auto;
}

/* ボタンリスト */
.wrapper_:not(:has(.mainframe_)) #yokoku_catalog ul.btn_list {
  width: 100%;
  margin-top: 10px;
  padding: 0 3%;
}

.wrapper_:not(:has(.mainframe_)) #yokoku_catalog ul.btn_list li {
  width: 100%;
  border: 1px solid #ccc;
}
.wrapper_:not(:has(.mainframe_)) #yokoku_catalog ul.btn_list li + li { margin-top: 10px; }

.wrapper_:not(:has(.mainframe_)) #yokoku_catalog ul.btn_list li a {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
  height: 70px;
  padding: 0 0 0 15px;
  background: #fff;
  border: 2px solid #fff;
}

.wrapper_:not(:has(.mainframe_)) #yokoku_catalog ul.btn_list li a::after {
  content: '';
  position: absolute;
  top: 50%;
  right: 10px;
  width: 10px;
  height: 10px;
  border-right: solid 1px #111;
  border-bottom: solid 1px #111;
  transform: translateY(-50%) rotate(-45deg);
}
