﻿@charset "utf-8";

/* CSS Document */
html,
body {
  width: 100%;
  overflow: auto;
}

/* ▼基本デザイン */
/* ----------------------------------------------------- */
html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  font-family: "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif !important;
}

#display img {
  max-width: 100%;
  height: auto;
}

.sample {
  font-family:
    YuMincho,
    /* Mac用 */
    'Yu Mincho',
    /* Windows用 */
    serif;
}

li {
  list-style: none;
  margin: 0;
  padding: 0;
}

.clear {
  clear: both;
}

.fade {
  -webkit-transition: 0.3s ease-in-out;
  -moz-transition: 0.3s ease-in-out;
  -o-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
}

.fade:hover {
  opacity: 0.5;
  filter: alpha(opacity=60);
}

.cap_b {
  line-height: 2;
  padding-bottom: 130px;
}

a:hover {
  text-decoration: none;
}

.disabled {
  pointer-events: none;
}

a,
a:visited {
  color: #2d2d2d;
}

/* ▼gグローバルナビ問題
/* ----------------------------------------------------- 

.header #ui-tab {
    display:block!important;
} */
#global-info {
  display: none !important;
}

.history-right {
  display: none !important;
}

/* ▼パンくず */
/* ----------------------------------------------------- */
#pankuzu {
  max-width: 1200px;
  margin: 0 auto !important;
  text-align: left;
  padding: 5px !important;
  font-size: 11px !important;
  background-color: transparent;
}

#pankuzu a:link {
  /* パンくずのリンク */
  text-decoration: none;
}

#pankuzu a:visited {
  /* パンくずのリンク */
  text-decoration: none;
}

#pankuzu a:hover {
  /* パンくずのリンク */
  text-decoration: underline;
}

/*#pankuzu {
  padding-top: 10px !important;
  padding-bottom: 0px !important;
  margin-bottom: -5px !important;
}*/
/* ▼各デザイン */
/* ----------------------------------------------------- */
.sp_only {
  display: none;
}

.all_cover p {
  font-size: 15px;
  line-height: 1.8;
  color: #2d2d2d;
}

.all_cover {
  width: 100%;
  /* background-color: #E3F2F2; */
}

#app {
  width: 100%;
  background-color: #E5E2DC;
  padding-bottom: 130px;
}

.contents_cover {
  width: 1200px;
  margin: 0 auto;
}



/* ▼main */
/* ----------------------------------------------------- */

/* ▼mv start */
/* --------------*/
.main_v {
  width: 100%;
  height: 800px !important;
  position: relative;
  margin: 0 auto;
  background-image: url("../img/mv_pc.jpg");
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}

.wcover {
  position: absolute;
  right: 0;
  left: 0;
  top: -9%;
  bottom: 0;
  margin: auto;
  display: block;
  width: 367px;
  height: 367px;
}

.wcover h1 {
  position: relative;
}

.mh_mv_cover {
  background-color: #eeac9c;
  width: 100%;
  height: 70px;
  position: absolute;
  bottom: 0;
}

.mh_mv {
  margin: 0 auto;
  display: flex;
  color: #fff;
  justify-content: center;
  align-items: center;
  height: 100%;
  width: 1200px;
}

img.apli {
  width: 133px;
  /* position: absolute; */
  bottom: 18px;
  left: 27%;
  margin: -96px 35px -0 0;
}

img.sp_image {
  width: 164px;
  align-self: flex-end;
  margin-left: 40px;
}

.mh_mv p {
  font-family: YuMincho, 'Yu Mincho', serif !important;
  font-size: 24px !important;
  color: #fff !important;
}

.mh_mv span {
  font-family: YuMincho, 'Yu Mincho', serif !important;
}

.yellow {
  text-decoration: underline;
  text-decoration-color: #ffde52;
  text-decoration-thickness: 5px;
  text-underline-offset: -1px;
}

span.mh_mvs {
  font-size: 16px;
}

/* ▼mv end */
/* --------------*/

/* ▼caption start */
/* --------------*/
.caption_txt p {
  line-height: 2.3 !important;
  letter-spacing: 0.5px !important;
  padding-bottom: 30px;
}

.caption {
  padding-top: 130px;
  /* padding-bottom: 100px; */
  background-color: #fff;
}

/* ▼caption end */
/* --------------*/

/* ▼app_banner start */
/* --------------*/
.bn_cover {
  max-width: 1200px;
  height: 187px;
  background-color: #ededed;
  position: relative;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  margin: 120px auto 0;
}

.pb {
  position: absolute;
  bottom: 0;
  left: 111px;
  width: 156px;
}

.v_area {
  width: 25%;
  position: relative;
  margin-left: 19px;
  height: 187px;
}

.v_area p {
  width: 138px;
  height: 138px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: #f2b1a5;
  color: #fff594;
  font-size: 32px;
  font-weight: bold;
  margin-top: 14px;
}

.mh4 {
  font-size: 20px;
  text-align: justify;
  padding-bottom: 6px;
}

.dl_t_cover {
  width: 40%;
  text-align: justify;
  padding-left: 24px;
}

.dl_t_cover p {
  width: 85%;
}

.store_cover {
  display: flex;
  text-align: justify;
  flex-direction: column;
  gap: 4px;
}

.icon_qr {
  width: 90px;
}

.dl_i_cover {
  width: 31%;
  justify-content: space-between;
  align-items: center;
  display: flex;
  margin-right: 55px;
  gap: 10px 0;
}

.store_cover img {
  height: 36px !important;
}

.icon_dl {
  width: 100px;
}

/* ▼app_baner end */
/* --------------*/

/* ▼nav start */
/* --------------*/
.mh2_cover {
  padding: 140px 0 70px 0;
}

.mh2 {
  font-family: garamond-premier-pro, serif !important;
  font-size: 48px;
  letter-spacing: 4px;
  font-weight: normal;
  color: #db6956;
  text-align: center;
}

.cap_h2 {
  display: block;
  font-size: 27px;
  letter-spacing: 1px;
  font-family: YuMincho, 'Yu Mincho', serif !important;
  color: #2d2d2d;
}

.f_item_cover {
  display: flex;
  justify-content: center;
  max-width: 1600px;
  gap: 0px 26px;
  margin: 0 auto 80px;
  width: 100%;
}

.nav_other_cover h4 {
  font-size: 23px;
  font-weight: normal;
  padding-bottom: 18px;
  display: inline-flex;
  align-items: center;
}

.nav_other_cover span {
  color: #db6956;
}


.mh4_nav_other::after,
.mh4_nav_other::before {
  content: "";
  background-color: rgb(17, 17, 17);
  height: 1.2px;
  width: 28px;
  display: inline-block;
}

.mh4_nav_other::before {
  margin-right: 6px;
  transform: rotate(60deg);
}

.mh4_nav_other::after {
  margin-right: 6px;
  transform: rotate(120deg);
}

.f_item {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  width: 380px;
}

.mh4_cover .mh4 {
  font-family: garamond-premier-pro, serif !important;
  /* font-weight: normal; */
  font-weight: normal;
  font-size: 24px;
  /* letter-spacing: 2px; */
  display: flex;
  flex-direction: column;
  padding: 34px 20px 34px 8px;
  text-align: center !important;
}

.nav_other .text_cover {
  height: auto;
}

.text_cover {
  background-color: #fff1ee;
  height: 333px;
  display: flex;
  flex-direction: column;
}

.text_main {
  font-size: 18px;
  font-weight: bold;
}

.text_sub {
  padding: 16px 0 40px;
  width: 80%;
  margin: 0 auto;
  text-align: justify;
}

.allow_cover {
  background-color: #eeac9c;
  height: 36px;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: auto;
}

.allow {
  content: "";
  width: 11px;
  height: 11px;
  border: 2px solid #fff;
  border-left: 0;
  border-bottom: 0;
  box-sizing: border-box;
  transform: translateY(-25%) rotate(135deg);
  margin: 0 auto;
}

.mh4_cover {
  display: flex;
  justify-content: center;
}

img.icon {
  width: 40px;
}

.nav_cover {
  padding-bottom: 80px;
}

/* ▲nav end */
/* --------------*/

/* ▼contents start */
/* ----------------------------------------------------- */
.sec_cover {
  width: 100%;
  background-color: #fff1ee;
  padding: 160px 0;
}

.sec {
  max-width: 1600px;
  margin: 0 auto 80px;
  background-color: #fff;
  overflow: hidden;
}

p.sec_featuredesc {
  text-align: justify;
  color: #fff;
  width: 85%;
  margin: 0 auto;
  letter-spacing: 0px;
}

.sec_head {
  text-align: center;
  padding: 70px 0;
  position: relative;
}

.sec_headicon {
  display: flex;
  justify-content: center;
  margin-bottom: 10px;
}

.sec_play {
  width: 44px;
  height: 34px;
  border: 2px solid #5a5551;
  border-radius: 6px;
  display: inline-block;
  position: relative;
}

.sec_play::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 55%;
  transform: translate(-50%, -50%);
  width: 0;
  height: 0;
  border-top: 7px solid transparent;
  border-bottom: 7px solid transparent;
  border-left: 10px solid #5a5551;
}

.sec_title {
  font-size: 34px;
  letter-spacing: 4px;
  color: #5a5551;
  font-weight: normal;
  margin-bottom: 12px;
}

.sec_subtitle {
  letter-spacing: 1px;
  padding-top: 10px;
}

.sec_en,
.point_en {
  font-family: garamond-premier-pro, serif !important;
  font-size: 22px;
  color: #5a5551;
  letter-spacing: 3px;
}

.sec_mh4,
.sec_mh4,
.point_mh4 {
  margin-bottom: 13px;
  font-style: italic;
  font-size: 24px !important;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: garamond-premier-pro, serif !important;
  letter-spacing: 2px;
  font-weight: 100;
}

.sec_mh4::before,
.point_mh4::before,
.sec_mh4::after,
.point_mh4::after {
  content: "";
  height: 1px;
  width: 15px;
  background-color: #2d2d2d;
  display: inline-block;
}

.sec_cover .mh2 {
  color: #2d2d2d;
  font-size: 40px;
  letter-spacing: 2px;
}

.icon_sec {
  width: 48px;
}

.sec_badge {
  position: absolute;
  right: 40px;
  top: 0;
  display: flex;
  gap: 12px;
}

.sec_badge span {
  width: 110px;
  height: 110px;
  border-radius: 50%;
  background-color: #cfcac7;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-size: 14px;
  line-height: 1.5;
  letter-spacing: 1px;
}

.sec_featurecover {
  display: flex;
  gap: 1%;
  width: 100%;
  counter-reset: sec_step;
}

.sec_feature {
  background-color: #fff;
  display: flex;
  flex-direction: column;
  width: 44%;
  position: relative;
  counter-increment: sec_step;
}

.sec_feature::before {
  content: counter(sec_step);
  position: absolute;
  top: 10px;
  left: 10px;
  width: 100px;
  height: 100px;
  background-image: url("../img/number.svg");
  background-size: contain;
  background-repeat: no-repeat;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 60px;
  font-weight: 500;
  color: #fff;
  font-family: garamond-premier-pro, serif !important;
}

#yomimono .sec_feature::before,
#ai .sec_feature::before {
  content: none;
  display: none;
}

.sec_featureimg {
  width: 100%;
  display: block;
}

.sec_featuretext {
  background-color: #e8a998;
  color: #fff;
  text-align: center;
  height: 195px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}

.sec_featuretitle {
  font-size: 21px;
  letter-spacing: 1px;
  padding: 28px 0 14px;
  font-weight: 600;
  font-family: YuMincho, 'Yu Mincho', serif !important;
}

.sec_featuredesc {
  font-size: 13px;
  line-height: 1.9;
  letter-spacing: 1px;
}

.point {
  max-width: 1200px;
  margin: 60px auto 0;
  background-color: #fff;
  padding: 10px 60px 50px;
  text-align: center;
}

.point_en {
  text-align: center;
  margin: 0 auto 36px;
}

.point_cover {
  display: flex;
  flex-wrap: wrap;
  gap: 50px 40px;
  justify-content: center;
}

.point_box {
  text-align: center;
  width: 30%;
}

.point_img {
  width: 100%;
  display: block;
  margin-bottom: 14px;
}

.point_title {
  font-size: 18px;
  padding: 10px 0;
  font-weight: bold;
}

.point_desc {
  letter-spacing: 0.5px;
  text-align: justify;
}

.icon_renewal {
  width: 106px;
  position: absolute;
  right: 54.5%;
  top: 35%;
}

.sec_merit p {
  color: #db6956;
  font-weight: bold;
  font-size: 13px !important;
  line-height: 1.4 !important;
}

.sec_merit {
  background-color: #fffda6;
  width: 78px;
  position: absolute;
  top: 0;
  left: 5%;
  padding: 16px 0;
  border-radius: 0 0 6px 6px;
}

.sec_merit span {
  display: block;
  font-size: 18px;
  text-decoration: underline;
}

/* ▼status start */
.status_cover {
  position: absolute;
  right: 2%;
  top: -5%;
  display: flex;
}

.status_round {
  border-radius: 50%;
  width: 190px;
  height: 190px;
  display: flex;
  justify-content: center;
  background-color: #d3d3d3;
  align-items: center;
  z-index: 1;
}

.next {
  margin-left: -12px;
  z-index: 1;
}

.status_round p {
  color: #fff;
  font-size: 31px !important;
  line-height: 1.3 !important;
  font-weight: bold;
  margin-top: 5px;
}

.status_round span {
  color: #fff;
  font-size: 24px !important;
}

.status_kaigyou {
  display: block;
  padding-left: 8px;
}

.status_cross {
  color: #fff;
  position: relative;
  z-index: 3;
}

.status_cross:before {
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
}

.status_cross:after {
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

.status_cross:before,
.status_cross:after {
  content: "";
  position: absolute;
  width: 2px;
  height: 30px;
  background-color: currentColor;
  top: 77px;
  right: 4px;
}

/* ▼status end */

/* ▼coupon start */
/* ----------------------------------------------------- */
.coupon_cover {
  width: 100%;
  background-color: #eeac9c;
  padding-bottom: 170px;
}

.mh2_coupon,
.mh2_coupon span {
  color: #fff;
}

.coupon_item {
  display: flex;
  justify-content: center;
  gap: 2%;
  width: 700px;
  margin: 0 auto;
}

.coupon_cover p {
  width: 700px;
  margin: 0 auto;
  text-align: justify;
  color: #2d2d2d;
  padding-top: 30px;
}

/* ▼coupon end */
/* ----------------------------------------------------- */

/* ▼mag*/
/* ----------------------------------------------------- */
.mag_cover {
  width: 1200px;
  margin: 0 auto;
  padding-bottom: 200px;
  /*padding-top: 150px;*/
}

.top-webmagazine .wm-inner {
  margin: 10px 16px 0 !important;
}

b {
  margin: 15px 3% 0 0 !important;
}

.top-webmagazine h2 {
  background: #c6cccf !important;
  color: white !important;
  border-radius: 0 !important;
  border: none !important;
  margin: 0 0 15px !important;
  padding: 10px 0 !important;
  font-size: 24px !important;
}


.tf_b {
  /* padding-bottom: 40px; */
  text-align: center;
}

.tf_b a {
  text-decoration: none;
  color: #111;
}

.garamond {
  font-family: 'EB Garamond', serif !important;
  font-weight: normal;
  letter-spacing: 2px;
}

/* ▼幅毎の調整 
/* ----------------------------------------------------- */

/*