@charset "UTF-8";
@import url(default.css);
/* ================================================================== */
/* General */
/* ================================================================== */
@import url(all.min.css);
.cnt, article { width: 800px; }

.flex_cnt, footer .f_ct, .booklist, .support, .btnarea, .tokuten .inner .t_lb { display: -webkit-flex; display: -moz-flex; display: -ms-flex; display: -o-flex; display: flex; flex-wrap: wrap; align-content: flex-start; /*	align-items:center;*/ justify-content: space-between; }

.hor { letter-spacing: -.4em; }

.hor li, .hor dt, .hor dd, .hor div { display: inline-block; letter-spacing: normal; }

.hor_tb, .f_info, .tokutei table.tb1 td dl { display: table; }

.hor_tb dt, .f_info dt, .tokutei table.tb1 td dl dt, .hor_tb dd, .f_info dd, .tokutei table.tb1 td dl dd, .hor_tb div, .f_info div, .tokutei table.tb1 td dl div { display: table-cell; }

/* ========================================================= */
/* フォントサイズ */
/* ========================================================= */
.fs10 { font-size: 1.0rem; }

.fs11 { font-size: 1.1rem; }

.fs12 { font-size: 1.2rem; }

.fs13 { font-size: 1.3rem; }

.fs14 { font-size: 1.4rem; }

.fs15 { font-size: 1.5rem; }

.fs16 { font-size: 1.6rem; }

.fs17 { font-size: 1.7rem; }

.fs18 { font-size: 1.8rem; }

.fs19 { font-size: 1.9rem; }

.fs20 { font-size: 2.0rem; }

.fs21 { font-size: 2.1rem; }

.fs22 { font-size: 2.2rem; }

.fs23 { font-size: 2.3rem; }

.fs24 { font-size: 2.4rem; }

.fs25 { font-size: 2.5rem; }

.fs26 { font-size: 2.6rem; }

.fs27 { font-size: 2.7rem; }

.fs28 { font-size: 2.8rem; }

.fs29 { font-size: 2.9rem; }

.fs30 { font-size: 3.0rem; }

/* ========================================================= */
/* フォントタイプ */
/* ========================================================= */
.f_g1, .bold, table th, .em, .em_red, article ul.checklist li, footer .copyright, .c_lb, ul.ctlist li, table.sche_tb td .rem, table.sche_tb td a.semlink, .support p:nth-of-type(1), .btnarea .btn, .formarea .form_lb, .formarea .form_btn input, .profile .p_name { font-family: メイリオ,Meiryo; }

.f_g2, .c_lb2, .tokuten .inner .t_lb p { font-family: "HGP創英角ｺﾞｼｯｸUB"; }

.f_m1 { font-family: "HGP明朝E", "細明朝体", "ヒラギノ明朝 Pro W3"; }

.f_m2, .commentbox p { font-family: Georgia, "游明朝体", "YuMincho", "游明朝", "Yu Mincho", serif; }

/* ========================================================= */
/* 装飾 */
/* ========================================================= */
.bold, table th { font-weight: bold; }

.normal { font-weight: normal; }

.imgborder, .booklist div img { border: 1px solid #969696; }

.imgborder_dash { border: 1px dashed #999; }

.imgshadow { box-shadow: 1px 1px 2px rgba(0, 0, 0, 0.4); }

.imgradius { border-radius: 50%; }

.photoframe, .tokuten .inner .t_cont img { margin: 2px; border: 10px solid #FFF; box-shadow: 0px 0px 2px rgba(0, 0, 0, 0.6); }

.underborder { border-bottom: 1px solid #CCC; }

.underborder_red { border-bottom: 2px solid #F00; }

.under_border_da { border-bottom: 1px dashed #CCC; }

.noborder, article .norborder { border: none; }

.line_through { text-decoration: line-through; }

.line-through { background: url(../img/dot.png) repeat-x 0 50%; }

.em { font-weight: bold; }

.em_red { font-weight: bold; }

.marker { background-color: #ffff00; }

.ind_n { text-indent: 0; }

.mail_ico::before { margin-right: 5px; content: "\f0e0"; font-family: "Font Awesome 5 Pro"; font-weight: 400; }

.back_ico::before { margin-right: 10px; content: "\f0a8"; font-family: "Font Awesome 5 Pro"; font-weight: bold; }

/* ========================================================= */
/* 表示 */
/* ========================================================= */
.nodisp { text-indent: -9999px; }

.disp_none { display: none; }

.txt1 { padding-left: 1em; text-indent: -1em; }

.txt1_ib { display: inline-block; padding-left: 1em; text-indent: -1em; }

.lh10 { line-height: 1; }

.lh13 { line-height: 1.3; }

.lh15 { line-height: 1.5; }

.lh18 { line-height: 1.8; }

.lh20 { line-height: 2; }

.br-pc { display: block; }

.br-sp { display: none; }

/* ========================================================= */
/* レイアウト調整 */
/* ========================================================= */
.al_right { text-align: right; }

.al_left { text-align: left; }

.al_center { text-align: center; }

.f_left { float: left; }

.f_right { float: right; }

.valign-t { vertical-align: top; }

.valign-b { vertical-align: bottom; }

.valign-m { vertical-align: middle; }

.mauto, article, .ct, .mainimg, article .mauto, article article, article .ct, article .mainimg { margin-left: auto; margin-right: auto; }

.mg, article .mg { margin: 0; }

.mg5, article .mg5 { margin: 5px; }

.mg10, article .mg10 { margin: 10px; }

.mg20, article .mg20 { margin: 20px; }

.mg30, article .mg30 { margin: 30px; }

.mg40, article .mg40 { margin: 40px; }

.mg50, article .mg50 { margin: 50px; }

.mg60, article .mg60 { margin: 60px; }

.mg70, article .mg70 { margin: 70px; }

.mg80, article .mg80 { margin: 80px; }

.mg90, article .mg90 { margin: 90px; }

.mg100, article .mg100 { margin: 100px; }

.mtop, article .mtop { margin-top: 0; }

.mtop5, article .mtop5 { margin-top: 5px; }

.mtop10, article .mtop10 { margin-top: 10px; }

.mtop20, article .mtop20 { margin-top: 20px; }

.mtop30, article .mtop30 { margin-top: 30px; }

.mtop40, article .mtop40 { margin-top: 40px; }

.mtop50, article .mtop50 { margin-top: 50px; }

.mtop60, article .mtop60 { margin-top: 60px; }

.mtop70, article .mtop70 { margin-top: 70px; }

.mtop80, article .mtop80 { margin-top: 80px; }

.mtop90, article .mtop90 { margin-top: 90px; }

.mtop100, article .mtop100 { margin-top: 100px; }

.mbottom, article .mbottom { margin-bottom: 0; }

.mbottom5, article .mbottom5 { margin-bottom: 5px; }

.mbottom10, article .mbottom10 { margin-bottom: 10px; }

.mbottom20, article .mbottom20 { margin-bottom: 20px; }

.mbottom30, article .mbottom30 { margin-bottom: 30px; }

.mbottom40, article .mbottom40 { margin-bottom: 40px; }

.mbottom50, article .mbottom50 { margin-bottom: 50px; }

.mbottom60, article .mbottom60 { margin-bottom: 60px; }

.mbottom70, article .mbottom70 { margin-bottom: 70px; }

.mbottom80, article .mbottom80 { margin-bottom: 80px; }

.mbottom90, article .mbottom90 { margin-bottom: 90px; }

.mbottom100, article .mbottom100 { margin-bottom: 100px; }

.mleft, article .mleft { margin-left: 0; }

.mleft5, article .mleft5 { margin-left: 5px; }

.mleft10, article .mleft10 { margin-left: 10px; }

.mleft20, article .mleft20 { margin-left: 20px; }

.mleft30, article .mleft30 { margin-left: 30px; }

.mleft40, article .mleft40 { margin-left: 40px; }

.mleft50, article .mleft50 { margin-left: 50px; }

.mleft60, article .mleft60 { margin-left: 60px; }

.mleft70, article .mleft70 { margin-left: 70px; }

.mleft80, article .mleft80 { margin-left: 80px; }

.mleft90, article .mleft90 { margin-left: 90px; }

.mleft100, article .mleft100 { margin-left: 100px; }

.mright, article .mright { margin-right: 0; }

.mright5, article .mright5 { margin-right: 5px; }

.mright10, article .mright10 { margin-right: 10px; }

.mright20, article .mright20 { margin-right: 20px; }

.mright30, article .mright30 { margin-right: 30px; }

.mright40, article .mright40 { margin-right: 40px; }

.mright50, article .mright50 { margin-right: 50px; }

.mright60, article .mright60 { margin-right: 60px; }

.mright70, article .mright70 { margin-right: 70px; }

.mright80, article .mright80 { margin-right: 80px; }

.mright90, article .mright90 { margin-right: 90px; }

.mright100, article .mright100 { margin-right: 100px; }

.pd, article .pd { padding: 0; }

.pd5, article .pd5 { padding: 5px; }

.pd10, article .pd10 { padding: 10px; }

.pd20, article .pd20 { padding: 20px; }

.pd30, article .pd30 { padding: 30px; }

.pd40, article .pd40 { padding: 40px; }

.pd50, article .pd50 { padding: 50px; }

.pd60, article .pd60 { padding: 60px; }

.pd70, article .pd70 { padding: 70px; }

.pd80, article .pd80 { padding: 80px; }

.pd90, article .pd90 { padding: 90px; }

.pd100, article .pd100 { padding: 100px; }

.pdtop, article .pdtop { padding-top: 0; }

.pdtop5, article .pdtop5 { padding-top: 5px; }

.pdtop10, article .pdtop10 { padding-top: 10px; }

.pdtop20, article .pdtop20 { padding-top: 20px; }

.pdtop30, article .pdtop30 { padding-top: 30px; }

.pdtop40, article .pdtop40 { padding-top: 40px; }

.pdtop50, article .pdtop50 { padding-top: 50px; }

.pdtop60, article .pdtop60 { padding-top: 60px; }

.pdtop70, article .pdtop70 { padding-top: 70px; }

.pdtop80, article .pdtop80 { padding-top: 80px; }

.pdtop90, article .pdtop90 { padding-top: 90px; }

.pdtop100, article .pdtop100 { padding-top: 100px; }

.pdbottom, article .pdbottom { padding-bottom: 0; }

.pdbottom5, article .pdbottom5 { padding-bottom: 5px; }

.pdbottom10, article .pdbottom10 { padding-bottom: 10px; }

.pdbottom20, article .pdbottom20 { padding-bottom: 20px; }

.pdbottom30, article .pdbottom30 { padding-bottom: 30px; }

.pdbottom40, article .pdbottom40 { padding-bottom: 40px; }

.pdbottom50, article .pdbottom50 { padding-bottom: 50px; }

.pdbottom60, article .pdbottom60 { padding-bottom: 60px; }

.pdbottom70, article .pdbottom70 { padding-bottom: 70px; }

.pdbottom80, article .pdbottom80 { padding-bottom: 80px; }

.pdbottom90, article .pdbottom90 { padding-bottom: 90px; }

.pdbottom100, article .pdbottom100 { padding-bottom: 100px; }

.pdleft, article .pdleft { padding-left: 0; }

.pdleft5, article .pdleft5 { padding-left: 5px; }

.pdleft10, article .pdleft10 { padding-left: 10px; }

.pdleft20, article .pdleft20 { padding-left: 20px; }

.pdleft30, article .pdleft30 { padding-left: 30px; }

.pdleft40, article .pdleft40 { padding-left: 40px; }

.pdleft50, article .pdleft50 { padding-left: 50px; }

.pdleft60, article .pdleft60 { padding-left: 60px; }

.pdleft70, article .pdleft70 { padding-left: 70px; }

.pdleft80, article .pdleft80 { padding-left: 80px; }

.pdleft90, article .pdleft90 { padding-left: 90px; }

.pdleft100, article .pdleft100 { padding-left: 100px; }

.pdright, article .pdright { padding-right: 0; }

.pdright5, article .pdright5 { padding-right: 5px; }

.pdright10, article .pdright10 { padding-right: 10px; }

.pdright20, article .pdright20 { padding-right: 20px; }

.pdright30, article .pdright30 { padding-right: 30px; }

.pdright40, article .pdright40 { padding-right: 40px; }

.pdright50, article .pdright50 { padding-right: 50px; }

.pdright60, article .pdright60 { padding-right: 60px; }

.pdright70, article .pdright70 { padding-right: 70px; }

.pdright80, article .pdright80 { padding-right: 80px; }

.pdright90, article .pdright90 { padding-right: 90px; }

.pdright100, article .pdright100 { padding-right: 100px; }

.dis-b { display: block; }

.dis-ib { display: inline-block; }

.pos-rl { position: relative; }

.pos-fix { position: fixed; z-index: 500; }

.of { overflow: hidden; }

.clearfix:before, .clearfix:after { content: " "; /* 1 */ display: table; /* 2 */ }

.clearfix:after { clear: both; }

.clearfix { *zoom: 1; }

/* ========================================================= */
/* Width調整 */
/* ========================================================= */
.w5 { width: 5%; }

.w6 { width: 6%; }

.w8 { width: 8%; }

.w10 { width: 10%; }

.w12 { width: 12%; }

.w15 { width: 15%; }

.w18 { width: 18%; }

.w20 { width: 20%; }

.w25 { width: 25%; }

.w30 { width: 30%; }

.w33 { width: 33.3%; }

.w35 { width: 35%; }

.w40 { width: 40%; }

.w45 { width: 45%; }

.w48 { width: 48%; }

.w50 { width: 50%; }

.w55 { width: 55%; }

.w60 { width: 60%; }

.w65 { width: 65%; }

.w70 { width: 70%; }

.w75 { width: 75%; }

.w80 { width: 80%; }

.w85 { width: 85%; }

.w90 { width: 90%; }

.w92 { width: 92%; }

.w93 { width: 93%; }

.w94 { width: 94%; }

.w95 { width: 95%; }

.w96 { width: 96%; }

.w97 { width: 97%; }

.w98 { width: 98%; }

.w99 { width: 99%; }

.w100 { width: 100%; }

/* ========================================================= */
/* カラー調整 */
/* ========================================================= */
.gray { color: #828282; }

.black { color: #000000; }

.red, .em_red, table.sche_tb td .rem { color: #fe0000; }

.red_d { color: #B00909; }

.pink { color: #fe6090; }

.blue { color: #227efc; }

.blue_l { color: #9ce8df; }

.blue_d { color: #1b528e; }

.yellow { color: #fffa7b; }

.orange { color: #ff7800; }

.green { color: #139b34; }

.white { color: #FFFFFF; }

.brown { color: #9f5a1d; }

.scrollbox { poisition: relative; width: 100%; overflow: auto; scrollbar-base-color: #FFF; scrollbar-3dlight-color: #ffffff; scrollbar-arrow-color: #ffffff; scrollbar-darkshadow-color: #ffffff; scrollbar-face-color: #f1f1f1; scrollbar-highlight-color: #f1f1f1; scrollbar-shadow-color: #f1f1f1; scrollbar-track-color: #ffffff; }

/*スクロールバー全体*/
.scrollbox::-webkit-scrollbar { width: 10px; }

/*横スクロールバー全体*/
.scrollbox::-webkit-scrollbar:horizontal { height: 10px; }

/*スクロールバー上下左右末端のボタン*/
.scrollbox::-webkit-scrollbar-button { width: 10px; height: 10px; }

/*ドラッグするツマミ部分*/
.scrollbox::-webkit-scrollbar-thumb { background: #f1f1f1; }

/*右下角部分*/
.scrollbox::-webkit-scrollbar-corner { background-color: transparent; }

html { font-size: 62.5%; }

@font-face { font-family: YuGothicM; src: local("Yu Gothic Medium"); }
body { padding: 0; text-align: center; color: #141414; font-size: 1.6rem; font-family: "ＭＳ ゴシック", "MS Gothic", "Osaka－等幅", Osaka-mono, monospace; /*	font-family:-apple-system,BlinkMacSystemFont,"Helvetica Neue","游ゴシック Medium",YuGothic,YuGothicM,"Hiragino Kaku Gothic ProN",メイリオ,Meiryo,sans-serif;*/ overflow-x: hidden; min-width: 320px; font-weight: 500; -webkit-text-size-adjust: 100%; /*	background:url(../img/bg01.png);*/ background-color: #d7f1fd; }

body, html { height: 100%; }

p, li, dt, dd, table, th, td { line-height: 1.8; }

img { margin: 0; padding: 0; border: none; vertical-align: bottom; }

a { color: #0c89bd; text-decoration: none; }
a.noborder { text-decoration: none; }
a:visited { color: #0c89bd; }
a:hover { color: #ff6102; text-decoration: underline; }

a:hover, input[type="submit"]:hover, input[type="reset"]:hover { filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=70); opacity: 0.7; }

a.nohover:hover { filter: progid:DXImageTransform.Microsoft.Alpha(enabled=false); opacity: 1; }

input[type="submit"], input[type="button"], input[type="reset"] { border-radius: 0; -webkit-box-sizing: content-box; -webkit-appearance: button; appearance: button; border: none; box-sizing: border-box; cursor: pointer; }

input[type="submit"]::-webkit-search-decoration, input[type="button"]::-webkit-search-decoration, input[type="reset"]::-webkit-search-decoration { display: none; }

input[type="submit"]::focus, input[type="button"]::focus, input[type="reset"]::focus { outline-offset: -2px; }

/* ====================================================================== */
/* HEADER */
/* ====================================================================== */
/* ====================================================================== */
/* CONTENT */
/* ====================================================================== */
article { text-align: left; background-color: white; -moz-box-shadow: 0 5px 5px rgba(50, 150, 170, 0.5); -webkit-box-shadow: 0 5px 5px rgba(50, 150, 170, 0.5); box-shadow: 0 5px 5px rgba(50, 150, 170, 0.5); overflow: hidden; position: relative; }

.ct { width: 80%; overflow: hidden; }

/* --------------------------------------------------- */
/* 見出し */
/* --------------------------------------------------- */
.lb { margin-top: 50px; font-size: 3rem; font-family: "HGP創英角ｺﾞｼｯｸUB"; font-weight: bold; line-height: 1.3; color: red; text-align: center; }
.lb.f_lb { font-size: 3rem; font-family: "HGP創英角ｺﾞｼｯｸUB"; font-weight: bold; margin-top: 0; color: black; }
.lb.lb_blk { color: black; }

.sublb { margin-top: 50px; padding-left: 45px; font-size: 2rem; font-family: "HGP創英角ｺﾞｼｯｸUB"; font-weight: bold; line-height: 1.3; position: relative; }
.sublb .num { position: absolute; top: 0; left: 0; }

.sublb_t { padding: 5px; padding-left: 90px; background-color: #e5e5e5; }
.sublb_t .num { top: 5px; left: 5px; }

/* --------------------------------------------------- */
/* パラグラフ */
/* --------------------------------------------------- */
p { margin-top: 50px; /*	text-indent:1.6rem;*/ }

/* --------------------------------------------------- */
/* Table */
/* --------------------------------------------------- */
table { margin-top: 50px; }
table th, table td { padding: 8px; border: 1px solid #969696; }
table th { background-color: rgba(0, 0, 0, 0.06); }

/* --------------------------------------------------- */
/* UL OL */
/* --------------------------------------------------- */
ul, ol { margin-top: 50px; }

ul.list_disc li { margin-left: 20px; margin-bottom: 5px; list-style-type: disc; }

article ul.checklist li { margin-bottom: 10px; padding-left: 40px; font-weight: bold; position: relative; }
article ul.checklist li::before { content: "\f00c"; font-family: "Font Awesome 5 Pro"; position: absolute; top: 0; left: 0; color: red; }

article ol.list_num li { margin-left: 30px; margin-bottom: 5px; list-style-type: decimal; }

/* --------------------------------------------------- */
/* DL */
/* --------------------------------------------------- */
/* --------------------------------------------------- */
/* Parts */
/* --------------------------------------------------- */
.imgcnt { margin-top: 50px; }

/* --------------------------------------------------- */
/* Bgbox */
/* --------------------------------------------------- */
.bgbox01 { width: 90%; margin: 50px auto 0; background: url(../img/line01.png); background-color: rgba(0, 0, 0, 0.15); overflow: hidden; }
.bgbox01 .inner { background-color: white; margin: 10px; padding: 20px; }
.bgbox01 .inner .imgbox { margin-right: 50px; float: left; }

.bgbox02 { width: 90%; margin: 50px auto 0; padding-bottom: 30px; border: 5px solid rgba(0, 0, 0, 0.2); box-sizing: border-box; }
.bgbox02 .ct { width: 85%; }

/* ====================================================================== */
/* Footer */
/* ====================================================================== */
footer { margin-top: 100px; padding-bottom: 20px; }

footer .f_ct { align-items: flex-start; }
footer .f_ct ul { margin-top: 0; letter-spacing: -.4em; }
footer .f_ct ul li { display: inline-block; margin-right: 15px; letter-spacing: normal; font-size: 1.4rem; }

footer .copyright { font-size: 1.2rem; }

/* ================================================================== */
/* TOP */
/* ================================================================== */
.mainimg { display: block; margin-top: 16px; }

.c_lb { position: relative; margin: 50px 2em 0; padding: .5em 1em; background: #1e85d1; background: url('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4gPHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PGRlZnM+PGxpbmVhckdyYWRpZW50IGlkPSJncmFkIiBncmFkaWVudFVuaXRzPSJvYmplY3RCb3VuZGluZ0JveCIgeDE9IjAuMCIgeTE9IjAuNSIgeDI9IjEuMCIgeTI9IjAuNSI+PHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iIzE1N2NkZCIvPjxzdG9wIG9mZnNldD0iMTAwJSIgc3RvcC1jb2xvcj0iIzc4YmNlNCIvPjwvbGluZWFyR3JhZGllbnQ+PC9kZWZzPjxyZWN0IHg9IjAiIHk9IjAiIHdpZHRoPSIxMDAlIiBoZWlnaHQ9IjEwMCUiIGZpbGw9InVybCgjZ3JhZCkiIC8+PC9zdmc+IA=='); background: -webkit-gradient(linear, 0% 50%, 100% 50%, color-stop(0%, #157cdd), color-stop(100%, #78bce4)); background: -moz-linear-gradient(left, #157cdd, #78bce4); background: -webkit-linear-gradient(left, #157cdd, #78bce4); background: linear-gradient(to right, #157cdd, #78bce4); /*	border-top: 7px solid #0d51a0;*/ font-size: 2.4rem; color: white; }
.c_lb::before { position: absolute; content: ''; top: 100%; left: 0; border: none; border-bottom: solid 15px transparent; border-right: solid 25px rgba(120, 188, 228, 0.5); }
.bgbox01 .c_lb { margin-left: auto; margin-right: auto; font-size: 2rem; }

.c_lb2 { margin: 50px 2em 0; position: relative; padding: .5em; border-top: solid 1px rgba(0, 0, 0, 0.7); border-bottom: solid 1px rgba(0, 0, 0, 0.7); font-size: 2.8rem; text-align: center; }
.c_lb2::before, .c_lb2::after { content: ''; position: absolute; top: -10px; width: 1px; height: -webkit-calc(100% + 20px); height: calc(100% + 20px); background-color: rgba(0, 0, 0, 0.7); }
.c_lb2::before { left: 10px; }
.c_lb2::after { right: 10px; }

ul.ctlist li { padding: 1em 0 1em 3em; border-bottom: 1px dashed #969696; position: relative; }
ul.ctlist li a { font-weight: bold; }
ul.ctlist li::before { display: inline-block; width: 30px; height: 30px; line-height: 30px; -moz-border-radius: 50%; -webkit-border-radius: 50%; border-radius: 50%; font-size: 1.6rem; color: white; text-align: center; position: absolute; top: 15px; left: 0; font-family: "Font Awesome 5 Pro"; }
ul.ctlist li:nth-of-type(1)::before { background-color: #0058c5; content: "\f303"; font-weight: 300; }
ul.ctlist li:nth-of-type(2)::before { background-color: #f18700; content: "\f129"; font-weight: bold; }
ul.ctlist li:nth-of-type(3)::before { background-color: #47aaee; content: "\f0e0"; font-weight: bold; }
ul.ctlist li:nth-of-type(4)::before { background-color: #4267b2; content: "\f39e"; font-family: "Font Awesome 5 Brands"; }

table.sche_tb { width: 100%; margin: 50px auto 0; border-collapse: collapse; border: 3px solid #87bdca; }
table.sche_tb col:nth-of-type(1) { width: 30%; }
table.sche_tb col:nth-of-type(2) { width: 20%; }
table.sche_tb th, table.sche_tb td { padding: .5em; border: 1px solid #7fc5d6; vertical-align: middle; line-height: 1.5; }
table.sche_tb th { background-color: #e9f7fa; }
table.sche_tb td:nth-of-type(1), table.sche_tb td:nth-of-type(2) { text-align: center; }
table.sche_tb .head th { background-color: #4786e7; color: white; }
table.sche_tb td .rem { font-weight: bold; }
table.sche_tb td a.semlink { font-weight: bold; }
table.sche_tb td a.semlink::after { margin-left: .5em; content: "\f35d"; font-family: "Font Awesome 5 Pro"; font-weight: normal; }

.booklist { margin: 50px auto 0; justify-content: flex-start; text-align: center; }
.booklist div { width: 33.3%; margin-bottom: 30px; }
.booklist div span { display: block; width: 90%; margin: 20px auto 0; font-size: 1.3rem; line-height: 1.3; text-align: left; }

.maincopy { display: block; margin: 50px auto 0; }

.support { margin-top: 50px; padding-bottom: 30px; align-items: flex-start; border-bottom: 1px solid rgba(0, 0, 0, 0.3); }
.support p { margin-top: 20px; }
.support p:nth-of-type(1) { margin-top: 0; font-weight: bold; }

.btnarea { margin-top: 100px; }
.btnarea .btn { display: block; width: 45%; padding: 30px 0; background-color: #ff5f18; text-align: center; color: white; position: relative; }
.btnarea .btn:nth-of-type(2) { background-color: #bd0f0f; }
.btnarea .btn:hover { text-decoration: none; }
.btnarea .btn::after { position: absolute; top: 50%; right: 15px; content: "\f105"; font-family: "Font Awesome 5 Pro"; font-size: 3rem; font-weight: 300; transform: translateY(-50%); }

.f_info { width: 100%; }
.f_info dt { width: 15%; }
.f_info dd { padding-left: 20px; position: relative; }
.f_info dd::before { content: "："; position: absolute; top: 0; left: 0; }

.formarea .form_lb { margin-top: 50px; padding: .75em 0; font-size: 1.8rem; background-color: #0a5ab9; color: white; text-align: center; line-height: 1.3; }
.formarea table { width: 100%; margin-top: 10px; font-size: 1.5rem; }
.formarea table th, .formarea table td { padding: .5em; vertical-align: top; }
.formarea input, .formarea select { padding: 5px; }
.formarea input[name="rdphone1"], .formarea input[name="rdphone2"], .formarea input[name="rdphone3"] { width: 80px; }
.formarea input[type=radio], .formarea input[type=checkbox] { width: 14px; height: 14px; vertical-align: -.2em; }
.formarea .form_btn { margin-top: 50px; }
.formarea .form_btn input { display: inline-block; margin-left: 20px; margin-right: 20px; padding: 15px 40px; border: none; background-color: #0a958d; color: white; font-size: 1.8rem; }
.formarea .form_btn input.reset_btn { background-color: rgba(0, 0, 0, 0.25); }

.tokuten { width: 90%; margin: 70px auto 0; background-color: #d6ae61; border: 1px solid #ebd7b0; box-sizing: border-box; position: relative; }
.tokuten .inner { margin: 4px; padding: 20px; background: url(../img/tokuten/tokuten_inner.png); overflow: hidden; }
.tokuten .inner .t_lb { justify-content: flex-end; }
.tokuten .inner .t_lb p { width: 80%; margin-top: 0; /*				margin-left: auto;*/ font-size: 2.6rem; line-height: 1.4; }
.tokuten .inner .t_cont { margin-top: 30px; padding: 15px; overflow: hidden; /*			@extend .flex_cnt;
			align-items: flex-start;*/ }
.tokuten .inner .t_cont img { margin-left: 30px; float: right; }
.tokuten .inner .t_cont p { display: inline; margin-top: 0; }
.tokuten img.tokuten_ic { position: absolute; top: -35px; left: 5px; }

.profilebox { overflow: hidden; *zoom: 1; }
.profilebox img { float: left; margin-top: 50px; margin-right: 50px; }

.tokutei table.tb1 td dl { width: 100%; }
.tokutei table.tb1 td dl.payment { margin-bottom: 10px; }
.tokutei table.tb1 td dl.payment dt { width: 15%; }
.tokutei table.tb1 td dl.payment:last-child { margin-bottom: 0; }

.sign { margin-top: 50px; text-align: right; }

.commentbox { position: relative; padding: 1.5em; margin-top: 50px; top: 0; background: #f6f6f6; }
.commentbox::before, .commentbox::after { position: absolute; top: 0; content: ''; width: 15px; height: 100%; display: inline-block; box-sizing: border-box; }
.commentbox::before { border-left: solid 1px #6c8083; border-top: solid 1px #6c8083; border-bottom: solid 1px #6c8083; left: 0; }
.commentbox::after { border-top: solid 1px #6c8083; border-right: solid 1px #6c8083; border-bottom: solid 1px #6c8083; right: 0; }
.commentbox p { margin: auto; font-style: italic; }

.profile img { margin: 50px 0 50px 25px; float: right; }
.profile .p_name { font-weight: bold; font-size: 2.4rem; }

.i_rightbox { display: -webkit-flex; display: flex; -webkit-flex-direction: row-reverse; flex-direction: row-reverse; -webkit-justify-content: space-between; justify-content: space-between; }
.i_rightbox img { margin-top: 50px; }

@media screen and (max-width: 767px) { body { font-family: sans-serif; }
  .f_g1, .bold, table th, .em, .em_red, article ul.checklist li, footer .copyright, .c_lb, ul.ctlist li, table.sche_tb td .rem, table.sche_tb td a.semlink, .support p:nth-of-type(1), .btnarea .btn, .formarea .form_lb, .formarea .form_btn input, .profile .p_name, .f_g2, .c_lb2, .tokuten .inner .t_lb p, .bold, table th { font-family: sans-serif; }
  img { width: 100%; }
  .cnt, article { width: auto; }
  article .ct { width: 90%; }
  article .lb { font-size: 2rem; font-family: sans-serif; line-height: 1.5; }
  article .lb.f_lb { font-size: 2rem; font-family: sans-serif; }
  .sublb { font-size: 1.6rem; font-family: sans-serif; }
  article ul.checklist li { line-height: 1.5; font-family: sans-serif; }
  article ol.list_num li { margin-left: 30px; }
  table th { font-family: sans-serif; }
  article .sign img { width: 30%; }
  .support { display: block; overflow: hidden; }
  .support img { display: inline; width: 20%; margin: 0 20px 20px 0; float: left; }
  .support div { width: auto; display: inline; }
  .support p:nth-of-type(1) { font-family: sans-serif; }
  .btnarea .btn { display: block; width: 90%; margin-left: auto; margin-right: auto; margin-bottom: 20px; padding: 30px 0; font-family: sans-serif; }
  /* --------------------------------------------------- */
  /* Bgbox */
  /* --------------------------------------------------- */
  .bgbox01 { width: 95%; }
  .bgbox01 .inner { margin: 8px; padding: 20px; }
  .bgbox01 .inner .imgbox { display: block; width: 100%; margin-right: auto; margin-bottom: 30px; float: none; }
  .bgbox02 { width: 95%; }
  .bgbox02 .ct .flex_cnt img, .bgbox02 .ct footer .f_ct img, footer .bgbox02 .ct .f_ct img, .bgbox02 .ct .booklist img, .bgbox02 .ct .support img, .bgbox02 .ct .btnarea img, .bgbox02 .ct .tokuten .inner .t_lb img, .tokuten .inner .bgbox02 .ct .t_lb img { height: 150px; }
  footer .copyright { font-family: sans-serif; }
  .f_info dt { width: 25%; }
  .formarea .form_lb { padding: .5em 0; font-size: 1.6rem; line-height: 1.5; }
  .formarea table { display: block; }
  .formarea table th, .formarea table td { display: block; width: 95%; padding: 6px 10px; border: none; }
  .formarea table td { padding: 20px 10px; }
  .formarea input, .formarea select { padding: 5px; }
  .formarea input[name="rdphone1"], .formarea input[name="rdphone2"], .formarea input[name="rdphone3"] { width: 60px; }
  .formarea select { width: 90%; }
  .formarea .form_btn input { display: inline-block; margin-left: 10px; margin-right: 10px; padding: 10px 30px; border: none; font-size: 1.6rem; }
  .booklist div { width: 50%; }
  .booklist div img { width: 50%; }
  .booklist div p .rank { font-family: sans-serif; }
  .tokuten { width: 95%; margin: 30px auto 0; }
  .tokuten .inner { padding: 10px; }
  .tokuten .inner .t_lb p { width: 80%; font-size: 1.8rem; font-weight: bold; }
  .tokuten .inner .t_cont { margin-top: 20px; padding: 10px; }
  .tokuten .inner .t_cont img { width: 30%; border-width: 7px; }
  .tokuten .inner .t_cont p { display: inline; margin-top: 0; }
  .tokuten img.tokuten_ic { top: -10px; }
  table.sche_tb col:nth-of-type(1) { width: auto; }
  table.sche_tb col:nth-of-type(2) { width: auto; }
  table.sche_tb th, table.sche_tb td { font-size: 1.3rem; }
  table.sche_tb th { background-color: #e9f7fa; }
  table.sche_tb .head th { background-color: #4786e7; }
  .profilebox img { display: block; width: 40%; float: none; margin-left: auto; margin-right: auto; }
  .tokutei table.tb1 { display: block; box-sizing: border-box; border: 1px solid rgba(0, 0, 0, 0.3); }
  .tokutei table.tb1 th, .tokutei table.tb1 td { display: block; border: none; }
  .tokutei table.tb1 td dl.payment { display: block; }
  .tokutei table.tb1 td dl.payment dt, .tokutei table.tb1 td dl.payment dd { display: block; }
  .tokutei table.tb1 td dl.payment dt { width: auto; }
  .maincopy { width: 90%; margin-top: 20px; }
  .mainimg { display: block; margin-top: 0; }
  .c_lb { position: relative; margin: 50px 0.5em 0; font-size: 1.8rem; }
  .c_lb2 { margin: 50px 0.5em 0; padding: .5em; font-size: 1.8rem; }
  .c_lb2::before, .c_lb2::after { content: ''; position: absolute; top: -7px; height: -webkit-calc(100% + 14px); height: calc(100% + 14px); }
  .c_lb2::before { left: 7px; }
  .c_lb2::after { right: 7px; }
  .profile img { width: 35%; }
  .profile .p_name { font-size: 2rem; }
  .br-pc { display: none; }
  .br-sp { display: block; }
  .smp10 { width: 10%; }
  .smp15 { width: 15%; }
  .smp18 { width: 18%; }
  .smp20 { width: 20%; }
  .smp25 { width: 25%; }
  .smp30 { width: 30%; }
  .smp33 { width: 33.3%; }
  .smp35 { width: 35%; }
  .smp40 { width: 40%; }
  .smp45 { width: 45%; }
  .smp50 { width: 50%; }
  .smp55 { width: 55%; }
  .smp60 { width: 60%; }
  .smp65 { width: 65%; }
  .smp70 { width: 70%; }
  .smp75 { width: 75%; }
  .smp80 { width: 80%; }
  .smp85 { width: 85%; }
  .smp90 { width: 90%; }
  .smp94 { width: 94%; }
  .smp95 { width: 95%; }
  .smp98 { width: 98%; }
  .smp100 { width: 100%; } }
