/* A Modern CSS Reset */
*,*::before,*::after{box-sizing:border-box}ul[class],ol[class]{padding:0}body,h1,h2,h3,h4,h5,h6,p,ul[class],ol[class],figure,blockquote,dl,dd{margin:0}body{min-height:100vh;scroll-behavior:smooth;/*text-rendering:optimizeSpeed;*/line-height:2}ul[class],ol[class]{list-style:none}a:not([class]){/*text-decoration-skip-ink:auto*/}img{max-width:100%;display:block;height:auto;}article>*+*{margin-top:1rem}input,button,textarea,select{font:inherit}@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}}


html { }
body { font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif !important; color:#125; background:#fff; position:relative; font-size:1rem; font-weight: 500; line-height:2; letter-spacing:0.02rem; overflow-x:hidden; margin:0; padding:0; -webkit-text-size-adjust:100%; -ms-text-size-adjust:100%; font-feature-settings:"palt"; }

a { color:#125; transition:0.15s; outline-style:none; cursor: pointer; }

.alert_box { display: none; position: fixed; z-index: 10000; top:1rem; left:10%; right:10%; padding:1rem 4.5rem 1rem 1.5rem; background-color: rgba(0,0,0,0.5); backdrop-filter: blur(15px); -webkit-backdrop-filter: blur(15px); color:#fff; border-radius:0.5rem; }
.alert_close { padding:0; margin:0; overflow:visible; width:3rem; height:3rem; position:absolute; top:1rem; right:1rem; font-size:2em; background:#fff url(../img/i_close.svg) center center /2rem no-repeat; vertical-align:middle; color:#fff; min-width:auto; text-indent:-1000rem; z-index:100000; border:none; border-radius:50%; }
html.safari1.mac .alert_box, html.safari2.mac .alert_box, html.safari3.mac .alert_box, html.safari4.mac .alert_box, html.safari5.mac .alert_box, html.safari6.mac .alert_box, html.safari7.mac .alert_box, html.safari8.mac .alert_box, html.safari9.mac .alert_box, html.safari10.mac .alert_box, html.safari11.mac .alert_box, html.safari12.mac .alert_box, html.safari13.mac .alert_box, html.safari14.mac .alert_box, html.safari15.mac .alert_box { display: block; }


/*校正用*/
div.test, li.test { display:none;}
body.test div.test { display:block; }
body.test li.test { display: inline-block; }

/*校正追記 20241204*/
ul.page-link li.test { display:none; }
body.test ul.page-link li.test { display: inline-block; }


.pc_no, .pc_no2, .dis_no { display:none; }
.sp_no { display:block; }
span.sp_no { display:inline; }
br.sp_no { display:inline; }
br.sp_no2 { display:inline; }
.tc { text-align: center; }
.tr { text-align: right; }
.img_pc { display:block; }
.img_sp { display:none; }
.clearfix { display: block; clear: both; }
.clearfix:after { content: ""; display: block; clear: both;}
.clearfix:before { content: ""; display: block; clear: both;}
.f_s { font-size: 0.8rem; }

.green { color:#372;}
.yellowgreen { color:#9d6;}
.yellow {color:#ec0;}
.red {color:#e66;}
.blue { color:#0ae;}
.orange { color:#f98;}

p { margin-bottom: 2rem;}
hr { background: none; border: none; border-top: 1px solid rgba(17,32,85,0.15);}
ul { padding:0 0 0 1rem; margin:0 0 1rem 0; }

.article { width:90vw; max-width:85rem; padding:0; margin:0 auto; box-sizing:border-box; z-index:1; position:relative; }
.full { margin-left:calc(50% - 50vw); margin-right:calc(50% - 50vw); }
.full_r { margin-left:0; margin-right:calc(50% - 43vw); }
.full_l { margin-left:calc(50% - 43vw); margin-right:0; }
.full_bg { padding-left:calc(50vw - 50%); padding-right:calc(50vw - 50%); }
.anchor { height:9rem; margin-top:-9rem; position:relative; z-index:-10; width:1px; }
body.logged-in .anchor { height:calc(3rem + 32px); margin-top:calc(-6rem - 32px); }

.flex { display:flex; flex-flow:row wrap; justify-content:space-between; position: relative; }
.flex.jcfs { justify-content:flex-start; }
.flex.aic { align-items: center; }
.flex.aifs { align-items: flex-start; }
.flex.aife { align-items: flex-end; }
.flex .fg1 { flex-grow: 1; }

.fadein { opacity : 0; transform : translate(0, 0); transition :all 0.75s ease 0.15s;}
.fadein.show { opacity : 1; transform : translate(0, 0); }

.fadeinUp { opacity : 0; transform : translate(0, 50px); transition :all 0.75s ease 0.15s;}
.fadeinUp.show { opacity : 1; transform : translate(0, 0); }

.fadeinDown { opacity : 0; transform : translate(0, -50px); transition :all 0.75s ease 0.15s;}
.fadeinDown.show { opacity : 1; transform : translate(0, 0); }

.fadeinLeft { opacity : 0; transform : translate(-50px, 0); transition :all 0.75s ease 0.15s;}
.fadeinLeft.show { opacity : 1; transform : translate(0, 0); }

.fadeinRight { opacity : 0; transform : translate(50px, 0); transition :all 0.75s ease 0.15s;}
.fadeinRight.show { opacity : 1; transform : translate(0, 0); }


.mb0 { margin-bottom:0 !important; }
.mb4 { margin-bottom:0.25rem !important; }
.mb8 { margin-bottom:0.5rem !important; }
.mb16 { margin-bottom:1rem !important; }
.mb24 { margin-bottom:1.5rem !important; }
.mb32 { margin-bottom:2rem !important; }

.mr0 { margin-right:0; }
.mr4 { margin-right:0.25rem; }
.mr8 { margin-right:0.5rem; }
.mr16 { margin-right:1rem; }
.mr24 { margin-right:1.5rem; }
.mr32 { margin-right:2rem; }

.mt0 { margin-top:0; }
.mt4 { margin-top:0.25rem; }
.mt8 { margin-top:0.5rem; }
.mt16 { margin-top:1rem; }
.mt24 { margin-top:1.5rem; }
.mt32 { margin-top:2rem; }

.ma { margin: auto; }


/*--HEADER--*/
.header { position: fixed; z-index:2000; display:flex; flex-flow:row wrap; align-items:center; justify-content:space-between; top:0; left:0; right:0; padding:2.5rem 0 0 3vw; line-height:1.25; transition:0.5s; }
.header.bg { background: rgba(255,255,255,0.8); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); padding:0.5rem 0 0.5rem 3vw; }
.header.bg .t_title { max-width:15rem; }
.header.bg .hm > ul { background: none; backdrop-filter: blur(0); -webkit-backdrop-filter: blur(0); }

/*--HEADER MENU--*/
.hm { transition:0.25s; margin-left: auto; }
.hm > ul { padding:0 5vw 0 1rem; margin:0; display:flex; flex-flow:row wrap; justify-content: space-between; align-items: flex-start; list-style: none; background: rgba(255,255,255,1); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); border-radius:3rem 0 0 3rem; }
.hm > ul > li { display: inline-block; margin: 0; position: relative; transition: all 0.4s ease;}
.hm > ul > li > a { display: block; padding:1rem 0.75rem; font-weight: 300; font-size:1.125rem; text-decoration: none; letter-spacing:0.1rem; }
.hm > ul > li:hover > a, .hm li.active > a { box-shadow:none; opacity:1; }
.hm > ul > li:hover > a, .header a:hover, .header a.active, .footer a.active { /*background: linear-gradient(to right, rgba(255,153,136,1) 0%,rgba(242,142,197,1) 100%);*/ background: linear-gradient(to right, rgba(255,109,85,1) 0%,rgba(237,96,174,1) 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; }


.hm li .sub { display: none; position:absolute; top:100%; left:calc(50% - 8rem); width:16rem; z-index:100000; box-shadow:0 1rem 0.5rem -0.75rem rgba(0,0,0,0.05); }
.hm li .sub::before { content:""; position:absolute; left:50%; top:-0.25rem; height:1.5rem; display:block; border-right:1px solid rgba(17,34,85,0.2); z-index: 1; }

.hm li a.feature + .sub { left:calc(50% - 7rem); width:14rem; } 
/*.hm li a.about + .sub { left:calc(50% - 8rem); width:16rem; } */
.hm li a.campuslife + .sub { left:calc(50% - 9.5rem); width:19rem; } 
.hm li a.admission + .sub { left:calc(50% - 7rem); width:14rem; } 
.hm li a.status + .sub { left:calc(50% - 7.5rem); width:15rem; } 

.hm li .sub > ul { display:flex; flex-flow:column wrap; margin:0.75rem 0 0 0; padding:0.75rem 0.5rem; text-align: left; background: rgba(255,255,255,0.85); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); width:100%; border-radius:0.5rem; box-shadow:0 0.25rem 0.75rem rgba(17,34,85,0.1); list-style: none; }

.hm li .sub ul li { width: 100%; margin: 0; /*font-size: 0.9rem;*/ }
.hm li .sub ul li a { display: block; width:100%; padding:0.5rem 0.75rem; text-align: left; text-decoration: none; position:relative;}
.hm li .sub ul li a:hover { background-color:rgba(255,255,255,0.5); color:#125; }
.hm li .sub ul li a[target='_blank']::after { top:-0.1rem; }

.hm li .sub ul li ul { list-style: none; padding-left:1.25rem; margin-bottom:0.5rem; }
.hm li .sub ul li ul li a::before { content:""; display: block; position: absolute; top:50%; left:-0.5rem; width: 1rem; border-top: 1px solid rgba(17,34,85,0.2); }

.mean-container .mean-nav ul li ul li a::before { content:""; position: absolute; top:1.2rem; left:0.75rem; width:0.5rem; height:0.5rem; border-top:1px solid #125; border-right:1px solid #125; transform: rotate(45deg); }
.mean-container .mean-nav ul li > a.info::before,
.mean-container .mean-nav ul li > a.member::before { right:1.3rem;}

.hm > ul > li.sp { display: none; }

/*--MAIN--*/
.main { position: relative; z-index:10; height:56.25vw; max-height:100vh; padding:0 2rem; }
.main img { width: 100%; margin: auto; }

.video_box { position: absolute; top:0; right:0; width:66.6vw; height: 56.25vw; max-height:100vh; max-width:1500px; z-index: -1; overflow: hidden; border-radius:0 0 0 2rem; }
.video_box video { position: relative; left:-25%; width:100vw; height: 56.25vw; max-height:100vh; bottom:0; z-index: -1;}
.video_box::after { /*content:""; display: block; position: absolute; top:0; bottom:0; left:0; width:3rem;  background: linear-gradient(to right, rgba(255,255,255,1) 0%,rgba(255,255,255,0) 100%);*/ }
.campuslife_video { width: 100%; height: 100%; }

.t_title { display: block; width:70%; max-width:22rem; text-decoration: none; transition:0.75s; }
.t_title img { width: 100%; max-width:22rem; }
.t_copy { width:40%; z-index: 100; position: absolute; top:calc(50% - 2.5rem); left:5vw; transform: translate(0, -50%); }



h1, h2, h3, h4, h5, h6 { line-height:1.5; position: relative; padding:0; text-align:left; font-family: dnp-shuei-mgothic-std, sans-serif; font-weight: 600; font-style: normal; }
h1 { font-size:3rem; margin-bottom: 1rem; }
h2 { font-size:2.5rem; margin-bottom: 1rem; }
h3 { font-size:2rem; margin-bottom: 0.75rem; }
h4 { font-size:1.5rem; margin-bottom: 0.75rem; }
h5 { font-size:1.25rem; margin-bottom: 0.5rem; }
h6 { font-size:1.125rem; margin-bottom: 0.5rem; }

h1 .comment, h2 .comment, h3 .comment, h4 .comment, h5 .comment { display: inline-block; font-size:1rem; letter-spacing:0.1rem; }
br + .comment { display: block; }

h2.tate, h3.tate, h4.tate { writing-mode:vertical-rl; font-feature-settings:initial; }
h2, .index_box h3 { letter-spacing:0.1rem; position: relative; display:flex; flex-flow:row wrap; align-items: center; justify-content:space-between; }
h2::after, .index_box h3::after { content:""; flex-grow: 1; margin-left:1rem; border-top:1px solid rgba(17,34,85,0.2); }
h2.left { text-align: left; justify-content:flex-start; position:relative; margin-left:0; margin-right: 0; }

h4 .icon { display: inline-block; margin-right: 0.5rem; vertical-align: middle; }
h2.grade, h3.grade, h4.grade { background: linear-gradient(to right, rgba(255,109,85,1) 0%,rgba(234,65,158,1) 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; }
a.more { text-decoration:none; position: relative; white-space: nowrap; padding:0.75rem 2rem 0.75rem 0; font-size: 1.125rem; }
a.more::before { content:""; display: block; width: 0.5rem; height: 0.5rem; border-top:1px solid #125; border-right:1px solid #125; position: absolute; top:1rem; right: 0; transform: rotate(45deg); transition:0.5s; }
a.more::after { content:""; display: block; border-top:1px solid #125; position: absolute; bottom:0; left:0; right:calc(50% - 50vw); }
a.more:hover::before { right:0.5rem; }

span.line { background: linear-gradient(transparent 60%, rgba(255,153,136,0.3) 60%); z-index: -1; } 





/*--ABOUT--*/
 .feature_area { display:flex; flex-flow:row wrap; align-items: flex-start; justify-content:space-between; width: 100%; margin: auto; padding:0 0 5rem 0; margin-bottom: 5rem; position: relative; z-index: 10;}
 .feature_area .photo { border-radius:1rem; overflow: hidden; margin:-5vw 0 0 -5vw; box-shadow:0 1rem 0.5rem -0.75rem rgba(17,34,85,0.1); position: relative; }
 .feature_area .photo img { width: 100%; max-width: 100vw; }
 .feature_area .text { display:flex; flex-flow:row wrap; justify-content:space-between; text-align: left; padding:4.5rem 3rem 0 0; }
 .feature_area .text p { width:calc(100% - 6rem); margin: 0 0 2rem 0; font-size: 1.125rem; }

model-viewer { position: absolute; z-index: 10; top:-5%; left:0; width:75%; height: 75%;  }

.pattern_box { position: relative; right:calc(50% - 45vw); top:0; z-index:-1; }
.pattern { position: absolute; display: block; border-radius:0.5rem; z-index:0; }
.pattern:nth-of-type(1) { width:14vw; height:21vw; top:-4vw; right:0; background: rgba(160,224,252,0.15); }
.pattern:nth-of-type(2) { width:21vw; height:14vw; top:11vw; right:8vw; background: rgba(168,156,232,0.15); }
.pattern:nth-of-type(3) { width:15vw; height: 15vw; top:18vw; right:25vw; background: rgba(225,106,105,0.1); }
.pattern:nth-of-type(4) { width:14vw; height: 21vw; top:28vw; right:20vw; background: rgba(233,186,95,0.15); }

 .feature_area .pattern_box .pattern:nth-of-type(1) { height:17vw; top:0; border-radius:0 0 0.5rem 0.5rem; }


/*--course--*/
.course_area { display:flex; flex-flow:row wrap; justify-content:space-between; margin-bottom:5rem; }
.course_area .bg { position: relative; display:flex; flex-flow:row wrap; justify-content:space-between; width:calc(100% - 7rem); padding:0 3rem 0 0; right:0; }

.course_area ul { width: 100%; display:flex; flex-flow:row wrap; justify-content:space-around; list-style: none; margin: 0; padding: 0; }
.course_area ul li { width:calc((100% - 6rem)/2); margin-bottom:3rem; position: relative; max-width:34rem; }
.course_area ul li:nth-of-type(2n - 1) { }
.course_area ul li:nth-of-type(2n + 0) { margin-top:-3rem; }


.course_area ul li .photo { border-radius:0.5rem; position: relative; overflow: hidden; margin-bottom:0.5rem; box-shadow:0 1rem 0.5rem -0.75rem rgba(17,34,85,0.1); }
.course_area ul li .text { font-size: 1.25rem; display:flex; flex-flow:row wrap; align-items:center; justify-content:space-between; position: relative; }
.course_area ul li .text::after { content:""; flex-grow: 1; margin-left:1rem; border-top:1px solid rgba(17,34,85,0.2); }
.course_area ul li a { text-decoration: none; color:#125; }

.course_area ul li::after { content: ""; position: absolute; display: block; border-radius:0.5rem; z-index: -1; }
.course_area ul li:nth-of-type(1)::after { width:14vw; height:21vw; top:-7vw; left:-2vw; background: rgba(160,224,252,0.15); }
.course_area ul li:nth-of-type(2)::after { width:21vw; height:14vw; top:-2vw; right:-5vw; background: rgba(168,156,232,0.15); }
.course_area ul li:nth-of-type(3)::after { width:15vw; height: 15vw; bottom:-3vw; left:-5vw; background: rgba(225,106,105,0.1); }
.course_area ul li:nth-of-type(4)::after { width:14vw; height: 21vw; bottom:2vw; right:-3vw; background: rgba(233,186,95,0.15); }


.course_area .tr { margin-top: -3rem; }




/*--FUTURE--*/
.future_area { display:flex; flex-flow:row wrap; justify-content:space-between; margin-bottom:5rem; }
.future_area .bg { position: relative; display:flex; flex-flow:row wrap; justify-content:space-between; width:calc(100% - 7rem); padding:0 3rem 3rem 0; right:0; }
.future_area .bg::after { content:""; position: absolute; top:9rem; bottom:0; left:calc(50% - 50vw - 3.5rem); right:calc(50% - 50vw + 3.5rem); background: url("../img/bg01.webp") center center /cover no-repeat fixed; z-index:-1; opacity: 0.1; }
.future_area ul { width: 100%; display:flex; flex-flow:row wrap; justify-content:space-between; list-style: none; margin:0; padding: 0; }
.future_area ul li:nth-of-type(3n - 2) { }
.future_area ul li:nth-of-type(3n - 1) { margin-top: 3rem; }
.future_area ul li:nth-of-type(3n - 0) { margin-top: 6rem; }

.future_area ul li { position: relative; display:flex; flex-flow:row nowrap; justify-content:space-between; width:30%; }
.future_area ul li .desc { writing-mode:vertical-rl; font-feature-settings:initial; font-weight: 400; }
.future_area ul li a { width:calc(100% - 3rem); }
.future_area ul li .photo { position: relative; box-shadow:0 1rem 0.5rem -1rem rgba(17,34,85,0.2); border-radius: 0.5rem; overflow: hidden; }
.future_area ul li .photo img { width: 100%; transition:1s ease;}
.future_area ul li a:hover .photo img { transform: scale(1.1); }
.future_area ul li .text { font-size:1.25rem; font-weight: 500; display: block; padding:0.25rem 1.25rem; position: absolute; bottom:1.25rem; right:1.25rem; left:1.25rem; background: rgba(255,255,255,0.9); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); border-radius:3rem; }
.future_area ul li .text::before { content:""; display: block; width: 0.5rem; height: 0.5rem; border-top:1px solid #125; border-right:1px solid #125; position: absolute; top:1.25rem; right: 1.5rem; transform: rotate(45deg); }


/*--ATMOSPHERE--*/
.atmos_area { margin-bottom:5rem; position: relative; height:75vw; }
.atmos_area .photo { /*background: url("../img/bg01.webp") top left /cover no-repeat fixed;*/ display:block; position: absolute; border-radius:0.5rem; }
.atmos_area .photo img { object-fit: cover; border-radius:0.5rem; box-shadow:0 1rem 0.5rem -1rem rgba(17,34,85,0.2); }
.atmos_area .photo::after { content: ""; display: block; border-radius:0.5rem; position: absolute; z-index: -1; }
.atmos_area .photo01 { width:33vw; height:27vw; top:3vw; left:-1rem; }
.atmos_area .photo01 img { width:33vw; height:27vw; }
.atmos_area .photo01::after { width:26.4vw; height:21.6vw; top:10vw; left:14vw; background: rgba(233,186,95,0.15); }
.atmos_area .photo02 { width:16vw; height:24vw; top:9vw; left: 46vw; }
.atmos_area .photo02 img { width:16vw; height:24vw; }
.atmos_area .photo02::after { width:12.8vw; height:19.2vw; top:-7vw; left:6vw; background: rgba(225,106,105,0.1); }
.atmos_area .photo03 { width:27vw; height:40vw; top:0; left: 73vw; }
.atmos_area .photo03 img { width:27vw; height:40vw; }
.atmos_area .photo03::after { width:21.6vw; height:32vw; top:13vw; left:-6vw; background: rgba(160,224,252,0.15); }
.atmos_area .photo04 { width:16vw; height:27vw; top:45vw; left: 5vw; }
.atmos_area .photo04 img { width:16vw; height:27vw; }
.atmos_area .photo04::after { width:12.8vw; height:21.6vw; top:-6vw; left:-5vw; background: rgba(160,224,252,0.15); }
.atmos_area .photo05 { width:21vw; height:21vw; top:38vw; left:28vw; }
.atmos_area .photo05 img { width:21vw; height:21vw; }
.atmos_area .photo05::after { width:16.8vw; height:16.8vw; top:12vw; left:8vw; background: rgba(168,156,232,0.15); }
.atmos_area .photo06 { width:37vw; height:21vw; top:48vw; left:58vw; }
.atmos_area .photo06 img { width:37vw; height:21vw; }
.atmos_area .photo06::after { width:29.6vw; height:16.8vw; top:10vw; left:12vw; background: rgba(233,186,95,0.15); }



/*--BLOG--*/
.blog_area { position:relative; display:flex; flex-flow:row nowrap; justify-content:space-between; margin-bottom:5rem; }
.blog_area .bg { position: relative; display:flex; flex-flow:row wrap; justify-content:space-between; width:calc(100% - 7rem); padding:0 3rem 0 0; right:0; }
.blog01 li, .blog02 li { margin-bottom: 2rem; }
.blog01 a, .blog02 a { text-decoration: none; }
.blog01 .photo { margin-bottom: 1rem; border-radius:0.5rem; overflow: hidden; box-shadow:0 1rem 0.5rem -1rem rgba(17,34,85,0.2); }
.blog01 .photo img, .blog02 .photo img { width: 100%; max-width: 100vw; height: auto; transition:1s ease; }
.blog01 a:hover .photo img, .blog02 a:hover .photo img { transform: scale(1.1); }
.blog01 .text, .blog02 .text { font-size: 1.25rem; line-height: 1.5; }
.blog01 .text .date, .blog02 .text .date { font-size: 0.875rem; margin-top:1rem; }
.blog02 li a { display:flex; flex-flow:row nowrap; align-items: flex-start; justify-content:space-between; }
.blog02 .photo { width: 35%; border-radius:0.5rem; overflow: hidden; box-shadow:0 1rem 0.5rem -1rem rgba(17,34,85,0.2); }
.blog02 .text { width: calc(65% - 1rem); position: relative; font-size: 1.25rem; line-height: 1.5; padding-bottom:2.5rem; }
.blog02 .text .date { position: absolute; bottom:0; font-size: 0.875rem; margin-top:1rem; }
.blog_area a.more { top: -2rem; }


/*--INFO--*/
.info_area { position:relative; display:flex; flex-flow:row nowrap; justify-content:space-between; margin-bottom:5rem; }
.info_area h2 { }
.info_area .bg { position: relative; width:calc(100% - 7rem); padding:2rem 3rem 3rem 3rem; right:0; }
.info_area .bg::after { content:""; position: absolute; top:0; bottom:0; left:0; right:calc(50% - 50vw); border-radius:2rem 0 0 2rem; background: url("../img/bg01.webp") center center /cover no-repeat fixed; z-index:-1; opacity: 0.1; }

.info_area ul { width: 100%; position: relative; background: none; margin:0 0 2rem 0; list-style: none; padding: 0; }
.info_area ul li { width: 100%; border-bottom:1px solid rgba(17,34,85,0.15); }
.info_area ul li a { text-decoration: none; display:flex; flex-flow:row nowrap; justify-content:space-between; padding:1rem 0; } 
.info_area ul li a .date { font-size:0.8125rem; width: 4.5rem; height: 4.5rem; margin-right:1rem; background:#fff; border-radius:3rem; display:flex; flex-flow:row wrap; align-items: center; justify-content: center; line-height: 1.25; }
.info_area ul li a .text { /*width:calc(100% - 6rem);*/ flex-grow: 1; }
.info_area ul li a:hover .text { text-decoration: underline; }

.i_cate { display: inline-block; border-radius:1rem; font-size:0.8125rem; padding:0 0.75rem; margin-bottom:0.25rem; }
.i_cate.info { background: rgba(187,0,153,0.2);}
.i_cate.kiso { background: rgba(160,224,252,0.4); }
.i_cate.seijin {background: rgba(168,156,232,0.4);}
.i_cate.bosei {background: rgba(225,106,105,0.4);}
.i_cate.chiiki {background: rgba(233,186,95,0.4);}

.i_cate.kango { background: rgba(187,0,153,0.2);}
.i_cate.eisei { background: rgba(160,224,252,0.4);}





/*--FOOTER--*/
.footer { padding-bottom: 6rem; position: relative; display:flex; flex-flow:row wrap; align-items: flex-start; justify-content:space-between; }

.f_title { display: block; width: 100%; max-width: 20rem; margin-bottom:1.5rem; margin-right:3vw; }
.f_title img { width: 100%; }

.address_box { display: flex; flex-flow: column wrap; justify-content: space-between; align-items:flex-start; margin-bottom:1.5rem; margin-right:3vw; }

.tel, .fax { display: inline-block; line-height: 1.5; }
.tel strong, .fax strong { font-size: 1.5rem; }
.tel strong::before { content:""; display: inline-block; width:1.5rem; height: 1.5rem; background: url(../img/i_tel.svg) center center /1.25rem no-repeat; 
margin:0 0.25rem 0.25rem 0; vertical-align: middle; }
.fax strong::before { content:""; display: inline-block; width:1.5rem; height: 1.5rem; background: url(../img/i_fax.svg) center center /1.25rem no-repeat; margin-right: 0.25rem; margin:0 0.25rem 0.25rem 0; vertical-align: middle; }

ul.um { margin-bottom: 2rem; margin-right:3vw; }
.um li a { text-decoration: none; }
.um li a:hover { text-decoration: underline; }

.tufm { display:flex; flex-flow:row wrap; align-items: center; justify-content:space-between; width:17rem; border:1px solid #125; border-radius:3rem; padding:0.5rem 1rem; position: relative; text-decoration: none; margin:0 0 2rem 0; }
.tufm span { margin:0 auto 0 1rem; }
.tufm::before { content:""; display: block; width: 0.5rem; height: 0.5rem; border-top:1px solid #125; border-right:1px solid #125; /*position: absolute; top:1.25rem;*/ left: 1rem; transform: rotate(45deg); }
.tufm::after { content:""; width: 1.5rem; height: 1.5rem; background: url("../img/i_blank.svg") center center /cover no-repeat; margin-left:0.25rem; }
.tufm:hover { opacity: 0.7; }

.copyright { width: 100%; bottom:1rem; letter-spacing:normal; font-size: 0.875rem; position: absolute; z-index:-1; }


.fm { position: fixed; bottom:0; right:0; background:rgba(255,255,255,0.7); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); border-radius:2rem 0 0 0; overflow: hidden; z-index: 10000; }
.fm::after { content:""; position: absolute; top:0; right: 0; bottom:0; left:0; background: url("../img/bg01.webp") center center /cover no-repeat fixed; z-index:0; opacity: 0.3; }
.fm ul { display:flex; flex-flow:row wrap; justify-content:flex-start; list-style: none; padding: 0 2rem 0 1rem; margin: 0; position: relative; z-index: 10; }
.fm ul li a { padding:0.875rem 1.25rem; display: block; text-decoration: none; }
.fm ul li a:hover { text-decoration: underline; }

.pagetop { position:absolute; display:flex; flex-flow:column nowrap; justify-content:center; bottom:0; right:-3vw; width: 2rem; font-size:0.875rem; height: 9rem; text-decoration: none; writing-mode:vertical-rl; z-index: 0; }
.pagetop::before { content:"TOP"; }
.pagetop::after { content:""; position:absolute; top:1.25rem; left:1rem; bottom:0; margin-top:1rem; border-right:1px solid #125; }
.pagetop:hover { opacity: 0.7; }




/*-- TEMPLARE CONTENTS --*/

body.temp .article { padding:10rem 0 0 0; }
body.temp .article.bg { padding:14rem 0 0 0; }


.hero { width:100%; max-width:70rem; display:flex; flex-flow:row wrap; justify-content:space-between; position: relative; margin:0 auto 2rem auto; z-index: 50; }
.hero h1 { width:100%; margin: 1.5rem 0; }

.hero .photo { width:50%; max-width:50rem;  height: 20rem; background:url("../img/bg01.webp") center center /cover no-repeat; border-radius:0.5rem; position:absolute; right:-10vw; display: none; }

.hero::after { content:""; position: absolute; width:66.6vw; max-width:1000px; top:-10rem; right:calc(50% - 50vw); height: 14rem; background:url("../img/bg01.webp") center center /cover no-repeat; opacity:0.15; z-index: -1; border-radius:0 0 0 1rem; }

body.cate .hero .photo { display: none; }
body.cate .hero h1 { width: 100%; }


body.page.course .hero { height: 10rem; }
body.page.course .hero .photo { display: block; background:url("../img/sample01.webp") center center /cover no-repeat; }
body.page.course .hero::after { height: 20rem; }

body.page.course.kiso .hero .photo { display: block; background:url("https://www.med.tottori-u.ac.jp/nursing/files/51771.webp") center center /cover no-repeat; }
body.page.course.seijin .hero .photo { display: block; background:url("https://www.med.tottori-u.ac.jp/nursing/files/51384.webp") center center /cover no-repeat; }
body.page.course.bosei .hero .photo { display: block; background:url("https://www.med.tottori-u.ac.jp/nursing/files/51537.webp") right top 60% /cover no-repeat; }
body.page.course.chiiki .hero .photo { display: block; background:url("https://www.med.tottori-u.ac.jp/nursing/files/51585.webp") center 90% /cover no-repeat; }



.text_area { width:100%; max-width:70rem; padding:0; margin:0 auto 3rem auto; z-index: 1000; text-align: justify; }
.text_area:empty, index_area:empty { display:none; }
.text_area h5:first-of-type { margin-top:0 }
.tc img { margin: auto; display: inline-block; }


.text_inner { display: flex; flex-flow:row wrap; justify-content: space-between; margin: 0 auto; }
.text_inner .hl { width:15rem; padding-right:1rem; padding:0 0 1rem 0; }
.text_inner .text { width:calc(100% - 15rem); }


.navibar { z-index:100; margin: 0; padding:0; position:absolute; left:-2.5rem; top:9rem; }
.navibar ul { display: flex; flex-flow:row wrap; justify-content: flex-end; margin:0; padding:0; font-size:0.8125rem; line-height:1.5; width:1.5rem; }
.navibar ul li { list-style-type:none; padding:0; display: inline-block; writing-mode:vertical-rl; max-height:12rem; max-width: 2rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; font-feature-settings: initial; }
.navibar ul li::before { content:"／"; margin:0.5rem 0.25rem; }
.navibar ul li:first-child::before { display:none; }
.navibar a { border:none !important; }
.navibar br { display:none; }
.navibar rt { display:none; }



/*-- 2 COLUMN/ --*/
.LR_box { display:inline-block; vertical-align:top; width:49%; margin:0; padding:0 2% calc(1rem + 2vw) 2%; box-sizing:border-box; }
.LR_box .LR_box { width:45% !important; }
.LR_box .LCR_box { width:31% !important; }



/*-- 3 COLUMN/ --*/
.LCR_box { display:inline-block; vertical-align:top; width:31%; margin:0; padding:0 2% 1rem 2%; box-sizing:border-box; letter-spacing:0.1rem; }
.LCR_box2 { display:inline-block; vertical-align:top; width:66%; margin:0; padding:0 2% 1rem 2%; box-sizing:border-box; letter-spacing:0.1rem; }
.LR_box img, .LCR_box img { width:100%; object-fit:cover; font-family:'object-fit:cover;'; margin-bottom:1rem; }
.LR_box h3, .LR_box h4, .LR_box h5, .LCR_box h3,.LCR_box h4, .LCR_box h5, .LCR_box2 h3,.LCR_box2 h4, .LCR_box2 h5 { white-space:normal; word-break:break-all; }

.col1 { padding:0 2%; }
.col2 { column-count:2; column-gap:2rem; padding:0 2%; }
.col3 { column-count:3; column-gap:2rem; padding:0 2%; }

.LR_box img + .caption, .LCR_box img + .caption { margin-top:-1rem; }

a.link, a span.link { padding:0.5rem 0.15rem 0.5rem 1rem; margin:0; text-decoration:underline; box-sizing:border-box; position:relative; overflow:hidden; font-size:1.125rem; font-weight: 600; }
a.link::after, a span.link::after { content: "."; width: 0; font-size: 0; color: transparent; margin-right: 1px; white-space:nowrap; }
a.link::before, a span.link::before { content:""; position:absolute; display:block; left:0; top:0.85rem; width:0.4rem; height:0.4rem; margin:0; border-top:1px solid #125; border-right:1px solid #125; transform:rotate(45deg); box-sizing:border-box; }
a.link.active::after { border-top:1px solid #fff; border-right:1px solid #fff; transform:rotate(45deg); }
a.link.red { color:#e66; }

.footer a.link { font-size: 0.9rem; font-weight: normal; }

ul.page-link { text-align: left; margin:0 auto 1.5rem auto !important; max-width:70rem; padding:0; display:flex; flex-flow:row wrap; justify-content:flex-start; position: relative; z-index: 0; transition:0.15s; }
ul.page-link li { display: inline-block; padding:0; margin: 0; box-sizing:border-box; position:relative; z-index:100; white-space:nowrap; }
ul.page-link li a { display: block; padding:0.5rem 1rem 0.5rem 1.5rem; text-decoration: none; position: relative; z-index:100; line-height: 1.5; font-size:0.9rem; }
ul.page-link li.active a, .index_box.active a .title { /*background: linear-gradient(to right, rgba(255,109,85,1) 0%,rgba(234,65,158,1) 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; font-weight: 600;*/ }
ul.page-link a::before { content:""; position:absolute; display:block; left:0.5rem; top:0.8rem; width:0.5rem; height:0.5rem; margin:0; border-bottom:1px solid #125; border-right:1px solid #125; transform:rotate(45deg); box-sizing:border-box; }
ul.page-link li.active a::before { /*border-color:#f65;*/ } 
.f_s ul.page-link a::before { top:0.9rem; }

.hero + ul.page-link li.active { border-top: none; }
.hero + ul.page-link li.active a { margin-bottom:-2px; border-top: none; /*background: linear-gradient(to right, rgba(255,109,85,1) 0%,rgba(237,96,174,1) 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent;*/ }

ul.page-link.bottom { max-width:70rem; margin:2rem auto 4.5rem auto !important; padding:1rem 0 0 0; border-top:1px solid rgba(17,34,85,0.2); }
ul.page-link.bottom a::before { top:1.1rem; transform:rotate(-135deg); }

body.course ul.page-link { margin:1.5rem auto 4.5rem auto !important; }

ul.page-link.bg, body.course ul.page-link.bg  { position: fixed; top:4.25rem; margin:0 -5vw !important; z-index: 2000; padding:0 calc(5vw + 3rem) 0 5vw; background: url("../img/bg02.webp") center center /cover no-repeat fixed; width:100vw; max-width:100vw; border-radius: 10rem 0 0 10rem; }



/*-- INDEX --*/
ul.index_area { width:100%; max-width:70rem; display:flex; flex-flow:row wrap; justify-content:flex-start; align-items: flex-start; padding:0; margin:0 auto 3rem auto; position: relative; z-index: 1000; }
body.page ul.index_area { max-width:70rem; }

.index_box { display:inline-block; position:relative; width:33.3%; vertical-align:top; box-sizing:border-box; text-align:left; padding:0 2% 4% 2%; transition:0.15s; }
.index_box a { display:block; width:100%; padding:0; text-decoration:none !important; color:#125 !important; }
.index_box .photo { width:100%; max-width:100vw; margin:0 0 0.5rem 0; position:relative; }
.index_box .photo img { width:100%; height: auto; background:center center /100% no-repeat; transition:1s; border-radius:0.5rem; }
.index_box a:hover { text-decoration:none; opacity:1; color:#125; }
.index_box a:hover strong { color:#f98; }
.index_box a:hover .photo img { transform: scale(1.1); }

.index_box p { margin:0; text-decoration:none; }
.index_box .cate_box { font-size:0.75rem; }
.index_box .cate_box .cate { display:inline-block; background:#f98; color:#fff; padding:0 0.5rem; margin:0 0.5rem 0.5rem 0; border-radius:0.25rem; white-space:nowrap; }
/*.index_box .cate_box .cate::after{ content: "."; width:0; font-size:0; color: transparent; margin-right: 1px; }*/
.index_box .new { font-size:0.8rem; display:inline-block; padding:0 0.5rem; background:#ff8e65; color:#fff; text-align:center; z-index:10; }
.index_box .text { display:flex; flex-grow:1; flex-flow:column nowrap; padding:0; }
.index_box .date { font-size:0.8rem; display: none; }
.index_box .comment { font-size:0.9rem; display: block; line-height: 1.5; }
.index_box .title { display:block; align-items:flex-start; position: relative; color:#125; line-height:1.5; /*font-weight:normal;*/ margin-bottom:0.25rem; /*font-weight: bold;*/ }
.tag { display:flex; flex-flow:row wrap; padding:0.5rem 0 0 0; }
.tag span { font-size:0.7rem; background:#125; color:#fff; padding:0 0.5rem 0.1rem 0.5rem; margin:0.5rem; text-align:center; border-radius:1rem; }



.index_box a[target='_blank'] .title::after,
.LCR_box a[target='_blank']::after,
body.link .article li a[target='_blank']::after,
body.link .article a:link[target='_blank']::after,
.article a:link[target='_blank']::after
 { content:""; position:relative; display:inline-block; vertical-align:middle; width:1.2rem; height:1.2rem; margin:0 0.1rem; background:url(../img/i_blank.svg) center bottom /100% no-repeat; }
.index_box a[target='_blank']::after { display:none !important; }
a[target='_blank'].banner::after { display:none !important; }

.index_box a[href*='.pdf'] .title::after, 
a[href*='.pdf']::after, 
.index_box ul li a[href*='.pdf']::after { content:"PDF" !important; position:relative; display:inline-block !important; font-size:0.6rem; line-height:1; width:auto !important; height:auto !important; padding:0.15rem 0.25rem; letter-spacing:normal; color:#e55; font-weight:bold; background:#fff !important; margin:0 0.25rem; border:1px solid #ddd; border-radius:2px; transform:translate(0,-2px); vertical-align:middle; }

.index_box a[href*='.pdf']::after { display:none !important; }

.index_box a[href*='.xls'] .title::after, 
.index_box a[href*='.xlsx'] .title::after, 
a[href*='.xls']::after, 
a[href*='.xlsx']::after, 
.index_box ul li a[href*='.xls']::after, 
.index_box ul li a[href*='.xlsx']::after { content:"Excel" !important; position:relative; display:inline-block !important; font-size:0.6rem; line-height:1; width:auto !important; height:auto !important; padding:0.15rem 0.25rem; letter-spacing:normal; color:#7da52b; font-weight:bold; background:#fff !important; margin:0 0.25rem; border:1px solid #ddd; border-radius:2px; transform:translate(0,-2px); } 

.index_box a[href*='.xls']::after,
.index_box a[href*='.xlsx']::after { display:none !important; }

.index_box a[href*='.doc'] .title::after, 
.index_box a[href*='.docx'] .title::after, 
a[href*='.doc']::after, 
a[href*='.docx']::after, 
.index_box ul li a[href*='.doc']::after, 
.index_box ul li a[href*='.docx']::after { content:"Word" !important; position:relative; display:inline-block !important; font-size:0.6rem; line-height:1; width:auto !important; height:auto !important; padding:0.15rem 0.25rem; letter-spacing:normal; color:#7b8d42; font-weight:bold; background:#fff !important; margin:0 0.5rem; border:1px solid #ddd; border-radius:2px; transform:translate(0,-2px); } 

.index_box a[href*='.doc']::after,
.index_box a[href*='.docx']::after { display:none !important; }

.index_box a[href*='.pdf'] .title::after,
.index_box a[href*='.xls'] .title::after, 
.index_box a[href*='.docx'] .title::after { /*top:0.5rem;*/ }

.info_box ul li a[href*='.pdf']::after,
.info_box ul li a[href*='.xlsx']::after,
.info_box ul li a[href*='.docx']::after { position: absolute; top:0.35rem; right:0; }


.b_box a[target="_blank"]::after, .b_box a[href$=".pdf"]::after, .b_box a[href$=".docx"]::after { display:none !important; }



body.info .contents { display: flex; flex-flow:row wrap; justify-content: space-between; max-width:70rem; margin:0 auto 5rem auto; }
body.info .index_area { /*margin:0 auto 5rem auto; display: flex; flex-flow:row wrap; box-sizing:border-box;*/ } 
body.info .side { display: inline-block; vertical-align: top; width: 13rem; box-sizing:border-box; margin-right: auto; position: relative; z-index: 1000; margin:0 0 0 2rem; } 
body.info .side h5 { margin-top:0; margin-bottom:0.5rem; }
body.info .side ul { padding-left:1.0rem; margin:0 0 2rem 0; font-size:0.9rem; }
body.info .side ul li::marker { color:rgba(17,34,85,0.2); }

body.cate .text_area { display: none ; }

body.info .index_box { width: 50%; padding:0 2%; }
body.info .index_box a { display:flex; padding: 1.5rem 0; border-top:1px solid rgba(17,34,85,0.2); }
body.info .index_box .date { display: inline-block; font-size: 0.8rem; }
body.info .index_box strong::after { display: none; }
body.info .index_box .photo { width: 25vw; min-width: 6rem; max-width: 10rem; margin-right: 1rem; margin-bottom: 0; }
body.info .index_box .photo img { width:100%; object-fit:contain; font-family:" object-fit: contain;"; }
body.info .index_box .text { padding:0; flex-grow: 1; display:flex; flex-flow:column wrap; align-items: flex-start; justify-content:flex-start; }
body.info .index_box .i_cate { display: inline-block; width: auto; }
body.info .date { font-size: 0.8rem; }

body.blog .side { display: none; }
body.blog .index_box { width: 50%; padding:0 2%; }
body.blog .index_box a { display:flex; padding: 1.5rem 0; border-top:1px solid rgba(17,34,85,0.2); }
body.blog .index_box .date { display: inline-block; font-size: 0.8rem; }
body.blog .index_box strong::after { display: none; }
body.blog .index_box .photo { width: 25vw; min-width: 6rem; max-width: 10rem; margin-right: 1rem; margin-bottom: 0; }
body.blog .index_box .photo img { width:100%; object-fit:contain; font-family:" object-fit: contain;"; }
body.blog .index_box .text { padding:0; flex-grow: 1; display:flex; flex-flow:column wrap; align-items: flex-start; justify-content:flex-start; }
body.blog .index_box .i_cate { display: inline-block; width: auto; }
body.blog .date { font-size: 0.8rem; }

body.cate.course .index_box { width: 50%; padding:0 2%; }

body.page .course_area ul li { width:calc((100% - 6rem)/4); margin-bottom:2rem; max-width:34rem; }
body.page .course_area ul li:nth-of-type(2n + 0) { margin-top:0; }
body.page .course_area ul li .photo { border-radius:0.5rem; }
body.page .course_area ul li .text { font-size: 1rem; line-height: 1.5; }
body.page .course_area ul li .text::after { display: none; }
body.page .info_area { margin-bottom: 7rem; }

body.page.course .page_title::before { content:""; border-radius:0.5rem; position: absolute; z-index:-1; }
body.page.course.kiso .page_title::before { width:14vw; height:21vw; top:-4vw; left:-7vw; background: rgba(160,224,252,0.15); }
body.page.course.seijin .page_title::before { width:21vw; height:14vw; top:-4vw; left:-7vw; background: rgba(168,156,232,0.15); }
body.page.course.bosei .page_title::before { width:15vw; height: 15vw; top:-4vw; left:-7vw; background: rgba(225,106,105,0.1); }
body.page.course.chiiki .page_title::before { width:14vw; height: 21vw; top:-4vw; left:-7vw; background: rgba(233,186,95,0.15); }

body.page.course.kiso .info_area .bg::after { background: url("../img/bg_b.jpg") center center /cover no-repeat fixed; opacity: 1; }
body.page.course.seijin .info_area .bg::after { background: url("../img/bg_p.jpg") center center /cover no-repeat fixed; opacity: 1; }
body.page.course.bosei .info_area .bg::after { background: url("../img/bg_r.jpg") center center /cover no-repeat fixed; opacity: 1; }
body.page.course.chiiki .info_area .bg::after { background: url("../img/bg_y.jpg") center center /cover no-repeat fixed; opacity: 1; }


body.page .info_area h3 { writing-mode:vertical-rl; font-feature-settings:initial; }
body.page .course_area h3 { writing-mode:vertical-rl; font-feature-settings:initial; }

body.page .course_area ul li::after, body.page .index_area.course li::after { content: ""; position: absolute; display: block; border-radius:0.5rem; z-index: -1; }
body.page .course_area ul li:nth-of-type(1)::after, body.page .index_area.course li:nth-of-type(1)::after { width:6vw; height:9vw; top:-4vw; left:-2vw; background: rgba(160,224,252,0.15); }
body.page .course_area ul li:nth-of-type(2)::after, body.page .index_area.course li:nth-of-type(2)::after { width:9vw; height:6vw; top:-2vw; right:-1vw; background: rgba(168,156,232,0.15); }
body.page .course_area ul li:nth-of-type(3)::after, body.page .index_area.course li:nth-of-type(3)::after { width:7vw; height: 7vw; bottom:-2vw; left:-1vw; background: rgba(225,106,105,0.1); }
body.page .course_area ul li:nth-of-type(4)::after, body.page .index_area.course li:nth-of-type(4)::after { width:6vw; height: 9vw; bottom:-3vw; right:-2vw; background: rgba(233,186,95,0.15); }

body.page .index_box { width:25%; }

body.page .index_box .title::before { /*content:""; position:absolute; display:block; left:-1rem; top:0.75rem; width:0.5rem; height:0.5rem; margin:0; border-top:1px solid #125; border-right:1px solid #125; transform:rotate(45deg); box-sizing:border-box;*/ }

.date_box { position:relative; margin:-1.5rem 0 1rem 0; text-align:right; }
.date_box .date { font-size:0.9rem; margin:0 0.5rem 0.5rem 0; }

img.radius { border-radius:0.5rem;}
.left_img { position: relative; left:calc(20% - 12vw); width:calc( 100% + 10vw ); }
.right_img { position: relative; right:calc(20% - 12vw); width:calc( 100% + 10vw ); }
.left_img img, .right_img img { width: 100%; }

.sticky { position: sticky; top:9rem; margin-bottom: 1rem; }


.i-prev, .i_next { }
.i-next::after { content:""; position:absolute; display:block; left:calc(50% - 6px); top:calc(50% - 4.5px); width:0.5rem; height:0.5rem; margin:0; border-top:1px solid #125; border-right:1px solid #125; transform:rotate(45deg); box-sizing:border-box; }
.i-prev::after { content:""; position:absolute; display:block; left:calc(50% - 3px); top:calc(50% - 4.5px); width:0.5rem; height:0.5rem; margin:0; border-bottom:1px solid #125; border-left:1px solid #125; transform:rotate(45deg); box-sizing:border-box; }

.pager { width:100%; margin:0 auto 3rem auto; }
.pagenavi { text-align:center; }
.pagenavi .page, .pagenavi .prev, .pagenavi .next, .pagenavi .current, .pagenavi .last, .pagenavi .page.s , .pagenavi .page.s:hover { display:inline-block; margin:0 5px; width:40px; height:40px; line-height:38px; background:#fff; color:#125; letter-spacing:1px; text-align:center; vertical-align:middle; border-radius:2rem; /*box-shadow:0 3px 0 rgba(0, 0, 0, 0.1); transition-delay:0s;*/ transition-duration:0.5s; transition-property:background-color, color; transition-timing-function:ease, ease; box-sizing:border-box; text-decoration:none; position:relative; }
.pagenavi .page.s { box-shadow:0 3px 0 rgba(0, 0, 0, 0.1); transition-delay:0s; transition-duration:0.25s; }
.pagenavi .prev.disable, .pagenavi .next.disable, .pagenavi .prev.disable:hover, .pagenavi .next.disable:hover { background:rgba(0, 0, 0, 0.1); box-shadow:none; cursor:default; color:#fff; }
.pagenavi .current, .pagenavi .page:hover, .pagenavi .prev:hover, .pagenavi .next:hover, .pagenavi .current:hover, .pagenavi .last:hover { background:#125; color:#fff; transition-property:background-color, color; transition-timing-function:ease, ease; }
.pagenavi .next:hover .i-next::after, .pagenavi .next.disable .i-next::after { border-color:#fff; }
.pagenavi .prev:hover .i-prev::after, .pagenavi .prev.disable .i-prev::after { border-color:#fff; }



/*-- FORM/ --*/
form { margin:0; padding:0; border:0; font-size:100%; vertical-align:middle; background:transparent; }
form label { vertical-align:middle; }

select, input, textarea, button { width:auto; max-width:100%; -webkit-appearance:none; vertical-align:middle; position:relative; line-height:1.5; font-size:1.2rem; margin:0 5px 0 0; padding:0.25rem 0.5rem; border:1px solid #125; border-radius:0; box-shadow:none; z-index:0; box-sizing:border-box; }
input[type="text"] { margin:5px 5px 5px 0; }
input.long { width:100%; margin:5px 0; position:relative; }
.button, input[type="button"], input[type="submit"] { display:inline-block !important; vertical-align:middle; -webkit-appearance:none; overflow:visible; width:auto; min-width:10rem; line-height:1.6rem; letter-spacing:0.1rem; margin:0.5rem 0.25rem 0.5rem 0; padding:0.75rem 1.2rem; background:#125; /*border:5px solid #7b8d42;*/ border:none; color:#fff !important; position:relative; text-decoration:none; border-radius:0; text-align:center; transition:all .2s; box-sizing:border-box; cursor:pointer; }
input::placeholder, textarea::placeholder { color:#777; }

.b_back { display:inline-block; -webkit-appearance:none; overflow:visible; width:auto; background:#ff8e65; position:relative; padding:10px 20px 10px 40px; height:50px; line-height:30px; font-size:1.2rem; letter-spacing:0; margin:10px; border:none; color:#125 !important; border-radius:3px; box-sizing:border-box; }
.b_back::after { content:""; position:absolute; display:inline-block; left:10px; top:18px; width:10px; height:10px; border-top:2px solid #125; border-right:2px solid #125; transform:rotate(45deg); box-sizing:border-box; }

.button:hover, input[type="button"]:hover, input[type="submit"]:hover { text-decoration:none; background:#f98; color:#fff; }

button[disabled], a.button[disabled], .button[disabled], input[type="button"][disabled], input[type="submit"][disabled],
button[disabled]:hover, a.button[disabled]:hover, .button[disabled]:hover, input[type="button"][disabled]:hover, input[type="submit"][disabled]:hover { background:#eee; border:none; color:#fff; opacity:1.0; cursor:default; position:relative; }

a.button { padding-right:2rem; position: relative; }
a.button::after { content:""; position:absolute; display:block; left: auto; right:1rem; top:50%; width:0.5rem !important; height:0.5rem !important; background: none; margin:0 !important; border-top:1px solid #fff; border-right:1px solid #fff; transform:translate(0,-45%)rotate(45deg); box-sizing:border-box; }
a.button[target='_blank']::after { right:-1rem; }

button.mini, .button.mini { min-width:0; }
input:focus, select:focus, textarea:focus { outline:none; box-shadow:0 0 3px rgba(208, 160, 116, 1); border:1px solid #ec0;}

input.button { width:15rem; display:flex; align-items: center; justify-content:center; text-align: center; text-decoration:none; position: relative; white-space: nowrap; margin: 0 auto; padding:0.5rem 2rem; background:#125 url("../img/i_arrow_rw.svg") right 0.75rem center /40px no-repeat; color: #fff; border-radius:2rem; }
input.button:hover { background:#f98 url("../img/i_arrow_rw.svg") right 0.75rem center /40px no-repeat; }

.w100 { width: 100%; margin-right:0 !important; margin-left:0 !important; }
.w90 { width: 90%; }
.w85 { width: 85%; }
.w80 { width: 80%; }
.w75 { width: 75%; }
.w70 { width: 70%; }
.w66 { width: 66%; }
.w65 { width: 65%; }
.w60 { width: 60%; }
.w55 { width: 55%; }
.w50 { width: 50%; }
.w49 { width: 49%; }
.w48 { width: 48%; }
.w47 { width: 47%; }
.w45 { width: 45%; }
.w40 { width: 40%; }
.w35 { width: 35%; }
.w33 { width: 33.33%; }
.w32 { width: 32%; }
.w30 { width: 30%; }
.w25 { width: 25%; }
.w24 { width: 24%; }
.w22 { width: 22%; }
.w20 { width: 20%; }
.w15 { width: 15%; }
.w13 { width: 13%; }
.w10 { width: 10%; }
.w5 { width: 5%; }

input.w75 { min-width:17.5rem; }
input.w50 { min-width:15rem; }
input.w33 { min-width:10rem; }
input.w25 { min-width:7.5rem; }
input.w20 { min-width:6rem; }
input.w10 { min-width:3rem; }
input.w5 { min-width:1.5rem; }


.r04 { border-radius:0.25rem; }
.r08 { border-radius:0.5rem; }
.r16 { border-radius:1rem; }


/*-- Radio and Checkbox/ --*/
input[type="radio"], input[type="checkbox"] { margin:0 3px 0 0; width:1.25rem; height:1.25rem; display:none; }
input[type="radio"] + span, input[type="checkbox"] + span { padding-left:1.5rem; position:relative; margin-right:1rem; display:inline-block; white-space:nowrap; min-height: 1.35rem; }
input[type="radio"] + span::before{ content:""; display:block; position:absolute; top:0.2rem; left:0; width:1.2rem; height:1.2rem; border:1px solid #125; border-radius:50%; z-index:5; margin-right:3px; box-sizing:border-box; }
input[type="radio"] + span::after{ content:""; display:block; position:absolute; top:0.65rem; left:0.5rem ; width:0.2rem; height:0.2rem; background:#f98; border-radius:50%; z-index:10; transition:0.25s; opacity:0; }
input[type="radio"]:checked + span, input[type="checkbox"]:checked + span { color:#f98; }
input[type="radio"]:checked + span::before { border:1px solid #f98; }
input[type="radio"]:checked + span::after{ content:""; display:block; position:absolute; top:0.4rem; left:calc(0.25rem - 1px); width:0.8rem; height:0.8rem; background:#f98; border-radius:50%; z-index:10; transition:0.25s; opacity:1; }
input[type="checkbox"] + span::before { content:""; display:block; position:absolute; top:calc(50% - 8px); top:0.25rem; left:0; width:1.2rem; height:1.2rem; border:1px solid rgba(17,32,85,0.15); border-radius:4px; margin-right:3px; box-sizing:border-box; }
input[type="checkbox"]:checked + span::after { content:""; display:block; position:absolute; top:calc(50% - 12px); top:0.2rem; left:5px; width:7px; height:14px; transform:rotate(40deg); border-bottom:3px solid #e66; border-right:3px solid #f98; box-sizing:border-box; }

input[type="checkbox"] + span:empty { margin: 0; padding: 0; }

button.i_delete { min-width:0 !important; }
button.i_delete::before { display:none; }

/*-- SELECT/ --*/
select { -webkit-appearance:none; -moz-appearance:none; position:relative; z-index:auto !important; border-radius:0; font-size:inherit; text-align:left; background:#fff url(../img/i_pulldown.png) right center /24px no-repeat; border:1px solid rgba(17,32,85,0.15); padding:0.25rem 2rem 0.25rem 0.25rem; margin:0 2px 0 0; box-sizing:border-box; display:none; display:inline-block; }
select:disabled, select.disabled { border:1px solid rgba(17,32,85,0.15); color:rgba(17,32,85,0.15); color:silver; background:none; z-index:auto; }

.error, .required { color:#e66; }
div.error { border:2px solid #e66; padding:0 0.5rem; margin:0; }
span.error { background:#e66; color:#fff; padding:2px 5px; display:block; }
.example { color:#777; white-space:nowrap; }

.hissu { display: inline-block; background:#e66; color:#fff; font-size:0.7rem; padding:0.1rem 0.25rem; vertical-align: middle; position: relative; margin:-0.1rem 0.15rem 0.25rem 0; }
.ninni {display: inline-block; background:rgba(17,32,85,0.15); color:#fff; font-size:0.7rem; padding:0.1rem 0.25rem; vertical-align: middle; position: relative; margin:-0.1rem 0.15rem 0.25rem 0; }

.notice { background: url("../img/bg02.webp") center center /cover no-repeat fixed; padding: 1rem 1.5rem; border-radius: 1rem; }
.bg01 .notice { background: #fff; box-shadow:0 1rem 0.5rem -0.75rem rgba(17,34,85,0.05); }
.bg01 .grade { text-shadow: 0 0.5rem 0.5rem rgba(17,34,85,0.05);}

/*--CONTACT--*/
body.contact .tab_menu,
body.contact .f_title,
body.contact .corp,
body.contact .fm { display:none; }

.wpcf7 form .wpcf7-response-output { margin: 1rem 0 0; padding: 0.5rem 1rem; text-shadow: 0 1px 0 rgba(255, 255, 255, 0.5); }
.wpcf7 form.failed .wpcf7-response-output,
.wpcf7 form.aborted .wpcf7-response-output,
.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output { color: #e66; background-color: #f9e3e9 !important; border:none !important; }
.wpcf7 form.sent .wpcf7-response-output { color: #3A87AD; background-color: #E1F5FE !important; border:none !important; }
.wpcf7 form .wpcf7-not-valid { background:#f9e3e9; }
.wpcf7 form .wpcf7-not-valid-tip { color:#e66; }
.wpcf7 form .wpcf7-spinner { display:block; margin:auto; }
form.wpcf7-form > br:first-of-type { display:none; }
.wpcf7-list-item { margin:0; }

/*--Privacy Policy--*/
.pp_box { text-align: left; max-height:400px; overflow-y: auto; padding: 1.5rem; border:1px solid #125; line-height:1.7; }
.pp_box ol { /*padding-left:1.5rem;*/ }

.grecaptcha-badge { opacity:0; }

.invisible { display: none; transition:0.5s ease; }



/*-- LIST/ --*/
ol { margin:0 0 2rem 0; padding:0 0 0 1.5rem; }
ol li{ padding:0; margin:0 0 0.5rem 0; }
.value { background:#125; vertical-align:middle; display:inline-block; width:1.6rem; line-height:1.6rem; font-size:1rem; font-weight:bolder; text-align:center; border-radius:50%; color:#fff; margin:-0.3rem 0.4rem 0 0; }
ol li ol.kakko {  }
ol li ol.kakko li { list-style: none; position: relative; margin-left: 1.5rem; }
ol li ol.kakko li::before { content: attr(value)')'; counter-increment: li; position: absolute; top: 0; left: -1.5rem; }

ul.marker { list-style:disc; margin:0; padding-left:1.5rem; }
ul.marker li::marker { color:rgba(17,34,85, 0.3); }

ul.li_half { display:flex; flex-flow:row wrap; justify-content:space-between; } 
ul.li_half li { width:calc((100% - 2rem)/2);} 

ol.faq { counter-reset:q; list-style:none; margin:0; padding:0; }
ol.faq >li::before { counter-increment:q; content:'Q'counter(q); content:'Q'attr(value); background:#f77; vertical-align:middle; display:inline-block; width:2.4rem; height:2.4rem; line-height:2.2rem; font-weight:bold; text-align:center; border-radius:50%; color:#fff; margin:0 0.4rem 0 -2.4rem; }
ol.faq >li { margin-bottom:1rem; }
ol.faq .a { padding:0.5rem 0 0.5rem 0.4rem; }
ol.faq .a h4 { display:inline-block; width:2.4rem; height:2.4rem; line-height:2.2rem; font-weight:bold; text-align:center; border-radius:50%; margin:0 0.4rem 0 -2.8rem; }
ol.faq li ol { display:inline-block; vertical-align:top; }
ol.faq >li h6.i_close { color:#e70; }

ol.val > li::before { content:attr(value); background:#064; vertical-align:middle; display:inline-block; width:1.6rem; line-height:1.6rem; letter-spacing:normal; font-size:0.8rem; font-weight:bold; text-align:center; border-radius:50%; color:#fff; margin:-0.3rem 0.4rem 0 -2rem; position:relative; }

ul.kome { list-style: none; padding:0; }
ul.kome li { display: block; margin-left:1rem; }
ul.kome li::before { content:"※"; margin:0 0 0 -1rem; }


.q, .q_open { margin:0; padding:0.5rem 2rem 0.5rem 0; position:relative; border-top: 1px solid rgba(0, 0, 0, 0.1); cursor: pointer; }
.q_open { padding:0.25rem; }
.q:hover { background: rgba(255,255,255,0.2); }
.q::before, .q_open::before { content:"Q. "; display:inline-block; font-weight:bold; margin-right:0.25rem; color:#0ae;  }
.q::after { content:"＋"; position:absolute; right:0.5rem; display:inline-block; transition:0.1s; font-size:1.125rem; top:1rem; line-height:1; color:#f4577a;}
.q.i_close { font-weight: bold; color:#0ae; }
.m.i_close { font-weight: bold; background: linear-gradient(to right, rgba(255,109,85,1) 0%,rgba(237,96,174,1) 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; }
.a, .a_open, .t, .t_open { display: none; margin-bottom: 1.5rem; padding:0.25rem 0; }
.a_open, .t_open { display: block; }
.a::before, .a_open::before { content:"A. "; display:inline-block; font-weight:bold; margin-right:0.25rem; color:#f4577a; font-size:1.2rem; }

.m, .m_open { margin:0; padding:0.5rem 0.5rem 0.5rem 1rem; position:relative; cursor: pointer; font-size: 1.125rem; line-height:1.5;  font-weight: bold; }
.m::after { content:"＋"; position:absolute; top:calc(50% - 0.6rem); left:-0.25rem; display:inline-block; transition:0.1s; font-size:1.125rem; line-height:1; color:#f4577a; z-index: 10;}
.q.i_close::after, .m.i_close::after { transform:rotate(45deg); -webkit-text-fill-color:#f4577a; }
.m.link { padding:0.25rem 1rem; }
.m + .t { padding:0.25rem 0; }
.m.no_open { color:rgba(17,34,85,0.5); pointer-events:none; }

.face { width:3rem; margin-right:0.5rem; margin-left:-0.5rem; font-size:0.75rem; line-height: 1.5; text-align: center;   }
.face .material-icons { font-size: 2.5rem;  display: block; }
.face.right { margin-right:-0.5rem; margin-left:0.5rem; }

.fukidashi { display: block; width:calc(100% - 3rem); flex-grow: 1;  background: #fff; border-radius: 1rem; padding:1rem; margin-bottom:1rem; line-height:1.5; box-shadow:0 1rem 0.5rem -0.75rem rgba(17,34,85,0.1); position: relative; }
.fukidashi::after { content: ""; display: block; width:0.8rem; height:0.8rem; border-top: 0.4rem solid #fff; border-left:0.4rem solid transparent; border-right: 0.4rem solid #fff; border-bottom: 0.4rem solid transparent; position: absolute; top: 1rem; left:-0.75rem; z-index: 0; box-shadow:0 1rem 0.5rem -0.75rem rgba(17,34,85,0.5);}
.fukidashi.right::after { border-left:0.4rem solid #fff; border-right: 0.4rem solid transparent;  left:auto; right: -0.75rem; }
.fukidashi::before { content: ""; display: block; width:0.8rem; height:0.8rem; border-top: 0.4rem solid rgba(17,34,85,0.2); border-left:0.4rem solid transparent; border-right: 0.4rem solid rgba(17,34,85,0.2); border-bottom: 0.4rem solid transparent; position: absolute; top:calc(1rem + 0.1rem); left:-0.75rem; z-index: -1; -webkit-filter: blur(0.25rem); filter: blur(0.25rem);}
.fukidashi.right::before { border-left:0.4rem solid rgba(17,34,85,0.2); border-right: 0.4rem solid transparent;  left:auto; right: -0.75rem; }

.fukidashi.wide { width: 100%; }
.fukidashi.wide::before, .fukidashi.wide::after { display: none; }

.oneday_box { position:relative; width:100%; height:676px; overflow-y: hidden; overflow-x: auto;}
.oneday_time { position: sticky; top:0; left:0; width:51px; height:660px; margin-top:0; z-index:10; background:url("https://www.med.tottori-u.ac.jp/nursing/files/51998.png") top left /750px no-repeat; }
.oneday_week { position: sticky; top:0; width:750px; height:90px; margin-top:-660px; z-index:20; background:url("https://www.med.tottori-u.ac.jp/nursing/files/51998.png") top left /750px no-repeat;  }
.oneday_sche { width:750px; height:660px; margin-top:-90px; background:url("https://www.med.tottori-u.ac.jp/nursing/files/51998.png") top left /750px no-repeat; z-index:10; }



/*-- TABLE/ --*/
caption { text-align:left; margin-bottom:10px; font-size:95%; }

table { border-collapse:collapse; width:100%; margin:0 auto 2rem auto; }
table th, table td { padding:1rem; letter-spacing:0.05rem; line-height:1.5; }

.table01 { border-bottom:1px dashed rgba(0, 38, 33, 0.2); }
.table01 th, .table01 td { border-top:1px dashed rgba(17,32,85,0.15); background-clip: padding-box;  }
.table01 thead th { }
.table01 th {text-align:left; }
.table01 td { }

.table02 { border-bottom:1px solid rgba(17,32,85,0.15); }
.table02 th, .table02 td { border-top:1px solid rgba(17,32,85,0.15); background-clip: padding-box; }
.table02 thead th, .table02 thead td { background:url("../img/bg02.webp") center center /cover no-repeat fixed; }
.table02 th { text-align:left; white-space:nowrap; }
.table02 td { }
.table02 td.tr { width:auto; }

.table03 { background:#fff; border:1px solid rgba(17,34,85,0.3); border-right: none; }
.table03 th, .table03 td { border-right:1px dashed rgba(17,34,85,0.3); border-bottom:1px solid rgba(17,34,85,0.3); text-align: left; background-clip: padding-box; }
.table03 thead th { background: rgba(119,187,238,0.5); }
.table03 thead td { background: rgba(119,187,238,0.5); }
.table03 tbody tr:last-of-type th, .table03 tbody tr:last-of-type td { border-bottom: none; }
.table03 tbody tr td:last-of-type { border-right:1px solid rgba(17,34,85,0.3); }

.table03.program th, .table03.program td { font-size: 0.9rem; text-align: center; }
.bgGrey { background:rgba(0,0,0,0.05); }

.table03.sche  { background:#fff; border:1px solid rgba(17,34,85,0.3); }
.table03.sche th, .table03.sche td { padding:0.25rem 0.5rem; border-right:1px solid rgba(17,34,85,0.3); border-bottom:1px solid rgba(17,34,85,0.3); text-align: left; background-clip: padding-box; min-height:1rem; }
.table03.sche thead th { text-align: center; }



/*-- TABLE ヘッダ・カラム固定 --*/
thead tr[class*="fixed-header-"] th { position: -webkit-sticky; position: sticky; z-index:2; white-space: nowrap; }
thead tr[class*="fixed-header-"] th[class*="fixed-column-"] { z-index:3; }
tbody th[class*="fixed-column-"], tbody td[class*="fixed-column-"] { background:#fff; position: -webkit-sticky; position: sticky; z-index:1; }

table.number {}
table.number td { text-align: right; }

.l_double { border-top:3px double rgba(17,32,85,0.15) !important; }
.l_dashed th, .l_dashed td { border-top:1px dashed rgba(17,32,85,0.15) !important; }
th p, td p { margin:0; }

.l_total th, .l_total td { padding:1px; }



/*-- 幅の広いテーブルにスクロール表示 --*/
.scroll, #calcResult { overflow:auto; }
.scroll::-webkit-scrollbar, #calcResult::-webkit-scrollbar { height:6px;}
.scroll::-webkit-scrollbar-track, #calcResult::-webkit-scrollbar-track { background:rgba(0,0,0,0); }
.scroll::-webkit-scrollbar-thumb, #calcResult::-webkit-scrollbar-thumb { background:rgba(51,170,153,1); background: #bbb; border-radius:3px; opacity: 0.5; }
.scroll::-webkit-scrollbar-thumb:hover, #calcResult::-webkit-scrollbar-thumb { background:rgba(51,170,153,1); background: #bbb; border-radius:3px; opacity: 0.5; }


.aligncenter {display:block; margin:0 auto; }
.alignright { float:right; margin:0 0 1.5rem 1.5rem; position:relative; z-index:1; max-width:360px; }
.alignleft { float:left; margin:0 1.5rem 1.5rem 0; position:relative; z-index:1; max-width:360px; }
img[class*="wp-image-"],
img[class*="attachment-"] { max-width:100%; height:auto; }
img.alignright, img.alignleft { max-width:40%; }


.flex.full_l .text { width:56%; order:2; }
.flex.full_r .text { width:56%; order:1; }
.flex.full_l .photo { width:40%; order:1; position:relative; }
.flex.full_r .photo { width:40%; order:2; position:relative; }





/*--PDF js--*/
.pdf_page { text-align:center; margin:auto; width:100%; }
.page_feed { margin-bottom:0.5rem; }
.pdf_page canvas, .pdf_page canvas img { /*pointer-events:none;*/ position:relative; z-index:1; width:100%; max-width: 800px; border:1px solid #ddd; margin: auto; background:transparent; }
.pdf_page canvas::before { content:""; position:absolute; top:0; right:0; bottom:0; left:0; background:rgba(17,34,85,0.2); z-index:10; }
.pdf_page button.prev, .pdf_page button.next { min-width:2rem; padding:0 0.5rem; box-sizing:border-box; position:relative; background:#125; border:none; }
.pdf_page button.prev:hover , .pdf_page button.next:hover { background:#fe3; }
.pdf_page button[disabled] { background:#eee !important; }
.pdf_page button.prev { margin:0 0 0 1rem; border-radius:1rem 0 0 1rem; border-right:none; }
.pdf_page button.next { margin:0 0 0 0 ; border-radius:0 1rem 1rem 0; border-left:none; }
.pdf_page button.prev::after, .pdf_page button.next::after { content:""; position:absolute; display:block; width:0.5rem; height:0.5rem; border-top:1px solid #fff; border-right:1px solid #fff; }
.pdf_page button.prev::after { transform:rotate(-135deg); top:calc(50% - 0.3rem + 1px); left:1rem; }
.pdf_page button.next::after { transform:rotate(45deg); top:calc(50% - 0.3rem + 1px); left:0.7rem; }
.pdf_page button.prev:hover::after , .pdf_page button.next:hover::after { border-color:#125; }
.pdf_page button[disabled].prev::after, .pdf_page button[disabled].prev::after,
.pdf_page button[disabled].next::after, .pdf_page button[disabled].next::after { border-color:#fff; }

.pdf_page img[usemap] { max-width:100%; height:auto; }

.pdf_notice { display:none; }
/*iE Edge*/
/*
_:-ms-lang(x), .pdf_page { }
_:-ms-lang(x), .pdf_notice { display:block; }
*/



.flex aside { margin:0; }
body.member .flex aside { margin:0; max-width:17rem; }
.flex aside .photo_box, .flex aside > div.sticky { display:flex; flex-flow:row wrap; /*align-items: flex-end;*/ justify-content:flex-start; margin-bottom: 1rem; position: sticky; top:1.5rem; }
.flex aside .photo_box .photo { position: relative; border-radius:1rem; overflow: hidden; width:40%; margin-right: 1rem; margin-bottom:0.75rem; max-width:10rem; }
.flex aside .photo_box .photo img { width:100%; height:100%; max-width:12rem; max-height:12rem; object-fit: cover; object-position:0 50%; }
.flex aside .photo_box .text { flex-grow: 1; margin-bottom:0.75rem; }
.flex aside .photo_box .text .title { display: block; margin-bottom:0.75rem; line-height: 1.5; letter-spacing: normal; }
.flex aside .photo_box .text ruby.name { line-height: 1.5; font-size: 1.4rem; font-weight: bold; margin-bottom:0.5rem; }
.flex aside .photo_box .text ruby.name rt { font-size: 0.75rem; margin-bottom: 0.25rem; }
.flex aside .photo_box .text .mail { display: block; margin-bottom:0.5rem; } 
.flex aside .photo_box .text .mail::before { content:""; display: inline-block; width:1rem; height: 1rem; background: url(../img/i_mail.svg) center center /1rem no-repeat; margin:0 0.5rem 0.25rem 0; vertical-align: middle; }


.researchmap, .researchers {position: relative; display:inline-block; padding:0 1rem 0 1.5rem; text-decoration: none; border-radius:2rem; margin:0.1rem; font-size: 0.9rem; }
.researchmap { background:rgba(52,122,183,0.2); }
.researchers { background:rgba(168,156,232,0.3); }
.researchmap::before, .researchers::before { content:""; display: block; position: absolute; width: 0.4rem; height: 0.4rem; border-top: 1px solid #125; border-right: 1px solid #125; top:calc(50% - 0.2rem); left:0.5rem; transform: rotate(45deg); }
.researchmap::after, .researchers::after { display: none !important; } 
.researchmap.icon, .researchers.icon { height: 1.5rem; width:1.5rem; padding:0; vertical-align: middle; }

td .researchmap, td .researchers { line-height: 2; }

div.w65.resp100 { min-height: 22rem; }
dl.profile { display:flex; flex-flow:row wrap; align-items: flex-start; }
dl.profile dt { width:6rem; font-weight: bold; padding: 0.75rem 0; margin: 0; border-top:1px solid rgba(0,0,0,0.1); line-height: 1.5; }
dl.profile dd { width:calc(100% - 6rem); padding: 0.75rem; border-top:1px solid rgba(0,0,0,0.1); line-height: 1.5; }
dl.profile dd ul { padding-left:1rem; margin: 0; }
dl.profile dd ul li { margin-bottom:0.5rem; }
dl.profile dd ul li::marker { color:#f98; }
dl.profile dd ul li:last-of-type { margin-bottom:0; }
dl.profile ol { margin-bottom: 1rem; }

#colorbox.teacher { width:100% !important; height:100% !important; max-width:700px !important; min-height:300px; max-height: 85vh !important; top:50% !important; left: 50% !important; transform: translate(-50%,-50%); }
#colorbox.teacher #cboxWrapper { width:100% !important; height:100% !important; max-width:700px !important; min-height:300px; max-height: 85vh !important; overflow: visible; }
#colorbox.teacher #cboxContent, #colorbox.alert #cboxLoadedContent, #colorbox.alert #cboxIframe { height:calc(100% - 3rem) !important; max-width:calc(700px - 2rem) !important; ; min-height:calc(300px - 3rem); max-height:calc(85vh - 3rem) !important; }
#colorbox.teacher #cboxContent { width:calc(100% - 2rem) !important; }
#colorbox.teacher #cboxLoadedContent, #colorbox.alert #cboxIframe { width:100% !important; margin: 0; height:calc(85vh - 3rem) !important; min-height:calc(300px - 3rem);  max-height:calc(85vh - 3rem) !important; }
#colorbox.teacher #cboxMiddleLeft { height: 0 !important; }

#colorbox.img #cboxLoadedContent { padding: 1rem; background:#fff; height: auto !important; max-width:96vw;  }
#colorbox.img #cboxLoadedContent img { width: 100% !important; height: auto !important;  }

body.modal { background: rgba(255,255,255,0); }
body.modal .article { padding-top:0; }
body.modal .alignright { float: right; width:25vw; }
body.modal .text_area { padding:5vw; margin: 0 auto; }
body.modal h2 { line-height: 1.5; }
body.modal h2::after { display:none; }
body.modal h2 span.title { display: block; font-size: 1rem; margin-bottom:0.75rem; }
body.modal h2 rt { font-size: 0.75rem; margin-bottom:0.15rem }


/*HISTORY*/
.timeline_item { display: flex; }
.timeline_item .date { width: 8rem; padding: 0; }
.timeline_item .text { position: relative; width:calc(100% - 8rem); padding: 0 0 3rem 2rem; border-left: 1px solid #ccc; text-align: justify;}
.timeline_item .text::before { content: ""; position: absolute; top: 0.5rem; left: -0.5rem; width: 1rem; height: 1rem; background-color: #125; border-radius: 1rem; }
.timeline_item .date .i_cate { }
.timeline_item .f_s { display:block; line-height: 1.5; }
.timeline_item .flex div { margin-bottom: 1rem; }
.timeline_item .flex img { vertical-align: bottom; margin-bottom:0.5rem; }



/*--PAGENATION--*/
.pagination-holder { margin:0 -1rem 4rem -1rem; text-align: center }

#page-1 { display:flex; }
.cnation-holder { width:100%; padding-top:4rem; }
.simple-pagination { display: block; overflow: hidden; padding: 0; margin: 0;}
.simple-pagination ul { list-style: none; padding:0; margin:0; display:flex; flex-flow:row wrap; justify-content:center;}
.simple-pagination ul li { padding:0; margin:0 -1px 0 0;}
.simple-pagination ul li a { display:block; background:#fff; text-decoration: none; }
span.ellipse.clickable { cursor: pointer; }
.ellipse input { width: 3em; }

.light-theme a, .light-theme span { cursor:pointer; display:block; text-align:center; color: #125; font-size:0.9rem; line-height:calc(2.5rem - 2px); font-weight: normal; letter-spacing:normal; border:1px solid #125; min-width: 2.5rem; height:2.5rem; padding:0 0.25rem; margin: 0; background:#fff; }
.light-theme a:hover, .light-theme li:not(.disabled):not(.active) span:hover { text-decoration: none; background: #FCFCFC; }
.light-theme .current { background: #125; color: #FFF; border-color: #125; cursor: default; }
.light-theme .ellipse { background: none; border: none; box-shadow: none; font-weight: bold; cursor: default; }
.light-theme .prev, .light-theme .next { background:#fff; padding: 0 0.75rem; color: #125; }
.light-theme .prev { border-radius: 2rem 0 0 2rem; }
.light-theme .next { border-radius: 0 2rem 2rem 0; }
.light-theme .disabled .prev, .light-theme .disabled .next { opacity:0.25;  }
.light-theme input { padding:0 0.5rem !important;  height:2.5rem; margin:-2px 0 !important;  }
.light-theme input:focus { box-shadow: none; }

/*FEATURE*/
.competency { width: 100%; max-width: 20rem; margin: -4rem auto; }
.competency02 { width: 100%; max-width:30rem; margin: auto; }
.competency03 {}
.takameru { position: relative;  } 
.takameru::after { content:""; display: block; position: absolute; top:10rem; right:-4.5rem; width:5rem; height:3rem; border-left:2.5rem solid rgba(17,34,85,0.5); border-top:1.5rem solid transparent; border-right:2.5rem solid transparent; border-bottom:1.5rem solid transparent;   }


.bg01 { position: relative; display:flex; flex-flow:row wrap; justify-content:space-between; width:100%; padding:0; right:0; }
.bg01::after { content:""; position: absolute; top:-2rem; bottom:0; left:calc(50% - 50vw); right:calc(50% - 50vw); background: url("../img/bg01.webp") center center /cover no-repeat fixed; z-index:-1; opacity: 0.15; }


/*教育の特色 別カラー校正用*/
/*body.feature.test { color:#222; font-family:'Noto Sans JP', "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif !important; font-weight:500; }
body.feature.test h1, body.feature.test h2, body.feature.test h3, body.feature.test h4, body.feature.test h5, body.feature.test h6 { font-family:'Noto Sans JP', "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif !important; font-weight:500; color:#125; }
*/

.site_preview { background: url("../img/bg02.webp") center center /cover no-repeat fixed; padding:4% 2.5%; justify-content: space-around; margin: 0 -1rem;  }
.site_preview div { border-radius:clamp(0.5rem, 1.6vw, 1rem); overflow: hidden; }


/*-- YOUTUBE/ --*/
.youtube { position:relative; width:100%; padding-top:56.25%; border-radius: 0.5rem; overflow: hidden; }
.youtube iframe{ position:absolute; top:0; right:0; width:100%; height:100%; }




@media screen and (max-width:1200px) {

body.temp .article { padding:7.5rem 0 0 0; }
body.temp .article.bg { padding:12.5rem 0 0 0; }


.navibar { margin:0 0 1rem 0; padding:0; width:100%; height:auto; position:relative; left:auto; top:0; z-index: 1000; }
.navibar ul { width:100%; margin:0; padding:0; line-height:1.5; font-size:0.6rem; }
.navibar ul li { writing-mode:horizontal-tb; max-width: none; max-height: none; }


/*ABOUT*/
 .feature_area .text p { font-size: 1rem; }
 .feature_area .text p br.sp_no { display: none; }



ul.page-link.bg, body.course ul.page-link.bg { position: fixed; top:3.6rem; }
}





@media screen and (max-width:960px) {

body { font-size:0.9rem; }
.pc_no { display:block; }
br.pc_no, span.pc_no { display:inline; }
.sp_no, br.sp_no { display:none; }
span.sp_no { display:none; }
.f_l { font-size:1.2rem }
	
.img_pc { display:none; }
.img_sp { display:block; }

body.top .article { padding:0; }
body.temp .article { padding:5rem 0 0 0; }

.header { background: linear-gradient(to bottom, rgba(255,255,255,0.9) 10%,rgba(255,255,255,0.6) 60%,rgba(255,255,255,0) 100%); }
.header, .header.bg, body.top .header.bg { padding:1.2rem 1rem 1rem 1rem; }

.hm { display:none; } 

.t_title, .header.bg .t_title { max-width: 18rem; }


/*--MAIN--*/
.main { height:125vw; max-height:900px; padding:0 2rem; overflow: hidden; }

.video_box { top:0; right:0; width:100vw; height: 100vw; max-height:calc(900px - 20vw); border-radius:0; }
.video_box video { position: relative; left:-38.9%; width:177.8vw; height: 100vw; max-height:calc(900px - 20vw); bottom:0; z-index: -1;}
.video_box::after { content:""; display: block; position: absolute; bottom:0; left:0; right:0; height:20vw;  background: linear-gradient(to bottom, rgba(255,255,255,0) 0%,rgba(255,255,255,1) 100%); }

.t_copy { width:70%; top:auto; bottom:0; left:6vw; transform: translate(0, -50%); }


/*--SCROLLNAVI--*/
.scrollnav > li a:hover { margin-left: 0; background: none; padding-left: 2rem; }

h1, h2, h3, h4, h5 { letter-spacing:normal; position: relative; }
h1 { font-size:1.5rem; margin-bottom:0.75rem; }
h2 { font-size:1.4rem; margin-bottom:0.75rem;}
h3 { font-size:1.3rem; margin-bottom:0.5rem; }
h4 { font-size:1.2rem; margin-bottom:0.5rem; }
h5 { font-size:1.1rem; margin-bottom:0.5rem; }
h6 { font-size:1rem; margin-bottom:0.5rem; }

h1 .comment, h2 .comment, h3 .comment, h4 .comment, h5 .comment { font-size:0.8rem; display: block; }

a.more { padding:0.75rem 2rem 0.75rem 0; font-size: 0.875rem; }
a.more::after { right:-5vw; }


/*--FEATURE--*/
 .feature_area { padding:0; margin-top:0; margin-bottom: 3rem; position: relative; }
 .feature_area .photo { border-radius:0 1rem 1rem 0; overflow: hidden; margin-left:-6vw; box-shadow:0 1rem 0.5rem -0.75rem rgba(17,34,85,0.1); }
 .feature_area .photo img { width: 100%; max-width: 100vw; }
 .feature_area .text { padding:3rem 0; }
 .feature_area .text p { width:calc(100% - 3rem); margin: 0 0 1.5rem 0; font-size: 0.875rem; }
 .feature_area .pattern, .feature_area .pattern:nth-of-type(1) { border-radius:0.25rem; }


/*--course--*/
.course_area { margin-bottom:5rem; }
.course_area .bg { width:calc(100% - 3rem); padding:0; }

.course_area ul { width: 100%; }
.course_area ul li { width:100%; margin-bottom:1.5rem; }
.course_area ul li:nth-of-type(2n + 0) { margin-top:0; }

.course_area ul li .photo { margin-bottom:0.25rem; }
.course_area ul li .text { font-size: 0.9rem; }
.course_area ul li .text::after { margin-left:1rem; }

.course_area ul li::after { }
.course_area ul li:nth-of-type(1)::after { width:28vw; height:42vw; top:-10vw; left:-4vw; }
.course_area ul li:nth-of-type(2)::after { width:37vw; height:28vw; top:-4vw; right:-5vw; border-radius:0.5rem 0 0 0.5rem }
.course_area ul li:nth-of-type(3)::after { width:30vw; height:30vw; bottom:-6vw; left:-10vw; }
.course_area ul li:nth-of-type(4)::after { width:27vw; height:42vw; bottom:4vw; right:-5vw; border-radius:0.5rem 0 0 0.5rem; }

.course_area .tr { margin-top: -1rem; }


/*--FUTURE--*/
.future_area { margin-bottom:5rem; }
.future_area .bg { width:100%; padding:0 0 3rem 0; }
.future_area .bg::after { top:-4rem; bottom:0; left:calc(50% - 50vw); right:calc(50% - 50vw); }
.future_area ul { width: 100%; }
.future_area ul li:nth-of-type(3n - 2) { order:2; margin:-8rem 1vw 0 1vw;}
.future_area ul li:nth-of-type(3n - 1) { order:1; margin:1rem 1vw 0 1vw; }
.future_area ul li:nth-of-type(3n - 0) { order:3; margin:-7rem 1vw 0 auto; }

.future_area ul li { width:45%; }
.future_area ul li .desc { display: none; }
.future_area ul li a { width:100%; }
.future_area ul li .text { font-size:0.9rem; padding:0 0.75rem; bottom:3vw; right:3vw; left:3vw; }
.future_area ul li .text::before { width: 0.5rem; height: 0.5rem; top:0.65rem; right: 0.75rem; }



/*--ATMOSPHERE--*/
.atmos_area { margin-bottom:5rem; position: relative; height:230vw; }

.atmos_area .photo01 { width:66vw; height:54vw; top:164vw; left:-5vw; }
.atmos_area .photo01 img { width:66vw; height:54vw; }
.atmos_area .photo01::after { width:25vw; height:30vw; top:-25vw; left:-2vw; background:rgba(160,224,252,0.15); }

.atmos_area .photo02 { width:32vw; height:48vw; top:0; left: -0.5rem; }
.atmos_area .photo02 img { width:32vw; height:48vw; }
.atmos_area .photo02::after { width:25.6vw; height:38.4vw; top:30vw; left:13vw; }

.atmos_area .photo03 { width:54vw; height:80vw; top:12vw; left:46vw; }
.atmos_area .photo03 img { width:54vw; height:80vw; border-radius:0.5rem 0 0 0.5rem; }
.atmos_area .photo03::after { width:17vw; height:32vw; top:-18vw; left:37vw; border-radius:0.5rem 0 0 0.5rem; }

.atmos_area .photo04 { width:32vw; height:54vw; top:177vw; left:68vw; }
.atmos_area .photo04 img { width:32vw; height:54vw; border-radius:0.5rem 0 0 0.5rem;}
.atmos_area .photo04::after { display: none; }

.atmos_area .photo05 { width:42vw; height:42vw; top:60vw; left:-2vw; }
.atmos_area .photo05 img { width:42vw; height:42vw; }
.atmos_area .photo05::after { width:42vw; height:42vw; top:20vw; left:15vw; }

.atmos_area .photo06 { width:74vw; height:42vw; top:114vw; left:26vw; }
.atmos_area .photo06 img { width:74vw; height:42vw; border-radius:0.5rem 0 0 0.5rem;}
.atmos_area .photo06::after { width:49vw; height:35vw; top:22vw; left:25vw; border-radius:0.5rem 0 0 0.5rem; }



/*--BLOG--*/
.blog_area { margin-bottom:5rem; }
.blog_area .bg { width:calc(100% - 3rem); padding:0; }
.blog01 li, .blog02 li { margin-bottom: 1.5rem; }
.blog01 .photo { margin-bottom: 0.5rem; }
.blog01 .text, .blog02 .text { font-size: 0.875rem; }
.blog01 .text .date, .blog02 .text .date { font-size: 0.7rem; margin-top:0.5rem; }

.blog02 li a { display:flex; flex-flow:row nowrap; justify-content:space-between; }
.blog02 .photo { width: 35%; border-radius:0.5rem; overflow: hidden; box-shadow:0 1rem 0.5rem -1rem rgba(17,34,85,0.2); }
.blog02 .text { width: calc(65% - 0.75rem); font-size: 0.875rem; padding-bottom:2rem; }
.blog02 .text .date { font-size: 0.7rem; margin-top:1rem; }
.blog_area a.more { top:0; }

body.blog .index_box .photo { margin-right: 0.75rem; margin-bottom: 0; }

/*--INFO--*/
.info_area { margin-bottom:3rem; }
.info_area .bg { width:calc(100% - 3rem); padding:0.5rem 0 1.5rem 1rem; }
.info_area .bg::after { border-radius:1rem 0 0 1rem; right:-5vw; }
.info_area ul { margin:0 0 0.5rem 0; }
.info_area ul li a .date { font-size:0.5rem; width: 2.5rem; height:2.5rem; }
.info_area ul li a .text { width:calc(100% - 3rem); line-height: 1.75; }
.info_area ul li a:hover .text { text-decoration: underline; }

.i_cate { display: inline-block; border-radius:1rem; font-size:0.75rem; padding:0 0.75rem; }



/*--FOOTER--*/
.footer { padding:0 2% 2rem 2% ; flex-flow: column wrap; margin: auto;}
.f_title { display: block; width: 100%; max-width:15rem; }

.address_box { margin-right:0; }

.copyright { bottom:0; font-size: 0.6125rem; position: relative; /*padding-bottom:7rem;*/ }

.um li { padding: 0.5rem 0; }
.um li a { text-decoration: none; }
.um li a:hover { text-decoration: underline; }

.fm { border-radius:1rem 0 0 0; width:100%; max-width: 36rem; display: none; }
.fm ul { padding: 0.5rem; }
.fm ul li a { padding:0.5rem; font-size: 0.75rem; }


.pagetop { height:11rem; font-size:0.75rem; }



.hero { padding: 0; margin-bottom:0; }
.hero h1 { width:100%; margin:1rem 0; }
.hero .photo { width: 40vw; height:24vw; right:0; }
.hero::after { top:-7.5rem; right:calc(50% - 50vw); width:100vw; height: 9.75rem; background:url("../img/bg01.webp") center center /cover no-repeat; opacity:0.15; z-index: -1; border-radius:0 0 0 1rem; }
body.cate .hero::after { height: 9.75rem; }


ul.page-link { margin:1rem auto 2rem auto !important; max-width:70rem; }
ul.page-link li a { font-size: 0.8125rem; }
ul.page-link li a::before { top:0.75rem; }
ul.page-link.bottom { margin:1.5rem auto 4.5rem auto !important; padding-top:1.5rem; }
ul.page-link.bottom a::before { top:1rem; transform:rotate(-135deg); }
body.course ul.page-link { margin:1rem auto 2rem auto !important; }
ul.page-link.bg, body.course ul.page-link.bg { top:5.1rem; padding:0 5vw; display: flex; flex-flow: row nowrap; overflow: auto; border-radius:0;}

/*--INFO--*/
body.info .text_area, body.info .index_area, body.info .side { width:100%; position: relative; }
body.info .side { width:100%; margin:0 auto; border-top:1px solid rgba(17, 34, 85, 0.1); padding-top:1rem; }


body.page .info_area { margin-bottom: 4rem; }
body.page .info_area h3 { writing-mode:vertical-rl; font-feature-settings:initial; }

body.page.course .hero { height: auto; min-height:20vw; }
body.page.course .hero h1 { width:50vw; margin:3rem 0; }
body.page.course .hero::after { top:-7rem; height:calc(9.75rem + 1.5rem); }
body.page .course_area { margin-bottom:0; }
body.page .course_area .bg { width: calc(100% - 2.5rem);}
body.page .course_area ul li { width:calc((100% - 2rem)/2); margin-bottom:1.5rem; }
body.page .course_area ul li .text { font-size: 0.8125rem; }

body.page .course_area h3 { writing-mode:vertical-rl; font-feature-settings:initial; }

body.page .course_area ul li::after { content: ""; position: absolute; display: block; border-radius:0.5rem; z-index: -1; }
body.page .course_area ul li:nth-of-type(1)::after, body.page .index_area.course li:nth-of-type(1)::after { width:16vw; height:27vw; top:-6vw; left:-3vw; background: rgba(160,224,252,0.15); }
body.page .course_area ul li:nth-of-type(2)::after, body.page .index_area.course li:nth-of-type(2)::after { width:27vw; height:18vw; top:-3vw; right:-2vw; background: rgba(168,156,232,0.15); }
body.page .course_area ul li:nth-of-type(3)::after, body.page .index_area.course li:nth-of-type(3)::after { width:21vw; height: 21vw; bottom:-1vw; left:-6vw; background: rgba(225,106,105,0.1); }
body.page .course_area ul li:nth-of-type(4)::after, body.page .index_area.course li:nth-of-type(4)::after { width:18vw; height: 27vw; bottom:-4vw; right:-2vw; background: rgba(233,186,95,0.15); }

.text_inner { flex-flow:column wrap; }
.text_inner .hl { width:100%; padding-right:0; }
.text_inner .text { width:100%; }


.left_img { position: relative; left:10%; width:80%; }


/*-- INDEX --*/

.index_box { width:33.3%; }
.index_box .date { font-size:0.75rem; margin-top:0.5rem; }
.index_box strong { font-size:0.9rem; }
.index_box .cat { font-size:0.75rem; }
.index_box .tab { display:flex; flex-flow:row wrap; justify-content:flex-end; padding:1rem 1rem 1rem 0.5rem; }
.index_box .tab span { font-size:0.75rem; background:#125; color:#fff; padding:0 0.25rem 0 0.45rem; margin-left:0.5rem; text-align:center; line-height:1.8; }
.index_box .title { font-size:0.8125rem; line-height:1.5; }
.index_box .comment { font-size:0.75rem; line-height:1.5; }


body.info .index_box { width:100%; padding:0; }
body.info .index_box a { padding: 1rem 0; }
body.info .index_box .photo { width:25vw; max-width:120px; margin-right:0.75rem; }

body.blog .index_area { width: 100%; margin: 0 auto 3rem auto}
body.blog .index_box { width: 100%; padding:0; }
h2.page_title::after { display: none; }

body.business .index_box { width:100%; }
body.exam .index_box { width:33.3%; }
body.exam .index_box .title { font-size: 0.9rem; }

body.about .index_box { width:50%; }
body.page .index_box { width:50%; }

.table01:not(.noresp) th, .table02:not(.noresp) th { display:inline-block; width:100%; padding:0.75rem 0 0 0; }
.table01:not(.noresp) td, .table02:not(.noresp) td { display:inline-block; width:100%; border-top:none; padding:0.75rem 0; }


.text_inner { flex-flow:column wrap; }
.text_inner .hl { width:100%; }
.text_inner .text { /*width:100%;*/ }


a.link::before, a span.link::before { top:0.7rem; }

.col2 { column-count:1; }

	
.scroll::before { content:"→ 横スクロールしてご確認ください。"; display: block; font-size:0.8rem; margin-bottom:0.5rem;}



/*WordPress*/
.aligncenter { display:block;margin: 0 auto; text-align: center; max-width:100%; }
.alignright { float:none; margin:0 auto 1rem auto; max-width:100%; }
.alignleft { float:none; margin:0 auto 1rem auto; max-width:100%; }
img[class*="wp-image-"],
img[class*="attachment-"] { max-width: 100%; height: auto; }
img.alignright, img.alignleft, .alignright img, .alignleft img { width:100%; max-width:80%; }
.alignright img, .alignleft img { margin: auto; }

.resp100 { width:100%; }
.resp90 { width:90% !important; }
.resp80 { width:80% !important; }
.resp70 { width:70% !important; }
.resp60 { width:60% !important; }
.resp50 { width:50% !important; }
.resp48 { width:48% !important; }
.resp47 { width:47% !important; }
.resp40 { width:40% !important; }
.resp30 { width:30% !important; }
.resp20 { width:20% !important; }
.resp10 { width:10% !important; }

.resp49 { width:49% !important; }
.resp_no { display: none; }
.resp_ma { margin:auto !important; }


a.link, a span.link { padding:0.5rem 0.15rem 0.5rem 0.8rem; font-size:0.9rem;  }
.m.link { padding:0.25rem 0 0.25rem 0.8rem; font-size:0.9rem; }

/*FEATURE*/
.competency { margin: 1rem auto; }
.takameru { margin-bottom:4rem;  } 
.takameru::after { top:calc(100% - 0.5rem); right:calc(50% - 1.5rem); width:3rem; height:5rem; border-left:1.5rem solid transparent; border-top:2.5rem solid rgba(17,34,85,0.5); border-right:1.5rem solid transparent; border-bottom:2.5rem solid transparent;   }



.notice { padding: 1rem; }

}






@media screen and (max-width:640px) {


br.sp_no2 { display:none; }
br.pc_no2 { display:inline; }
p { margin-bottom: 1rem; }


a.more { max-width: 15rem; }


table th, table td { padding:0.5rem; }

.navibar { margin:0 0 0.75rem 0; }
body.cate ul.page-link { /*margin: 0 auto 1.5rem auto !important;*/}

.h_contact li a span { display:none;}

.big_photo + .flex > .LR_box:nth-of-type(1) { order:1; }
.big_photo + .flex > .LR_box:nth-of-type(2) { order:2; }
.big_photo_text { top:-5rem; margin-bottom:-3rem; }

.b_box { display:flex; flex-flow:column wrap; }
.b_box a { width:100%; }

.index_box { width:50%; }


ul.li_half { flex-flow:column wrap; } 
ul.li_half li { width:100%;} 
	
.LR_box { width:100% !important; padding:0 0 1rem 0 ; }
.LCR_box, .LCR_box2 { width:100% !important; padding:0 0 2rem 0; margin:0; overflow:visible !important; }

.col1, .col2, .col3 { column-count:1; padding:0; }

.flex.full_r .text, .flex.full_l .text { width:100%;}
.flex.full_r, .flex.full_l { display: block; }
.flex.full_l .photo { width:60%; margin:0 auto 1rem auto; }
.flex.full_r .photo { width:60%; margin:0 auto 1rem auto; }

.flex.noresp .w32 { width:32%; }
.flex.noresp .w49 { width:49%; }
.flex.noresp .w50 { width:50%; }
.flex.noresp .w66 { width:66%; }


.fm { max-width: 22.5rem; }
.fm ul li:nth-of-type(3) { width:7rem; }
.tel strong, .fax strong { font-size: 1.25rem; }

 .i_cate { font-size: 0.6rem; padding:0 0.5rem; }
 

}


@media screen and (max-width:480px) {

body { font-size:0.8125rem; }

/*TEACHER*/
dl.profile dt { width:100%; font-weight: bold; padding: 0.75rem 0 0 0; margin: 0; border-top:1px solid rgba(0,0,0,0.1); line-height: 1.5; }
dl.profile dt br { display: none; }
dl.profile dd { width:100%; padding:0.75rem 0; border-top:0 solid rgba(0,0,0,0.1); line-height: 1.5; }
.w70.resp100 table td.tr {}
.w70.resp100 table td.tr a.link { font-size: 0.5rem; } 


.researchmap, .researchers { padding:0 0.6rem 0 0.9rem; font-size: 0.6rem; letter-spacing: normal; }
.researchmap::before, .researchers::before { width: 0.3rem; height: 0.3rem; border-top: 1px solid #125; border-right: 1px solid #125; top:calc(50% - 0.15rem); left:0.3rem; }

body.modal .text_area { padding:8vw; }

/*HISTORY*/
.timeline_item { display: flex; flex-flow: column; padding: 0 0 2rem 1rem; border-left: 1px solid #ccc; position: relative; }
.timeline_item::before { content: ""; position: absolute; top: 0.25rem; left: -0.5rem; width: 1rem; height: 1rem; background-color: #125; border-radius: 1rem; }

.timeline_item .date { width: 100%; padding: 0; margin-bottom:0.5rem; display: flex; align-items: center;  }
.timeline_item .date br { display: none; }
.timeline_item .text { width:100%; padding: 0; border-left:none;}
.timeline_item .text::before { display: none; }
.timeline_item .date .i_cate { margin:0 0 0 0.25rem;  }
.timeline_item .f_s { display:block; line-height: 1.5; }
.timeline_item .flex div { margin-bottom: 1rem; }
.timeline_item .flex img { vertical-align: bottom; margin-bottom:0.5rem; }


.light-theme a, .light-theme span {  min-width: 2.25rem;  }
}

@media screen and (max-width:375px) {
ul.page-link.bg, body.course ul.page-link.bg { position: fixed; top:4.75rem; }
}