@charset "utf-8";

html, body                 {width:100%;margin:0 auto;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;}
body                       {-webkit-text-size-adjust:100%;}
div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, font, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
dl, dt, dd, ol, ul, li,
table, caption, tbody, tfoot, thead, tr, th, td, p,
fieldset, form, label, legend, input,
article, aside, canvas, figure, figcaption,
footer, header, nav, section,
b, u, i                    {margin:0;padding:0;list-style:none;font-style:normal;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;}
main                       {display: block;}
a                          {outline:none;}
img                        {border:0 none;vertical-align:top;max-width:100%;height:auto;}
em                         {font-style:normal;font-weight:bold;}
nav ul, nav li             {list-style:none;}
.h a, .f a,
nav a, nav span            {text-decoration:none;}
table                      {border-collapse:collapse;}
p, li                      {line-height: 1.8;}

.no-link                   {pointer-events: none;}

/* ----------------------------------------------- font */
html                       {font-size:62.5%;}
body                       {font-size:16px;font-size:1.6rem;font-family: 'Noto Sans JP', "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ ゴシック", sans-serif;}
h1, h2,  h3                {font-weight:normal;}
.en                        {font-family: 'M PLUS Rounded 1c', sans-serif;}
@font-face                 {font-family: 'ensign';src: url('./fonts/England Signature.woff') format('woff'), url('./fonts/England Signature.ttf') format('truetype');}
.ensign                    {font-family: 'ensign', sans-serif;}


/* ============================================================== base */
html, body                 {height:100%;}
body                       {-webkit-text-size-adjust:100%;}
/* ============================================================== common */

/* ============================================================== header */

header {
	border-top:#0081CC 10px solid;
	display:flex;
	margin:0;
	padding:10px 20px 20px 20px;
	justify-content: space-between
}

header p {
	margin-top:20px;
}

header h1 {
	font-size:16px;
	margin-top:25px;}

.main {
	background-image: url(../images/main_back.png);
	background-size:cover;
	height:200px;
	width:100%;
	text-align:center;
	position:relative;
	margin-bottom:0px;
}

.main img {
	position:absolute;
	left:0;
	right:0;
	text-align:center;
	display:block;
	width:500px;
	top:35%;
	margin:auto;
}

.wrap {
	max-width:1000px;
	width:100%;
	margin-left:auto;
	margin-right:auto;}

.flex {
	display:flex;}

.what_box {
	border:1px solid #ccc;
	padding:20px;}

.what_txt{
	margin-left:30px;
}

.what_txt h2 {
	color:#23598E;
	font-weight:bold;
	border-bottom:4px solid #87BDDD;
	width:70%;
	margin-bottom:20px;}

.merit_area{
	margin:50px auto;}

.merit_area .flex {
	flex-flow: wrap;
	flex-direction: row;
	justify-content: space-between;}

.merit_box {
	border:1px solid #ccc;
	width:48.5%;
	padding:20px;
	background-color:#fdfdfd;
	}

.merit_area h2 {
	font-size:28px;
	text-align:center;
	font-weight:bold;
	color:cornflowerblue;
	margin-bottom:30px;}

.merit_area h2 span {
	font-size:70%;
	display:block;
	color:#8B8B8B;}

.merit_box:nth-child(n+3) {
	margin-top:30px;}

.merit_box h3 {
	background-color:#C5E1E8;
	color:#165C83;
	font-weight:bold;
	padding:5px 20px;
	margin-bottom:15px;}


.banner_area {
	background-image:linear-gradient(135deg,#ffffff 49%, #E4EDF3 49%,#E4EDF3 51%, #ffffff 51%);
	background-size:6px 6px;
	background-repeat:repeat;
	box-shadow:inset 0 2px 3px 0px rgba(0,0,0,0.1);
	padding:50px 0;
	margin:50px 0;
	text-align:center;
	}

.banner_area p {
	color:#333333;
	font-weight:bold;
	}
.banner_area h2 {
	color:#165C83;
	font-weight:bold;
	font-size:32px;
	margin-bottom:30px;
	display:block;}

.banner_box{
	margin-top:30px;
	border-top:1px solid #ccc;
	border-bottom:1px solid #ccc;
	background-color:#ffffff;
	max-width:1000px;
	margin-left:auto;
	margin-right:auto;
	padding:25px 0;}

.rank_head {
	box-shadow:0 0 3px rgba(0,0,0,0.1);
	background-color:#F9FAFC;}

.rank_number {
	background-image:url(../images/rank_back.png);
	background-repeat:no-repeat;
	height:90px;
	padding:40px 30px;
	color:#ffffff;
	font-size:20px;
	text-shadow:0 0 7px #000000;
	display:inline-block;
	margin:-10px 0 -10px 7px;
	position:relative;}

.rank_number:after {
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 10px 0 0 5px;
	border-color: transparent transparent 	transparent #0a265e;
	content:"";
	right:-5px;
	top:0;
	position:absolute;}

.rank_head h2 {
	margin:20px 0 0px 30px;}

.rank_top p.right_gray {
	margin:28px 30px 0 auto;
	text-align:right;
	color:#cccccc;}


.rank_body {
	background-color:#F9FAFC;
	margin-top:5px;
	box-shadow:0 0 3px rgba(0,0,0,0.1);
	padding-top:1px;
	padding-bottom:30px;}

.rank_body .point {
	color:darkred;
	font-size:120%;
	font-weight:bold;
	text-align:left;
	max-width:700px;
	margin:40px auto 0 70px;
	background-image:linear-gradient(to right,#E4E8EB,transparent);
	padding:5px 0 0 30px;
	position:relative;}

.rank_body .point:before {
	content:"";
	position:absolute;
	top:0;
	left:0;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 75px 20px 0 0;
	border-color: #f9fafc transparent		transparent transparent;}

.rank_body .point span {
	font-size:200%;}

.rank_body .point span+span {
	font-size:120%;}

.rank_pic_area {
	display:flex;
	justify-content: space-between;}

.rank_capture {
	margin-left:50px}

.rank_graph {
	margin:-50px 50px 0 auto;}

.rank_body h3 {
	text-align:center;
	background-color:#E4E8EB;
	max-width:900px;
	padding:10px 0;
	color:#19528A;
	font-weight:bold;
	margin:20px auto;}

.rank_body h3+p {
	max-width:900px;
	text-align:left;
	display:block;
	color:#000000;
	margin:0 auto 20px auto;}

.rank_body table {
	max-width:900px;
	width:100%;
	text-align:center;
	margin:0 auto 0 auto;}

.rank_body table th,.rank_body table td {
	border:1px solid #ccc;
	padding:10px 10px;
	background-color:#ffffff;
	vertical-align:middle;}

.rank_body table img {
	margin-top:5px;
}

.rank_body table img+img {
	margin-left:3px;}

.rank_foot {
	background-color:#E4E8EB;
	padding:40px;
	justify-content: space-between}

.rank_foot .rank_voice {
	width:32%;
	background-color:#ffffff;
	padding:5px 10px;
	box-shadow:0 0 2px rgba(0,0,0,0.3)}

.rank_foot .rank_voice p.voice_name {
	position:relative;
	left:0;
	text-align:left;
	color:#000000;
	}

.rank_foot .rank_voice p.voice_name:before {
	content:"■";
	display:inline-block;
	color:#22598F;
	border:1px solid #ffffff;
	text-shadow:0 0 2px;
	margin-right:4px;}

.rank_voice h3 {
	color:#215D94;
	font-weight:bold;
	border-bottom:1px solid #ccc;
	padding-bottom:10px;
	margin-bottom:10px;}

.rank_voice p {
	color:#555555;
	font-size:90%;}

.rank_foot2 {
	background-color:#F9FAFC;
	padding:30px 0;
	text-align:center;}

.rank_foot2 a {
	display:inline-block;
	margin-left:auto;
	margin-right:auto;
	background-color:#ff9f05;
	color:#ffffff;
	text-decoration:none;
	padding:20px 40px;
	width:100%;
	max-width:300px;}

.rank_top+.rank_top {
	margin-top:40px;
}

.rank_bottom {
	justify-content: space-between;
	flex-wrap:wrap;
	margin:50px auto;
	max-width:1000px;}

.rank_bottom .rank_box {
	position:relative;
	width:48.5%;
	display:block;
	margin-bottom:30px;}

.rank_bottom .rank_number2 {
	background-image:url(../images/rank_back2.png);
	background-repeat:no-repeat;
	height:135px;
	position:absolute;
	left:10px;
	width:100px;
	text-align:center;
	padding:40px 0px 0 0px;
	color:#ffffff;
	text-shadow:0 0 3px rgb(0,0,0);
	font-size:150%;}

.rank_box .rank_head2 {
	background-color:#F9FAFC;
	text-align:center;
	font-size:120%;
	font-weight:bold;
	color:#555555;
	padding:20px 0 20px 100px;
	box-shadow:0 0 1px rgba(0,0,0,0.1);}

.rank_box .rank_body2 {
	background-color:#F9FAFC;
	text-align:center;
	font-size:120%;
	color:#9A2728;
	padding:20px 0 20px 100px;
	margin-top:5px;
	box-shadow:0 0 1px rgba(0,0,0,0.1);
	font-weight:bold;}

.rank_box .rank_body2 span {
	font-size:220%;
	margin-left:5px;}

.rank_box .rank_body2 span+span {
	font-size:130%;}

.blue_box {
	background-color:#EEF6FF;
	max-width:1000px;
	margin:0 auto 50px auto;
	padding:60px 40px 40px 40px;}

.blue_box h2 {
	color:#20568B;
	text-align:center;
	font-size:200%;
	margin-bottom:40px;
	}

.blue_lr {
	flex-wrap:wrap;
	justify-content: space-between;}

.blue_lr div {
	width:48%;}

.blue_box h3 {
	background-color:#ffffff;
	padding:5px 10px;
	color:#20568B;
	font-weight:bold;}

.blue_lr div p {
	margin:10px 0 30px 0;}

.blue_box ul {
	display:flex;
	justify-content: space-between;
	flex-wrap:wrap;
	margin-top:10px;
	font-size:100%;}

.blue_box ul li {
	width:50%;}

footer {
    text-align: center;
    background-color: #283874;
    color: #ffffff;
    padding: 60px 0 15px 0;
    font-size: 90%;
    position: relative;}

.qa_area {
	background-color: #FCFCFC;
	border-top:#FaFaFa 4px solid;
	border-bottom:#FaFaFa 4px solid;	
	padding:50px 0;}

.qa_area h2 {
	text-align:center;
	color:#1D548A;
	font-weight:bold;
	font-size:180%;
	margin-bottom:40px;}

.qa_box {
	max-width:1000px;
	margin-left:auto;
	margin-right:auto;
	background-color:#ffffff;
	box-shadow:0 0 3px rgba(0,0,0,0.2);
	padding:20px 30px;
	margin-bottom:30px;}

.qa_box h3 {
	position:relative;
	color:#2C5E93;
	font-weight:bold;}

.qa_box h3:before {
	content:url(../images/qaq.png);
	content: none;
	display:inline-block;
	margin-right:30px;
	position:relative;
	color:#2C5E93;
	bottom:-5px;
	font-weight:bold;}

.qaa {
	margin-top:15px;
	border-top:2px solid #f2f2f2;
	padding-top:15px;}

.qaa:before {
	content:url(../images/qaa.png);
	content: none;
	display:inline-block;
	margin-right:30px;
	bottom:-5px;
	position:relative;
	color:#2C5E93;
	font-weight:bold;}

.qa_box dl dt {
	display: inline-block;
	width: 4%;
	vertical-align: top;
	}
.qa_box dl dd {
	display: inline-block;
	width: 92%;
	vertical-align: top;}
.qa_box dl dt:before {
	content:url(../images/qaq.png);
	display:inline-block;
	margin-right:30px;
	position:relative;
	color:#2C5E93;
	bottom:-5px;
	font-weight:bold;}
.qa_box .qaa dl dt:before {
	content:url(../images/qaa.png);
	display:inline-block;
	margin-right:30px;
	bottom:-5px;
	position:relative;
	color:#2C5E93;
	font-weight:bold;}


/* 運営会社 */
.about_area {
    border-top: #FaFaFa 4px solid;
    padding: 50px 0;}

.about_area h2 {
    text-align: center;
    color: #1D548A;
    font-weight: bold;
    font-size: 180%;
    margin-bottom: 40px;}

.about_box {
    max-width: 1000px;
    margin-left: auto;
    margin-right: auto;}

.about_box table {
    width: 100%;
	border-top: 1px solid #d2d2d2;}

.about_box table tr {
	display: flex;
	border-bottom: 1px solid #d2d2d2;}

.about_box table th {
	display: inline-block;
	width: 16%;
	text-align: left;
	border-left: 1px solid #d2d2d2;
	border-right: 1px solid #d2d2d2;
	padding: 16px 5px 16px 15px;
	background-color: #EEF6FF;}

.about_box table td {
	display: inline-block;
	width: 84%;
	text-align: left;
	padding: 16px 5px 16px 15px;
	border-right: 1px solid #d2d2d2;}



/* プライバシーポリシー */
.policy_area {
    padding: 50px 0;}

.policy_area h2 {
    text-align: center;
    color: #1D548A;
    font-weight: bold;
    font-size: 180%;
    margin-bottom: 40px;}

.policy_box {
    max-width: 1000px;
    margin-left: auto;
    margin-right: auto;}

.policy_box .text_box {
	margin-top: 40px;}

.policy_box .text_box .title {
	color: #1D548A;
	font-weight: bold;
	margin-bottom: 10px;
	font-size: 110%;}

.policy_box .policy_foot {
	margin: 15px auto 40px auto;}

.policy_box .policy_foot dl dt {
	display: inline-block;
	width: 12.5%;
	vertical-align: top;}

.policy_box .policy_foot dl dd {
	display: inline-block;
	width: 86%;
	vertical-align: top;
	padding-left: 1em;
    text-indent: -1em;}

/* ページトップへ */
#page-top {
	position: absolute;
    bottom: 60px;
    right: 45%;
  font-size: 14px;
  line-height: 1;
  z-index: 99;
}
#page-top a {
  text-decoration: none;
  width: 60px;
  padding: 28px 5px;
  text-align: center;
  display: block;
  border-radius: 90px;
  opacity: 1;
    background-image: url(../images/totop.png);
    background-repeat: no-repeat;
    width: 80px;
    height: 80px;
    background-size: cover;
}
#page-top a:hover {
  text-decoration: none;
  opacity: .95;
  transition: .3s;
}



@media screen and (min-width:768px) and (max-width:1000px){
.policy_box .policy_foot dl dt {
    width: 16%;
	}
.policy_box .policy_foot dl dd {
    width: 82%;
	}
}
@media screen and (max-width:900px){
.rank_body h3 {
	width: 96%;
	padding: 10px 5px;
	}
.rank_body h3+p ,
.rank_body table {
	width: 96%;
	}
}
@media screen and (min-width:768px) and (max-width:900px){
.rank_pic_area {
    display: block;
	}
.rank_capture {
    margin-left: 10px;
    display: inline-block;
    width: 50%;
	}
.rank_graph {
    display: inline-block;
    width: 40%;
	margin: -50px 0px 0 20px;
    position: relative;
	}
}

@media screen and (min-width: 768px){

	
	
	
	
	
	
	
	
	
	
	
.forsp {display:none;}
}

@media screen and (max-width:767px){
header a {
	width: 58%;
	}
header h1 {
	width: 38%;
	margin-top: 0;
    font-size: 14px;
    text-align: center;
    line-height: 1.3;
	}

.merit_area h2 {
    font-size: 22px;
	}

.what_box.wrap.flex {
	display: block;
    padding: 20px;
	}
.what_box.wrap.flex img {
	width: 100%;
	}
.what_txt {
    margin: 15px auto 0 auto;
	}
.what_txt h2 {
    width: 100%;
	}

.banner_area h2 {
    font-size: 28px;
    margin-bottom: 20px;
	}
.banner_box img {
	width: 70%;
	margin-bottom: 10px;
	}

.rank_pic_area {
    display: block;
	}
.rank_head h2 {
    margin: 20px 0 0px 10px;
	}
.rank_capture {
    margin-left: 0;
	}
.rank_graph {
    margin: 28px auto 0 auto;
	}
.rank_pic_area {
    width: 96%;
    margin-left: auto;
    margin-right: auto;
	}
.rank_pic_area img {
    width: 100%;
	}
.rank_foot {
	display: block;
	}
.rank_foot .rank_voice {
    width: 100%;
	}
.rank_foot {
    padding: 30px 20px;
	}
.rank_body table th, .rank_body table td {
    padding: 10px 0px;
    font-size: 80%;
	}
.rank_bottom .rank_number2 {
    background-size: contain;
    height: 130px;
    left: 0;
    width: 65px;
    font-size: 120%;
	}
.rank_box .rank_body2 {
    margin-top: 10px;
    padding: 10px 0 10px 0;
	}
.rank_box .rank_head2 {
	font-size: 89%;
    padding: 20px 0 20px 65px;
	}

.blue_lr {
    display: block;
	}
.blue_lr div {
    width: 100%;
	}
.blue_box {
    width: 100%;
    padding: 30px 10px 20px 10px;
	}
.blue_box ul {
    display: block;
	}
.blue_box ul li {
    width: 100%;
	}

.qa_box {
    width: 100%;
    padding: 20px 10px;
    margin-bottom: 20px;
	}
.qa_box dl dt {
    width: 8%;
	}
.qa_box dl dd {
    width: 90%;
	}

.about_box table th {
    width: 36%;
    padding: 16px 6px 16px 6px;
	}
.policy_area {
    width: 96%;
    margin-left: auto;
    margin-right: auto;
	}
.policy_box .policy_foot dl dt {
    width: 34%;
	}
.policy_box .policy_foot dl dd {
    width: 64%;
	}

#page-top {
    right: 42.5%;
	}
#page-top a {
    width: 60px;
    height: 60px;
	}
	
.forpc {display: none!important;}
}





@media screen and (max-width:400px){

}