@charset "utf-8";
* {
	margin: 0;
	padding: 0;
}
body {
	font-size: 14px;
	font-family: "Roboto", sans-serif;
	font-optical-sizing: auto;
	font-weight: 900;
	font-style: normal;
	font-variation-settings:
	"wdth" 100;
	line-height: 1.6;
	margin: 0px auto;
	background-size: auto auto;
	background-color: rgba(193, 245, 241, 1);
	background-color: #fff;
	background-image:
		radial-gradient(#d9ecff 15%, transparent 10%),
		radial-gradient(#ffbcbc 15%, transparent 10%);
	background-size: 40px 40px;
	background-position: 0 0, 20px 20px;
}
h2 {
	font-size: 40px;
	font-weight: 900;
	line-height: 0.9;
}
h3 {
	font-size: 20px;
	font-weight: 900;
	line-height: 1.2;
	letter-spacing: 1px;
}
a {
	text-decoration: none;
	-webkit-transition: 0.3s ease-in-out;
	transition: 0.3s ease-in-out;
	word-break: break-word;
	overflow-wrap: anywhere;
}
a:hover {
	opacity: 0.6;
	-webkit-transition: 0.3s ease-in-out;
	transition: 0.3s ease-in-out;
}
img {
	max-width: 100%;
	vertical-align: bottom;
}
.pc {
	display: block !important;
}
.sp {
	display: none !important;
}
ul {
	list-style: none;
}
.content {
	position: relative;
	z-index: 2;
	max-width: 1050px;
	margin: 115px auto 0px;
	padding: 0px 60px;
}
.utikeshi {
	text-decoration: line-through
}
/*フッター*/
footer {
	position: relative;
	margin: 0px auto;
	padding: 50px 30px;
	background-color: #fff;
	z-index: 2;
}
footer .footer {
	max-width: 1050px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin: 0px auto;
}
footer .footer div {
	display: flex;
	align-items: center;
}
footer .footer div a {
	width: 153px;
	margin-right: 25px;
}
/*フッター*/
.mb05 {
	margin-bottom: 5px !important;
}
.mb15 {
	margin-bottom: 15px !important;
}
.mb25 {
	margin-bottom: 25px !important;
}
.mb45 {
	margin-bottom: 45px !important;
}
.mt45 {
	margin-top: 45px !important;
}
.youtube_area {
	max-width: 560px;
	margin: 0px auto;
	background-color: #fff;
	padding: 25px;
}
.youtube {
	position: relative;
	width: 100%;
	padding-top: 56.25%;
}
.youtube iframe {
	position: absolute;
	top: 0;
	right: 0;
	width: 100%;
	height: 100%;
}

@media screen and (max-width: 850px) {
	.content {
		margin: 90px auto 0px;
	}
}
@media only screen and (max-width: 600px) {
	.pc {
		display: none !important;
	}
	.sp {
		display: block !important;
	}
	.content {
		margin: 60px auto 0px;
	}
	footer .footer {
		flex-wrap: wrap;
	}
	footer .footer div {
		flex-wrap: wrap;
		justify-content: center;
	}
	footer .footer div a {
		width: 100%;
		margin-right: 0px;
		margin-bottom: 25px;
		text-align: center;
	}
	footer .footer div a img {
		width: 183px;
	}
}



.side{
	position: relative;
	overflow: hidden;
}
.content::before {
	content: "";
	position: absolute;
	z-index: -1;
	top:-130px;
	left: -10vw;
	background-image: url("../images/side-le.png");
	background-size: 100%;
	background-repeat: repeat-y;
	width: 300px;
	height: 100%;
}
.content::after {
	content: "";
	position: absolute;
	z-index: -1;
	top:-150px;
	right: -150px;
	background-image: url("../images/side-ri.png");
	background-size: 100%;
	background-repeat: repeat-y;
	width: 300px;
	height: 100%;
}

.main_bg {
	position: relative;
	width: 100%;
	margin: 0px auto;
	background-image: url("../images/db_main_bg.png");
	width: auto;
	height: 80vh;
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center;
	display: flex;
	justify-content: center;
	align-items: end;
	overflow: hidden;
}
.main_catch {
	text-align: center;
}
.main_catch img {
	width: auto;
	height: 77vh;
	margin: auto;
}
.main_catch p {
	font-size: 20px;
	margin-top: 35px
}
.bg {
	position: relative;
	width: 100%;
	margin: 0px auto;
	padding: 75px 0px;
	/*
	background-size: auto auto;
	background-color: rgba(193, 245, 241, 1);
	background-color: #fff;
	background-image:
		radial-gradient(#d9ecff 15%, transparent 15%),
		radial-gradient(#ffbcbc 15%, transparent 15%);
	background-size: 40px 40px;
	background-position: 0 0, 20px 20px;
	*/
}
.bg::before {
	content: "";
	width: 100%;
	margin: 0px auto;
	background-image: url("../images/db_main_under.png");
	height: 130px;
	background-size: contain;
	background-repeat: repeat-x;
	background-position: top;
	position: absolute;
	top: 0px;
}
.toTop {
	position: fixed;
	bottom: 20px;
	right: 20px;
	width: 100px;
	height: auto;
	margin: 0;
	text-align: right;
	vertical-align: baseline;
	float: right;
	z-index: 50;
	cursor: pointer;
}
.toTop img {
	width: 100%;
	height: auto;
}
.txt_con {
	position: relative;
	margin-bottom: 75px;
}
.txt_con.last {
	margin-bottom: 0px;
}
.txt_con h2 {
	position: absolute;
	top: -20px;
	right: 0;
	left: 0;
	margin: 0px auto;
	z-index: 2;
	display: inline-block;
	text-align: center;
}
.txt_con h2 span {
	background-color: #3868d2;
	border-radius: 40px;
	padding: 8px 60px;
	color: #fff;
	font-size: 30px;
	box-shadow: inset 10px 10px 0 rgba(0,0,0,.1);
	box-shadow: 10px 10px 0 #c0defb;
}
.news, .txt_item, .txt_goods {
	position: relative;
	padding: 75px 70px;
	background-color: #ffffff;
	border-radius: 40px;
	box-shadow: 10px 10px 0 #c0defb;
}
.news li {
	display: flex;
	padding-bottom: 10px;
	border-bottom: 2px dotted #97C8E6;
	margin-bottom: 15px;
}
.news li.last {
	margin-bottom: 0px;
}
.news li p {
	font-size: 16px;
	letter-spacing: 0.1em;
}
.news li .day {
	color: #ed7591;
	font-size: 18px;
	line-height: 1;
	font-weight: 700;
	margin-right: 35px;
}
.txt_item li {
	display: flex;
	margin-bottom: 35px;
}
.txt_item li p {
	font-size: 16px;
	letter-spacing: 0.1em;
	line-height: 2em;
}
.txt_item li h5 {
	font-size: 16px;
	font-weight: 900;
	color: #3868d2;
}
.txt_item li .sub_txt {
	width: 120px;
	height: 100%;
	margin-right: 24px;
	background: #f7931e;
	border-radius: 40px;
	color: #fff;
	font-weight: 700;
	text-align: center;
	line-height: 1.4;
	padding: 7px 0px;
}
.txt_item li .sub_txt.tume {
	letter-spacing: -1px;
}
.sub_con {
	width: 84%;
}
.txt_item li .sub_con_p {
	width: 85%;
	display: flex;
}
.txt_item li .sub_con_p .sub_item {
	width: 25%;
	padding: 10px 10px 15px;
	margin-right: 20px;
	background: #fff;
}
.txt_item li .sub_con_p .sub_item:last-child {
	margin-right: 0px;
}
.txt_item li .sub_con_p .sub_item img {
	margin-bottom: 15px;
}
.txt_item li .sub_con_p .sub_item p {
	font-size: 15px;
	font-weight: 700;
	text-align: center;
}
.txt_link {
	display: inline-block;
	color: #008BE2;
	margin-right: 20px;
}
.txt_link.none {
	color: #000;
}
.txt_link.none:hover {
	opacity: 1.0;
}
.txt_link p {
	font-weight: 700;
	border-bottom: 2px solid #008BE2;
	overflow-wrap: anywhere;
}
.txt_link.none p {
	border-bottom: 0px solid #008BE2;
}
p .txt_link span {
	font-weight: 700;
	border-bottom: 2px solid #008BE2;
}
.news .txt_link {
	margin-right: 0px;
	font-weight: 700;
	border-bottom: 0px solid #008BE2;
}
.news .txt_link p, .news .txt_link span {
	border-bottom: 0px solid #008BE2;
}
.tyui_link {
	display: inline-block;
	color: #008BE2;
	font-weight: 700;
	border-bottom: 2px solid #008BE2;
	line-height: 1.5em;
	overflow-wrap: anywhere;
}
p.big {
	font-weight: 700;
}
.small, .sub_con .small {
	font-size: 14px !important;
	margin-bottom: 10px;
}
.txt_item li.cs {
	font-size: 28px;
	color: #8B7A73;
	font-weight: 700;
	margin-bottom: 0px;
}
.txt_item li.cs h4 {
	margin: auto;
	text-align: center;
	color: #000;
}
.txt_goods {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
.txt_goods li.goods_txt {
	width: 100%;
	padding: 0px;
	margin-bottom: 35px;
	background: #fff0;
	text-align: center;
}
.txt_goods li.goods_txt .txt {
	font-size: 25px;
	font-weight: 900;
	margin-bottom: 10px;
}
.red {
	font-weight: 900;
	color: #D7591B;
}
.txt_red {
	font-size: 20px;
	font-weight: 900;
	color: #D7591B;
}
.txt_red_ev {
	font-size: 18px;
	font-weight: 900;
	color: #D7591B;
	margin-top: 35px;
	text-align: center;
}
.youtube_area .txt_red_ev {
	margin-top: 0px;
}
.txt_goods li {
	width: 43%;
	padding: 20px 20px 10px;
	margin-bottom: 35px;
	background: #d9ecff;
}
.txt_goods li .goods_img {
	width: 100%;
	margin-bottom: 25px;
	border: 0px solid #A77C6B;
}
.txt_goods li .goods_list {
	display: flex;
	justify-content: space-between;
	margin-bottom: 20px;
}
.txt_goods li .goods_list .sub_txt {
	color: #3868d2;
	font-weight: 700;
}
.txt_goods li .goods_list .sub_con {
	width: 80%;
}
.goods_txt .tyui_con {
	font-size: 16px;
	letter-spacing: 0.1em;
	line-height: 2em;
	text-align: left;
}
.txt_item.tyui li {
	display: block;
	max-width: 775px;
	margin: 0px auto 50px;
}
.txt_item.cp li {
	display: block;
}
.txt_item.tyui li .small {
	margin-top: -30px;
	margin-bottom: 30px;
}
.txt_item.tyui h4 {
	font-size: 20px;
	color: #E10000;
	margin-bottom: 30px;
}
.tyui_txt {
	display: inline-block;
	font-size: 16px;
	font-weight: 700;
	color: #fff;
	padding: 5px 20px;
	background: #f7931e;
	border-radius: 30px;
	margin-bottom: 14px;
}
.txt_item.tyui .tyui_con {
	margin-bottom: 30px;
}
.txt_item.tyui .tyui_con .soroe {
	padding-left: 118px;
}
li.last {
	margin-bottom: 0px !important;
}
.goods_btn {
	padding: 10px;
	text-align: center;
	font-weight: 900;
	background-color: #ff6c91;
	margin-bottom: 20px;
	border-radius: 40px;
}
.goods_btn a {
	font-size: 16px;
	color: #fff;
}
.tuiki {
	font-weight: 900;
}
.red_midashi {
	font-size: 20px;
	color: #fff;
	font-weight: 900;
	background: #C64810;
	padding: 2px 0px;
}
#senkou_01, #djcd {
	padding-top: 55px;
	margin-top: -55px;
}
.txt_link.g_t_link {
	margin-bottom: 20px;
	margin-right: 0px;
}
.txt_link .zizen {
	font-size: 20px;
}
.cp_sub {
	padding: 20px;
	background-color: #FFFAF1;
}
/*sp*/
@media screen and (max-width: 1200px) {
	.main_catch img{
		width: auto;
		height: 70vh;
	}
}
@media screen and (max-width: 1050px) {
	.news, .txt_item, .txt_goods {
		padding: 75px 60px;
	}
	.main_bg{
		width: auto;
		height: 70vh;
	}
	.main_catch img{
		width: auto;
		height: 60vh;
	}
}
@media screen and (max-width: 900px) {
	.main_bg{
		width: auto;
		height: 60vh;
	}
	.main_catch img{
		width: auto;
		height: 50vh;
	}
}
@media screen and (max-width: 850px) {
	.content::before{
		left: -100px;
	}
	.content::after{
		right: -100px;
	}
	.txt_item li .sub_con_p {
		flex-wrap: wrap;
	}
	.txt_item li .sub_con_p .sub_item {
		margin-bottom: 20px;
	}
	.txt_con h2 span {
		font-size: 20px;
		display: inline-block;
		padding: 18px 60px;
	}
	.txt_con h2.long{
		top: -30px;
	}
	.txt_con h2.long span {
		padding: 18px 20px;
		line-height: 1.2;
	}
}
@media screen and (max-width: 600px) {
	.txt_goods li {
		width: 100%;
	}
}
@media screen and (max-width: 600px) {
	.content {
		padding: 0px 30px;
	}
	.content::before {
		left: -100px;
		width: 180px;
	}
	.content::after {
		right: -100px;
		width: 180px;
	}
	.top_btn {
		right: 20px;
		bottom: 20px;
	}
	.top_btn a img {
		width: 80px;
	}
	.main_bg {
		background-image: url("../images/db_main_bg_sp.png");
		height: 480px;
	}
	.main_catch img {
		max-width: 100%;
	height: 440px;
	}
	.main_catch h3 {
		font-size: 26px;
		color: #C64810;
		margin: 35px auto 15px;
	}
	.main_catch p {
		font-size: 17px;
	}
	.txt_con h2 {}
	.txt_con .subt02 {
		width: 300px;
	}
	.txt_con .subt03 {
		width: 330px;
		left: -5px;
	}
	.news, .txt_item, .txt_goods {
		padding: 75px 20px 55px;
	}
	.news li {
		flex-wrap: wrap;
		padding-bottom: 20px;
		margin-bottom: 20px;
	}
	.news li .day {
		margin-bottom: 15px;
	}
	.txt_item li {
		flex-wrap: wrap;
	}
	.txt_item li .sub_txt {
		font-size: 16px;
		line-height: 2em;
		margin-bottom: 15px;
	}
	.txt_item.cp .tyui_txt {
		font-size: 16px;
		line-height: 18px;
		padding: 15px 20px;
	}
	.txt_item li p {
		font-size: 14px;
		letter-spacing: 0.05em;
		line-height: 1.8em;
	}
	.txt_item li .sub_con {
		width: 100%;
	}
	.txt_item li .sub_con_p {
		width: 100%;
		flex-wrap: wrap;
	}
	.txt_item li .sub_con_p .sub_item {
		width: 70%;
		margin: 0px auto 25px;
	}
	.txt_item li .sub_con_p .sub_item:last-child {
		margin: 0px auto 25px;
	}
	.txt_link {
		margin-bottom: 10px;
	}
	.txt_goods {
		flex-wrap: wrap;
	}
	.txt_goods li {
		width: 100%;
		padding: 20px 20px 0px;
	}
	.txt_goods li .goods_list {
		margin-bottom: 30px;
		flex-wrap: wrap;
	}
	.txt_goods li .goods_list .sub_txt {
		width: 100%;
	}
	.txt_goods li .goods_list .sub_con {
		width: 100%;
	}
	.goods_txt .tyui_txt, .goods_txt .tyui_con {
		font-size: 14px;
		letter-spacing: 0.05em;
		line-height: 1.8em;
	}
	.txt_item.tyui h4 {
		font-size: 16px;
	}
	.txt_link .zizen.sp {
		font-size: 18px;
		display: inline-block !important;
	}
	.txt_item.tyui .tyui_con .soroe {
		padding-left: 0px;
	}
}