body{
font-family: "M PLUS 1", sans-serif;
overflow-x: hidden; 
-webkit-font-smoothing: antialiased;
line-height: 1.5; 
font-optical-sizing: auto;
font-weight: 400;
font-style: normal;
}
a{
text-decoration: none;
word-break: break-all;
}
i{
margin-right: 8px;
}
strong{
font-weight: bold;
}
/*＝＝＝＝＝　header　＝＝＝＝＝*/
header{
position: relative;
}
header p.top_add{
padding: 5px 10px;
color: #6e9dd3;
text-align: right;
}
.top_logo_img{
width: 16%;
position: absolute;
left: 3%;
top: 10px;
-webkit-animation:fuwafuwa 0.5s  linear alternate;
animation:fuwafuwa 0.5s  linear alternate;
}
.top_logo_img img{
width: 100%;
}
.top_cont{
position: relative;
width: 100%;
height: 250px;
margin: 0 auto;
background-image: url("../img/top/top_common.jpg");
background-size: cover;
background-position: center;
background-repeat: no-repeat;
}
.top_cont_info{
background-image: url("../img/top/top_common_info.jpg");
background-size: cover;
}
.top_cont_consult{
background-image: url("../img/top/top_common_consult.jpg");
background-size: cover;
}
.top_cont_infl{
background-image: url("../img/top/top_common_infl.jpg");
background-size: cover;
}
.top_cont_visitor{
background-image: url("../img/top/top_common_visitor.jpg");
background-size: cover;
}
.top_cont_book{
background-image: url("../img/top/top_common_book.jpg");
background-size: cover;
}

/*＝＝＝＝＝　見出し　＝＝＝＝＝*/
.top_title{
font-weight: bold;
padding: 15px;
text-align: center;
width: 50%;
position: absolute;
top: 15%;
background: rgba(110,157,211,0.85);
border:solid 2px rgba(211,197,6,1.00);
border-left: none;
border-right: none;
}
h1{
font-size:400%;
font-weight: bold;
background-clip: text;
-webkit-background-clip: text;
text-align: center;
animation: fadeIn 1.5s cubic-bezier(0.33, 1, 0.68, 1) forwards;
font-style: normal;
color: #ffffff;
letter-spacing:0.3em; 
}
h1 span{
text-shadow:  0 0 1px #fff, 0 0 1px #fff, 0 0 1px #fff, 0 0 10px #6E9DD3,0 0 10px #6E9DD3, 0 0 10px #6E9DD3, 0 0 10px #6E9DD3, 0 0 10px #6E9DD3;
}
h1.motoni{
letter-spacing:0; 
}
.glowAnime span{opacity: 0.5;}
/*アニメーションで透過を0から1に変化させtext-shadowをつける*/
.glowAnime.glow span{ animation:glow_anime_on 1s ease-out forwards; }
@keyframes glow_anime_on{
0% { opacity:0; text-shadow: 0 0 0 #fff,0 0 0 #fff;}
100% { opacity:1; text-shadow: 0 0 10 #fff,0 0 15 #fff;}
}
h2 {
background-color: #fff;
padding: 10px 0 10px 20px;
position: relative;
font-size: 140%;
font-weight: bold;
background: #E1EDF7;
color: #4883C7;
margin-bottom: 20px;
border-top: 3px solid #4883C7;
}
h2.dotchan::before {
content: '';
width: 100%;
height: 40%;
background-image: radial-gradient(#FFE605 8%, transparent 16%), radial-gradient(#FFE605 8%, transparent 16%);
background-position: 0 0, 7px 7px;
background-size: 12px 12px;
position: absolute;
bottom: -5px;
left: 0px;
}
h2:after {
content: " ";
display: block;
position: absolute;
right: 0;
bottom: 0;
border-width: 0 30px 30px 0; border-style: solid; width: 0;
-webkit-transform: rotate(90deg);
transform: rotate(90deg);
border-color: #fff #fff #CADEED #CADEED;
}
h3{
color: #525252;
background:#ffffff;
font-size: 120%;
font-weight: bold;
line-height: 1.5;
margin-bottom: 10px;
margin-top: 5px;
border-left: 2px dotted rgba(0,0,0,.1);/* テープのギザギザ左*/
border-right: 2px dotted rgba(0,0,0,.1);/* テープのギザギザ右*/
padding:5px 15px;/*タイトルの余白*/
box-shadow: 3px 3px 0px 0px rgba(0, 0, 0, 0.1);
border-top: 0.2px #E8EAEB solid;
}
.h3_blue {
color: #6e9dd3;
background: repeating-linear-gradient(-45deg, #e8f3f9, #e8f3f9 5px, #fff 0, #fff 10px);
margin-bottom: 10px;
box-shadow: 3px 3px 0px 0px rgba(0, 0, 0, 0.1);
}
.h3_check {
 background-image: linear-gradient(45deg, #e8f3f9 25%, transparent 25%, transparent 50%, #e8f3f9 50%, #e8f3f9 75%, transparent 75%, transparent), linear-gradient(-45deg, #e8f3f9 25%, transparent 25%, transparent 50%, #e8f3f9 50%, #e8f3f9 75%, transparent 75%, transparent);
 background-color: #ffffff;
 background-size: 15px 15px;
 color: #6094CF;
}

h4{
position: relative;
padding: 10px 20px 10px 10px;
border-left: 15px solid #2589d0;
background-color: #f5f5f5;
box-shadow: 0px 1px 2px 2px rgba(110,157,211,0.30);
margin-bottom: 10px;
color: #2589d0;
font-weight: bold;
font-size: 115%;
}

h5{
position: relative;
padding: .3em 0 .2em 1em;
border-bottom: 3px dashed #2589d0;
color: #2589d0;
font-weight: bold;
font-size: 115%;
}
h5 span{
font-size: 130%;
}
h5::before {
position: absolute;
top: 0;
left: .3em;
transform: rotate(55deg);
height: 11px;
width: 12px;
background: #2589d0;
content: '';
}
h5::after{
position: absolute;
transform: rotate(15deg);
top: .6em;
left: 0;
height: 8px;
width: 8px;
background: #2589d0;
content: '';
}
h6{
font-size: 200%;
font-weight: 900;
color: #6e9dd3;
position: relative;
text-align: center;
margin: 50px auto 35px;
}
h6 img{
position: absolute;
top: -100px;
right: 0;
bottom: 0;
left: 0;
margin: auto;
}
h6 p{
font-size: 90%;
}

.midashi01{
font-size: 110%;
font-weight: bold;
color: #c63c5d;
}
.list01{
position: relative;
padding: 5px 0 5px 25px;
text-align: left;
font-size: 105%;
font-weight: bold;
}
.list01::after { 
position: absolute;
top: 2px;
left: 0px;
color: #efdb17;
content: "★";
font-size: 120%;
}
.list02{
position: relative;
padding: 5px 0 5px 25px;
text-align: left;
font-size: 105%;
font-weight: bold;
}
.list02::after { 
position: absolute;
top: 10px;
left: 5px;
content: '';
width: 12px;
height: 12px;
background-color: #efdb17;
-webkit-transform: rotate(45deg);
transform: rotate(45deg);
}

.common_cont{
padding: 40px 0;
max-height: 1600;
}
.common_box{
width: 85%;
margin: 0 auto;
}
.bg001{
background-image:url("../img/bg001.png");
background-size: contain;
background-repeat: no-repeat;
}
.bg002{
background-image:url("../img/bg002.png");
background-size: contain;
background-repeat: no-repeat;
}
.sep3 {
transform: translateY(10%) translateY(2px) scale(1,1);
transform-origin: top;
}

/* ＝＝＝＝＝＝　ノーマル　＝＝＝＝＝＝ */
.normal_cont{
margin: 0px auto;
max-width: 1500px;
width: 90%;
padding: 60px 0;
}
/*＝＝＝＝＝　common ＝＝＝＝＝*/
.common_title{
width: 65%;
text-align: center;
-webkit-animation:zoomIn 1.5s forwards;
animation:zoomIn 1.5s forwards;
}

/*＝＝＝＝＝ footer ＝＝＝＝＝*/
footer{
position: relative;
font-weight: bold;
text-align: center;
border-bottom: 30px solid #6A8DC3;
padding-top: 50px;
margin: 0 auto;
}
.footer_btn{
margin: 20px auto;
text-align: center;
}
.footer_btn a{
display: flex;
width: 90%;
padding: 10px 30px;
margin: 0 auto;
font-size: 130%;
font-weight: bold;
border-radius: 20px;
background: #E6CAFF;
color: #BF76FF;
text-align: center;
box-shadow: 0px 2px 2px 0px rgba(247,11,218,0.30), inset 0px -3px 6px -2px rgba(0, 0, 0, 0.1);
justify-content: center;
}
.footer_btn a:hover{
opacity: 0.7;
}
.footer_info02{
display: flex;
justify-content: center;
width: 80%;
margin: 0 auto;
max-width: 1600px;
}
.footer_info02 a{
width: 45%;
padding: 10px 30px;
margin: 0 5px;
font-size: 110%;
font-weight: bold;
border-radius: 20px;
text-align: center;
}
.footer_info02 a:hover{
opacity: 0.7;
}
.footer_img{
width: 17%;
margin: 10px auto;
}
.footer_img img{
width: 100%;
}
.footerbox{
width: 90%;
margin: 10px auto;
font-weight: bold;
}
/*＝＝＝＝＝ footerマップ ＝＝＝＝＝*/
.sitemap{
width: 95%;
margin: 20px auto;
max-width: 1600px;
}
.sitemap nav ul {
display: flex;
flex-flow: row;
justify-content: center;  
padding: 6px 0;
align-items: stretch;
flex-wrap: wrap;
white-space: wrap;
}
.sitemap nav ul li{
border-radius: 30px;
font-size: 100%;
font-weight: 500;
border: 1px solid #6e9dd3;
margin: 5px;
background: #FFFFFF;
cursor: pointer;
position: relative;
transition: 0.5s;
box-shadow: 1px 1px 0 rgba(110,157,211,0.50), 0 0 2px 2px rgba(110,157,211,0.20), inset 2px 2px 0 rgba(248,231,116,0.20);
}
.sitemap nav ul li a{
color: #6e9dd3; 
padding: 12px 50px 12px 20px;
display: inline-block;
}
.sitemap nav ul li a::before {
border-right: 3px solid #6e9dd3;
border-top: 3px solid #6e9dd3;
bottom: 0;
content: "";
height: 10px;
margin: auto;
position: absolute;
right: 20px;
top: 0;
transform: rotate(45deg);
transition: right .5s; 
width: 10px;
}
.sitemap nav ul li a:hover{
color: #ffffff;
}
.sitemap nav ul li:hover{
opacity: 0.9;
background: #6e9dd3;
}
.sitemap nav ul li a:hover::before {
right: 10px;
border-right: 3px solid #ffffff;
border-top: 3px solid #ffffff;
}
.copy{
font-size: 80%;
}
.logo_midashi{
border-bottom: dotted 4px #6e9dd3;
font-size:130%;
text-align: center;
font-weight: bold;
color: #033D7A;
margin: 5px auto 15px;
}
.logo_midashi::before {
content: '';/*何も入れない*/
display: inline-block;/*忘れずに！*/
width: 40px;/*画像の幅*/
height: 40px;/*画像の高さ*/
background-image: url("../img/logo_boy.png");
background-size: contain;
vertical-align: middle;	
margin-right: 10px;
}

.logo_midashi::after {
content: '';/*何も入れない*/
display: inline-block;/*忘れずに！*/
width: 40px;/*画像の幅*/
height: 40px;/*画像の高さ*/
background-image: url("../img/logo_girl.png");
background-size: contain;
vertical-align: middle;	
margin-left: 10px;
}
@media screen and (max-width: 960px){

}
@media screen and (max-width: 789px){
header p.top_add{
padding: 5px;
text-align: left;
font-size: 80%;
}
.top_logo_img{
position: inherit;
width: 45%;
left: inherit;
top: inherit;
margin: 10px auto;
}
.top_cont{
height: 200px;
margin: 10px auto;
}
.top_title{
width: 80%;
margin: 0 auto;
position: inherit;
}
h1{
font-size:200%;
}
h2{
font-size: 125%;
}
h3 {
font-size: 115%;
line-height: 1.5;
margin-bottom: 10px;
margin-top: 10px;
}
h4{
font-size: 115%;
}
h5 span{
font-size: 125%;
}
h2{
font-size: 160%;
margin: 60px auto 30px;
}
h2 img{
top: -125px;
}
h2 p{
font-size: 90%;
}
h6{
font-size: 140%;
margin:40px auto 30px;
}
h6 img{
position: absolute;
top: -80px;
}

/*＝＝＝＝＝　header　＝＝＝＝＝*/
header{
}
header p{
padding: 5px;
color: #6e9dd3;
text-align: right;
}
.common_cont{
padding: 20px 0;
}
/* ＝＝＝＝＝＝　contener　＝＝＝＝＝＝ */
.common_box{
width: 96%;
margin: 0 auto;
}
.normal_cont{
margin: 0px auto;
max-width: 1500px;
width: 100%;
padding: 30px 0;
}
/*フッター*/
footer{
border-bottom: 60px solid #6A8DC3;
}
footer p{
font-size: 90%;
}
.footerbox{
width: 95%;
margin: 0 auto;
}
/* サイトマップ*/
.sitemap{
width: 98%;
margin: 5px auto;
}
.sitemap nav ul {
justify-content: center;  
align-items: stretch;
flex-wrap: wrap;
white-space: wrap;
}
.sitemap nav ul li{
border-radius: 30px;
font-size: 85%;
font-weight: 500;
width: 46%;
}
.sitemap nav ul li a{
padding: 10px 30px 10px 15px;
display: inherit;
}
.sitemap nav ul li a::before {
border-right: 3px solid #6e9dd3;
border-top: 3px solid #6e9dd3;
height: 5px;
right: 20px;
width: 5px;
}
.sitemap nav ul li:hover{
opacity: 0.9;

}
.sitemap nav ul li a:hover::before {
right: 10px;
border-right: 3px solid #6e9dd3;
border-top: 3px solid #6e9dd3;
}
.copy{
font-size: 60%;
}
.footer_info02{
flex-direction: column;
align-items:center;
justify-content: center;
flex-wrap: wrap;
width: 98%;
margin: 10px auto;
}
.footer_info02 a{
width: 90%;
padding: 10px 0px;
margin: 10px auto;
font-size: 90%;
border-radius: 10px;
}
.footer_img{
width: 60%;
margin: 10px auto;
}
}
@media only screen and (max-width:520px){
.top_logo_img{
left: 1%;
top: 10%;
}
.common_box{
width: 98%;
margin: 0 auto;
}
}
@media only screen and (max-width:400px){

}
