@charset "UTF-8";

.m_img {
    background-image: url(../images/price/m_img@2x.jpg);
}
/* PC,Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) {
.lead_txt {
	padding: 0 5.5%;
}
}
/*---------------------------------------------------------
com_btn1
---------------------------------------------------------*/
.com_btn1 {
	margin-top: 0;
	max-width: 380px;
	white-space: nowrap;
}
.com_btn1 a {
	width: 100%;
	min-width: auto;
	min-width: max-content;
}
.primenu .com_btn1 {
	flex: 0 1 calc(30%);
	max-width: 360px;
}
.anclist .com_btn1 a {
	color: #492922;
	background-color: #FCF9F5;
}
.anclist .com_btn1 a:hover {
	background-color: #F9E5CB;
}
.primenu .com_btn1 a::before,
.anclist .com_btn1 a::before {
	transform: rotate(90deg);
}#payment .com_btn1,
#deduction .com_btn1 {
	margin-left: auto;
	margin-right: auto;
}
#payment .com_btn1 a::before,
#deduction .com_btn1 a::before {
	content: '\e80b';
	font-size: 75%;
	right: 1.5em;
}
@media only screen and (min-width: 960px) and (max-width: 1140px) {
.primenu .com_btn1 a,
.anclist .com_btn1 a {
	font-size: min(1.8vw,125%);
}
}
/* PC,Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) {
.com_btn1 a {
	min-width: max-content;
}
}
/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
.primenu .com_btn1 {
	flex: 0 1 calc(40%);
}
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.primenu .com_btn1 {
	flex: 0 1 calc(70%);
	max-width: 400px;
}
	
#payment .com_btn1,
#deduction .com_btn1 {
	width: 70%;
}
}
/*---------------------------------------------------------
box1
---------------------------------------------------------*/
.box1 {
	display: flex;
    justify-content: space-between;
	margin-left: auto;
	margin-right: auto;
}
.box1 .hoken .txt_color {color: #69B391;}
.box1 .zihi .txt_color {color: #ED8180;}
.box1 .hoken {background: rgba(116, 200, 178, .1);}
.box1 .zihi {background: rgba(245, 162, 148, .1);}
.box1 li {
	position: relative;
	box-sizing: border-box;
	width: 48%;
	max-width: 620px;
}
.box1 li img {
	position: absolute;
	width: 6em;
	top: -2.2em;
	left: 50%;
	transform: translateX(-50%);
}
.box1 li dl {
	box-sizing: border-box;
	padding: 80px 6% 40px;
}
.box1 li dt {
	text-align: center;
	font-weight: bold;
	font-size: 165%;
	font-size: min(165%,2.5vw);
	letter-spacing: .18em;
	line-height: 1.2em;
	margin-bottom: .8em;
	padding-bottom: .8em;
}
.box1 li.hoken dt {border-bottom: 1px solid #74C8B2;}
.box1 li.zihi dt {border-bottom: 1px solid #F5A294;}
/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
.box1 li dl {
	padding: 20% 6% 8%;
}
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.box1 {
	display: block;
}
.box1 li {
	width: 100%;
	max-width: 100%;
	margin-bottom: 14%;
}
.box1 li:last-child {
	margin-bottom: 0;
}
.box1 li img {
	width: 5em;
	top: -1.7em;
}
.box1 li dl {
	box-sizing: border-box;
	padding: 20% 6% 8%;
}
.box1 li dl:last-child {
	margin-bottom: 0;
}
.box1 li dt {
	font-size: 140%;
}
}
/*---------------------------------------------------------
primenu
---------------------------------------------------------*/
.primenu {
	display: flex;
	flex-wrap: wrap;
	gap: 0 2%;
}
.primenu.jus_c {
	justify-content: center;
}
/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
.primenu > li:last-of-type {
	margin-top: 1em;
}
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.primenu > li {
	margin-top: .8em;
}
.primenu > li:first-child {
	margin-top: 0;
}
}
/*---------------------------------------------------------
anclist
---------------------------------------------------------*/
.anclist {
	display: grid;
	justify-content: space-between;
	flex-wrap: wrap;
	row-gap: 1.5em;
}
.anclist.jus_c {
	justify-content: center;
}
.anclist .com_btn1 {
	max-width: 290px;
}
/* PC
------------------------------------------*/
@media only screen and (min-width: 960px) {
.anclist {
	grid-template-columns: repeat(4, min(290px,24%));
}
}
@media only screen and (min-width: 960px) and (max-width: 1140px) {
.anclist {
	row-gap: 1.2em;
}
}
/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
.anclist {
	grid-template-columns: repeat(3, 31.5%);
}
/* .anclist .com_btn1 {
	flex: 0 1 calc(30%);
} */
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.anclist {
	row-gap: .8em;
	grid-template-columns: repeat(2, 48.5%);
}
}
/*---------------------------------------------------------
plice list
---------------------------------------------------------*/
#pricelist h5 {
	position: relative;
	font-weight: bold;
	font-size: min(125%,2vw);
	letter-spacing: .15em;
	line-height: 1.4em;
	font-feature-settings: "halt";
	padding-left: 1.6em;
	margin-bottom: 1em;
}
#pricelist h5::before {
	position: absolute;
	font-family: 'fontello';
	content: '\e800';
	font-size: 115%;
	color: #ffd000;
	top: -.1em;
	left: 0;
}
.tbl_price {
	text-align: left;
	border-bottom: 1px solid rgba(73, 41, 34, .15);
	width: 100%;
}
.tbl_price th,
.tbl_price td {
	box-sizing: border-box;
	border-top: 1px solid rgba(73, 41, 34, .15);
	font-weight: normal;
}
.tbl_price th {
	width: 73.5%;
	vertical-align: top;
	padding: 50px 0;
	padding-left: 0;
}
.tbl_price th .flt_box {
	overflow: hidden;
}
.tbl_price th .flt_box .img_l {
	width: 31%;
	max-width: 290px;
	float: left;
}
.tbl_price th .flt_box .txt_r {
	width: 64%;
	box-sizing: border-box;
	float: right;
}
.tbl_price th .txt_r {
	padding-right: 5.5%;
}
.tbl_price th dt {
	font-size: 190%;
	font-size: min(190%,2.6vw);
	letter-spacing: .15em;
	line-height: 1.4em;
	margin-bottom: .5em;
}
.tbl_price th dt .txt_small {
	font-size: 75%;
	letter-spacing: .15em;
	line-height: 1.4em;
}
.tbl_price th .pick_title {
	display: flex;
	align-items: center;
}
.tbl_price th .pick_title span:not(.ft_min) {
	display: inline-block;
	box-sizing: border-box;
	background: #f5a294;
	color: #fff;
	font-size: 50%;
	font-weight: bold;
	letter-spacing: .1em;
	line-height: 1;
	border-radius: 2em;
	padding: .8em 3%;
	margin-right: .8em;
	white-space: nowrap;
}
.tbl_price th .pick_title span.ft_min {
	white-space: nowrap;
}
.tbl_price th dd .caption {
	color: #a49490;
	font-size: 85%;
	letter-spacing: .05em;
	line-height: 1.7em;
	margin-top: .8em;
}
.tbl_price td {
	width: 26.5%;
	background: #FCF9F5;
	vertical-align: middle;
	padding: 40px 1%;
	text-align: center;
	font-size: 100%;
	font-size: min(100%,1.4vw);
}
.tbl_price td .price_txt {
	margin-top: 30px;
}
.tbl_price td .price_txt:first-child {
	margin-top: 0;
}
.tbl_price td .price_txt dt {
	font-weight: bold;
	color: #DF7C00;
	line-height: 1.5em;
	margin-bottom: .3em;
}
.tbl_price td p.price_txt,
.tbl_price td .price_txt dd {
	font-weight: bold;
	font-size: 125%;
	font-size: min(125%,1.7vw);
	letter-spacing: .15em;
	line-height: 1.7em;
}
.tbl_price td p.price_txt.price_free,
.tbl_price td .price_txt.price_free dd {
	font-size: 145%;
}
.tbl_price td .price_txt .tax {
	display: block;
	font-size: 75%;
	letter-spacing: .15em;
	line-height: 1.8em;
}
.tbl_price td .price_txt .ft_jos {
	font-weight: 500;
	font-size: 120%;
	margin-right: .15em;
}
.tbl_price td .price_txt .tax .ft_jos {
	margin-left: .15em;
}
.tbl_price th .type {
	margin-top: 30px;
}
.tbl_price th .type dl{
	display: flex;
	align-items: flex-start;
	margin-bottom: 1.2em;
}
.tbl_price th .type dl:last-child{
	margin-bottom: 0;
}
.tbl_price .pink,
.tbl_price .blue {
	box-sizing: border-box;
	text-align: center;
	width: 13em;
	font-size: 100%;
	font-weight: bold;
	color: #fff !important;
	padding: .5em;
	margin-left: auto;
	margin-right: auto;
	border-radius: 2em;
}
.tbl_price .pink {background-color: #F5A294;}
.tbl_price .blue {background-color: #97CCD9;}
.tbl_price td .price_txt dt.pink,
.tbl_price td .price_txt dt.blue {
	width: 11em;
	padding: .3em;
	margin-bottom: .5em;
}
.tbl_price th .type dd {
	width: calc(100% - 13em);
	margin-left: .5em;
}
/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
.tbl_price th {
	padding: 4% 0;
}
.tbl_price th .txt_r {
	padding-right: 4%;
}
.tbl_price th dt {
	letter-spacing: .1em;
	margin-bottom: .3em;
}
.tbl_price th dt .txt_small {
	letter-spacing: .1em;
}
.tbl_price td {
	padding: 4% 1%;
	letter-spacing: .1em;
}
.tbl_price td .price_txt {
	margin-top: 9%;
}
.tbl_price td p.price_txt,
.tbl_price td .price_txt dd {
	line-height: 1.5em;
}
.tbl_price th .type {
	margin-top: 3%;
}
.tbl_price th .type dl {
	font-size: 90%;
	margin-bottom: .7em;
}
.tbl_price th .type dt.pink,
.tbl_price th .type dt.blue {
	width: 11em;
}
.tbl_price th .type dd {
	width: calc(100% - 11em);
}
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
	
#pricelist h5 {
	font-size: 110%;
	padding-left: 1.3em;
	margin-bottom: .8em;
}
	
.tbl_price tr,
.tbl_price th,
.tbl_price td {
	display: block;
	box-sizing: border-box;
	width: 100%;
}
.tbl_price td {
	border-top: none;
}
.tbl_price th {
	width: 100%;
	padding: 8% 3% 5%;
}
.tbl_price th .flt_box .img_l {
	width: 60%;
	margin: 0 auto 1.4em;
	float: none;
}
.tbl_price th .flt_box .txt_r {
	width: 100%;
	max-width: 100%;
	float: none;
}
.tbl_price th .txt_r {
	padding: 0;
}
.tbl_price th dt {
	text-align: center;
	font-size: 140%;
	letter-spacing: .05em;
	line-height: 1.2em;
	margin-bottom: .5em;
}
.tbl_price th dt .txt_small {
	letter-spacing: normal;
}
.tbl_price th .pick_title {
	flex-direction: column;
}
.tbl_price th .pick_title span:not(.ft_min) {
	font-size: 70%;
	padding: .8em 6%;
	margin-right: 0;
}
.tbl_price th .pick_title span.ft_min {
	margin-top: .5em;
}
.tbl_price th dd .caption {
	letter-spacing: normal;
}
.tbl_price td {
	font-size: 95%;
	letter-spacing: .1em;
	padding: 1.4em 0 1.2em;
}
.tbl_price td .price_txt {
	margin-top: 3%;
}
.tbl_price td dl.price_txt {
	display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
}
.tbl_price td .price_txt dt,
.tbl_price td .price_txt dd {
	margin: 0 .5em;
}
.tbl_price td p.price_txt,
.tbl_price td .price_txt dd {
	font-size: 100%;
	letter-spacing: .1em;
	line-height: 1.4em;
}
.tbl_price td p.price_txt.price_free,
.tbl_price td .price_txt.price_free dd {
	font-size: 130%;
}
.tbl_price td .price_txt .tax {
	font-size: 80%;
}
.tbl_price th .type {
	letter-spacing: normal;
	margin-top: 5%;
}
.tbl_price th .type dl {
	font-size: 90%;
	margin-bottom: .5em;
}
.tbl_price th .type dt.pink,
.tbl_price th .type dt.blue {
	width: 10.5em;
}
.tbl_price td .price_txt dt.pink,
.tbl_price td .price_txt dt.blue {
	width: 10em;
	font-size: 95%;
	letter-spacing: normal;
	margin: 0;
}
.tbl_price th .type dd {
	width: calc(100% - 10.5em);
}
}
/*---------------------------------------------------------
payment
---------------------------------------------------------*/
.payment {
	padding: 110px 0 140px;
	background: rgba(223, 124, 0, .1);
}
#payment h4 {
	background: #DF7C00;
	text-align: center;
	color: #fff;
	font-size: 130%;
	font-size: min(130%, 2.4vw);
	letter-spacing: .15em;
	line-height: 1.4em;
	padding: .8em 3%;
}
#payment .card ul {
	display: flex;
    justify-content: space-between;
    align-items: center;
	margin-left: auto;
	margin-right: auto;
	width: 70%;
	max-width: 700px;
}
#payment .card ul li {
	width: 15%;
	max-width: 100px;
}
#payment .card .touch {
	width: 100%;
	max-width: 180px;
	display: flex;
	justify-content: space-between;
	margin-left: auto;
	margin-right: auto;
	
}
#payment .card .touch img {
	width: 16%;
	max-width: 29px;
}
#payment .card .touch p {
	margin-left: .8em;
}
/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
.payment {
	padding: 10% 0 12%;
}
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.payment {
	padding: 12% 0 14%;
}
#payment h4 {
	font-size: 110%;
	letter-spacing: .1em;
	padding: .6em 3%;
}
#payment .card ul {
	width: 100%;
}
#payment .card .touch {
	width: 42%;
}
#payment .card .touch img {
	width: 12%;
}
#payment .card .touch p {
	font-size: 90%;
	margin-left: .4em;
}
}
/*---------------------------------------------------------
deduction
---------------------------------------------------------*/
.deduction {
	padding: 110px 0 140px;
}
#deduction .formula {
	background: #FCF9F5;
	box-sizing: border-box;
	border-radius: 30px;
	text-align: center;
	font-weight: bold;
	padding: 40px 0;
}
#deduction .formula > div {
	display: inline-block;
}
#deduction .formula p:nth-child(1){
	position: relative;
	text-align: left;
	font-size: 140%;
	font-size: min(148%,2.4vw);
	letter-spacing: .1em;
	line-height: 1.4em;
	margin-bottom: .5em;
}
#deduction .formula p .small1 {
	font-size: 65%;
	letter-spacing: .1em;
}
#deduction .formula p .small2 {
	font-size: 85%;
	letter-spacing: .1em;
}
#deduction .formula p .small3 {
	font-size: 95%;
	letter-spacing: .1em;
}
#deduction .formula p .col1 {
	color: #DF7C00;
}
#deduction .formula p .col2 {
	color: #AA9AC1;
}
#deduction .formula p sup {
	font-size: 60%;
}
#deduction .formula p:nth-child(2) {
	text-align: right;
	line-height: 1.4em;
	padding-left: 1em;
	text-indent: -1em;
}
/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
.deduction {
	padding: 10% 0 12%;
}
#deduction .formula {
	padding: 4% 0;
}
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.deduction {
	padding: 12% 0 14%;
}
#deduction .formula {
	padding: 8% 0;
}
 #deduction .formula p:nth-child(1){
	font-size: 100%;
	letter-spacing: .05em;
}
#deduction .formula p .small1 {
	letter-spacing: .05em;
}
#deduction .formula p .small2 {
	letter-spacing: .05em;
}
#deduction .formula p:nth-child(2) {
	font-size: 90%;
	letter-spacing: .05em;
}
}
/*---------------------------------------------------------

---------------------------------------------------------*/

/* PC,Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) {}
/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {}