@charset "utf-8";

@import url("ress.css");
@import url("base.css");
@import url('https://fonts.googleapis.com/css2?family=M+PLUS+Rounded+1c:wght@300&display=swap');

/* __________________________________________________
   common
__________________________________________________ */

html { overflow-y: scroll; _overflow: auto; font-size: 62.5%;}/**1rem=10px**/
body { overflow-x: hidden; position: relative; font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif; font-weight: normal; font-feature-settings: "palt"; letter-spacing: 0; line-height: 1.75; color: #333; padding: 0; margin: 0; font-size: 1.5rem;}

html, body { width: 100%; min-height: 100%; position: relative;}

a { color: #2b9ea7; text-decoration: none;}
a:hover { color: #ccc;}
a[href^="tel:"]{ display: inline-block; pointer-events: none;}

@media screen and (max-width: 767px) {
body {font-size: 1.5rem;}
a[href^="tel:"] { pointer-events: auto; text-decoration: underline; color: #2b9ea7;}
}

/*
COMING SOON
*/
div.soon { display: flex; align-items: center; justify-content: center; width: 100%; height: 100%; background: rgba(255, 255, 255, 0.8); border: 2px solid #333; position: absolute; top: 0; left: 0; z-index: 5;}
div.soon span { font-size: 2.4rem; color: #333; text-align: center;}
div.soon + a { pointer-events: none!important;}

@media screen and (max-width: 768px) {
div.soon span { font-size: 2rem;}
}

/* __________________________________________________
   header
__________________________________________________ */
header { width: 100%; background: #fff; border-top: 6px solid #2b9ea7;}
header .inner { max-width: 1560px; height: 104px; display: flex; align-items: center; justify-content: space-between; padding: 0; margin: 0 auto; position: relative;}
header .logo { margin-left: 10px;}
header .logo a { width: 330px; height: 94px; display: block; background: url(../images/share/logoMark.svg) 0 0 no-repeat; background-size: 100%; text-indent: -9876em; overflow: hidden;}

header .upperpartNav { height: 100%; padding-bottom: 20px;}
header .upperpartNav ul { height: 100%; list-style: none; display: flex; justify-content: flex-end;}
header .upperpartNav a { display: flex; align-items: center; justify-content: center; height: 100%; font-size: 1.5rem; color: #000; font-weight: bolder; text-decoration: none; line-height: 1.4; padding: 0 20px; position: relative; transition: .5s;}
header .upperpartNav a:hover { color: #2b9ea7; transition: .5s;}
header .upperpartNav .current a:after { content: ""; display: block; width: calc(100% - 40px); border-bottom: 2px solid #2b9ea7; position: absolute; bottom: 20px; left: 20px;}
header .upperpartNav .current a:hover { color: #000;}
header .upperpartNav li.publish { background: #2b9ea7; border-radius: 0 0 0 30px;}
header .upperpartNav li.publish a { color: #fff;}
header .upperpartNav li.publish a:hover { color: #c9c9c9;}
header .upperpartNav .publish.current a:after { content: ""; display: block; width: calc(100% - 40px); border-bottom: 2px solid #fff; position: absolute; bottom: 20px; left: 20px;}
header .upperpartNav li:nth-child(3) { background: #2b9ea7;}
header .upperpartNav li:nth-child(3) a { background: #fff; border-radius: 0 10px 0 0; padding-right: 30px;}

header #menuTrigger,
header .menuBg { display: none;}

@media screen and (max-width: 1000px){
header .inner { max-width: 100%; height: 60px;}
header .upperpartNav { display: none;}
header #menuTrigger { display: block;}
header .logo a { width: 200px; height: 57px;}
}

/*
gn
*/
#menuTrigger { display: block; width: 40px; height: 24px; cursor: pointer; z-index: 51; position: absolute; right: 20px; top: 20px}
.menuIcon { position: relative; height: 18px;}
.menuIcon > div { position: absolute; left: 0; width: 100%; height: 2px; background: #2b9ea7; transition: .3s;}
.menuIcon > div:nth-of-type(1) { top: 0;}
.menuIcon > div:nth-of-type(2) { top: 11px;}
.menuIcon > div:nth-of-type(3) { top: 22px;}
.menuIcon.open::before { content: ""; display: block; width: 135px; height: 90px; position: absolute; top: -45px; right: -30px;}
.menuIcon.open > div { background: #2b9ea7;}
.menuIcon.open > div:nth-of-type(1) { top: 8px;
 -webkit-transform: rotate(45deg);
 -moz-transform: rotate(45deg);
 -ms-transform: rotate(45deg);
 -o-transform: rotate(45deg);
 transform: rotate(45deg); transition: .3s;}
.menuIcon.open > div:nth-of-type(2) { opacity: 0;}
.menuIcon.open > div:nth-of-type(3) { top: 8px;
 -webkit-transform: rotate(-45deg);
 -moz-transform: rotate(-45deg);
 -ms-transform: rotate(-45deg);
 -o-transform: rotate(-45deg);
 transform: rotate(-45deg); transition: .3s;}
.menuIcon span { font-size: 1.2rem; color: #333; position: absolute; top: 30px;}
.menuIcon.open span { display: none;}

.menuBg { width: 100vw; height: 100vh; overflow-y: scroll; background: rgb(245, 245, 245); padding: 0; position: absolute; top: 0; left: 0; z-index: 50;}
.menuArea { max-width: 1300px; padding: 40px 130px; margin: 0 auto;}
.menuArea a { color: #333; display: inline-block; text-decoration: none; overflow: hidden; position: relative;}
.menuArea a:after { content: ""; width: 100%; height: 1px; background: #2b9ea7; position: absolute; bottom: 0;left: 0;
transform: translate(-100%, 0);
transition: transform cubic-bezier(0.215, 0.61, 0.355, 1) 0.4s;
}
.menuArea a:hover:after { transform: translate(0, 0);}

.menuBg { display: none;}
.fixed { position: fixed;}

@media screen and (max-width: 768px){
.menuArea { max-width: calc(100vw - 80px); padding: 80px 40px;}
.menuArea nav ul { list-style: none;}
.menuArea .mainNav { margin-bottom: 30px;}
.menuArea li { margin-bottom: 20px; }
.menuArea li.cat01,
.menuArea li.cat02,
.menuArea li.cat03,
.menuArea li.cat04 { display: flex; width: 100%; align-items: center; justify-content: flex-start; flex-direction: column; background: #ccc; padding: 10px 20px; border-radius: 10px;}
.menuArea li.cat04 { margin-bottom: 30px;}
.menuArea li.cat01 a,
.menuArea li.cat02 a,
.menuArea li.cat03 a,
.menuArea li.cat04 a { display: block; width: 100%; color: #fff; font-weight: bolder;} 
.menuArea li a span { display: block; font-size: 1.2rem; font-weight: normal;} 
.menuArea li.cat01 { background: #cfad24 url(../images/top/icon_cat01.svg) 100% 0 no-repeat;}
.menuArea li.cat02 { background: #c85e97 url(../images/top/icon_cat02.svg) 100% 0 no-repeat;}
.menuArea li.cat03 { background: #6561be url(../images/top/icon_cat03.svg) 100% 0 no-repeat;}
.menuArea li.cat04 { background: #2b9ea7}
.menuArea .other { display: block;}
.menuArea .other > li { font-size: 1.2rem; margin-bottom: 10px; padding: 0;}
}

@media screen and (max-width: 600px){
.menuIcon span { display: none;}
.menuArea { max-width: calc(100vw - 40px); padding: 60px 20px;}
.menuArea li.cat01,
.menuArea li.cat02,
.menuArea li.cat03,
.menuArea li.cat04 { padding: 10px;}
}

.snsArea { display: flex; align-items: center; justify-content: center; margin: 50px 0;}
.snsArea a { display: flex; align-items: center; justify-content: center; width: 40px; height: 40px; border-radius: 50px; margin: 0 10px;}
.snsArea a.facebook { background: #1877f2;}
.snsArea a.youtube { background: #c4302b;}
.snsArea a.twitter { background: linear-gradient(to right,  #204bff 0%,#b039db 17%,#f1224d 34%,#ffa915 51%,#ffe987 68%,#ffffd4 84%,#00fffc 100%);}
.snsArea a.facebook { background: #1877f2;}
.snsArea a:hover { opacity: .7; transition: .2s;}
.snsArea a img { width: 70%;}


/* __________________________________________________
   footer
__________________________________________________ */
footer { width: 100%; height: auto; position: static; z-index: 10;}
footer .contactArea { width: 100%; display: flex; align-items: center; justify-content: center; flex-direction: column; color: #fff; padding: 70px 0; background: #2b9ea7 url(../images/share/bg_contact.png) 0 center no-repeat;}

footer .contactArea .btArea { display: flex; justify-content: center; margin-top: 30px;}
footer .contactArea a.bt { display: inline-block; text-align: center; color: #2b9ea7; text-decoration: none; font-size: 1.4rem; font-weight: bolder; background: #fff; border-radius: 30px; line-height: 1; padding: 10px 50px 10px 20px; margin: 0 10px; position: relative;}
footer .contactArea a.bt:after { content: ""; width: 10px; height: 10px; border-top: 3px solid #2b9ea7; border-left: 3px solid #2b9ea7; transform: rotate(135deg); position: absolute; top: calc(50% - 5px); right: 20px; transition: .3s;}
footer .contactArea a.bt:hover:after { position: absolute; right: 15px; transition: .3s;}

@media screen and (max-width: 600px){
footer .contactArea h1 { font-size: 2.2rem; font-weight: bold;}
footer .contactArea { background-size: cover; padding: 40px 20px;}
footer .contactArea .btArea { flex-direction: column;}
footer .contactArea a.bt { margin-bottom: 30px;}
}

footer .inner { display: flex; align-items:flex-end; flex-wrap: wrap; max-width: 1080px; margin: 0 auto; padding: 40px 40px 10px 40px;}
footer .inner > div { width: 50%;}
footer .inner a { color: #282828;}
footer .inner > div ul { list-style: none;}
footer .inner > div li { display: block; margin-bottom: .8em;}
footer .inner > div li a { display: inline-block;}
footer .inner > div li a:after { content: ""; display: inline-block; width: 6px; height: 6px; border-top: 3px solid #2b9ea7; border-left: 3px solid #2b9ea7; margin-left: 10px; transform: rotate(135deg);}
/*
copyright
 */
footer .inner > div.copyright { width: 100%; border-top: 2px solid #bfbfbf; font-size: 1.1rem; text-align: center; color: #282828; margin-top: 40px; padding: 10px;}

@media screen and (max-width: 768px){
footer .inner { margin: 0 auto; padding: 40px 20px 10px 20px;}
footer .inner > div { width: 100%;}
footer .inner > div:nth-child(2) { display: none;}
}

/*
Go to top
*/
a.bt_pageTop { display: block; width: 40px; height: 40px; z-index: 10; padding: 10px 15px; background: rgba(0, 0, 0, 0.4); border-radius: 20px; border: 1px solid #fff; color: #fff; text-indent: -999em; position: fixed; right: 30px; bottom: -50px; overflow: hidden; opacity: 0; transition: 1s;}
a.bt_pageTop:before { content: ''; width: 10px; height: 10px; border-top: solid 1px #fff; border-right: solid 1px #fff; position: absolute; top: 55%; left: calc(50% - 5px); margin-top: -4px;
  transform: rotate(-45deg);
}
a.bt_pageTop.fixed { display: block; position: fixed; right: 30px; bottom: 30px; opacity: 1; transition: 1s;}


/* __________________________________________________
   main
__________________________________________________ */
main { width: 100%; padding: 0; position: relative;}
main section { display: block; width: 100%;}
main section .inner { max-width: 1080px; padding: 60px 40px; margin: 0 auto;}

.bg_title {  text-align: center; padding: 80px 0 50px 0;
background: rgb(43,122,167);
background: linear-gradient(90deg, rgba(43,122,167,1) 0%, rgba(43,158,167,1) 52%, rgba(70,212,187,1) 100%);
}

.title { text-align: center; margin-bottom: 20px;}
h1 { display: inline-block; color: #fff; font-size: 3.6rem; font-weight: normal; letter-spacing: .2em; margin-bottom: 30px; position: relative;}
h1:before { display: inline-block; content: ""; width: 30px; height: 1px; background-color: #fff; position: absolute; bottom: -10px; left: 50%; transform: translate(-50%);}
h2 { font-size: 3rem; text-align: center; margin: 0 0 20px 0;}
h3 { font-size: 2rem; font-weight: 600; color: #2b9ea7; margin-bottom: 15px;}

main section .inner p { text-align: justify; padding-bottom: 1em;}

@media screen and (max-width: 1079px){
main section .inner { max-width: 100%; margin: 0 auto; padding: 40px;}
}

@media screen and (max-width: 768px){
main section .inner { padding: 40px 30px;}
}

@media screen and (max-width: 540px){
main section .inner { padding: 40px 20px;}
h1 { font-size: 3rem;}
h2 { font-size: 2.4rem;}
h3 { font-size: 1.8rem; margin-bottom: 10px;}
}

/*
button
*/
a.bt { display: inline-block; text-align: center; color: #2b9ea7; text-decoration: none; border: 1px solid #2b9ea7; border-radius: 30px; padding: 5px 50px 5px 20px; position: relative;}
a.bt:after { content: ""; width: 10px; height: 10px; border-top: 3px solid #2b9ea7; border-left: 3px solid #2b9ea7; transform: rotate(135deg); position: absolute; top: calc(50% - 5px); right: 20px; transition: .3s;}
a.bt:hover:after { position: absolute; right: 15px; transition: .3s;}

a.underLine {display: inline-block; text-decoration: none; overflow: hidden; position: relative;}
a.underLine:after { content: ""; width: 100%; height: 1px; background: #2b9ea7; position: absolute; bottom: 0;left: 0;
transform: translate(-100%, 0);
transition: transform cubic-bezier(0.215, 0.61, 0.355, 1) 0.4s;
}
a.underLine:hover:after { transform: translate(0, 0);}



/* __________________________________________________
   form
__________________________________________________ */
form input,
form textarea,
form select { width: 100%;
-moz-appearance: none;
-webkit-appearance: none; appearance: none; background: #fff; background-image: none; 
border: 1px solid #b4b4b4; color: inherit; font-size: 1.6rem; font-family: inherit; padding: 0.4em 0.8em; border-radius: 5px;}
select:-ms-expand { display: none;}
form input:focus,
form input textarea:focus,
form select:focus { border: 1px solid rgba(0, 0, 0, 0.32); box-shadow: none; outline: none;}

/* セレクトボックス */
form select { background: url(../images/share/icon-down-solid.svg) 95% center no-repeat; background-size: 16px 16px; background-color: transparent; padding-right: 30px;}
form select.disabled { color: #ccc;}

form .error_area { border: 1px solid #ff0000; border-radius: 3px; color: #ff0000; margin: 0 auto 15px auto;}
form .error { background-color: rgba(255, 0, 64, 0.1);}
form select.error { background: rgba(255, 0, 64, 0.1) url(../images/share/icon-down-solid.svg) 95% center no-repeat; background-size:  16px 16px;}

form input[type=file] { background: none; border: none;}

/* ラジオボタン */
form input[type=radio] { display: none;}
form input[type=radio] + label { display: inline-block; width: auto; padding: 5px 30px; position: relative; cursor: pointer;}
form input[type=radio] + label:before { display: block; content: ""; width: 16px; height: 16px; background: #e5e5e5; border: 1px solid #d2d2d2; border-radius: 50%; margin-top: -8px; position: absolute; top: 50%; left: 5px;}
form input[type=radio] + label:after { display: block; content: ""; width: 10px; height: 10px; background: #2b9ea7; border-radius: 50%; margin-top: -4px; position: absolute; top: 50%; left: 9px; opacity: 0; transform: scale3d(.3,.3,1); transition: transform .2s ease-in-out, opacity .2s ease-in-out;}
form input[type=radio]:checked + label:before { border-color: #666;}
form input[type=radio]:checked + label:after { opacity: 1; transform: scale3d(1,1,1);}

/* チェックボックス */
form input[type=checkbox] { display: none;}
form input[type=checkbox] + label { display: inline-block; width: auto; cursor: pointer; padding: 5px 30px; position: relative;}
form input[type=checkbox] + label:before { display: block; content: ""; width: 16px; height: 16px; background: #e5e5e5; border: 1px solid #d2d2d2;  margin-top: -8px; position: absolute; top: 50%; left: 5px;}
form input[type=checkbox] + label:after { display: block; content: ""; width: 9px; height: 20px; border-right: 6px solid #2b9ea7; border-bottom: 3px solid #7ecef4; margin-top: -16px; position: absolute; top: 50%; left: 7px; opacity: 0; transform: rotate(45deg) translate3d(0,2px,0) scale3d(.7,.7,1); transition: transform .2s ease-in-out, opacity .2s ease-in-out;}
form input[type=checkbox]:checked + label:before { border-color: #666;}
form input[type=checkbox]:checked + label:after { opacity: 1; transform: rotate(45deg) scale3d(1,1,1);}


/* 送信 */
form input[type=submit] { display: block; width: 200px; background: #2b9ea7; border: none; color: #fff; text-align: center; border-radius: 30px; padding: 8px 20px; margin: 20px auto 0 auto; transition: .3s; cursor: pointer;}
form input[type=submit]:hover { opacity: .7; transition: .3s;}

section form dl { display: flex; justify-content: center; width: 80%; border-bottom: 1px solid #ccc; padding-bottom: 10px; margin: 0 auto 10px auto;}
section form dl:first-of-type { padding-top: 10px; border-top: 1px solid #ccc; margin-top: 30px;}
section form dt { width: 25%; color: #2b9ea7; padding: 10px;}
section form dt span { font-size: 70%; padding-left: 10px; color: #ff0000;}
section form dd { width: 75%; display: flex; flex-wrap: wrap; align-items: center;}
section form dd span { font-size: 80%;}
section form section input { display: inline-block; width: 100%;}
section form textarea { display: inline-block; width: 100%; height: 10em;}

form .thanks { font-size: 2rem; text-align: center; line-height: 2em; padding: 50px 0;}


@media screen and (max-width: 768px){
section form dl { width: 100%;}
}

@media screen and (max-width: 540px){
section form dl { display: block; width: 100%;}
section form dt,
section form dd { width: 100%;}
}


/* __________________________________________________
   top
__________________________________________________ */
/*
メインビジュアル
*/
.mv { background: url(../images/top/bg_mv.jpg) 50% 50% no-repeat;}
.mv .inner { max-width: 1560px; display: flex; justify-content: space-between; padding: 0 10px}
.mv .inner .categoryBnArea { width: 500px;}
.mv .inner .categoryBnArea a { display: flex; align-items: center; flex-wrap: wrap; color: #fff; border-radius: 15px; padding: 50px 30px; margin-bottom: 10px; transition: .3s;}
.mv .inner .categoryBnArea a:hover { filter: saturate(40%); transition: .6s;}
.mv .inner .categoryBnArea a strong { font-family: 'M PLUS Rounded 1c', sans-serif; font-size: 3rem; font-weight: normal; line-height: 1.4em;}
.mv .inner .categoryBnArea a strong:after { content: ""; display: inline-block; width: 10px; height: 10px; border-top: 2px solid #fff; border-left: 2px solid #fff; margin: 0 0 0 10px; transform: rotate(135deg);}
.mv .inner .categoryBnArea a span { display: block; width: 100%;}
.mv .inner .categoryBnArea a.cat01 { background: #cfad24 url(../images/top/icon_cat01.svg) 95% 0 no-repeat;}
.mv .inner .categoryBnArea a.cat02 { background: #c85e97 url(../images/top/icon_cat02.svg) 95% 0 no-repeat;}
.mv .inner .categoryBnArea a.cat03 { background: #6561be url(../images/top/icon_cat03.svg) 95% 0 no-repeat;}

.mv .inner .catchcopy { width: calc(100% - 530px); position: relative;}
.mv .inner .catchcopy img { position: absolute; bottom: 200px; right: 40px;}
.mv .inner .catchcopy .aboutLink { display: inline-block; position: absolute; bottom: 100px; right: 50px; text-align: right; z-index: 3;}
.mv .inner .catchcopy .aboutLink:before { content: ""; display: inline-block; width: 400px; height: 100px; background: #fff; position: absolute; bottom: -10px; right: -30px; filter: blur(15px); z-index: -1;}
.mv .inner .catchcopy .aboutLink span { font-family: 'M PLUS Rounded 1c', sans-serif; font-size: 3rem;}
.mv .inner .catchcopy .aboutLink a { text-decoration: underline;}
.mv .inner .catchcopy .aboutLink a:after { content: ""; display: inline-block; width: 8px; height: 8px; border-top: 2px solid #2b9ea7; border-left: 2px solid #2b9ea7; margin: 0 0 0 8px; transform: rotate(135deg);}

@media screen and (max-width: 768px){
.mv { background: url(../images/top/bg_mv.jpg) 30% 0 no-repeat;}
.mv .inner { max-width: 100%; flex-wrap: wrap; padding: 0 20px}
.mv .inner .categoryBnArea,
.mv .inner .catchcopy { width: 100%;}
.mv .inner .catchcopy { padding: 200px 20px 200px 20px;}
.mv .inner .catchcopy img { width: 100%; position: static; margin: 0 auto;}
}

@media screen and (max-width: 500px){
.mv { background: url(../images/top/bg_mv.jpg) 25% 0 no-repeat; background-size: 350%;}
.mv .inner .catchcopy .aboutLink span,
.mv .inner .categoryBnArea a strong { font-size: 2.2rem;}
.mv .inner .categoryBnArea a strong:after { margin: 0 0 0 5px;}
}

/*
注目講座
*/
.focus { background: #2b9ea7 url(../images/top/bg_focus.png) 100% 50% no-repeat; }
.focus .inner { display: flex; align-items: center; flex-direction: column;}
.focus h1 { font-size: 2rem; border-bottom: 2px solid #fff; margin-bottom: 15px;}
.focus h1:before { display: none;}
main section.focus .inner p { font-family: 'M PLUS Rounded 1c', sans-serif; font-size: 3rem; color: #fff; text-align: center; padding-bottom: 20px; line-height: 1.4;}
.focus a.bt { display: inline-block; font-size: 1.2rem; text-align: center; color: #fff; text-decoration: none; border: 1px solid #fff; border-radius: 30px; padding: 3px 80px 3px 50px; position: relative;}
.focus a.bt:after { content: ""; width: 5px; height: 5px; border-top: 2px solid #fff; border-left: 2px solid #fff; transform: rotate(135deg); position: absolute; top: calc(50% - 2.5px); right: 20px; transition: .3s;}
.focus a.bt:hover:after { position: absolute; right: 15px; transition: .3s;}

@media screen and (max-width: 768px){
.focus { padding: 40px 0;}
main section.focus .inner p {font-size: 2.4rem;}
}

/*
NEWS
*/
.news { background: #eee;;}
.news .inner { display: flex; justify-content: space-between; padding: 60px 40px;}
.news .inner h1 { width: 160px; color: #2b9ea7; font-size: 4rem; font-weight: 100; letter-spacing: 0; }
.news .inner h1:before { display: none;}
.news .inner > div { width: calc(100% - 160px); border-left: 1px solid #2b9ea7; padding-left: 30px;}
.news .inner > div dl { display: flex;}
.news .inner > div dt { width: 100px; padding-top: 10px;}
.news .inner > div dd { width: calc(100% - 120px);}
.news .inner > div dd a { display: block; color: #2b9ea7; padding: 10px 50px 10px 10px; position: relative;}
.news .inner > div dd a:after { content: ""; width: 10px; height: 10px; border-top: 3px solid #2b9ea7; border-left: 3px solid #2b9ea7; transform: rotate(135deg); position: absolute; top: calc(50% - 5px); right: 20px; transition: .3s; line-height: 1.2rem;}
.news .inner > div dd a:hover:after { position: absolute; right: 15px; transition: .3s;}
.news .inner > div .btArea { margin-top: 20px; text-align: right;}
.news .inner > div .btArea a { display:inline-block; color: #2b9ea7; text-decoration: underline; padding: 0; position: relative;}
.news .inner > div .btArea a:after { content: ""; display:inline-block; width: 8px; height: 8px; border-top: 1px solid #2b9ea7; border-left: 1px solid #2b9ea7; transform: rotate(135deg); }

@media screen and (max-width: 700px){
.news .inner h1 { width: 100%; font-size: 3rem; text-align: center; border-bottom: 1px solid #2b9ea7; margin-bottom: 20px;}
.news .inner { flex-direction: column; padding: 40px 20px;}
.news .inner > div { width: 100%; border-left: none; padding-left: 0;}
}

@media screen and (max-width: 500px){
.news .inner > div dl { flex-direction: column;}
.news .inner > div dt, 
.news .inner > div dd { width: 100%;}
.news .inner > div dd a {padding: 0 50px 10px 10px;}
}

/*
mainContents
*/
.mainContents {
background: rgb(43,122,167);
background: linear-gradient(90deg, rgba(43,122,167,1) 0%, rgba(43,158,167,1) 52%, rgba(70,212,187,1) 100%);
}

/*
検索セット
*/
.searchBlock { width: 100%; background: #fff; border-radius: 20px; padding: 50px; margin-bottom: 50px;} 
.searchBlock .freeword { display: flex; justify-content: space-between; margin-bottom: 20px;}
.searchBlock .freeword input[type="text"] { width: 89%;}
.searchBlock .freeword input[type="submit"] { width: 10%; background: #ed7f1d; color: #fff; margin: 0; padding: 8px 5px; border-radius: 5px;}

.searchBlock .searchParameters dl { width: 100%; display: flex; border-bottom: 1px solid #ccc; margin: 0 0 10px 0; padding: 0;}
.searchBlock .searchParameters dt { width: 110px; background: #2b9ea7; color: #fff; padding: 10px;}
.searchBlock .searchParameters dd { width: calc(100% - 110px); padding: 10px;}
.searchBlock .searchParameters input[type="submit"] { display: block; width: 60%; background: #ed7f1d; color: #fff;}

@media screen and (max-width: 700px){
.searchBlock {padding: 30px 20px;} 
.searchBlock .freeword input[type="text"] { width: 80%;}
.searchBlock .freeword input[type="submit"] { width: 15%;}
.searchBlock .searchParameters dl { flex-direction: column;}
.searchBlock .searchParameters dt,
.searchBlock .searchParameters dd { width: 100%;}
.searchBlock .searchParameters dt { text-align: center;}
}

/*
新着・ランキング
*/
.newest_ranking { display: flex; justify-content: space-between;}
.newest_ranking h1 { display: block; font-size: 2.6rem; font-weight: bold; text-align: center; margin-bottom: 15px;}
.newest_ranking h1:before { display: none;}
.newest_ranking > div { width: 47.5%;}
.newest_ranking > div img { width: 100%; margin-bottom: 15px;}
.newest_ranking > div dl { padding: 25px; box-shadow: 0px 0px 16px -1px rgba(0,0,0,0.6); border-radius: 10px; margin-bottom: 20px;}
.newest_ranking > div dt { font-size: 1.6rem; color: #2b9ea7; line-height: 1.4; font-weight: 700; padding-bottom: 10px; margin-bottom: 15px; border-bottom: 2px solid #2b9ea7;}
.newest_ranking > div dt span { display: block; color: #000; font-size: 1.4rem; margin-bottom: 5px;}
.newest_ranking > div dd a { display: block; width: 100%; background: #ed7f1d; color: #fff; text-align: center; border-radius: 30px; padding: 5px; font-weight: bold;}

.newest_ranking > div.newest h1 { color: #ffee72;}
.newest_ranking > div.newest dl { background: #fffad5;}
.newest_ranking > div.ranking h1 { color: #fff;}
.newest_ranking > div.ranking dl { background: #fff;}

@media screen and (max-width: 600px){
.newest_ranking { flex-direction: column;}
.newest_ranking > div { width: 100%; margin-bottom: 30px;}
}

/*
リカデントについて
*/
.recurrent .inner { display: flex; justify-content: space-between;}
.recurrent .inner > div { width: 47.5%;}
.recurrent .inner > div img { width: 100%; margin-bottom: 20px;}
.recurrent .inner > div dt { font-size: 2rem; font-weight: 700; color:#2b9ea7;line-height: 1.4; margin-bottom: 5px;}
.recurrent .inner > div dd p { font-size: 1.4rem; padding-bottom: 20px;}
.recurrent .inner > div dd .bt { display: block; width: 60%; padding: 3px 30px 3px 0; margin: 0 auto;}

@media screen and (max-width: 600px){
.recurrent .inner { flex-direction: column;}
.recurrent .inner > div { width:100%; margin-bottom: 30px;}
}


/* __________________________________________________
   list
__________________________________________________ */
.list main { background: #eee;}
.list .bt_search { display: flex; align-items: center; background: #7d7d7d; color: #fff; font-size: 1.8rem; font-weight: 500; letter-spacing: .1em; padding: 3px 20px; margin-bottom: 30px;}
.list .bt_search:before { content: ""; display: block; width: 8px; height: 8px; border-top: 3px solid #fff; border-left: 3px solid #fff; transform: rotate(-135deg); margin: -5px 10px 0 0;}
.list .bt_search.open:before { content: ""; display: block; width: 8px; height: 8px; border-top: 3px solid #fff; border-left: 3px solid #fff; transform: rotate(45deg); margin: 5px 10px 0 0;}
.list .searchBlock { display: none;}

.listBlock { display: flex; flex-wrap: wrap;}
.listBlock > div { width: 47%; background: #fff; border-radius: 20px; box-shadow: 0px 0px 16px -1px rgba(0,0,0,0.6); padding: 50px 25px 25px; margin: 0 1.5% 5%; position: relative;}
.listBlock > div > span { width: 140px; color: 1.3rem; color: #fff; font-weight: 600; background: #000; border-radius: 0 0 5px 5px; padding: 3px 10px 3px 40px; position: absolute; top: 0; right: 20px;}
.listBlock > div > dl > dt { font-size: 2rem; color: #ccc; font-weight: 600; border-bottom: 16px solid #ccc; line-height: 1.4;}
.listBlock > div > dl > dt span { display: block; font-size: 1.4rem; color: #000; font-weight: normal;}
.listBlock > div > dl > dd .imgArea { position: relative; margin-bottom: 10px;}
.listBlock > div > dl > dd .imgArea img { width: 100%; vertical-align: top; z-index: 0;}
.listBlock > div > dl > dd .imgArea span { display: block; width: 42px; height: 42px; position: absolute; top: 15px; right: 15px; text-indent: -9876em;}
.listBlock > div > dl > dd .imgArea span.icon_free { background: url(../images/share/icon_free.svg) 0 0 no-repeat;}
.listBlock > div > dl > dd p { font-size: 1.4rem;}
.listBlock > div .outline { margin-bottom: 20px;}
.listBlock > div .outline > dl { display: flex; font-size: 1.4rem; border-bottom: 1px solid #bfbfbf; padding: 0; margin-bottom: 10px;}
.listBlock > div .outline > dl dt { width: 75px; background: #7d7d7d; color: #fff; padding: 8px;}
.listBlock > div .outline > dl dd { width: calc(100% - 75px); padding: 8px;}
