:root {
  --base-kentakukenpo-beige: #F7F7F4;
  --base-kentakukenpo-red: #D4272B;
  --base-kentakukenpo-gold: #928149;
}
/* ---------------表示制御--------------- */
[data-browse-mode="P"] .sp_only {
    display: none !important;
}

[data-browse-mode="S"] .pc_only {
    display: none !important;
}

/* ---------------コンテンツ--------------- */
/* ----------common---------- */
#kentakukenpo {
    margin-bottom: 100px;
    font-weight: normal;
}

#kentakukenpo h1,
#kentakukenpo h2,
#kentakukenpo h3,
#kentakukenpo h4,
#kentakukenpo h5 {
    font-weight: 500;
    margin: 0;
    padding: 0;
    border: none;
    background-color: transparent;
}

#w-cover img,
.connection img {
    vertical-align: top;
    height: auto;
}

.contents_inner {
    width: 100%;
    max-width: 1000px;
    margin: 40px auto 0;
}

.contents_inner > * + * {
    margin-top: 50px;
}

#kentakukenpo .content {
    background: var(--base-kentakukenpo-beige);
    padding: 0 5px 5px;
    margin-top: 45px;
    margin-bottom: 45px;
}
#kentakukenpo .content-title {
    text-align: center;
    padding: 10px;
    font-size: 22px;
    font-weight: bold;
}
#kentakukenpo .content-inner {
	background: white;
	padding: 2em;
}
#kentakukenpo .content-inner .catch_txt {
	text-align: justify;
	margin: 0;
}
#kentakukenpo .content-inner .catch_txt small {
	font-size: 0.85em;
}
#kentakukenpo .content-sub-title {
    font-weight: bold;
    font-size: 18px;
    margin-top: 24px;
    margin-bottom: 10px;
}
@media screen and (max-width: 768px) {
    .contents_inner {
        width: calc(100% - calc(60 * (100vw / 750)));
        margin: 0 calc(30 * (100vw / 750));
    }
	#kentakukenpo .content-inner {
		padding: 1em;
	}
}

/* ----------mv---------- */
#kentakukenpo h1 img {
    display: block;
    width: 100%;
    max-width: 1000px;
    margin: auto;
}

.catch_txt {
    font-size: 16px;
    text-align: center;
    line-height: 2;
}

.catch_txt span {
    color: var(--base-kentakukenpo-red);
}

@media screen and (max-width: 768px) {
    #kentakukenpo h1 img {
        height: auto;
    }

    .catch_txt {
        font-size: 14px;
        line-height: 1.8;
        margin: 20px auto 30px;
        text-align: justify;
    }
}

/* ----------ご優待内容---------- */
#kentakukenpo .discount-info-details {
  font-size: 18px;
}
#kentakukenpo .discount-info-details .font-red {
    color: var(--base-kentakukenpo-red);
}
#kentakukenpo .discount-info-details .font-w {
  font-size: 1.1em;
  font-weight: bold;
}

#kentakukenpo .discount-info-details li+li {
  margin-top: 5px;
}
@media screen and (max-width: 768px) {
    #kentakukenpo .discount-info-details {
        font-size: 14px;
    }
}
/* ----------エントリーはこちらから---------- */
.entry-content {
    width: 100%;
    padding: 35px;
    background: white;
    border: 5px solid #B8A361;
}
#kentakukenpo .entry-content .entry-title {
	text-align: center;
	font-size: clamp(14px,5.4vw,24px);
	font-weight: bold;
	margin-bottom: 20px;
}
.entry_box .consent_txt {
    display: table;
    margin: auto;
    font-size: 18px;
    text-align: center;
    cursor: pointer;
}
.entry_box .consent_txt:hover {
    opacity: 0.7;
}
.entry_box .consent_txt .is-checkBox {
    display: inline-block;
    vertical-align: middle;
    width: 20px;
    height: 20px;
    background: #fff;
    border: 1px solid #ddd;
    margin-top: -3px;
    margin-right: 12px;
    position: relative;
}
.entry_box .consent_txt.acc_check .is-checkBox::before {
    content: "";
    position: absolute;
    left: 0;
    right: -3px;
    bottom: 0;
    top: -5px;
    margin: auto;
    z-index: 1;
    width: 17px;
    height: 8px;
    border: 3px solid #e03310;
    border-top-style: none;
    border-right-style: none;
    transform: rotate(-45deg);
}
.entry_box .entry-btns {
    display: none;
}
.entry_box .entry-btns a {
    display: block;
    font-size: 18px;
    margin-top: 10px;
    text-align: center;
    padding: 10px;
    border-radius: 100em;
    margin: 20px auto 0;
    font-size: 17px;
    border-radius: 25px;
    border: 1px solid #b8a361;
    background-color: #b8a361;
    color: #fff;
    transition: .5s;
    position: relative;
    max-width: 400px;
    font-weight: bold;
}
.entry_box .entry-btns a:hover {
	color:#b8a361;
	background-color:#fff;
}
.entry_box .entry-btns a::before {
    content: "";
    position: absolute;
    right: 20px;
    top: 0;
    bottom: 0;
    margin: auto;
    background: white;
    height: calc(tan(70deg) * 8px / 2);
    width: 8px;
    clip-path: polygon(0 0, 100% 50%, 0 100%);
}
@media screen and (max-width: 768px) {
    .entry-content {
        padding: 25px 15px;
    }
    .entry_box .consent_txt {
        font-size: 16px;
    }
}
/* ----------同意---------- */
.coupon_box .consent_txt {
    display: flex;
    justify-content: center;
    flex-direction: row-reverse;
    font-size: clamp(10px,4.5vw,23px);
    align-items: center;
    cursor: pointer;
    width: 100%;
    background: #444;
    border: 1px solid #444;
    padding: 10px;
    gap: 10px;
    font-weight: bold;
    position: relative;
    z-index: 1;
    margin-left: auto;
    margin-right: auto;
    color: white;
}

.coupon_box .consent_txt .is-checkBox {
    display: inline-block;
    width: 20px;
    aspect-ratio: 1;
    position: absolute;
    right: 20px;
}

.coupon_box .consent_txt .is-checkBox::before,
.coupon_box .consent_txt .is-checkBox::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    top: 0;
    margin: auto;
    z-index: 1;
    width: 100%;
    height: 2px;
    background: white;
    transition: .2s;
}
.coupon_box .consent_txt .is-checkBox::after {
    transform: rotate(90deg);
}
.coupon_box .consent_txt.acc_check .is-checkBox::after {
    transform: rotate(180deg);
}
.coupon_detail {
    display: none;
    border: 3px solid #444444;
    padding: 30px 3em;
}

@media screen and (max-width: 768px) {
    .consent_txt {
        font-size: 16px;
    }
    .coupon_detail {
        padding: 60px 1em 30px;
        margin-top: -30px;
    }
}
/* ---------- 参加方法 ---------- */
.about-login-step {
    list-style: none;
}
#kentakukenpo .about-login-step .step-title {
    font-size: clamp(10px,4.7vw,20px);
    font-weight: bold;
    margin-bottom: 10px;
}
#kentakukenpo .about-login-step .step-title .step-num {
    background-color: var(--base-kentakukenpo-red);
    color: white;
    padding: 0.2em 0.4em;
    margin-right: 1em;
}
#kentakukenpo .about-login-step .step-content + .step-content {
    margin-top: 4em;
}
#kentakukenpo .about-login-step .step-content > * + * {
    margin-top: 2em;
}
#kentakukenpo .about-login-step .step-content ul li {
    text-indent: -1em;
    padding-left: 1em;
}
#kentakukenpo .about-login-step .step-content ul li + li {
    margin-top: 0.5em;
}
#kentakukenpo .about-login-step .step-content .img-block .figcaption {
    font-weight: bold;
    font-size: 16px;
    margin-bottom: 10px;
}
#kentakukenpo .about-login-step .step-content .link a { text-decoration: underline; }
#kentakukenpo .about-login-step .step-content .login-content {
    background: #f8f7f2;
    padding: 40px;
}
#kentakukenpo .about-login-step .step-content .login-content h4 {
    text-align: center;
    font-weight: bold;
    font-size: clamp(14px,5.4vw,24px);
}
#kentakukenpo .about-login-step .step-content .login-content .login-btns {
    display: flex;
    justify-content: center;
    margin-top: 30px;
    gap: 40px;
}
#kentakukenpo .about-login-step .step-content .login-content .login-btns .text {
    font-size: clamp(12px,4.1vw,18px);
}
#kentakukenpo .about-login-step .step-content .login-content .login-btns a {
    display: block;
    font-size: 18px;
    margin-top: 10px;
    text-align: center;
    padding: 10px;
    border-radius: 100em;
    margin: 20px auto 0;
    font-size: 17px;
    border-radius: 25px;
	border: 1px solid #b8a361;
    background-color: #b8a361;
    color: #fff;
    transition: .5s;
    position: relative;
    font-weight: bold;
}
#kentakukenpo .about-login-step .step-content .login-content .login-btns a:hover {
	color:#b8a361;
	background-color:#fff;
}
#kentakukenpo .about-login-step .step-content .login-content .login-btns a::before {
    content: "";
    position: absolute;
    right: 20px;
    top: 0;
    bottom: 0;
    margin: auto;
    background: white;
    height: calc(tan(70deg) * 8px / 2);
    width: 8px;
    clip-path: polygon(0 0, 100% 50%, 0 100%);
}
@media screen and (min-width: 769px) {
	#kentakukenpo .about-login-step .step-content .login-content .login-btns .btn-wrap {
	    width: calc(50% - 20px);
	    text-align: center;
	}
}
@media screen and (max-width: 768px) {
    #kentakukenpo .about-login-step .step-content + .step-content {
        margin-top: 2.5em;
    }
    #kentakukenpo .about-login-step .step-content > * + * {
        margin-top: 1em;
    }
	#kentakukenpo .about-login-step .step-content .login-content {
	    padding: 20px;
	}
    #kentakukenpo .about-login-step .step-content .login-content .login-btns {
        flex-direction: column;
        gap: 20px;
    }
    #kentakukenpo .about-login-step .step-content .login-content .login-btns .text {
        text-align: center;
    }
    #kentakukenpo .about-login-step .step-content .login-content .login-btns a {
        margin-top: 10px;
    }
	#kentakukenpo .about-login-step .step-title {
		display: flex;
		gap: 10px;
		align-items: flex-start;
	}
	#kentakukenpo .about-login-step .step-title .step-num {
	    margin-right: 0;
	    white-space: nowrap;
	}
}
/* ---------- キャンペーン概要 ---------- */
#kentakukenpo .campagin-detail .content-title {
    padding: 0;
    margin-bottom: 40px;
    position: relative;
}
#kentakukenpo .campagin-detail .content-title::before {
    content: "";
    display: inline-block;
    width: 100%;
    height: 1px;
    background-color: #707070;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    right: 0;
    margin: auto;
    z-index: 0;
}
#kentakukenpo .campagin-detail .content-title .inner {
    background: white;
    padding: 0 1em;
    display: inline-block;
    position: relative;
    z-index: 1;
}
#kentakukenpo .campagin-detail {
        width: 100%;
    }
#kentakukenpo .campagin-detail tbody {
    border: 1px solid #EBEBE5;
    }
#kentakukenpo .campagin-detail tr + tr {
    border-top: 1px solid #EBEBE5;
}
#kentakukenpo .campagin-detail .title {
    background: #FAFAF8;
    vertical-align: middle;
    padding: 1em;
    width: 20%;
}
#kentakukenpo .campagin-detail .detail {
    padding: 1em;
    width: 80%;
    }
#kentakukenpo .campagin-detail .notes-list .notes-list li {
    text-indent: -1em;
    padding-left: 1em;
}
@media screen and (max-width: 768px) {
    #kentakukenpo .campagin-detail tr {
        display: flex;
        flex-direction: column;
    }
    #kentakukenpo .campagin-detail .title,
    #kentakukenpo .campagin-detail .detail{
        width: 100%;
        text-align: justify;
    }
	#kentakukenpo .campagin-detail .content-title {
	    margin-bottom: 20px;
	}
	#kentakukenpo .campagin-detail tbody {
	    border: 0;
	}
	#kentakukenpo .campagin-detail tr + tr {
	    border-top: 0;
	}
}