html,body{
	margin:0;
	padding:0;
}
#ol_shop {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
	color: #333;
}
#ol_shop a{
	transition: all 0.3s ease 0s;
	text-decoration:none;
	color: #07c;
}
#ol_shop a:hover{
	filter: alpha(opacity=60);
	-moz-opacity:0.6;
	opacity:0.6;
}
#ol_shop {
    width: 650px;
    margin: 0 auto;
}

#ol_shop .w90 {
	width: 90%;
	margin-right: auto;
	margin-left: auto;
}


#ol_shop > .w90 > p,
#ol_shop .flx_itxt p {
    font-size: 20px;
	color: #5c5c5c;
}

#ol_shop > .w90 > p {
	margin-bottom: 5%;
}

#ol_shop > .w90 > figure {
	margin-bottom: 3%;
}

#ol_shop > .w90 .note {
	display: block;
    font-size: 16px;
	margin-bottom: 5%;
}

#ol_shop strong {
    color: #ed6e8e;
	font-weight: bold;
}


/* ======================================
bace
====================================== */
#ol_shop h2 {
    margin: 11% auto 7%;
    display: flex;
    border: 3px solid #f2a1b6;
    background-color: #fffcfd;
    font-family: dnp-shuei-mgothic-std, sans-serif;
    font-weight: 600;
    font-style: normal;
    line-height: 1;
    border-radius: 8px;
	position: relative;
}

#ol_shop h2 .h2_nmbr {
	width: 13%;
	padding: 2% 0%;
	display: flex;
    flex-direction: column;
    justify-content: center;
	background-color: #ffdde6;
    color: #ed6e8e;
    text-align: center;
    font-size: 18px;
    border-radius: 5px 0 0 5px;
}

#ol_shop h2 .h2_nmbr b {
    display: block;
    font-size: 36px;
    padding-top: 6%;
}

#ol_shop h2 .h2_txt {
    width: 87%;
    padding: 4% 3%;
    line-height: 1.4;
}

#ol_shop h2 .h2_txt strong {
    font-size: 26px;
    margin-top: 1%;
    line-height: 1.3;
	display: inline-block;
}

#ol_shop .flx_itxt {
    display: flex;
    justify-content: center;
	margin-bottom: 5%;
}

#ol_shop .flx_itxt figure {
    width: 30%;
    margin-right: 4%;
}

#ol_shop .flx_itxt p {
	width: 62%;
}

#ol_shop .pink_b {
    width: 80%;
    margin: 0 auto 3%;
    position: relative;
}

#ol_shop .pink_b:last-child {
    margin-bottom: 0;
}

#ol_shop .pink_b a {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 4% 6%;
    text-align: center;
    text-decoration: none;
    line-height: 1.5;
    border-radius: 100px;
    color: #fff;
    background-color: #f982a0;
    font-family: dnp-shuei-mgothic-std, sans-serif;
    font-weight: 600;
    letter-spacing: 1px;
    font-size: 20px;
}

#ol_shop .pink_b::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 22px;
    width: 9px;
    height: 9px;
    border-top: solid 1.5px #fff;
    border-right: solid 1.5px #fff;
    transform: translateY(-50%) rotate(45deg);
    z-index: 2;
}

/* ======================================
上下ライン
====================================== */

#ol_shop .h3_line {
    margin: 15% 0 5%;
	padding: 6% 0;
	border-top: 3px solid #f2a1b6;
	border-bottom: 3px solid #f2a1b6;
	text-align: center;
	font-size: 21px;
    position: relative;
}

#ol_shop .h3_line h3 {
	font-family: dnp-shuei-mgothic-std, sans-serif;
    font-weight: 600;
}

#ol_shop .h3_line .pink_bg {
    padding: 1% 10%;
    color: #fff;
    background-color: #ee7897;
    font-family: dnp-shuei-mgothic-std, sans-serif;
    font-weight: 600;
    width: fit-content;
    margin: 0 auto;
    border-radius: 31px;
}

#ol_shop .h3_line .tel {
    color: #ee7897;
    font-family: dnp-shuei-mgothic-std, sans-serif;
    font-weight: 600;
    margin: 0% 0;
    font-size: 60px;
}


/* ======================================
アイコン調整
====================================== */

#ol_shop h2.icon_track::after {
    content: "";
    position: absolute;
    width: 81px;
    height: 65px;
    right: 3%;
    bottom: 9%;
    background: url(/introduction/privilege/assets/img/icon_track.png) center / contain no-repeat;
}

#ol_shop h2.icon_present::after {
    content: "";
    position: absolute;
    width: 87px;
    height: 87px;
    right: 2%;
    top: 11%;
    background: url(/introduction/privilege/assets/img/icon_present.png) center / contain no-repeat;
}

#ol_shop h2.icon_muryo::after {
    content: "";
    position: absolute;
    width: 67px;
    height: 57px;
    right: 4%;
    top: 50%;
    transform: translateY(-50%);
    background: url(/introduction/privilege/assets/img/icon_muryo.png) center / contain no-repeat;
}

#ol_shop h2.icon_ope::before {
    content: "";
    position: absolute;
    width: 60px;
    height: 60px;
    right: 4%;
    top: 50%;
    transform: translateY(-50%);
    background: url(/introduction/privilege/assets/img/icon_ope.png) center / contain no-repeat;
}

#ol_shop .h3_line.icon_mail::before {
    content: "";
    position: absolute;
    width: 160px;
    height: 58px;
    left: 50%;
    transform: translateX(-50%);
    background: url(/introduction/privilege/assets/img/icon_mailmag.png) center / contain no-repeat;
    top: -26%;
}

#ol_shop .h3_line.icon_tell::before {
    content: "";
    position: absolute;
    width: 160px;
    height: 58px;
    left: 50%;
    transform: translateX(-50%);
    background: url(/introduction/privilege/assets/img/icon_tell.png) center / contain no-repeat;
    top: -13%;
}


/* ======================================
テーブル
====================================== */
#ol_shop .y_table {
	margin-top: 10%;
	background-color: #fffdee;
	border-radius: 20px;
}

#ol_shop .y_table th,
#ol_shop .y_table td {
	display: block;
	width: 100%;
}

#ol_shop .y_table th {
    padding: 3% 8%;
    background-color: #fff7d4;
    font-family: dnp-shuei-mgothic-std, sans-serif;
    font-weight: 600;
    color: #5c5c5c;
    text-align: left;
    font-size: 23px;
    letter-spacing: 1px;
}

#ol_shop .y_table td {
	padding: 6% 7%;
    color: #5c5c5c;
    font-size: 20px;
}

#ol_shop .y_table tr:first-child th {
	border-radius: 20px 20px 0 0;
}

/* ======================================
ボタン
====================================== */
.fixed-btn {
    position: fixed;
    right: 5%;
    bottom: 5%;
    animation: anim-scale 0.5s ease-out;
    transform-origin: 50% 50%;
}


@media screen and (max-width: 750px) {
    /* ======================================
    bace
    ====================================== */
    #ol_shop {
        width: 100%;
    }
    #ol_shop > .w90 > p, #ol_shop .flx_itxt p {
        font-size: 3.4vw;
    }
    #ol_shop > .w90 .note {
        font-size: 2.9vw;
    }
    #ol_shop h2 {
        border: 2px solid #f2a1b6;
    }
    #ol_shop h2 .h2_txt {
        font-size: 3.4vw;
    }
    #ol_shop h2 .h2_nmbr {
        font-size: 3vw;
    }
    #ol_shop h2 .h2_nmbr b {
        font-size: 6vw;
    }
    #ol_shop h2 .h2_txt strong {
        font-size: 3.9vw;
    }
    #ol_shop .pink_b {
        width: 100%;
    }
    #ol_shop .pink_b a {
        font-size: 3.9vw;
    }
    /* ======================================
    上下ライン
    ====================================== */
    #ol_shop .h3_line .tel {
        font-size: 11vw;
    }
    #ol_shop .h3_line .pink_bg {
        font-size: 4vw;
    }
    #ol_shop .h3_line .info {
        font-size: 3.4vw;
    }
    /* ======================================
    テーブル
    ====================================== */
    #ol_shop .y_table th {
        font-size: 4.1vw;
    }
    #ol_shop .y_table td {
        font-size: 3.6vw;
    }
    /* ======================================
    アイコン調整
    ====================================== */
    #ol_shop h2.icon_present::after {
        width: 57px;
        height: 57px;
        right: 2%;
        top: 50%;
        transform: translateY(-50%);
    }
    #ol_shop h2.icon_track::after {
        width: 49px;
        height: 36px;
        right: 2%;
        bottom: 9%;
    }
    #ol_shop h2.icon_muryo::after {
        width: 39px;
        height: 39px;
        right: 3%;
    }
    #ol_shop h2.icon_ope::before {
        width: 62px;
        height: 51px;
    }
    #ol_shop .h3_line {
        margin: 15% 0 5%;
        padding: 9% 0 5%;
        border-top: 2px solid #f2a1b6;
        border-bottom: 2px solid #f2a1b6;
        text-align: center;
        font-size: 4.3vw;
    }
    #ol_shop .h3_line.icon_tell::before {
        width: 132px;
        height: 42px;
        top: -13%;
    }
    /* ======================================
    ボタン
    ====================================== */
    .fixed-btn {
        right: 2%;
        bottom: 2%;
        width: 80px;
    }
    
}