@charset "UTF-8";
/* ------------------------
    index.php
------------------------ */
#top_part img.main {
		position: absolute;
		top: 15px;
		left: 475px;
		max-width: 540px;
}
#top_part h1 img {
    max-width: 440px;
}
#price #top_part {
    margin: 0px 5px;
}

#top_part p {
		margin: 10px 0 30px 20px;
		padding: 0;
		line-height: 1em;
}
#top_part p img {
	max-width: 325px;
}
#top_part .grid {
		margin: 0 0 5px 25px;
		max-width: 440px;
}
#top_part .grid .col {
	max-width: 100px;
	padding: 10px 5px 0;
}
@media screen and (max-width: 768px) {
	#price #top_part {
		margin: -3px 2px;
	}
	#top_part h1 img {
		width: calc(100% - 30px);
	}
	#top_part p {
		margin: 10px 30px 30px;
	}
	#top_part .main_wrap {
		width: auto;
		height: 0;
		display: block;
		background-image: url(./img/top-bg.jpg);
		background-repeat: no-repeat;
		background-size: contain;
		background-position: center center;
		padding-top: 73.2%;
		margin: 40px 0 0;
		position: relative;
	}
	#top_part img.main {
		display: block;
		margin: auto;
		width: 90%;
		top: -50px;
		left: 0;
		right: 0;
	}
	#top_part .grid {
        margin: 20px auto 0;
        justify-content: center;
        padding: 0 15px;
	}
}

#part2 {
		margin: 60px 20px 80px;
		padding: 0;
		line-height: 1em;
}
#part2.price-index {
	margin: 60px 0 80px;
}

#part2 span.type {
		max-width: 435px;
		margin: 0 0 50px 25px;
		padding: 0;
		line-height: 1em;
		float: left;
}

#part2 .btn_price {
		margin: 0 auto 40px auto;
		clear: both;
}

#article #part2 {
		margin: 0;
}
#part2 h2.dotted small {
	margin: 0;
	display: inline-block;
}
#part2 .txtCenter {
    margin: 0 0 60px;
}
#part2 .txtCenter a {
    display: block;
    margin-top: 12px;
}
@media screen and (max-width: 768px) {
	.price-index .dotted {
		margin: 0 20px 25px 20px;
	}
	#part2 {
		margin: 40px 0;
	}
	#part2 .txtCenter {
		margin: 0 0 30px;
	}
	#part2 span.type {
		margin: 0 25px 20px;
	}
}

#part3 {
		margin: 0 18px;
		padding: 0;
}
#part3 h2 .sp {
	display: none;
}
#part3 h3.moya {
	width: 100%;
    max-width: 410px;
}

#part3 .left_img,
#part3 .right_img {
		display: flex;
		justify-content: space-between;
		margin: 15px 0;
		padding: 0;
}

#part3 .right_img {
	flex-direction: row-reverse;
}

#part3 .left_img .alignleft {
		/* float: left; */
		margin: 15px 20px 30px 32px;
		padding: 0;
}

#part3 .right_img .alignright {
		/* float: right; */
		margin: 15px 30px 30px 0;
		padding: 0;
}

#part3 .left_img .text,
#part3 .right_img .text {
		/* float: left; */
		max-width: 440px;
		width: 100%;
}

#part3 .left_img p,
#part3 .right_img p {
		/* margin: 0 0 0 40px; */
		margin: 0;
		line-height: 2em;
}

#part3 .left_img blockquote {
		margin: 10px 7px 8px 38px;
		padding: 7px 12px 5px 12px;
		font-size: 0.85em;
}

#part3 .left_img blockquote strong {
		display: block;
		font-size: 1em;
		margin: 1px 0 2px 0;
		padding: 0;
}

#part3 .left_img blockquote.options {
		margin: 10px 7px 8px 38px;
		padding: 7px 12px 5px 12px;
		font-size: 0.85em;
}
#part3 + .txtCenter {
	margin: 0 20px;
}
@media screen and (max-width: 600px) {
	#part3 h2 .sp {
		display: block;
		width: calc(100% + 20px);
		max-width: 300px;
	}
	#part3 h2 .pc {
		display: none;
	}
}

.options {
		margin: 10px 7px 8px 38px;
		padding: 7px 12px 5px 12px;
		font-size: 0.85em;
}

.why {
		/*font-size: 1.2em;
	line-height: 1.9em;
	letter-spacing: 1px;*/
		margin: 40px 0 60px 0;
}

.option {
		margin: 60px 0 60px 0;
		border-bottom: 1px dotted #ccc;
}

.discount {
		margin: 0px 0 80px -2px;
		position: relative;
}

.discount img {
		float: left;
		margin: 0;
}

/* .discount span {
		position: relative;
		top: 330px;
		left: -700px;
} */

.center {
		text-align: center;
}

/*アコーディオン*/
/*ボックス全体*/
.accbox {
		margin: 0 auto auto 35px;
		padding: 0;
		max-width: 850px;
		/*最大幅*/
}

/*ラベル*/
.accbox label {
		display: block;
		margin: 1.5px 0;
		padding: 11px 12px;
		color: #ffffff;
		font-weight: bold;
		background: #29b2c8;
		cursor: pointer;
		transition: all 0.5s;
		border-radius: 6px;
		-webkit-border-radius: 6px;
		/* for Safari and Chrome 対応*/
		-moz-border-radius: 6px;
		/* for Firefox 対応*/
}

/*ラベルホバー時*/
.accbox label:hover {
		background: #bee7ee;
}

/*チェックは隠す*/
.accbox input {
		display: none;
}

/*中身を非表示にしておく*/
.accbox .accshow {
		height: 0;
		padding: 0;
		overflow: hidden;
		opacity: 0;
		transition: 0.8s;
}

/*クリックで中身表示*/
.cssacc:checked + .accshow {
		height: auto;
		padding: 5px;
		background: #ffffff;
		opacity: 1;
}

/* ------------------------
    価格について price.php
------------------------ */
#contents:has(.page-price) #inner {
	padding: 5px 0 0;
}
.page-price h1 {
    margin: 30px 20px 0;
    padding: 40px 0 20px 60px;
	font: bold 2em/1em hanazonoFont, "ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", serif;
	color: #d48697;
	letter-spacing: 1px;
    position: relative;
    z-index: 1;
}
.page-price h1::before {
    content: '';
    display: block;
    position: absolute;
    width: 95px;
    height: 92px;
    background-image: url(../img/bg_article_h1.png);
    background-repeat: no-repeat;
    background-size: contain;
    left: 0;
    top: 0;
    z-index: -1;
}
.page-price .str-box {
	background-color: #f8f5f3;
    margin: 20px 20px 30px;
	padding: 20px 10px;
	box-sizing: border-box;
	-webkit-border-radius: 5px;
	border-radius: 5px;
}
.page-price .str-box p {
	margin: 0;
}
.page-price ul {
    list-style: none;
    padding: 0;
    margin: 0;
}
.page-price ul li {
	padding: 0;
}
.page-price .type {
    color: #000;
    padding: 30px 18px;
    border-bottom: 1px solid #fff;
    background-color: #35a5b9;
    margin: 0 5px;
    width: calc(100% - 10px);
    box-sizing: border-box;
}
.page-price .type .slider {
    padding-bottom: 35px;
}
.page-price .type p {
    padding: 20px 0;
    line-height: 1.7;
    color: #fff;
}
.page-price .type figure:nth-of-type(2) {
    padding: 0 10px 20px 15px;
}
.page-price .type figure:nth-of-type(3) {
    padding: 0 10px 0 15px;
}
.page-price .type.type01 figure:nth-of-type(1) {
    margin-left: -8px;
    padding-right: 18px;
}
.page-price .type.type02 figure:nth-of-type(1) {
    margin-left: -8px;
    padding-right: 90px;
}
.page-price .type.type03 figure:nth-of-type(1) {
    padding: 0 53px 0;
}
.page-price .ac-price p {
    padding: 0;
}
.page-price .ac-price p .btn {
    margin-top: 10px;
    border: 0 none;
    background-color: #fff;
    color: #35a5b9;
}
.page-price .ac-price p .btn::after {
    background-image: url(../lp/img/ico_arrow02.png);
    transform: rotate(90deg);
    transition: all .5s;
}
.page-price .ac-price p .btn.open::after {
    transform: rotate(-90deg);
    transition: all .5s;
}
.page-price .ac-price ul {
    display: none;
}
.page-price .ac-price ul li {
    overflow-x: scroll;
}
.page-price .ac-price ul li .ac-table {
    text-align: center;
    margin-top: 15px;
    width: 200%;
    border: 1px solid #9d9f9f;
    color: #000;
}
.page-price .new_price .ac-price ul li .ac-table {
	width: 100%;
	min-width: 850px;
}
.page-price .ac-price ul li .ac-table thead {
    background-color: #e4e4e4;
}
.page-price .ac-price ul li .ac-table thead th {
    font-weight: bold;
    text-align: center;
    padding: 10px;
    border-left: 1px solid #9d9f9f;
}
.page-price .ac-price ul li .ac-table thead th:first-of-type {
    border-left: 0 none;
}
.page-price .ac-price ul li .ac-table tbody tr {
    background-color: #fff;
}
.page-price .ac-price ul li .ac-table tbody tr:nth-of-type(even) {
    background-color: #e4e4e4;
}
.page-price .ac-price ul li .ac-table tbody tr th {
    font-weight: bold;
    padding: 10px;
    text-align: center;
}
.page-price .ac-price ul li .ac-table tbody tr td {
    border-left: 1px solid #9d9f9f;
    padding: 10px;
}
.page-price .five-minutes {
    margin: 35px 0;
}
.page-price .chapter-m {
    display: block;
    font-size: 19px;
    font-family: hanazonoFont, "ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", serif;
    font-weight: normal;
    letter-spacing: 2px;
    border-bottom: 2px solid #F3A8BB;
    padding-bottom: 10px;
    margin-bottom: 25px;
}
.page-price .chapter-l {
    display: block;
    font-family: hanazonoFont, "ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", serif;
    font-size: 22px;
    font-weight: normal;
    color: #fff;
    letter-spacing: 2px;
    background-color: #F3A8BB;
    padding: 20px 30px;
    box-sizing: border-box;
    line-height: 1.7;
    border-bottom: 1px solid #fff;
    position: relative;
}
.btn02 {
	display: block;
	position: relative;
	width: 85%;
	color: #fff;
	letter-spacing: 1px;
	border-radius: 30px;
	margin: 0 auto 15px;
	padding: 20px 0 20px 15px;
	box-sizing: border-box;
}
.btn02::before {
	content: '';
	display: block;
	position: absolute;
	margin: auto;
	top: 0;
	bottom: 0;
	left: 40px;
	background-repeat: no-repeat;
	background-size: contain;
}
.btn02.ico-est::before {
	width: 30px;
	height: 33px;
	background-image: url(../img/ico_est.png);
}

.btn02.ico-mail::before {
	width: 30px;
	height: 29px;
	background-image: url(../img/ico_mail.png);
}

.btn02 img {
    display: block;
	width: 50%;
	margin: 0 auto;
}
.page-price .accordion {
    margin-bottom: 30px;
}
.page-price .accordion dt h2 {
    margin-bottom: 0;
    border-bottom: 1px solid #fff;
    position: relative;
}
.page-price .accordion dt h2::after {
    content: '';
    display: block;
    position: absolute;
    width: 7px;
    height: 12px;
    background: url(../img/ico_arrow01.png) no-repeat;
    background-size: contain;
    margin: auto;
    top: 0;
    bottom: 0;
    right: 15px;
    transform: rotate(90deg);
    transition: all .5s;
}
.page-price .accordion dt.open h2::after {
    transform: rotate(-90deg);
    transition: all .5s;
}
.page-price .accordion dd {
    margin-top: 30px;
    display: none;
}
.page-price .option .chapter-m {
    margin-bottom: 15px;
    color: #e7286c;
}
.page-price .discount {
    margin-bottom: 35px;
}
.page-price .discount .chapter-m {
    margin-bottom: 15px;
    color: #e7286c;
    font-size: 20px;
    font-weight: bold;
    padding-left: 5px;
}
.page-price .discount em {
    display: block;
    margin-bottom: 10px;
}
.page-price .discount p {
    font-size: 18px;
    font-weight: bold;
}
.page-price .discount p span {
    color: #da115f;
    font-size: 20px;
}
.page-price .discount .dis-cap {
    display: block;
    text-align: center;
}
.page-price .discount .dis-cap span {
    padding: 5px;
    margin: 10px 0;
    border-top: 1px dotted #888;
    border-bottom: 1px dotted #888;
    display: inline-block;
}
.page-price .discount .dis-cap small {
    display: block;
    text-align: left;
}
.page-price .discount.discount04 .dis-cap {
    text-align: left;
}
.page-price .osowari {
    overflow: hidden;
    text-align: center;
}
.page-price .osowari .grid .col {
    margin-bottom: 15px;
}
.page-price .osowari .grid .col p span {
    display: block;
}
#price section {
    padding: 0 8px;
}
#price section.sec01 {
    padding: 0;
    margin-bottom: 30px;
}
#price section.sec01 .headline {
    text-align: left;
    margin-top: 15px;
    padding: 0 8px;
}
#price section.sec01 .txt-discount {
    padding: 5px 8px;
    font-weight: bold;
    margin: 5px 0 25px;
    border-top: 1px solid #ccc;
    border-bottom: 1px solid #ccc;
}
#price section.sec02 {
    padding-bottom: 30px;
}
#price section.sec03 {
    padding-bottom: 15px;
}
.page-price .price-link {
    padding: 30px 0 0;
    margin-bottom: 30px;
}
.page-price .sec02 .pro figure {
    padding: 0 0 30px;
}
.page-price .sec02 .pro .chapter-m {
    margin: 25px 0 15px;
}
.page-price .sec02 .pro p {
    margin-bottom: 15px;
}
.page-price .sec02 .pro blockquote {
    padding: 10px 5px;
    background-color: #f7fbdc;
    margin-bottom: 15px;
}
.page-price .accordion dd .option{
	padding: 0 10px;
    margin: 10px 0 30px;
}
.page-price .discount .dis-cap span {
    margin: 10px 0 20px;
}
.page-price .discount .dis-cap a {
	display: block;
}


@media screen and (min-width: 769px) {
	.page-price h1 {
		font-size: 2.6em;
		margin: 30px 25px 0;
		padding: 80px 0 0 100px;
		min-height: 105px;
	}
	.page-price h1::before {
		width: 190px;
		height: 185px;
	}
	#price section.sec01 {
		margin-bottom: 50px;
	}
	.page-price .type {
		display: flex;
		flex-wrap: wrap;
		align-items: center;
        gap: 4%;
	}
	.page-price .type .slider {
		order: 1;
		width: 48%;
        margin-top: 30px;
	}
	.page-price .type .text {
		width: 48%;
	}
	.btn {
        display: block;
        position: relative;
        line-height: 62px;
        color: #fff;
        border-bottom: 2px solid #646361;
        text-align: center;
        letter-spacing: 1px;
    }
	.btn::after {
		content: '';
		display: block;
		position: absolute;
		width: 7px;
		height: 12px;
		background: url(../img/ico_arrow01.png) no-repeat;
		background-size: contain;
		margin: auto;
		top: 0;
		bottom: 0;
		right: 15px;
	}
	.str-box-ef {
        border: 1px #ccc dashed;
        margin: 20px 0 5px ;
        padding: 20px 15px;
        box-sizing: border-box;
        border-radius: 5px;
        -webkit-border-radius: 5px;
        -moz-border-radius: 5px;
	}
	.page-price .ac-price {
		width: 100%;
		order: 2;
	}
	.page-price .ac-price p .btn {
		max-width: 48%;
	}
	.page-price .sec03 .link {
		display: flex;
        gap: 20px;
		justify-content: center;
	}
	.page-price .sec03 .link a {
		max-width: 310px;
        margin: 0 0 50px;
	}
	.page-price .ac-price ul li .ac-table {
		width: 100%;
	}
	.page-price .delivery {
		display: flex;
		flex-wrap: wrap;
	}
	.page-price .delivery li {
		width: 25%;
		background-color: #eb8799;
	}
	.page-price .delivery li:first-child {
		width: 100%;
		border-bottom: solid 1px #fff;
	}
	.page-price .delivery li:first-child img {
		max-width: 500px;
		display: block;
		margin: 0 auto;
	}
	.page-price .accordion dd {
		display: block;
		padding: 0 15px;
	}
	.page-price .accordion dt h2::after {
		display: none;
	}
	.page-price .accordion dd .option {
		display: flex;
		flex-wrap: wrap;
        gap: 20px 50px;
		border: none;
	}
	.page-price .accordion dd .discount {
		gap: 0;
        max-width: 850px;
        margin: 0 auto;
	}
	.page-price .accordion dd .option .col {
		width: calc(50% - 25px);
	}
	.page-price .accordion dd .discount .col {
		width: 50%;
	}
	.page-price .accordion dd .discount .dis-cap {
		margin-left: 40px;
	}
	.page-price .discount .dis-cap span {
		margin: 20px 0 30px;
	}
	.page-price .col.col-l-6 {
		width: 20%;
	}

}



/* ------------------------
    cover.php
------------------------ */
.page-cover {
		position: relative;
		z-index: 1;
}

.chara {
		position: relative;
		display: flex;
		flex-wrap: wrap;
		justify-content: space-around;
		margin: 0 auto 20px;
		z-index: -1;
}

.chara figure {
		width: 40%;
}

.chara figure img {
		max-width: 100%;
}

.cover {
		display: flex;
		flex-wrap: wrap;
		align-items: flex-start;
		justify-content: center;
		margin: 60px -10px 20px;
		box-sizing: border-box;
}

.cover * {
		box-sizing: border-box;
}

.cover-grid {
		display: flex;
		flex-wrap: wrap;
		width: 50%;
		padding: 0 10px;
		margin-bottom: 30px;
}

.cover-grid--text {
		display: block;
		width: 100%;
		text-align: center;
		margin: -25px 0 45px;
}

.cover-grid--3 {
		margin-bottom: 10px;
}

.cover-grid--3 + .cover-grid--text {
		margin-top: 0;
}

.cover-grid__image {
		width: 50%;
		padding: 0 5px;
}

.cover-grid__image strong {
		display: block;
		text-align: center;
		font-size: 15px;
		font-weight: bold;
		color: #4d4d4d;
		margin: 0 0 5px 0;
}

.cover-grid__image a {
		display: block;
}

.cover-grid__image a img {
		display: block;
		max-width: 100%;
		margin: 0 auto 15px;
}

.cover-grid__image p {
		text-align: center;
}

.cover-grid__text {
		width: 100%;
		text-align: center;
}

.cover-cont {
		text-align: center;
		margin-bottom: 60px;
}

.cover-cont-chara {
		display: flex;
		flex-wrap: wrap;
		align-items: flex-end;
		justify-content: space-between;
		position: relative;
		z-index: 0;
}

.cover-cont-chara figure {
		width: 40%;
}

.cover-cont-chara figure img {
		display: block;
		margin: 10px auto 0;
}

.cover-btn01{
		display: inline-block;
		background-color: #2fa7b8;
		font-size: 20px;
		color: #fff;
		border-radius: 20px;
		padding: 15px 30px;
		box-shadow: 2px 2px 4px rgba(0, 0, 0, 0.6);
		margin-bottom: 15px;
		line-height: 1.6;
}



.center img {
	width: 100%;
	margin-bottom: 10px;
}
#part3 .left_img blockquote {
	margin-left: 0 !important;
}
#part3 .right_img blockquote {
	margin-left: 0 !important;
}
.price-img_flex {
	display: flex;
	justify-content: space-between;
}
.price-img_flex img {
	width: 50%;
}
#waribiki img  {
	width: 50%;
}
.price-column {
	display: flex;
    padding: 0;
    margin: 0 0 0 0;
    list-style: none;
    max-width: 900px;
    width: 100%;
    justify-content: space-between;
}
.price-column li {
    display: block;
    padding: 0;
    margin: 30px 0 0 0;
    max-width: 401px;
	width: 100%;
    float: none;
}
.center.zoomico_flex {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}
.zoomico_flex a {
	width: 18%;
	padding: 5px;
}
.option_clearfix {
	max-width: 600px;
    width: 100%;
    margin: 0 auto;
}
.price_overflow {
	overflow-x: scroll;
	padding-top: 40px;
}
.min-w {
	min-width: 700px;
}


@media screen and (max-width: 1000px) {
	#part3 .left_img,
	#part3 .right_img {
		display: flex;
        flex-wrap: wrap;
        margin: 15px 0;
        padding: 0;
		flex-direction: row;
	}
	#part3 .right_img .alignright {
		/* float: right; */
		margin: 15px auto 30px auto;
		padding: 0;
	}
	#part3 .left_img .text,
	#part3 .right_img .text {
		/* float: left; */
		max-width: none;
		width: 100%;
	}
	#part3 .left_img .alignleft {
		/* float: left; */
		margin: 15px auto 30px auto;
		padding: 0;
	}
	.price-column {
		display: block;
	}
	.price-column li {
		max-width: none;
	}
	.price-why_flxe {
		margin: 40px 0 60px 0;
    	display: flex;
    	flex-wrap: wrap;
	}
	.price-why_flxe >.flame_236.alignright {
		margin: 0 auto 20px !important;
	}
	.zoomico_flex a {
		width: 18%;
		padding: 5px;
	}
}


@media screen and (max-width: 600px) {
	.price-img_flex {
		display: block;
	}
	.price-img_flex img {
		width: 100%;
	}
	#part3 .left_img,
	#part3 .right_img {
		display: flex;
        flex-wrap: wrap;
        margin: 15px 0;
        padding: 0;
	}
	.zoomico_flex a {
		width: 30%;
		padding: 5px;
	}
}