@charset "UTF-8";

/* --- reset default style ---------------*/
body,
h1, h2, h3, h4, h5, h6,
div, p, ul, ol, li,
dl, dt, dd,
pre, blockquote, address,
table, thead, tbody, tfoot,
 tr, th, td, caption,
form, fieldset, legend,
optgroup, option,
del, ins,
span, a, img,
dfn, em, strong, bdo,
abbr, acronym, cite, q,
kbd, code, samp, var,
input, select, textarea, button, label, iframe
{
	font-size: 100%;
	font-style: normal;
	font-weight: normal;
	padding: 0px;
	margin: 0px;
}
sup {
	font-size: 80%;
	font-style: normal;
	font-weight: normal;
}
sub {
	font-size: 80%;
	font-style: normal;
	font-weight: normal;
	vertical-align: bottom;
}
fieldset, del, ins, img, abbr, acronym
{
	border: 0;
    vertical-align:bottom
}
li {
	list-style-type: none;
}
area {
	border:none;
	outline: none;
}
/* --- ページの基本 ---------------*/
body {
	font-family: "Noto Sans JP", sans-serif;
	font-size: 1.1rem;
	color:#161C2D;
	background: #fff;
}
.fontfamily-serif {
	font-family: "Noto Sans JP", sans-serif;
}
table {
	border-collapse:collapse;
	border:none;
}
tr,th,td {
	border:none;
}
th,td {
	vertical-align:top;
}
a {
	/* color: #000; */
	text-decoration: none;
}
a:link {
	/* color: #000; */
	text-decoration: none;
}
a:visited {
	/* color: #000; */
	text-decoration: none;
}
a:hover {
	filter:alpha(opacity=50);
	-moz-opacity: 0.5;
	opacity: 0.5;
}
a:active {
	filter:alpha(opacity=50);
	-moz-opacity: 0.5;
	opacity: 0.5;
}

ol {
	padding-left: 2em;
}
ol li {
	list-style-type: decimal;
}
.gsc-control-cse {
	padding: 0em!important; 
}
#navmenu1 .gsc-control-cse { 
	padding: 0em!important; 
	background-color: #C1272D!important;
	border: none!important; 
}

/* 左右幅リミッター */

.max-width {
	max-width: 991px;
}

/* ガタツキ修正 */
.no-gutters {
	margin:0;
	padding:0;
}
 
.no-gutters > .col,
.no-gutters > [class*="col-"] {
	margin:0;
	padding:0;
}


.dec-rel {
	position: relative;
}

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

/* ヘッダー */
.dec-logo {
	position: fixed;
	top: 5px;
	z-index: 12;
}


.dec-h00 {
	position: fixed;
	z-index: 10;
	top: 0;
}

.dec-h01 {
	margin-top: 10px;
	line-height: 1.5rem;
	p.dec-h01a {
		font-weight: bold;
		font-size: 0.9rem;
	}
	p.dec-h01b {
		color: #407BFF;
		font-weight: bold;
		font-size: 1.5rem;
	}
	p.dec-h01c {
		font-size: 0.8rem;
	}
	animation: poyopoyo 2s ease-out infinite;
}
@keyframes poyopoyo {
	0%, 40%, 60%, 80% {
	transform: scale(1.0);
	}
	50%, 70% {
	transform: scale(0.95);
	}
}
.dec-h02 {
	margin-top: 10px;
	right: 220px;
	a {
		display: block;
		background-color: #fff;
		padding: 20px 28px;
		border: 2px solid #407BFF;
		border-radius: 50px;
		font-size: 1.1rem;
		font-weight: bold;
		color: #407BFF;
		&:hover {
			background-color: #407BFF;
			color: #fff;
		}
		opacity: 1;
	}
}

.dec-h03 {
	margin-top: 10px;
	right: 65px;
	a {
		display: block;
		background-image: linear-gradient(75deg, #407bff, #393bb7);
		padding: 22px 28px;
		border-radius: 50px;
		font-size: 1.1rem;
		font-weight: bold;
		color: #fff;
		transition: 2s;
		&:hover {
			background-image: linear-gradient(75deg, #393bb7, #407bff);
			transform: scale(1.1);
		}
		opacity: 1;
	}
}

@media screen and (max-width:767px) {
	.dec-h05 {
		position: fixed;
		bottom: 0;
		left: 0;
		z-index: 10;
		width: 98vw;
	}
	.dec-h06 {
		display: block;
		text-align: center;
		background: #fff;
		color: #407BFF;
		font-size: 1rem;
		font-weight: bold;
		padding: 15px 0;
		border: 2px solid #407BFF;
	}
	.dec-h07 {
		display: block;
		text-align: center;
		background-image: linear-gradient(75deg, #407bff, #393bb7);
		color: #fff;
		font-size: 1rem;
		font-weight: bold;
		padding: 15px 0;
		border: 2px solid #407BFF;
	}
	.dec-h08 {
		background-color: #fff;
		font-size: 0.8rem;
		padding: 15px 0;
		text-align: center;
		strong {
			font-size: 1.2rem;
			color: #407BFF;
			font-weight: bold;
			padding: 0 10px;
		}
		span {
			font-size: 0.7rem;
		}
	}
}


/* メインビジュアル */
.dec-01{
	background-image: url(../img/img-01.png);
	background-size: cover;
	background-repeat: no-repeat;
	background-position: top right;
	height: 500px;
}
@media screen and (max-width:767px) {
	.dec-01{
		height: 420px;
	}
}

.dec-02 {
	position: absolute;
	bottom: 0px;
	padding-left: 520px;
}
@media (max-width: 991px) {
	.dec-02 {
		padding-left: calc(520 / 991 * 100vw);
	}
}
@media screen and (max-width:767px) {
	.dec-02 {
		padding-left: 0;
		right: 0px;
		width: 230px;
		height: auto;
	}
}
.dec-03 {
	position: absolute;
	top: 20px;
	p.dec-03a {
		font-size: 1.4rem;
		font-weight: bold;
		padding-bottom: 15px;
	}
	p.dec-03b {
		font-size: 2.8rem;
		font-weight: bold;
		line-height: 3.8rem;
		span {
			font-size: 4.5rem;
			font-weight: bold;
			color: #393BB7;
			padding: 0 5px;
		}
	}
	p.dec-03c {
		font-size: 2.2rem;
		font-weight: bold;
		color: #393BB7;
	}
}
@media screen and (max-width:767px) {
	.dec-03 p.dec-03b {
		font-size: 2.2rem;
		line-height: 3rem;
		span {
			font-size: 3rem;
		}
	}
	.dec-03 p.dec-03c {
		font-size: 1.8rem;
		text-shadow: 1px 0 4px #fff;
	}
}
.dec-04 div img {
	 filter: drop-shadow(0px 0px 5px rgba(160, 160, 160, 0.7));
}
@media screen and (max-width:767px) {
	.dec-04 {
		width: 400px;
	}
}

/* コンテンツ１ */
.dec-11 {
	text-align: center;
	font-size: 1.8rem;
	font-weight: bold;
}
.dec-12 {
	background-color: #fff;
	filter: drop-shadow(0px 0px 5px rgba(160, 160, 160, 0.7));
	border-radius: 16px;
	padding: 20px;
	min-height: 376px;
}
.dec-13 {
	text-align: center;
	font-size: 1.2rem;
	span {
		font-weight: bold;
	}
	
}
.dec-13a {
	text-align: center;
	font-size: 1rem;
}


/* コンテンツ２ */
.dec-21 {
	text-align: center;
	font-size: 1.8rem;
	font-weight: bold;
}
.dec-22 {
	font-size: 1.4rem;
	text-align: center;
	color: #5c606c;
}
.dec-23 {
	width: 600px;
	margin: 0 auto;
}
@media screen and (max-width:767px) {
	.dec-23{
		width: 300px;
	}
}
/* コンテンツ３ */
.dec-32 {
	width: 80px;
}
.dec-32b {
	width: 105px;
}
.dec-32c {
	width: 105px;
}
.dec-33 {
	display: table-cell;
	height: 120px;
	vertical-align:middle;
	font-size: 1.8rem;
	font-weight: bold;
}
.dec-34 {
	text-align: justify;
	span {
		font-weight: bold;
		color: #7778CC;
	}
}
.dec-35 {
	background-color: #ECF2FF;
	border-radius: 20px;
	padding: 20px;
}

/* コンテンツ４ */
.dec-41{
	background-image: url(../img/img-17.png);
	background-size: cover;
	background-repeat: no-repeat;
	background-position: top right;
}

.dec-42 {
	font-size: 1.8rem;
	font-weight: bold;
	color: #fff;
}
.dec-43 {
	font-size: 1.2rem;
	color: #fff;
}
.dec-44 {
	margin: 10px 0;
	color: #fff;
	&:before {
		content: "✓";
		color: #393BB7;
		background-color: #fff;
		border-radius: 50%;
		padding: 0 6px;
		margin-right: 5px;
	}
}
.dec-45 {
	display: block;
	background-color: #fff;
	text-align: center;
	border-radius: 30px;
	padding: 15px 20px;
	width: 250px;
	margin-right: auto;
	color: #393BB7;
}

/* コンテンツ５ */
.dec-51 {
	background-color: #F5FAFC;
}
.dec-52 {
	text-align: center;
	font-size: 1.8rem;
	font-weight: bold;
}
.dec-53 {
	font-size: 1.4rem;
	text-align: center;
	color: #5c606c;
}
.dec-54 {
	background-color: #fff;
	padding: 20px;
	border: 3px solid #393BB7;
	border-radius: 15px;
	text-align: center;
	min-height: 150px;
}
.dec-55 {
	font-size: 1.3rem;
	font-weight: bold;
	color: #393BB7;
}
.dec-56 {
	font-size: 0.9rem;
	color: #5c606c;
}
.dec-57 {
	text-align: center;
	font-weight: bold;
}
.dec-58 {
	text-align: center;
	font-size: 3.4rem;
	font-weight: bold;
	color: #393BB7;
	span {
		font-weight: bold;
		font-size: 65%;
	}
}
.dec-59 {
	display: block;
	background-image: linear-gradient(75deg, #84DB9C, #8BC84C);
	text-align: center;
	border-radius: 30px;
	padding: 15px 20px;
	margin: auto;
	width: 300px;
	color: #fff;
}

/* コンテンツ６ */
.dec-61 {
	text-align: center;
	font-size: 1.8rem;
	font-weight: bold;
}
.dec-62 {
	padding: 20px;
}
.dec-63a {
	background-color: #F54B4B;
	border-radius: 50%;
	width: 60px;
	height: 60px;
	margin: auto;
	text-align: center;
	line-height: 55px;
	font-size: 2.2rem;
	font-weight: bold;
	color: #fff;
}
.dec-63b {
	background-color: #67D485;
}
.dec-63c {
	background-color: #3AA5C8;
}
.dec-64a {
	text-align: center;
	font-weight: bold;
	font-size: 1.4rem;
	color: #F54B4B;
}
.dec-64b {
	color: #67D485;
}
.dec-64c {
	color: #3AA5C8;
}
.dec-65 {
	text-align: center;
	color: #5c606c;
}
.dec-66 {
	position: absolute;
	border-bottom: 2px dashed #D4D6DC;
	width: 700px;
	top: 100px;
	right: 0;
	left: 0;
	margin: 0 auto;
	z-index: -1;
}
@media (max-width: 991px) {
	.dec-66 {
		width: calc(700 / 991 * 100vw);
	}
}

/* コンテンツ７ */
.dec-71 {
	background-color: #F5FAFC;
}
.dec-72 {
	text-align: center;
	font-size: 1.8rem;
	font-weight: bold;
}
.dec-73 {
	background-color: #fff;
	filter: drop-shadow(0px 0px 5px rgba(160, 160, 160, 0.7));
	padding: 20px 40px;
}
.dec-74 {
	font-size: 1.4rem;
	font-weight: bold;
}

/* コンテンツ８ */
.dec-81 {
	background-color: #67D485;
}
.dec-82 {
	text-align: center;
	font-size: 2.2rem;
	font-weight: bold;
	color: #fff;
}
.dec-83 {
	font-size: 1.2rem;
	text-align: center;
	color: #fff;
}


/* コンテンツ９ */
.dec-91 {
	background: #262B38;
}
.dec-92 {
	font-size: 1.2rem;
	color: #fff;
}
.dec-93 {
	font-size: 1rem;
	color: #67D485;
	margin-bottom: 10px;
}
.dec-94 {
	font-size: 0.8rem;
	color: #9DA0A6;
	margin-bottom: 10px;
}
.dec-95 {
	border-bottom: 2px solid #fff;
}