/*======注文フォーム======*/
/*商品欄のレイアウト*/
.orderboxwrap {
	position: relative;
	margin-bottom: 85px;
}
.orderboxwrap.tea {
	margin-bottom: 0 !important;
}
.orderboxwrap .box {
	margin-bottom: 75px;
}
.order .box .count:first-child {
	margin-top: 7px;
}
.order .box .count {
	display: flex;
	justify-content: center;
	width: fit-content;
}
.order .box .count .cell {
	position: relative;
}
.order .box .count .cell select {
	padding: 0 2px;
	margin-right: .5em;
	cursor: pointer;
	width: 100px;
	background: #fff;
	border: 1px solid #c2c2c2;
	border-radius: 3px;
}
.order .box .count .cell::after {
	font-family: "Font Awesome 6 Free";
	content: "\f107";
	display: block;
	font-weight: bold;
	font-size: 14px;
	line-height: 1;
	position: absolute;
	top: 48%;
	right: 15px;
	transform: translateY(-50%);
	z-index: 1;
	pointer-events: none;
	color: #333;
}
.count p {
	white-space: nowrap;
	margin-right: 13px;
}
@media (max-width: 750px) {
	.order .box .image {
		margin-bottom: 12px;
	}
}
@media (max-width: 550px) {
	.orderboxwrap .box {
		margin-bottom: 55px;
	}
	.orderboxwrap {
		margin-bottom: 65px;
	}
}
/*見出し*/
.orderboxwrap .mtitle {
	margin-bottom: 17px;
}
@media (max-width: 550px) {
	.orderboxwrap .mtitle {
		margin-bottom: 10px;
	}
}
.ptitle {
	position: relative;
	font-weight: 700;
	margin-bottom: 70px;
	letter-spacing: 0.1em;
	font-size: 1.85rem;
	text-align: center;
}
.ptitle::after {
	content: '';
	display: block;
	width: 80px;
	height: 1px;
	border-radius: 5px;
	margin: 5px auto 0;
	opacity: 0.75;
}
.greentea .ptitle::after {
	border-bottom: 5px solid #0c8948;
}
.greentea .mtitle {
	background: #0c8948;
}
.greentea .info_table tr {
	border-bottom: 2px dotted #66bd90;
}
/*
.info .info_table tr:first-child th, .info .info_table tr:first-child td {
	padding-top: 0;
}
*/
.intrtext {
	padding: 0 10px 17px;
	border-bottom: 2px dotted #f1a947;
}
.intrtext p {
	margin-bottom: 0;
}
.greentea .intrtext {
	border-bottom: 2px dotted #66bd90;
}
@media (max-width: 550px) {
	/*
	.info .info_table tr:first-child td {
		padding-top: 6px;
	}
	*/
	.greentea .info_table tr {
		border-bottom: none;
	}
	.greentea .info_table td {
		border-bottom: 2px dotted #66bd90;
	}
	.intrtext {
		padding-bottom: 15px;
	}
}
.tea .ptitle::after {
	border-bottom: 5px solid #f1a947;
}
/**/
.fbold {
	font-weight: 700;
	font-size: 107%;
	display: block;
	margin-bottom: 3px;
}
.fbold::before {
	font-family: "Font Awesome 6 Free";
	content: "\f06c";
	font-weight: bold;
	margin-right: 5px;
}
.greentea .fbold::before {
	color: #0c8948;
}
.tea .fbold::before {
	color: #f1a947;
}
@media (max-width: 550px) {
	.fbold {
		font-size: 100%;
	}
	.ptitle {
		font-size: 1.35rem;
		margin-bottom: 37px;
	}
	.ptitle::after {
		width: 55px;
	}
}
/*合計金額とリセットボタン*/
.order .total {
	text-align: center;
	margin: 85px 0 95px;
	padding: 20px 0;
	background-color: #fff6e8;
}
.order .total .mfp {
	display: inline-block;
}
.order .total .total_main {
	font-weight: 700;
	font-size: 1.2rem;
	margin-bottom: 5px;
}
.order .button_wrap button::before {
	display: none;
}
.order .button_wrap .reset {
	font-size: 0.8rem;
	color: #0c8948;
	background: #fff;
	border: 1px solid #0c8948;
	margin-top: 13px;
	width: 180px !important;
}
.order .button_wrap .reset:hover {
	color: #fff;
	background: #0c8948;
}
@media (max-width: 550px) {
	.order .total {
		margin: 40px 0 53px;
	}
	.order .total .total_main {
		font-size: 1.13rem;
		margin-bottom: 3px;
	}
	.total_sub {
		font-size: 0.87rem;
	}
}
/*===メールフォーム(共通)==============================*/
.mailform .mtitle {
	font-size: 1rem;
	padding-left: 10px;
	margin-bottom: 0;
	margin-top: 35px;
	background-color: #e1ede7;
	color: #333;
	border-left: 6px solid #0c8948;
}
.mailform .mtitle:first-child {
	margin-top: 0;
}
.mailform .mtitle::after {
	content: none;
}
.mailform {
	margin: 0 auto;
	max-width: 1050px;
}
.mailform .row {
	padding: 20px 0;
	display: flex;
	justify-content: space-between;
}
.mailform .row:not(.last) {
	border-bottom: 1px dotted #cccccc;
}
.mailform .row div:nth-child(1) {
	width: 28%;
	font-weight: 500;
	font-size: 0.9rem;
}
.mailform .row div:nth-child(2) {
	width: 70%;
	line-height: 1.5;
}
.mailform .row span {
	color: #fff;
	background: #0c8948;
	padding: 5px;
	margin-right: 5px;
	font-size: 11px;
	vertical-align: middle;
	font-weight: 500;
}
.mailform .row small {
	display: block;
	margin-top: 3px;
}
.mailsp {
	background: #fff !important;
	border: 1px solid #0c8948;
	color: #0c8948 !important;
}
.mailform .box, .mailform textarea {
	border: 1px solid #ddd;
	padding: 5px;
	width: 100% !important;
	border-radius: 0;
	-webkit-appearance: none;
	margin-bottom: 5px;
	background: #fff;
	max-width: 100%;
}
.mailform .postal_btn {
	padding: 2px 10px;
	background: #0c8948;
	color: #fff;
	border-radius: 2px;
	margin-top: 5px;
	border: 1px solid #0c8948;
}
.mailform .postal_btn:hover {
	background: #0c8948;
	opacity: 0.9;
}
.mailform button {
	display: block;
	text-align: center;
	transition: .6s;
	font-size: 1rem;
	font-weight: 500;
	padding: 9px 5px !important;
	margin: 0 auto;
	width: 230px !important;
	background: #0c8948;
	border: 1px solid #0c8948;
	color: #fff;
}
.mailform button:hover {
	background: #fff;
	color: #0c8948;
}
.mailform button::before {
	font-family: "Font Awesome 6 Free";
	content: "\f0e0";
	font-weight: 700;
	margin-right: 10px;
}
.row.last {
	margin-bottom: 25px;
}
@media (max-width: 750px) {
	.mailform .row {
		padding: 20px 0;
		flex-direction: column;
	}
	.mailform .row div:nth-child(1) {
		width: 100%;
		margin-bottom: 20px;
	}
	.mailform .row div:nth-child(2) {
		width: 100%;
	}
	.mailform .row:first-child {
		padding-top: 0;
	}
}
/*チェックボックス*/
input[type=checkbox] {
	display: none;
}
input[type=checkbox] + label {
	display: inline-block;
	padding-left: 20px;
	position: relative;
	margin-right: 20px;
	margin-bottom: 10px;
	cursor: pointer;
}
input[type=checkbox] + label::before {
	background: #fff;
	border: 1px solid #999;
	content: '';
	display: block;
	position: absolute;
	top: 55%;
	transform: translate(0, -50%);
	left: 0;
	width: 15px;
	height: 15px;
	border-radius: 3px;
}
input[type=checkbox] + label::after {
	border-right: 3px solid #0c8948;
	border-bottom: 3px solid #0c8948;
	content: '';
	display: block;
	height: 15px;
	left: 8px;
	margin-top: -7px;
	opacity: 0;
	position: absolute;
	top: 36%;
	width: 5px;
	transform: rotate(45deg) translate3d(0, 2px, 0) scale3d(.7, .7, 1);
	transition: transform .2s ease-in-out, opacity .2s ease-in-out;
}
input[type=checkbox]:checked + label::after {
	opacity: 1;
	transform: rotate(45deg) scale3d(1, 1, 1);
}
@media (max-width: 750px) {
	input[type=checkbox] + label {
		display: block;
	}
}
/*ラジオボタン*/
input[type=radio] {
	display: none;
}
input[type=radio] + label {
	display: inline-block;
	padding-left: 20px;
	position: relative;
	margin-right: 20px;
	margin-bottom: 10px;
	cursor: pointer;
}
input[type=radio] + label::before {
	content: "";
	display: block;
	position: absolute;
	top: 55%;
	transform: translate(0, -50%);
	left: 0;
	width: 15px;
	height: 15px;
	background: #f4f4f4;
	border-radius: 100%;
	border: 1px solid #b4b4b4;
	cursor: pointer;
	text-align: center;
	transition: all 250ms ease;
}
input[type=radio]:checked + label::before {
	background-color: #0c8948;
	box-shadow: inset 0 0 0 2px #f4f4f4;
}
input[type=radio]:focus + label::before {
	outline: none;
	border-color: #0c8948;
}
input[type=radio]:disabled + label::before {
	box-shadow: inset 0 0 0 2px #f4f4f4;
	border-color: #b4b4b4;
	background: #b4b4b4;
}
input[type=radio] + label:empty::before {
	margin-right: 0;
}
@media (max-width: 750px) {
	input[type=radio] + label {
		display: block;
	}
}
/*特定商取引法に基づく表記*/
.nomgb {
	margin-bottom: 65px;
}
@media(max-width:1100px) {
	.nomgb {
		margin-bottom: 50px;
	}
}
@media(max-width:550px) {
	.nomgb {
		margin-bottom: 40px;
	}
}