/* 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*/ vertical-align:bottom; }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 { overflow-x:clip; }
body { font-family:"Noto Sans JP", sans-serif; color:#222; position:relative; font-size:clamp(0.875rem, 1.6vw, 1rem); line-height:2; letter-spacing:0.1rem; margin:0; padding:0; -webkit-text-size-adjust:100%; -ms-text-size-adjust:100%; font-feature-settings:"palt"; box-sizing:border-box; background:#fff; width:100vw; overflow-x:clip; }

title span { display:none; }
a { color:#222; transition:0.15s; outline-style:none; cursor:pointer; }
a:hover { color:#222; } 

.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:clamp(16px, 2.9vw, 32px); background: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; }

.tc { text-align:center; }
.tr { text-align:right; }
.tl { text-align:left; }
.vt { vertical-align:top; }
.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_ll { font-size:clamp(1.25rem, 2.4vw, 1.5rem); }
.f_l { font-size:clamp(1rem, 2vw, 1.25rem); }
.f_m { font-size:clamp(0.9rem, 1.6vw, 1rem); }
.f_s { font-size:clamp(0.75rem, 1.3vw, 0.8rem); }
span.f_s { display:inline-block; }
.lh100 { line-height:1; } 
.lh125 { line-height:1.25; } 
.lh150 { line-height:1.5; } 
.lh200 { line-height:2; } 

.pc_no, .pc_no2, span.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; }


.green { color:#0b6;}
.yellow {color:#F5DF4D;}
.red {color:#e66;}
.blue { color:#08d;}
.orange { color:#F18D5F;}
.gray { color:gray;}

p { margin-bottom:2rem; }
hr { background:none; border:none; border-bottom:1px solid; border-image:linear-gradient(to right, #08d 30%, #f68 90%) 1; }
ul { padding:0 0 0 1.25rem; margin:0 0 1rem 0; }

.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:12rem; margin-top:-12rem; position:relative; z-index:-10; width:1px; }

.flex { display:flex; flex-flow:row wrap; justify-content:space-between; position:relative; }
.flex.rowre { flex-flow:row-reverse wrap; }
.flex.jcfs { justify-content:flex-start; }
.flex.jcc { justify-content:center; }
.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, .fadeinUp_once { opacity :0; transform :translate(0, 50px); transition :all 0.75s ease 0.15s;}
.fadeinUp.show, .fadeinUp_once.show { opacity :1; transform :translate(0, 0); }

.fadeinDown, .fadeinDown_once { opacity :0; transform :translate(0, -50px); transition :all 0.75s ease 0.15s;}
.fadeinDown.show, .fadeinDown_once.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; }
.mb48 { margin-bottom:3rem !important; }

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

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

.ma { margin:auto; }

.multiply { mix-blend-mode:multiply; }


/*TEST用*/
div.test, body.test .test_no { display:none;}
body.test div.test { display:block; }



.article { width:100%; max-width:80rem; padding:8rem clamp(1.5rem, 5vw, 3rem) 0 clamp(1.5rem, 5vw, 3rem); margin:0 auto; box-sizing:border-box; position:relative; z-index: 0; }
body.top .article { padding-top:1px; }
body.contact .article { max-width:60rem; }

/*--HEADER--*/
.header { width:100%; margin:0 auto; position:fixed; top:0; left:0; right:0; transition:0.3s; z-index:3000; padding:clamp(1rem,1.6vw,2rem) clamp(1rem, 4vw, 2.5rem); box-sizing:border-box; height:7rem; }
.header.bg { background:linear-gradient(to bottom,rgba(255,255,255,0.97) 60%,rgba(255,255,255,0) 100%); }
body.temp .header.bg { background:linear-gradient(to bottom,rgba(255,255,255,0.97) 80%,rgba(255,255,255,0.9) 100%);  }
.t_title { width:calc(100vw - 6rem); max-width:24rem; display:block; text-decoration:none; transition:0.25s; position:relative; }
.t_title img { width:100%; -webkit-filter: drop-shadow(1px 1px 0 rgba(255, 255, 255, 1)); filter: drop-shadow(1px 1px 0 rgba(255, 255, 255, 1));  }
/*body.top .header.bg .t_title::after,*/ body.temp .header .t_title::after { content:""; position: absolute; top:clamp(-2rem,-1.6vw,-1rem); left:-20rem; bottom:clamp(-2rem,-3vw,-1rem); right: clamp(-2rem, -3vw, -1rem); background:radial-gradient(rgba(255,255,255,0.97) 50% ,rgba(255,255,255,0) 65% ); z-index: -10; }
body.temp .header.bg .t_title::after { display: none; }

/*--HEADER MENU--*/
.hm { position:fixed; right:2rem; top:1rem; z-index:100000; }
.hm > ul { padding:0; margin:0; display:flex; flex-flow:row wrap; list-style:none; }
.hm > ul > li { display:block; margin:0; position:relative; transition:all 0.4s ease;}
.hm > ul > li > a { display:flex; align-items:center; padding:0.5rem 0.75rem; width:100%; font-weight:300; text-decoration:none; letter-spacing:1px; position:relative; height:2.5rem; }
.hm > ul > li:hover > a, .hm li.active > a, body.med .hm_med > a { box-shadow:none; opacity:1; color:#08d; }
.hm > ul > li > a.active, ul > li.active > a, .hm li .sub ul li a.active, .page-link li a.active, body.top .hm_top a { position:relative; color:#08d; }
.hm > ul > li > a::after { content:""; width:0; height:0; position:absolute; top:100%; left:50%; right:50%; margin:auto; border-bottom:1px solid; border-image:linear-gradient(to right, #08d 30%, #f68 90%) 1; transition:0.3s; }
.hm > ul > li:hover > a::after, 
.hm > ul > li.active > a::after, 
body.top .hm_top > a::after,
body.about .hm_about > a::after,
body.med .hm_med > a::after,
body.research .hm_research > a::after,
body.edu .hm_edu > a::after,
body.robot .hm_robot > a::after { width:auto; left:0.75rem; right:0.75rem; }
 


.hm li .sub { visibility:hidden; opacity:0; position:absolute; top:120%; left:0; width:13rem; z-index:100000; box-shadow:0 1rem 0.5rem -0.75rem rgba(0,0,0,0.05); transition:0.5s; }
.hm li:hover .sub { visibility:visible; opacity:1; top:calc(100% + 1px); }
.hm li .sub > ul { display:flex; flex-flow:column wrap; margin:0; padding:0.5rem 1rem 0.5rem 0; text-align:left; background:rgba(255,255,255,1); backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px); width:100%; box-shadow:0 0 0.25rem -0.75rem rgba(34,34,34,0.05); list-style:none; border:1px solid #ddd; /*border-radius:0.75rem;*/ }
.hm li .sub ul li { width:100%; margin:0; }
.hm li .sub ul li a { display:block; width:100%; padding:0.5rem 0 0.5rem 2rem; text-align:left; text-decoration:none; position:relative; line-height:1.5; background:url("../img/i_arrow_r.svg") left top 0.6rem /1.5rem no-repeat; }
.hm li .sub ul li a:hover { background-color:rgba(255,255,255,0.5); color:#08d; }
.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(34,34,34,0.2); }
.hm li.hm_home { display:none; }
.hm li.hm_results:hover .sub { top:-3rem; }
.hm li.hm_entry:hover .sub { top:-3rem; }
.hm li.hm_ig a { height:3rem; }
.hm ul li.hm_ig a::after {display:none !important ; }
.hm_ig a .icon { width:2rem; margin-right:0.5rem; }

.mean-container .mean-nav > ul > li > a { display:block; padding:0.75rem 0 0.75rem 2rem; background:url("../img/i_arrow_r.svg") left center /1.5rem no-repeat; text-decoration:none; }
.mean-container .mean-nav .sub li a { display:block; padding:0.75rem 0 0.75rem 3rem; background:url("../img/i_arrow_r.svg") left 1rem center /1.5rem no-repeat; text-decoration:none; }
.mean-container .mean-nav .sub li a.active::before { border-color:#08d; }
.mean-container .mean-nav ul li > a.info::before,
.mean-container .mean-nav ul li > a.member::before { right:1.3rem;}
.mean-container .mean-nav ul li a { display:flex; align-items:center; }
.mean-container .mean-nav ul li.mean-last { /*border-bottom:none;*/ }
.mean-container .mean-nav .sub li a br { display:none; }

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



/*--MAIN--*/
.main { position:relative; z-index:0; padding:5rem clamp(1.5rem, 5vw, 3rem) clamp(3rem, 10vw, 6rem) clamp(1.5rem, 5vw, 3rem); margin:0 auto; max-width:100rem; }
.main::before { content:""; width:120vw; height:120vw; background:radial-gradient(ellipse at center, rgba(0,187,238,0.1) 30%, rgba(0,187,238,0) 70%); position:absolute; left:clamp(-50rem,-60vw,-15rem); top:-5vw; max-width:100rem; max-height:100rem; z-index:-1; }
.main ul.slick { list-style:none; width:66%; aspect-ratio:10/7; margin:0 0 0 auto; padding:0; position:relative; z-index:-10;  }
.main ul.slick::before { content:""; background:linear-gradient(to right, rgba(255,255,255,1) 10%,rgba(255,255,255,0) 100%); position:absolute; top:0; left:0; bottom:0; right:66%; z-index:1030; }
.main ul.slick .slick-list, .main ul.slick .slick-track, .main ul.slick li > div { position:absolute; top:0; left:0; right:0; bottom:0; }
.main .copy { background:linear-gradient(135deg, rgba(0,136,221,1) 25%,rgba(255,102,136,1) 75%); -webkit-background-clip:text; -webkit-text-fill-color:transparent; font-size:clamp(1.5rem,6vw,4.5rem); line-height:1.3; width:clamp(17rem,50vw,34rem); font-feature-settings:"palt"; opacity:0.9; z-index:10000; position:absolute; top:calc(50% - clamp(4rem,12vw,8rem)); } 
.main .scroll { position:absolute; bottom:0; right:0; width:3rem; font-size:0.875rem; height:7rem; padding-top:0.75rem; border-radius:1rem 0 0 0; text-decoration:none; writing-mode:vertical-rl; z-index:10000; color:rgba(0,0,0,0.7); display:flex; flex-flow:column nowrap; justify-content:center; }
.main .scroll::before { content:"SCROLL"; color:#fff; text-shadow:1px 1px 0 rgba(0,0,0,0.1); }
.main .scroll::after { content:""; position:absolute; top:4.5rem; left:1.5rem; bottom:0; border-right:1px solid rgba(255,255,255,0.8); }
.main .scroll:hover { opacity:0.7; }
.main ul.slick .slick-list li { aspect-ratio:10/7; }
.main ul.slick .slick-list  li img { width: 100%; height: 100%; object-fit: cover; }

.slick-dots { position: absolute; right:0.75rem; bottom:0.5rem; z-index: 3000; display: flex; flex-flow: row nowrap; justify-content: center; align-items: center; }
.slick-dots li { display: block; line-height: 1; padding: 0; position: relative; width:2rem; height:2rem;  }
.slick-dots li::after { content: ""; display: block; width: 0.4rem; height: 0.4rem; position: absolute; top:calc(50% - 0.2rem); left:calc(50% - 0.2rem); border-radius: 1rem; z-index: 100; background: #fff;  }
.slick-dots li button { min-width: 1px; padding:0; margin: 0; height:100%; width:100%; text-indent:-3rem; overflow: hidden;  background: rgba(255,255,255,0); vertical-align: bottom; opacity: 0; }

.slick-dots li svg { position: absolute; left: 0; top: 0px; z-index: 10; width: 100%; height: 100%; fill: none; stroke-width: 2px; stroke-dasharray: 130;  }
.slick-dots li.slick-active svg  { stroke-width: 2px; stroke:#fff; transform: rotate(-90deg); animation: load 3s linear; }
.slick-dots li.slick-off svg  { stroke-width: 2px; stroke-dashoffset: 0; transform: rotate(-90deg); animation: reverseLoad 1s linear; }
@keyframes load {
0% { stroke-dashoffset: 130; }
100% { stroke-dashoffset: 0; }
}
@keyframes reverseLoad {
0% { stroke-dashoffset: 0; stroke:#fff; }
100% { stroke-dashoffset: 130; stroke:#fff; }
}


.main ul.slick .slick-track .slick-slide::before { content:""; position:absolute; top:0; right:0; bottom:0; left:0; background:linear-gradient(135deg,rgba(0,136,221,0.2) 50%, rgba(255,102,136,0.2) 100%); z-index:1000 }
.main .slick .caption { position:absolute; right:0; bottom:0; color:#fff; padding:0.5rem 1rem; font-size:clamp(0.75rem,1.4vw,0.875rem); z-index:1020; }

h1, h2, h3, h4, h5, h6 { line-height:1.5; letter-spacing:clamp(0.1rem, 0.2vw, 0.3rem); position:relative; padding:0; text-align:left; font-family:"Noto Serif JP", serif; }
h1 { font-size:clamp(1.8rem, 4.8vw, 3rem); margin-bottom:clamp(1rem, 3.2vw, 2rem); font-weight:300;}
h2 { font-size:clamp(1.6rem, 3.6vw, 2.25rem); margin-bottom:clamp(1rem, 3.2vw, 2rem); font-weight:300;}
h3 { font-size:clamp(1.4rem, 2.8vw, 1.75rem); margin-bottom:clamp(0.5rem, 1.6vw, 1rem); position:relative; display:flex; align-items:center; font-weight:300; flex-flow:row nowrap; }
h4 { font-size:clamp(1.2rem, 2.4vw, 1.5rem); margin-bottom:clamp(0.5rem, 1.6vw, 1rem); color:#08d; font-weight:400;}
h5 { font-size:clamp(1.1rem, 2vw, 1.25rem); margin-bottom:clamp(0.5rem, 1.2vw, 0.75rem); font-weight:400;}
h6 { font-size:clamp(1.0rem, 2vw, 1.125rem);; margin-bottom:0.5rem; font-weight:400; }

.mincho { font-family:"Noto Serif JP", serif; }
.gothic { font-family:"Noto Sans JP", sans-serif; }
.garede {font-family:"garage-gothic", sans-serif; font-weight:700; font-style:normal; letter-spacing:normal; line-height:1; }


body.modal h1, body.modal h2, body.modal h3, body.modal h4, body.modal h5, body.modal h6 {letter-spacing:0.05rem; }
h1 .comment, h2 .comment, h3 .comment, h4 .comment, h5 .comment { display:block; font-size:clamp(0.875rem, 1.6vw, 1.0rem); letter-spacing:0.1rem; margin-top:0.5rem; }
br + .comment { display:block; }

h2.bar { display:flex; align-items:center; flex-flow:row nowrap; }
h2.bar::after { content:""; border-bottom:1px solid; border-image:linear-gradient(to right, #08d 30%, #f68 90%) 1; flex-grow:1; margin-left:1rem; opacity:1; mix-blend-mode:multiply; }

h3::after { content:""; border-bottom:1px solid; border-image:linear-gradient(to right, #08d 30%, #f68 90%) 1; flex-grow:1; margin-left:1rem; opacity:0.3; mix-blend-mode:multiply; }
h3.page_title + .date { display:block; text-align:right; margin-top:-2rem; }
h3.page_title + .comment { margin-top:clamp(-1rem, -1.6vw, -0.5rem); margin-bottom:clamp(0.5rem, 3.2vw, 2rem); font-size:clamp(0.875rem, 1.4vw, 0.9rem); }
.page_title br { display:none; }

h4.bar { display:flex; align-items:center; flex-flow:row nowrap; }
h4.bar::after { content:""; border-bottom:1px solid; border-image:linear-gradient(to right, #08d 30%, #f68 90%) 1; flex-grow:1; margin-left:1rem; opacity:0.3; mix-blend-mode:multiply; }

a.more { text-decoration:none; font-weight:300; font-size:clamp(0.75rem,1.4vw,0.875rem); letter-spacing:0.1rem; }

span.line { text-decoration:underline; text-decoration-thickness:0.8rem; text-decoration-color:rgba(0, 170, 170, 0.1); text-underline-offset:-0.4rem; text-decoration-skip-ink:none; }

body.top .section { margin-bottom:clamp(3rem, 7.5vw, 5.5rem); }

.tate { writing-mode:vertical-rl; font-feature-settings:initial; border-top:none; padding-top:0; }


/*--INFO--*/
.info_box { padding-bottom:clamp(3rem, 10vw, 6rem); }
.info_box h2, h2.cate_title, h2.page_title { position:relative; display:flex; width:100%; flex-flow:row wrap; justify-content:space-between; align-items:center; margin-bottom:clamp(0.75rem,2.4vw,1.5rem); }
.info_box h2::before { content:"NEWS"; font-family:"garage-gothic", sans-serif; font-weight:700; font-style:normal; color:rgba(0,0,0,0.05); font-size:clamp(2rem,6vw,3.75rem); position:absolute; top:clamp(-3.5rem,-6vw,-1.75rem); left:0; line-height:1; letter-spacing:normal;}
.info_box h2 .bar, h2.cate_title .bar, h2.page_title .bar { flex-grow:1; margin-left:1rem; border-bottom:1px solid; border-image:linear-gradient(to right, #08d 30%, #f68 90%) 1; mix-blend-mode:multiply; }
.info_box h2 .more { display:block; padding:0 0 0 1.5rem; background:url("../img/i_arrow_rp.svg") left center /1rem no-repeat; }

.info_box .index_area {display:flex; flex-flow:row wrap; justify-content:space-between; position:relative; background:none; margin:0 -2.5%; list-style:none; padding:0; flex-grow:2; }
.info_box .index_area .index_box { width:25%; min-width:10rem; padding:0 2.5%; }
.info_box .index_area .index_box a { text-decoration:none; display:flex; flex-flow:row wrap; align-items:flex-start; justify-content:space-between; padding:0.5rem 0; line-height:1.5; border:none; }
.info_box .index_area .index_box .photo { width:100%; aspect-ratio:1; margin:0 0 0.75rem 0; }
.info_box .index_area .index_box .photo img { width:100%; height:100%; object-fit:cover; object-position:top; }
.info_box .index_area .index_box a .date { font-size:clamp(0.75rem, 1.3vw, 0.875rem); display:flex; flex-flow:row wrap; align-items:center; justify-content:flex-start; white-space:nowrap; padding-bottom:0.5rem; width:100%; }
.info_box .index_area .index_box a .title { flex-grow:2; position:relative; padding:0; }

.desc { margin-bottom:clamp(1rem, 3.2vw, 2rem); font-size:clamp(0.875rem, 1.4vw, 1.125rem); }




/*--EVENTS--*/
.event_box { padding-bottom:clamp(4rem, 12vw, 8rem); }
.event_box h2, h2.cate_title, h2.page_title { position:relative; display:flex; width:100%; flex-flow:row wrap; justify-content:space-between; align-items:center; margin-bottom:clamp(0.75rem,2.4vw,1.5rem); }
.event_box h2::before { content:"EVENTS"; font-family:"garage-gothic", sans-serif; font-weight:700; font-style:normal; color:rgba(0,0,0,0.05); font-size:clamp(2rem,6vw,3.75rem); position:absolute; top:clamp(-3.5rem,-6vw,-1.75rem); left:0; line-height:1; letter-spacing:normal;}
.event_box h2 .bar, h2.cate_title .bar, h2.page_title .bar { flex-grow:1; margin-left:1rem; border-bottom:1px solid; border-image:linear-gradient(to right, #08d 30%, #f68 90%) 1; mix-blend-mode:multiply; }
.event_box h2 .more { display:block; padding:0 0 0 1.5rem; background:url("../img/i_arrow_rp.svg") left center /1rem no-repeat; }

.event_box .index_area {display:flex; flex-flow:row wrap; justify-content:space-between; position:relative; background:none; margin:0 -2.5%; list-style:none; padding:0; flex-grow:2; }
.event_box .index_area .index_box { width:50%; padding:0 2.5%; }
.event_box .index_area .index_box a { text-decoration:none; display:flex; flex-flow:row wrap; align-items:flex-start; justify-content:space-between; padding:0.5rem 0; line-height:1.5; border:none; }
.event_box .index_area .index_box .photo { width:49%; aspect-ratio:1/1.414; margin:0; }
.event_box .index_area .index_box .photo img { width:100%; height:100%; object-fit:cover; object-position:top; }
.event_box .index_area .index_box .text { width:49%; padding-left:clamp(0.75rem,2.4vw,1.5rem);  }
.event_box .index_area .index_box .date { font-size:clamp(0.75rem, 1.3vw, 0.875rem); display:flex; flex-flow:row wrap; align-items:center; justify-content:flex-start; white-space:nowrap; padding-bottom:0.5rem; width:100%; }
.event_box .index_area .index_box .title { flex-grow:2; position:relative; padding:0; font-size:clamp(1rem, 1.8vw, 1.125rem); }
.event_box .index_area .index_box .comment { padding:0;}

body.event .index_area .index_box .photo { aspect-ratio:1/1.414;}
body.event .index_area .index_box .photo img { width:100%; height:100%; object-fit:cover; object-position:top; }



/*--ABOUT--*/
.about_area { padding-bottom:clamp(3rem, 10vw, 6rem); display:flex; flex-flow:row wrap; justify-content:space-between; align-items:flex-start; }
.about_area::before { content:""; width:120vw; height:120vw; background:radial-gradient(ellipse at center, rgba(255,102,136,0.1) 30%, rgba(255,102,136,0) 70%); position:absolute; right:clamp(-50rem,-60vw,-15rem); top:40vw; max-width:100rem; max-height:100rem; z-index:-10; }
.about_area h2 { position:relative; display:flex; width:100%; flex-flow:row wrap; justify-content:space-between; align-items:center; margin-bottom:clamp(1.5rem,5vw,3rem); }
.about_area h2::before { content:"MEDICAL OFFICE"; font-family:"garage-gothic", sans-serif; font-weight:700; font-style:normal; color:rgba(0,0,0,0.05); font-size:clamp(1.5rem,6vw,3.75rem); position:absolute; top:clamp(-3.5rem,-6vw,-1.75rem); left:0; line-height:1; letter-spacing:normal; }
.about_area h2 .bar { flex-grow:1; margin-left:1rem; border-bottom:1px solid; border-image:linear-gradient(to right, #08d 30%, #f68 90%) 1;}
.about_area h2 .more { display:block; padding:0 0 0 1.5rem; background:url("../img/i_arrow_rp.svg") left center /1rem no-repeat; }

.about_area .copy { background:linear-gradient(135deg, rgba(0,136,221,1) 20%,rgba(255,102,136,1) 60%); -webkit-background-clip:text; -webkit-text-fill-color:transparent; font-size:clamp(2rem,6vw,4rem); line-height:1.3; width:clamp(5rem,16vw,10rem); font-feature-settings:"palt"; opacity:0.85; z-index:100; white-space:nowrap; }

.about_box { width:80%; display:flex; flex-flow:row wrap; justify-content:space-between; }
.about_box .about_photo { margin-bottom:clamp(0.5rem,1.6vw,1rem); position:relative; }
.about_box .about_menu ul.menu { display:flex; flex-flow:row wrap; justify-content:space-between; list-style:none; padding:0; width:100%; margin-bottom:clamp(1.5rem,5vw,3rem); }
.about_box .about_menu ul.menu li { width:28%; }
.about_box .about_menu ul.menu li:first-child { width:33%; }
.about_box ul.menu li a { display:block; text-decoration:none; position:relative; border-bottom:1px solid rgba(0,0,0,0.15); padding:0.75rem 0; background:url("../img/i_arrow_r.svg") center right /1.5rem no-repeat; line-height:1.5; font-weight:300; }


/*--ABOUT_PROF--*/
.prof_menu { position:relative; width:30%; }
.prof_menu a, .staff_box ul li a { display:block; text-decoration:none; position:relative; padding:0 0 clamp(1rem,3vw,2rem) 0; line-height:1.5; font-weight:300;}
.prof_menu .photo, .staff_box ul li .photo { margin-bottom:0.75rem; aspect-ratio:3/4; }
.prof_menu .photo img, .staff_box ul li .photo img { width:100%; height:100%; object-fit:cover; }
.prof_menu .title, .staff_box ul li .title { font-size:clamp(0.75rem,1.4vw,0.875rem); letter-spacing:0.05rem; }
.prof_menu .name, .staff_box ul li .name { font-size:clamp(1rem,2.4vw,1.5rem); position:relative; }
.prof_menu ul.menu { list-style:none; padding:0; width:100%; }
.prof_menu ul.menu li { width:100%; }
.prof_menu ul.menu li a { border-bottom:1px solid rgba(0,0,0,0.15); padding:0.75rem 0; background:url("../img/i_arrow_r.svg") center right /1.5rem no-repeat; }

/*--ABOUT_STAFF--*/
.staff_box { position:relative; width:66%; }
.staff_box ul { list-style:none; display:flex; flex-flow:row wrap; justify-content:space-between; padding:0; margin:0 }
.staff_box ul li { width:29.5%; }



/*--MED--*/
.med_box { padding:clamp(1.5rem, 6vw, 4rem) 0; position:relative; display:flex; flex-flow:row wrap; justify-content:space-around; z-index:0; background:#999 url("../img/bg_med.webp") center center /cover no-repeat; }
.med_box .med_title h2 { position:relative; display:flex; align-items:center; max-width:80rem; margin:auto; padding:0 clamp(1.5rem, 5vw, 3rem); z-index:100; }
.med_box .med_title h2 .bar { flex-grow:1; margin-left:1rem; border-bottom:1px solid; border-image:linear-gradient(to right, #08d 30%, #f68 90%) 1;}

.med_box::after { content:""; position:absolute; top:0; right:0; bottom:0; left:0; background:linear-gradient(to right, rgba(0,136,221,1) 30%,rgba(255,102,136,1) 70%); z-index:10; mix-blend-mode:screen; }
.med_box .b_gts, .med_box .b_bes { display:flex; flex-flow:column nowrap; width:50%; max-width:30rem; padding:0 clamp(1.5rem, 5vw, 3rem); text-decoration:none; position:relative; z-index:100; min-height:25vw; color:#222; }
.med_box .b_gts .en, .med_box .b_bes .en { font-size:clamp(1.5rem,6vw,3.75rem); color:rgba(255,255,255,0.7); margin-top:auto; margin-bottom:0.5rem; }
.med_box .b_gts .btn, .med_box .b_bes .btn { font-size:clamp(0.875rem,2vw,1.25rem); background:rgba(255,255,255,0.7) url("../img/i_arrow_r.svg") center right clamp(0.5rem,3vw,1.5rem) /1.5rem no-repeat; padding:clamp(0.25rem,0.8vw,0.5rem) clamp(0.75rem,3vw,1.75rem); border-radius:3rem; margin:0 clamp(-1.5rem,-3vw,-0.75rem); }
.med_box .b_gts:hover .btn, .med_box .b_bes:hover .btn { background-color:rgba(255,255,255,0.9); }
.med_box .b_bes .en { text-align:right; }


/*--EDUCATION--*/
.edu_box { padding-bottom:clamp(3rem, 10vw, 6rem); padding-top:clamp(3rem, 10vw, 6rem); display:flex; align-items:flex-start; flex-flow:row wrap; justify-content:space-between; position:relative; }
.edu_box::after { content:""; position:absolute; top:0; left:0; right:0; bottom:clamp(5rem,15vw,10rem); background:linear-gradient(135deg, rgba(0,136,221,0.07) 30%,rgba(255,102,136,0.07) 70%); z-index:-10; }
.edu_box h2 { position:relative; display:flex; align-items:center; margin-bottom:clamp(1.5rem,5vw,3rem); z-index:100; }
.edu_box h2 .bar { flex-grow:1; margin-left:1rem; border-bottom:1px solid; border-image:linear-gradient(to right, #08d 30%, #f68 90%) 1;}
.edu_box .text { position:relative; }
.edu_box .copy, .edu_box .copy02 { position:relative; color:#fff; font-size:clamp(1.25rem,6vw,3rem); margin-bottom:clamp(1.5rem,5vw,3rem); line-height:1.3; font-feature-settings:"palt";z-index:100; white-space:nowrap; overflow:visible; }
.edu_box .copy { display:none; }
.edu_box .copy02 { /*position:absolute; left:-1px; top:-1px; background:linear-gradient(135deg, rgba(0,136,221,1) 20%,rgba(255,102,136,1) 60%); -webkit-background-clip:text; -webkit-text-fill-color:transparent; opacity:0.85;*/ color:#08d; display:flex; flex-flow:column wrap; justify-content:flex-start; align-items:flex-start; margin-left:-0.5rem; }
.edu_box .copy02 span { display:block; width:auto; padding:0.25rem 0.5rem; margin-bottom:clamp(0.25rem,0.8vw,0.5rem); background:rgba(255,255,255,0.9); }
/*.edu_box .copy02::after { content:""; position:absolute; top:0; right:0; bottom:0; left:0; background:#fff; z-index:-1; }*/
.edu_box ul { list-style:none; padding:0; margin-bottom:0; width:100%; }
.edu_box ul li { width:100%; }
.edu_box ul li a { display:block; text-decoration:none; position:relative; line-height:1.5; font-weight:300; border-bottom:1px solid rgba(0,0,0,0.15); padding:0.75rem 0; background:url("../img/i_arrow_r.svg") center right /1.5rem no-repeat; }
.edu_box .photo { margin-top:clamp(1rem,3vw,2rem); position:relative; }
.edu_box .photo::after { /*content:""; position:absolute; width:80%; height:80%; right:-5%; bottom:-5%; z-index:-1; background:linear-gradient(135deg, rgba(0,136,221,0.3) 50%,rgba(255,102,136,0.3) 90%);*/ }
.edu_box .photo::before, .about_box .about_photo::before { content:""; position:absolute; top:4px; right:4px; bottom:4px; left:4px; border:1px solid; border-image:linear-gradient(135deg, rgba(0,136,221,0.5) 50%,rgba(255,102,136,0.5) 90%) 1; }

/*--OTHER--*/
.other_box { padding:clamp(3rem, 10vw, 6rem) 0; display:flex; flex-flow:row wrap; justify-content:space-between; }
.other_box a { display:block; position:relative; width:30%; max-width:33rem; text-decoration:none; }
.other_box a .photo { width:100%; position:relative; aspect-ratio:1; }
.other_box a .photo::after { content:""; display:block; position:absolute; top:0; right:0; bottom:0; left:0; background:linear-gradient(to right ,rgba(255,255,255,1) 0, rgba(255,255,255,0) 30%); z-index:50; }
.other_box a .photo::before { content:""; position:absolute; top:0; right:0; bottom:0; left:0; background:linear-gradient(135deg,rgba(0,136,221,0.1) 70%, rgba(255,102,136,0.3) 100%); z-index:10 }
.other_box a .photo img { width:100%; height:100%; object-fit:cover; }
.other_box a::before { content:""; position:absolute; top:4px; right:4px; bottom:4px; left:4px; border:1px solid; border-image:linear-gradient(135deg, rgba(0,136,221,0.5) 50%,rgba(255,102,136,0.5) 90%) 1; z-index:50; }

.other_box a .en { position:absolute; right:clamp(-0.15rem,-0.24vw,-0.075rem); bottom:clamp(-0.5rem,-0.8vw,-0.25rem); text-align:right; font-size:clamp(1.75rem,5vw,3.75rem); color:rgba(255,255,255,0.8); line-height:0.9; z-index:100; }
.other_box a .title { writing-mode:vertical-rl; font-size:clamp(1.25rem,2.8vw,1.75rem); font-feature-settings:normal; position:absolute; top:clamp(-1.5rem,-2.4vw,-0.75rem); left:0; line-height:1; z-index:200; white-space:nowrap; }



/* ----------- Prev＆Next add */
.slick-prev { background:rgba(179,202,208,0.2); width:3rem; height:3rem; min-width:3rem; display:block; position:absolute; bottom:-5rem; left:1.25rem; margin:0; transition:all 0.2s; z-index:1000; border-radius:3rem; }
.slick-prev::after { border-left:2px solid #8fc21f; border-top:2px solid #8fc21f; border-right:none; content:""; display:block; width:0.8rem !important; height:0.8rem !important; position:absolute; top:calc(50% - 0.4rem); left:calc(55% - 0.4rem); z-index:1000; transform:rotate(-45deg); }

.slick-next { background:rgba(179,202,208,0.2); width:3rem; height:3rem; min-width:3rem; display:block; position:absolute; bottom:-5rem; left:4.75rem; margin:0; transition:all 0.2s; z-index:1000; border-radius:3rem; }
.slick-next::after { border-right:2px solid #8fc21f; border-top:2px solid #8fc21f; content:""; display:block; width:0.8rem !important; height:0.8rem !important; position:absolute; top:calc(50% - 0.4rem); left:calc(45% - 0.4rem); transform:rotate(45deg); }

.slick-prev:hover,
.slick-next:hover { background:rgba(179,202,208,0.5) }


/*--FOOTER--*/
.footer { font-size:clamp(0.875rem, 1.6vw, 1rem); line-height:1.5; padding-top:clamp(2rem,6vw,4rem); padding-bottom:clamp(2rem,6vw,4rem); position:relative; text-align:center; }
body.top .footer { margin-top:0; border:none; }

.footer .title { width:100%; display:flex; align-items:center; }
.footer .title a { margin:auto; }
.footer .title::before, .footer .title::after { content:""; flex-grow:1; border-bottom:1px solid rgba(0,0,0,0.15); margin-bottom:2rem; }
.footer .title::before { margin-right:2rem; }
.footer .title:after { margin-left:2rem; }
.footer .title img { width:100%; height:auto; }

.tel, .fax { display:inline-block; line-height:1.5; position:relative; }
.tel strong, .fax strong { font-size:clamp(1rem, 2.4vw, 1.5rem); font-weight:normal; font-weight:300;}
.tel.blue a { color:#08d; }

.copyright { width:100%; padding:0.25rem 0 0 0; letter-spacing:normal; font-size:clamp(0.75rem, 1.2vw, 0.8125rem); position:relative; z-index:-1; mix-blend-mode:multiply;}

.footer a.link { display:block; padding:0.75rem 0.75rem 0.75rem 1.5rem; text-decoration:none; }

.fm { display:flex; flex-flow:row wrap; justify-content:center; }
.fm ul { list-style:none; padding:0; margin:0; display:flex; flex-flow:row wrap; justify-content:space-between; }
.fm ul li { padding:0; max-height:14rem}
.fm a { display:flex; align-items:center; width:100%; height:100%; padding:0.75rem; margin:0; text-decoration:none; box-sizing:border-box; position:relative; overflow:hidden; font-weight:300; font-size:clamp(0.75rem,1.4vw,0.875rem); }

.fm a:hover, .fm a.active { }

/*body.contact .fm { display:none; } */

.pagetop { position:fixed; /*display:flex; flex-flow:column nowrap; justify-content:center;*/ bottom:0; right:0; width:3rem; font-size:0.875rem; height:8.5rem; padding-top:0.75rem; border-radius:1rem 0 0 0; text-decoration:none; writing-mode:vertical-rl; z-index:1000; color:rgba(0,0,0,0.7); display:flex; flex-flow:column nowrap; justify-content:center; }
.pagetop::before { content:"TOP"; }
.pagetop::after { content:""; position:absolute; top:1.25rem; left:1.5rem; bottom:0; margin-top:2rem; border-right:1px solid rgba(0,0,0,0.2); }
.pagetop:hover { opacity:0.7; }




/*-- TEMPLARE CONTENTS --*/
.text_area { width:100%; max-width:80rem; /*margin:auto;*/ }

.navibar { z-index:100; margin:0 0 0.5rem 0; padding:0; }
.navibar ul { display:flex; flex-flow:row wrap; justify-content:flex-end; margin:0; padding:0; font-size:clamp(0.75rem, 1.5vw, 0.8125rem); line-height:1.5; }
.navibar ul li { list-style-type:none; padding:0; max-width:15rem; display:inline-block; 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; }



.col2 { column-count:2; column-gap:clamp(0.5rem,3vw,2rem); }
.col3 { column-count:3; column-gap:clamp(0.5rem,3vw,2rem); }
.col4 { column-count:4; column-gap:clamp(0.5rem,3vw,2rem); }
.col2 li, .col3 li, .col4 li { break-inside:avoid; line-height:1.5;  }
.col2 li a, .col3 li a, .col4 li a { display: block;  padding:0.5rem 0; }

 .caption { color:#777; line-height:1.5; font-size:clamp(0.8125rem,1.4vw,0.9rem); padding-top:0.5rem; letter-spacing:0.025rem; }


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; }
a.link::after, a span.link::after { content:"."; width:0; color:transparent; margin-right:1px; white-space:nowrap; }
a.link::before, a span.link::before { content:""; position:absolute; left:0; top:calc(50% - 0.2rem); display:block; width:0.4rem; height:0.4rem; margin:0; border-top:1px solid #222; border-right:1px solid #222; transform:rotate(45deg); box-sizing:border-box; vertical-align:middle; }
a.link.active::after { border-top:1px solid #fff; border-right:1px solid #fff; transform:rotate(45deg); }
a.link.red { color:#e66; }

a.link .icon { display:inline-block; margin-right:0.5rem; vertical-align:middle; }

h5 a.link::before { top:1.3rem; }


ul.page-link { text-align:left; margin:0 -0.6rem 2rem -0.6rem !important; padding:0.5rem 0.5rem; display:flex; flex-flow:row wrap; justify-content:flex-start; position:relative; z-index:0; transition:0.25s; width:calc(100% + 1.2rem); max-width:80rem; overflow-x:auto; background:linear-gradient(135deg,rgba(241,249,254,0.9) 60%, rgba(255,238,242,0.9) 100%); /*border-top:1px solid #666; border-bottom:1px solid #666;*/ }
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:clamp(0.875rem, 1.5vw, 0.9rem); }
ul.page-link li a:hover { color:#08d;} 
ul.page-link li.active a, .index_box.active a .title { }
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 #222; border-right:1px solid #222; 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; }
ul.page-link.bottom { max-width:80rem; margin:2rem auto 4.5rem auto !important; padding:1rem 0 0 0; border-top:1px solid rgba(34,34,34,0.2); }
ul.page-link.bottom a::before { top:1.1rem; transform:rotate(-135deg); }
ul.page-link li a.index { pointer-events:none; padding-left:1rem; color:#08d; }
ul.page-link li a.index::before { display:none; }

ul.page-link.bg { position:sticky; top:7rem; /*transform:translate(-50%, 0);*/ z-index:2000; width:100%; flex-flow:row nowrap; }
/*ul.page-link.bg::after { content:""; background:rgba(255,255,255,0.9); position:absolute; top:0; right:0; left:0; bottom:0; }*/
ul.page-link.bg::after { content:""; position:absolute; top:0; right:0; }

h3.page_title + ul.page-link { margin:-1rem auto 1rem auto !important; }

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

.index_box { position:relative; width:50%; vertical-align:top; box-sizing:border-box; text-align:left; padding:0 1.5%; margin:0; transition:0.15s; }
.index_box a { display:flex; align-items:flex-start; padding:1.5rem 0; border-top:1px solid rgba(34,34,34,0.2); text-decoration:none; }
.index_box .photo { width:30%; min-width:clamp(6rem,16vw,10rem); margin-right:1rem; margin-bottom:0; aspect-ratio:1; }
.index_box .photo span { display:block; width:100%; padding-top:100%; position:relative; }
.index_box .photo img { width:100%; height:100%; object-fit:cover; font-family:'object-fit:cover;'; object-position:top; transition:0.15s; }
.index_box a:hover { text-decoration:none; opacity:1; }
/*.index_box a:hover strong { color:#08d; }
.index_box a:hover .text { color:#08d; }
.index_box a:hover .comment { color:#222; }*/

.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:#08d; color:#fff; padding:0 0.5rem; margin:0 0.5rem 0.5rem 0; border-radius:0.25rem; white-space:nowrap; }
.index_box .new { font-size:clamp(0.75rem, 1.3vw, 0.8rem); display:inline-block; padding:0 0.5rem; margin-right:0.5rem; background:linear-gradient(135deg, rgba(0,136,221,0.6) 20%,rgba(255,102,136,0.6) 80%); color:#fff; text-align:center; z-index:10; letter-spacing:normal; border-radius:2rem; }
.index_box .text { display:flex; flex-grow:1; flex-flow:column nowrap; padding:0; line-height:1.5; }
.index_box .date { font-size:clamp(0.75rem, 1.3vw, 0.8rem); display:none; }
.index_box .comment { display:block; line-height:1.5; margin-top:0.5rem; color:#666; }
.tag { display:flex; flex-flow:row wrap; padding:0.5rem 0 0 0; }
.index_box .title { display:block; align-items:flex-start; position:relative; line-height:1.6; font-weight:normal; }
.tag span { font-size:0.7rem; background:#222; color:#fff; padding:0 0.5rem 0.1rem 0.5rem; margin:0.5rem; text-align:center; border-radius:1rem; }

.index_box .text br, .hm li a br { /*display:none;*/ }
.index_box .text br.br, .index_box .text .comment br, .hm li a br.br { display:inline-block; }

.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,
.hm li .sub ul li a[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; }


.contents { display:flex; flex-flow:row wrap; justify-content:space-between; margin:0 auto; }
.contents .text_area { width:calc(100% - 10rem); }
.contents .side { width:8rem; }
.contents .side ul li { padding:0; line-height:1.5; margin-bottom:0.5rem; }

.mceContentBody img { height: auto; }

/*業績報告*/
body.results .contents .text_area { width:calc(100% - 16rem); }
body.results .contents .side { width:14rem; }
.contents .side ul.col4 { column-count:1; }
.contents .side ul.col3 { column-count: 1; }
.contents .side ul li a { padding: 0; }

/*お知らせ*/
body.info .contents { display:flex; flex-flow:row wrap; justify-content:space-between; max-width:80rem; margin:0 auto 5rem auto; }

body.info .index_area { }
body.info .side { display:inline-block; vertical-align:top; box-sizing:border-box; margin-right:auto; position:relative; z-index:1000; margin:0 ; }
body.info .side h5 { margin-top:0; margin-bottom:0.5rem; }
body.info .side ul { display:flex; flex-flow:row wrap; justify-content:flex-start; margin:0; padding:0 0 0 1rem; font-size:0.9rem; }
body.info .side ul li { padding:0; }
body.info .side ul li::marker { color:rgba(0,136,221,0.2); }


body.info .index_box { width:50%; margin:0; padding:0 1.5%; }
body.info .index_box a { display:flex; padding:1.5rem 0; border-top:1px solid rgba(34,34,34,0.2); }
body.info .index_box .date { display:block; font-size:0.75rem; padding-bottom:0.5rem; }
body.info .index_box strong::after { display:none; }
body.info .index_box .photo { width:clamp(5rem,16vw,10rem); height:auto; min-width:clamp(5rem,16vw,10rem); margin-right:1rem; margin-bottom:0; position:relative; }
body.info .index_box .text { padding:0; }
body.info .index_box .i_tag { font-size:0.8rem; left:0.5rem; display:none; }

body.info h3.page_title::after { display:none; }
body.info h3.page_title span { text-decoration:underline; text-decoration-thickness:0.8rem; text-decoration-color:rgba(0, 170, 170, 0.1); text-underline-offset:-0.4rem; text-decoration-skip-ink:none; }

body.links .index_box a { padding-left:1.25rem; position:relative; }
body.links .index_box a[target='_blank']::after { display:inline-block !important; }
body.links .index_box a::before { content:""; position:absolute; display:block; left:0; top:calc(50% - 0.25rem); width:0.5rem; height:0.5rem; margin:0; border-top:1px solid #222; border-right:1px solid #222; transform:rotate(45deg); box-sizing:border-box; }

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

ul.disc { list-style:disc; padding-left:1rem; }
ol.deci { list-style:disc; list-style:decimal; padding-left:1rem; }


.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:12rem; 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 #222; border-right:1px solid #222; 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 #222; border-left:1px solid #222; 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:#222; 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:#222; 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.15rem 0.5rem; border:1px solid #666; box-shadow:none; z-index:0; box-sizing:border-box; border-radius:0.25rem; background:rgba(255,255,255,0.5); }
input[type="text"] { margin:0 0.25rem 0 0; }
input.long { width:100%; margin:0; position:relative; }
button, a.btn, input[type="button"], input[type="submit"] { display:inline-block; 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; border:5px solid #7b8d42; border:none;*/ color:#fff !important; position:relative; text-decoration:none; text-align:center; transition:all .2s; box-sizing:border-box; cursor:pointer; border-radius:0.25rem; padding:0.5rem 2rem; background:#08d url("../img/i_arrow_rw.svg") right 0.75rem center /1.25rem no-repeat; border:1px solid #08d; }
input::placeholder, textarea::placeholder { color:#777; }

.b_back { display:inline-block; -webkit-appearance:none; overflow:visible; width:auto; background:#fff url("../img/i_arrow_l.svg") left 0.75rem center /1.25rem no-repeat; border:1px solid #08d; color:#333 !important;  }


button:hover, a.btn:hover, input[type="button"]:hover, input[type="submit"]:hover { text-decoration:none; filter:brightness(85%); color:#fff; }

button[disabled], a.btn[disabled], .button[disabled], input[type="button"][disabled], input[type="submit"][disabled],
button[disabled]:hover, a.btn[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.btn { padding-right:2rem; position:relative; }
/*a.btn::after, 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.btn[target='_blank']::after { right:-1rem; visibility:hidden; }

button.mini, .button.mini { min-width:0; }
input:focus, select:focus, textarea:focus { outline:none; box-shadow:0 0 3px rgba(0, 155,62, 1); border:1px solid #08d;}

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:#08d url("../img/i_arrow_rw.svg") right 0.75rem center /1.25rem no-repeat; color:#fff; border-radius:0.25rem; }
input.button:hover { background:#08d url("../img/i_arrow_rw.svg") right 0.75rem center /40px no-repeat; }




/*-- Radio and Checkbox/ --*/
input[type="radio"], input[type="checkbox"] { margin:0 0.25rem 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:calc(50% - 0.6rem); left:0; width:1.2rem; height:1.2rem; border:1px solid #222; border-radius:50%; z-index:5; margin-right:0.25rem; box-sizing:border-box; }
input[type="radio"] + span::after{ content:""; display:block; position:absolute; top:calc(50% - 0.1rem);; left:0.5rem ; width:0.2rem; height:0.2rem; background:#08d; border-radius:50%; z-index:10; transition:0.25s; opacity:0; }
input[type="radio"]:checked + span, input[type="checkbox"]:checked + span { color:#08d; }
input[type="radio"]:checked + span::before { border:1px solid #08d; }
input[type="radio"]:checked + span::after{ content:""; display:block; position:absolute; top:calc(50% - 0.4rem); left:calc(0.25rem - 1px); width:0.8rem; height:0.8rem; background:#08d; border-radius:50%; z-index:10; transition:0.25s; opacity:1; }
input[type="checkbox"] + span::before { content:""; display:block; position:absolute; top:calc(50% - 0.6rem); left:0; width:1.2rem; height:1.2rem; border:1px solid #666; border-radius:0.25rem; margin-right:0.25rem; box-sizing:border-box; }
input[type="checkbox"]:checked + span::after { content:""; display:block; position:absolute; top:calc(50% - 0.9rem); left:0.5rem; width:0.5rem; height:1.2rem; transform:rotate(40deg); border-bottom:2px solid #08d; border-right:2px solid #08d; 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; text-align:left; background:rgba(255,255,255,0.5) url(../img/i_pulldown.svg) right center /24px no-repeat; border:1px solid #666; padding:0.25rem 2rem 0.25rem 0.5rem; margin:0 2px 0 0; box-sizing:border-box; display:none; display:inline-block; border-radius:0.25rem; color:#222;}
select:disabled, select.disabled { border:1px solid rgba(0,0,0,0.2); color:rgba(0,0,0,0.2); color:silver; background:none; z-index:auto; }

/*.error, .required, .alert { color:#e66; }*/
div.error { background:rgba(238,102,102, 0.1); padding:0.25rem 0.5rem; margin:0; color:#e66; }
span.error { background:rgba(238,102,102, 0.1); padding:0.25rem 0.5rem; color:#e66; display:block; }

td.error input[type="text"], 
td.error textarea,
td.error select,
td.error label { border:1px solid #e66; color:#222; border-radius:0.25rem; }
td.error label { padding:0.25rem; }

td.error input:focus, td.error select:focus, td.error textarea:focus { outline:none; box-shadow:0 0 3px rgba(238,102,102, 1); border:1px solid #e66;}

.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.25rem 0.25rem 0; border-radius:0.25rem; line-height:1.5; }
.hissu::before { content:"必須";}
.ninni {display:inline-block; background:rgba(34,34,34,0.3); color:#fff; font-size:0.7rem; padding:0.1rem 0.25rem; vertical-align:middle; position:relative; margin:-0.1rem 0.25rem 0.25rem 0; border-radius:0.25rem; line-height:1.5; }
.ninni::before { content:"任意";}

.notice { background:rgba(0,136,221,0.05); padding:1rem 1.5rem; border-radius:0.5rem; }
.bg01 .notice { background:#fff; box-shadow:0 1rem 0.5rem -0.75rem rgba(34,34,34,0.05); }
.bg01 .grade { text-shadow:0 0.5rem 0.5rem rgba(34,34,34,0.05);}


/*--CONTACT--*/
body.contact .tab_menu,
body.contact .f_title,
body.contact .corp { 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 #222; line-height:1.7; }
.pp_box ol { /*padding-left:1.5rem;*/ }

.grecaptcha-badge { opacity:0; }

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


.w100 { width:100%; margin-right:0 !important; margin-left:0 !important; }
.w95 { width:95%; }
.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%; }
.w32 { width:32%; }
.w30 { width:30%; }
.w25 { width:25%; }
.w24 { width:24%; }
.w22 { width:22%; }
.w21 { width:21%; }
.w20 { width:20%; }
.w19 { width:19%; }
.w18 { width:18%; }
.w15 { width:15%; }
.w10 { width:10%; }
.w5 { width:5%; }

input.w75 { min-width:15rem; }
input.w50 { min-width:10rem; }
input.w33 { min-width:6.5rem; }
input.w25 { min-width:5rem; }
input.w20 { min-width:4rem; }
input.w10 { min-width:2rem; }
input.w5 { min-width:1rem; }


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



/*-- LIST/ --*/
ol { margin:0 0 2rem 0; padding:0 0 0 1.5rem; }
ol::marker { }
ol li{ padding:0; }
.value { background:#222; 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 li::marker { color:#08d; } 

ul.marker { list-style:disc; margin:0; padding-left:1rem; }
ul.marker li::marker { color:rgba(34,34,34, 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:#001A43; 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:clamp(0.9rem, 1.8vw,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:clamp(0.9rem, 1.8vw,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:clamp(0.9rem, 1.8vw,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(34,34,34,0.5); pointer-events:none; }


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

table { border-collapse:collapse; width:100%; margin:0 0 2rem 0; }
table th, table td { padding:clamp(0.5rem, 1.6vw, 1rem); letter-spacing:0.05rem; line-height:1.5; }

.table01 { border-bottom:1px dashed rgba(0, 38, 33, 0.1); }
.table01 th, .table01 td { border-top:1px dashed rgba(0,0,0,0.1); }
.table01 thead th { }
.table01 th {text-align:left; }
.table01 td { }

.table02, .deco-tb { border-bottom:1px solid rgba(0,0,0,0.15); }
.table02 th, .table02 td, .deco-tb th, .deco-tb td { border-top:1px solid rgba(0,0,0,0.15); }
.table02 thead th, .table02 thead td, .deco-tb thead th, .deco-tb thead td { background:rgba(0,136,221,0.05); }
.table02 th, .deco-tb th { text-align:left; /*white-space:nowrap; background:rgba(0,136,221,0.05);*/ }
.table02 td, .deco-tb td { }
.table02 th.tr, .deco-tb th.tr, .table02 td.tr, .deco-tb td.tr { width:auto; text-align:right;}


.table03 { background:rgba(255,255,255,0.5); border-spacing:0; border:1px solid rgba(0,0,0,0.15); }
.table03 th, .table03 td { border-right:1px dashed rgba(0,0,0,0.15); border-bottom:1px solid rgba(0,0,0,0.15); vertical-align:top; }
.table03 thead th { background:rgba(0,136,221,0.05); }
.table03 thead td { background:rgba(0,136,221,0.05); }
.table03 tbody tr:last-of-type th, .table03 tbody tr:last-of-type td { border-bottom:none; }

.table03 th.vm, .table03 td.vm, .table03 tr.vm th, .table03 tr.vm td { vertical-align:middle; }

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




/*-- 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; }
body 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(0,0,0,0.1) !important; }
.l_dashed th, .l_dashed td { border-top:1px dashed rgba(0,0,0,0.1) !important; }
th p, td p { /*margin:0;*/ }

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

table.fixed_column { background:#fff; }
.fixed01{ position:sticky; left:0; background:rgba(255,255,255,0.95); border-collapse:separate; }
.fixed01:before{ content:""; position:absolute; top:-1px; left:-1px; width:calc(100% + 2px); height:100%; border-top:1px solid rgba(0,0,0,0.1); border-left:1px solid rgba(0,0,0,0.1); border-right:1px dashed #e5e5e5; }
tr.l_double th.fixed01 { border-top:3px double rgba(0,0,0,0.1) !important; }
.table02 thead th.fixed01, .table03 thead th.fixed01 { background:#f2faf5; }


/*-- 幅の広いテーブルにスクロール表示 --*/
.scroll { overflow:auto; max-width:calc(100vw - 2rem); position:relative; }
.scroll::-webkit-scrollbar { height:6px;}
.scroll::-webkit-scrollbar-track { background:rgba(0,0,0,0); }
.scroll::-webkit-scrollbar-thumb { background:rgba(34,34,34,1); background:#bbb; border-radius:3px; opacity:0.5; }
.scroll::-webkit-scrollbar-thumb:hover { background:rgba(34,34,34,1); background:#bbb; border-radius:3px; opacity:0.5; }

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




.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; }



#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 { border:none; }
body.modal .article { padding:1.5rem; display:block; }
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 }



/*--PAGENATION--*/
.pagination-holder { margin:0 auto 4rem auto; }

#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.25rem; margin:0;}
.simple-pagination ul li a { display:block; background:#fff; }
span.ellipse.clickable { cursor:pointer; }
.ellipse input { width:3em; }

.light-theme a, .light-theme span { cursor:pointer; display:block; text-align:center; color:#222; font-size:0.9rem; line-height:calc(2.5rem - 2px); font-weight:normal; letter-spacing:normal; border:1px solid #222; min-width:2.5rem; height:2.5rem; padding:0 0.5rem; 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:#222; color:#FFF; border-color:#222; 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:#222; }
.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; }


.bg01 { position:relative; display:flex; flex-flow:row wrap; justify-content:space-between; width:100%; padding:0; right:0; }

.material-icons { vertical-align:middle; }


noprint { pointer-events:none; }

/*--診療科紹介--*/
ul::marker { color:rgba(143,194,31,0.5); }
ul.sub_list { margin-bottom:2rem; }
ul.sub_list li { list-style:none; font-size:clamp(0.875rem,1.6vw, 1rem); line-height:1.5; padding:0; /*display:inline-block;*/ }
ul.sub_list li a { display:block; width:100%; padding:0.5rem 1rem 0.5rem 2rem; text-align:left; text-decoration:none; position:relative; line-height:1.5; background:url("../img/i_arrow_r.svg") left center /1.5rem no-repeat; }

.material-symbols-outlined { vertical-align:middle; margin:-0.15rem 0.1rem 0 0; font-size:inherit; }
.f_ll .material-symbols-outlined { font-size:clamp(1.5rem, 3.2vw, 2rem); margin-top:-0.4rem; }

video { vertical-align:bottom; }

/*タブ*/
.tab { display:flex; flex-flow:row nowrap; margin:0; padding:0 1rem; position:relative; z-index:0; }
.tab li { position:relative; z-index:10; padding:clamp(0.5rem, 1.2vw, 0.75rem) clamp(1rem, 2.4vw, 1.5rem); text-decoration:none; line-height:1.25; white-space:nowrap; cursor:pointer; border:1.5px solid rgba(0,0,0,0); border-bottom:none; margin-bottom:-1px; margin-right:clamp(0.5rem,1.6vw,1rem); background:rgba(0,0,0,0.05); }
.tab li span.f_ll { font-size:clamp(1.5rem, 3.2vw, 2rem); letter-spacing:0.25rem; }
.tab li.select { border-color:#222; /* border-color:rgba(143,194,31,1); color:#08d;*/ background:none; }


.tab_content { overflow:hidden; padding:0; margin:0; list-style:none !important; transition:0.5s; }
.tab_content > li { padding:1rem 0; margin:0; display:none; }
.tab_content > li.is_show { display:block; }



/*業績報告*/
body.results ol {}
body.results ol li { margin-bottom:1rem; line-height:1.75; }


.site_preview { background:rgba(0,136,221,0.15); padding:1.5rem 1rem; justify-content:space-around; margin:0 -1.5rem; }
.site_preview div { border-radius:clamp(0.5rem, 1.6vw, 1rem); overflow:hidden; }


body.temp #colorbox.staff #cboxPrevious, 
body.temp #colorbox.staff #cboxNext { display:none !important; }

ul.flow_box {}
ul.flow_box li { display:flex; flex-flow:row wrap; align-items:flex-start; position:relative; padding-left:1.5rem; padding-bottom:2rem; }
ul.flow_box li::after { content:""; height:100%; position:absolute; top:1rem; left:calc(0.5rem - 2px); border-left:4px solid #f9f9f9; z-index:1; }
ul.flow_box li h4 { }
ul.flow_box li::before { content:""; width:1rem; height:1rem; position:absolute; left:0; top:0.6rem; border-radius:4rem; background:#08d; z-index:10; }
ul.flow_box li.no::before { display:none; }
ul.flow_box li .w70, ul.flow_box li .w75 { padding-bottom:clamp(1rem,3vw,2rem); border-bottom:1px dashed #ccc; }
ul.flow_box li:last-of-type::after { display:none; }


/*外来担当医表*/
.table.thoracic .deco-tb, .table.breast .deco-tb { border:1px solid rgba(0,0,0,0.15); margin:0 0 1rem 0; }
.table.thoracic .deco-tb th, .table.thoracic .deco-tb td,
.table.breast .deco-tb th, .table.breast .deco-tb td { width:auto !important; border-right:1px dashed rgba(0,0,0,0.1); }


body.temp .article::before { content:""; position:fixed; top:0; left:0; bottom:0; right:0; background:linear-gradient(240deg, rgba(0,136,221,0) 70% ,rgba(0,136,221,0.1)100%); z-index:-100; }
body.temp .article::after { content:""; position:fixed; top:0; left:0; bottom:0; right:0; background:linear-gradient(120deg, rgba(255,102,136,0) 70% ,rgba(255,102,136,0.1)100%); z-index:-1; }
body.temp .w25 + .w75 { padding-top:0.5rem; }

/*医局紹介*/
body.temp .staff_box { width:100%; font-weight:300; }
body.temp .staff_box p { font-weight:400; }
body.temp .staff_box .photo { margin-bottom:0.75rem; aspect-ratio:3/4; }
body.temp .staff_box .photo img { width:100%; height:100%; object-fit:cover; }
body.temp .staff_box .title { font-size:clamp(0.75rem,1.4vw,0.875rem); letter-spacing:0.05rem; line-height:1.5; }
body.temp .staff_box .name { font-size:clamp(1rem,2.4vw,1.5rem); position:relative; line-height:1.5; }
body.temp .staff_area { width:104%; margin:0 -2%; display:flex; flex-flow:row wrap; justify-content:flex-start; }
body.temp .staff_area .staff { width:25%; padding:0 2% 5% 2%; }

a.staff_modal { text-decoration:none; }
a.staff_modal .name { padding-right:1rem; background:url("../img/i_arrow_r.svg") right center /1.5rem no-repeat; }

.photo_box { margin-bottom:1rem; font-weight:300; /*align-items:flex-end;*/ }
.photo_box .photo { position:relative; margin-bottom:1rem; overflow:hidden; }
.photo_box .text { position:relative; margin-bottom:1rem; overflow:hidden; display:flex; flex-flow:column wrap; justify-content:flex-end;}
.photo_box .text .title { font-size:clamp(0.75rem,1.6vw,1rem); display:block; margin:1rem 0 0.75rem 0; line-height:1.5; }
.photo_box .text .name { font-size:clamp(1.5rem,4vw,2.5rem); position:relative; line-height:1.25; }
.photo_box .text .name rt { font-size:0.75rem; /*margin-bottom:0.25rem;*/ letter-spacing:normal; }
.photo_box .text .photo { margin-bottom:auto; }

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



/*呼吸器外科*/
body.gts::after { content:""; position:fixed; top:0; left:0; bottom:0; right:0; z-index:-100; }
body.gts h2:not(.page_title), body.gts h4 { color:rgba(0,136,221,0.8); mix-blend-mode:multiply; }
body.gts ul.page-link { background:linear-gradient(to right, rgba(241,249,254,0.9) 70%, rgba(255,255,255,0.9)100%); }
/*body.gts .table02 th,*/ body.gts .table03 th, .table.thoracic .deco-tb th { background:rgba(0,136,221,0.05);}


/*乳腺内分泌外科*/
body.bes::after { content:""; position:fixed; top:0; left:0; bottom:0; right:0; z-index:-100; }
body.bes h2:not(.page_title), body.bes h4 { color:rgba(255,102,136,0.8); mix-blend-mode:multiply; }
/*body.bes .table02 th,*/ body.bes .table03 th, .table.breast .deco-tb th { background:rgba(255,102,136,0.05); }
body.bes ul.page-link { background:linear-gradient(to right, rgba(255,238,242,0.9) 70%, rgba(255,255,255,0.9)100%); }
body.bes ul.page-link li a:hover { color:#f68;} 
body.bes ul.flow_box li::before { background:#f68; z-index:10; }
body.bes ul li::marker { color:#f68; } 

body.gts .page_title, body.bes .page_title { /* width:100vw; margin:0 calc(50% - 50vw); padding:8vw calc(50vw - 50%);*/ margin:0 calc(50% - 50vw) 0 0; padding:8vw 0; width:auto; }
body.gts .page_title { background:url(../img/h_gts.png) right center /cover no-repeat; }
body.bes .page_title { background:url(../img/h_bes.png) right center /cover no-repeat; }
body.gts .page_title .bar { flex-grow:1; margin-left:1rem; border-bottom:1px solid; border-image:linear-gradient(to right, rgba(0,136,221,1) 30%,rgba(0,136,221,0) 90%)1; mix-blend-mode:multiply; }
body.bes .page_title .bar { flex-grow:1; margin-left:1rem; border-bottom:1px solid; border-image:linear-gradient(to right, rgba(255,102,136,1) 30%,rgba(255,102,136,0) 90%)1; mix-blend-mode:multiply; }

body.gts .page_title::after, body.bes .page_title::after { font-family:"garage-gothic", sans-serif; font-weight:700; font-style:normal; color:rgba(255,255,255,0.7); font-size:clamp(1.75rem,6vw,4rem); position:absolute; bottom:0.5vw; right:2vw; line-height:1; letter-spacing:normal; text-transform:uppercase; z-index:50; }
body.gts .page_title::after { content:"General Thoracic Surgery"; }
body.bes .page_title::after { content:"Breast and Endocrine Surgery"; }



/*ロボット支援手術*/
.davinciStyle div.hr { border-bottom:5px solid #fafafa; width:100%; height:5px; margin:50px 0; }
.davinciStyle h3 { color:#7046bc; border:none; }
.davinciStyle h3.first { margin:0 0 20px; }
#mainContents.davinci h3, #mainContents.davinci h4, #mainContents.davinci h5, #mainContents.davinci h6 { color:#7046bd; }
.davinciStyle table.deco-tb { text-align:left; border-collapse:collapse; border:1px solid #cccccc; margin:0 auto; }
.davinciStyle table.deco-tb th.t_top { border-top:5px solid #7046bc; }
.davinciStyle table.deco-tb td.t_top { border-top:5px solid #7046bc; }
.davinciStyle table.deco-tb th { background-color:#e4dfed; /*color:#343434;padding:8px 10px; border:1px dotted #cccccc;*/ }
.davinciStyle table.deco-tb td { border:1px dotted #cccccc; /*padding:8px 10px; background-color:#fff;*/ }
.davinciStyle table.feature td { padding:20px; width:32%; vertical-align:top; /* border-top:3px solid #eeeeee; */ color:#ffffff; font-weight:bold; background:#7046bc; border:5px solid #7046bc; border-radius:5px; }
.davinciStyle table.feature td.empty { width:1%; border:none; background:none; }
.davinciStyle table.feature { margin-bottom:40px; }
.davinciStyle div.bg { background:url(https://www.med.tottori-u.ac.jp/thoracicsurg/files/16144.jpg) no-repeat; }
.davinciStyle h4.middle { color:#7046bc; }
.davinciStyle h5.feature { /*border-left:5px solid #ffe94e;*/ }
.davinciStyle h5.feature span { font-weight:normal; }
.davinciStyle div.chigaibg { background:url(https://www.med.tottori-u.ac.jp/thoracicsurg/files/47064.jpg) no-repeat right top; background-size:500px; mix-blend-mode: multiply; }
.davinciStyle div.meritbg { background:url(https://www.med.tottori-u.ac.jp/thoracicsurg/files/47065.jpg) no-repeat right top; background-size:500px; mix-blend-mode: multiply;}
.davinciStyle ul.shikkan { list-style:none; margin-bottom:40px; }
.davinciStyle ul.shikkan li { background:url(https://www.med.tottori-u.ac.jp/thoracicsurg/files/16224.jpg) no-repeat 0 2px; padding:0 0 0 25px; float:left; margin-right:20px; }
.davinciStyle ul.shikkan li a { color:#343434; }
.davinciStyle p.alert { color:#e40040; }
.davinciStyle h4.question { /*border-bottom:2px solid #cccccc; font-size:115%; font-weight:bold; margin-bottom:10px; padding:0;*/ }
.davinciStyle p.answer { margin-bottom:30px; }
.davinciStyle p.link { /*background:url(https://www.med.tottori-u.ac.jp/thoracicsurg/files/16224.jpg) no-repeat 0 1px; padding:0 0 0 25px; margin:0 0 10px 0;*/ }
.davinciStyle p.link.last { /*margin:0 0 40px 0;*/ }
.davinciStyle p.link a { /*background:none; padding:0; display:inline; */ }
.davinciStyle .console { background:url(https://www.med.tottori-u.ac.jp/thoracicsurg/files/47068.jpg) center center /cover no-repeat ; aspect-ratio:920/600; display:block; mix-blend-mode:multiply; }
.davinciStyle .patient { background:url(https://www.med.tottori-u.ac.jp/thoracicsurg/files/47070.jpg) center center /cover no-repeat ; aspect-ratio:920/480; display:block; mix-blend-mode:multiply; }
.davinciStyle .vision { background:url(https://www.med.tottori-u.ac.jp/thoracicsurg/files/47072.jpg) center center /cover no-repeat ; aspect-ratio:920/400; display:block; mix-blend-mode:multiply; }


/* ダビンチ又はロボット手術 当科のロボット手術の特徴 */
.feature-point { width:920px; height:400px; position:relative; font-size:21px; line-height:1.5; }
.feature-point-description.number-01 { position:absolute; left:110px; top:60px; z-index:1; }
.feature-point-description.number-02 { position:absolute; left:110px; top:170px; z-index:1; }
.feature-point-description.number-03 { position:absolute; left:110px; top:290px; z-index:1; }
.feature-point-description span { background:#fee351; font-weight:bold; }
.feature-point-bg img { position:absolute; top:0; left:0; display:block; z-index:0; }
.new-feature-point .bg { font-size:18px; padding-top:10px; padding-bottom:10px; text-align:center; vertical-align:bottom; box-sizing:border-box; border:3px solid #6f3a7e; border-radius:10px; max-width: 24rem; }
.new-feature-point .bg div.icon { display:block; vertical-align:middle; text-align:center; }
.new-feature-point .bg div.icon img { margin-left:auto; margin-right:auto; display:inline; width:125px; mix-blend-mode:multiply}
.new-feature-point .bg span { font-size:42px; font-weight:bold; vertical-align:middle; position:relative; top:-8px; }
.new-feature-point .bg span.note { font-size:16px; font-weight:bold; color:#7046bd; position:relative; top:0; }


/* 教育研修 */
.bg_light_yellow { background: rgba(245,223,77,0.07); }
.bg_light_blue { background: rgba(0,136,221,0.07); }
.bg_pink { background: rgba(238,102,102,0.07); }
.bg_orange { background: rgba(241,171,95,0.07); }
.bg_green { background: rgba(0,187,102,0.07); }




@media screen and (max-width:1080px) {
.hm { display:none; }
}





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

.pc_no { display:block; }
br.pc_no, span.pc_no { display:inline; }
.sp_no, br.sp_no { display:none; }
span.sp_no { display:none; }
	
.img_pc { display:none; }
.img_sp { display:block; }

body.temp .article { flex-flow:column wrap; padding:5.5rem clamp(1.5rem, 5vw, 3rem) 1rem clamp(1.5rem, 5vw, 3rem); }
body.temp .article.bg { padding-top:7rem; }

.anchor { height:10rem; margin-top:-10rem; }

.header { position:fixed; width:100%; max-width:100%; top:0; left:0; right:0; margin:0; transform:translate(0,0); height:6.5rem; }
.header .inner { padding:1rem 1.25rem; margin:0 auto; display:flex; align-items:center; justify-content:flex-start; box-sizing:border-box; }
.header .logo { width:4rem; margin-right:1rem; }
.header .logo2 { width:12rem; mix-blend-mode:multiply; }
.header .bar { display:none; }




.sticky { position:sticky; top:7rem; }


/*--MAIN--*/
.main .title, .main .scroll { display:none; }
.movie-wrap { position:relative; width:100%; padding-bottom:56.25%; margin:0; }
.movie-wrap iframe { position:absolute; top:-20%; left:-20%; width:140%; height:140%; filter:brightness(1.4); }
/*.movie-wrap::after { content:"SAMPLE"; position:absolute; left:0.5rem; bottom:0; opacity:0.5; font-size:1.5rem; color:#fff; }*/
div#slider { position:relative; left:0; top:auto; margin-top:1.75rem; margin-bottom:3rem; padding:0 1.25rem; height:auto; width:100%; max-width:500px; overflow:hidden; }
div#slider ul { position:relative; left:0; top:0; width:90%; max-width:500px; }
div#slider ul li { white-space:nowrap; position:absolute; left:0; top:0; }
div#slider ul li img { width:100%; position:relative; transition:1s; margin-left:100px; opacity:0.0; }
div#slider ul li.flex-active-slide img { margin-left:0; opacity:1; }


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


/*--INFO--*/
.info_box .index_area { flex-flow:row nowrap; overflow-x:auto; margin-right:clamp(-3rem,-5vw,-1.5rem); padding-right:calc(clamp(1.5rem,5vw,3rem) - 2.5%); }

/*--ABOUT_PROF--*/
.prof_menu { display:flex; flex-flow:row wrap; /*width:calc(100% - clamp(7rem,18vw,15rem));*/ width:100%; }
.prof_menu .professor { width:45%; }
.prof_menu ul.menu { width:50%; margin-left:auto; }
.staff_box { width:100%; }



/*--MED--*/
.med_box .b_gts, .med_box .b_bes { height:48vw; }


/*--EDUCATION--*/
.edu_box .photo { margin-top:clamp(3rem,9vw,6rem); position:absolute; right:0;width:95%; }
.edu_box .copy { display:block; aspect-ratio:7/5; margin:0 clamp(-3rem,-5vw,-1.5rem) clamp(1rem,3vw,2rem) 0; }
.edu_box .copy span { display:none; }
.edu_box .copy02 { position:absolute; top:calc(68vw - clamp(7rem,26vw,16rem)); right:-1rem; align-items:flex-end; z-index:100; }


/*--FOOTER--*/
.footer { }

ul.page-link { }
ul.page-link.bg { top:6.5rem; width:calc(100% + clamp(1.5rem,5vw,3rem)); margin-right:clamp(-3rem,-5vw,-1.5rem) !important; }
ul.page-link li a { }
ul.page-link li a::before { top:0.8rem; }


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


h3.page_title + .date { margin-top:0; } 

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


/*-- INDEX --*/
ul.index_area { }
body.page ul.index_area { }

.index_box { width:50%; }
.index_box:nth-of-type(2n) { margin-right:0; }
.index_box:nth-of-type(3n) { margin-right:0; }
.index_box:nth-of-type(6n) { margin-right:0; }

.index_box .tag { display:flex; flex-flow:row wrap; justify-content:flex-end; padding:1rem 1rem 1rem 0.5rem; }
.index_box .tag span { background:#222; color:#fff; padding:0 0.25rem 0 0.45rem; margin-left:0.5rem; text-align:center; line-height:1.8; }


body.info .index_box { width:100%; padding:0; }
body.info .index_box a { padding:1rem 0; }
body.info .index_box .photo { width:clamp(5rem,12vw,7.5rem); min-width:clamp(5rem,12vw,7.5rem); margin-right:0.75rem; }

body.links .index_box { width:100%; }

body.edu .index_box, body.research .index_box { width:33%; }

a.link::before, a span.link::before { top:0.6rem; }
.f_s a.link::before, .f_s a span.link::before { top:0.5rem; }
h5 a.link::before { top:0.7rem; }


.col2 { column-count:1; }
.col3 { column-count:2; }
.col4 { column-count:3; }
.resp_col2 { column-count:2 !important; }

.contents .side ul.col4 { column-count:4; }
.contents .side ul.col3 { column-count:3; }


ul.sub_list li { display:inline-block; }

/*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:100%; }
.alignright img, .alignleft img { margin:auto; }

.resp100 { width:100% !important; }
.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; }

.resp66 { width:66.6% !important; }
.resp33 { width:33.3% !important; }
.resp49 { width:49% !important; }
.resp32 { width:32% !important; }

.resp_no { display:none; }
.resp_ma { margin:auto !important; }
.resp_column { flex-flow:column wrap; }

a.link, a span.link { padding:0.1rem 0.15rem 0.1rem 0.8rem;}

.m.link { padding:0.25rem 0 0.25rem 0.8rem; }


.notice { padding:0.75rem 1rem; }




.table01:not(.noresp) th, .table02:not(.noresp) th
/*, .deco-tb:not(.noresp) th*/ { display:inline-block; width:100%; padding:1rem 0 0 0; background:none; }
.table01:not(.noresp) td, .table02:not(.noresp) td,
/*.deco-tb:not(.noresp) td { display:inline-block; width:100%; border-top:none; padding:0.5rem 0; }*/

.deco-tb.noresp th, .deco-tb.noresp td { display:table-cell; width:auto; }

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

.graph_box.drinking_scene img { width:1000px; min-width:1000px; margin-top:0.5rem; margin-bottom:1rem; }


body.modal .w25.resp50.resp_ma { width:25% !important; margin:0 !important; }
body.modal .w70.resp100 { width:70% !important; }


/*外来担当医表*/
.table.thoracic, .table.breast { overflow-x:auto; }
.table.thoracic .deco-tb th, .table.thoracic .deco-tb td,
.table.breast .deco-tb th, .table.breast .deco-tb td { white-space:nowrap; }

body.temp .staff_area .staff { width:33.33%; }


.svg-wrap svg { position:absolute; width:6rem; top:calc(45% - 3rem); left:calc(50% - 3rem); fill:none; animation:svg_tr0_sp 2.0s forwards;}

}

@keyframes svg_tr0_sp { 
0% { transform:translate(0, 0); opacity:1; }
70% { transform:translate(0, 0); opacity:1; width:6rem; }
100% { transform:translate(-35vw, -35vh); opacity:0; width:5rem; }
}







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

br.sp_no2 { display:none; }
br.pc_no2 { display:inline; }
span.pc_no2 { display:block; }

.main ul.slick { width:100%; }
.main .copy { position:relative; top:-5vw; font-size:clamp(2.2rem,8vw,5rem); width:clamp(17rem,65vw,38rem); /*margin-bottom:clamp(1.5rem,5vw,3rem);*/ } 
.main ul.slick::before { right:50%; }
.main ul.slick::after { content:""; background:linear-gradient(to bottom, rgba(255,255,255,0) 10%,rgba(255,255,255,1) 100%); position:absolute; top:85%; left:0; bottom:0; right:0%; z-index:20; }
.main .slick .caption { padding:1.25rem 1rem; }

.slick-dots { flex-flow: column nowrap; top:50%; bottom: auto; transform: translate(0,-50%);}


.index_box { width:100%; }

.event_box .index_area .index_box .photo { width:100%; margin-bottom: 0.5rem; }
.event_box .index_area .index_box .text { width:100%; padding-left:0;  }

table th, table td { padding:0.75rem 0.3rem; }

.navibar { margin:0 0 0.75rem 0; }

.h_contact li a span { display:none;}


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

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

.contents .side ul.col4 { column-count:3; }
.contents .side ul.col3 { column-count:2; }



.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%; }

body.modal .w25.resp50.resp_ma { width:50% !important; margin:auto !important; }
body.modal .w70.resp100 { width:100% !important; }


body.temp .staff_area .staff { width:50%; }


}

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

/*--ABOUT--*/
.about_area .copy { width:100%; writing-mode:horizontal-tb; font-size:clamp(2.2rem,8vw,5rem); margin-bottom:clamp(1.5rem,5vw,3rem); }
.about_box { width:100%; }
/*.prof_menu { width:50%; flex-flow:column wrap; margin:0 auto clamp(2rem,6vw,4rem) auto; }
.prof_menu .professor { width:100%; }
.prof_menu ul.menu { width:100%; margin-left:auto; }*/
.staff_box ul li { /*width:47%;*/ }

.header { height:5.5rem; }
.t_title { max-width:20rem; }
ul.page-link.bg { top:5.5rem; }

.other_box a { width:80%; margin: 0 auto 2rem auto; }

.contents .side ul.col4 { column-count:2; }
.contents .side ul.col3 { column-count:1; }

}


@media print {
body { background:none; }
.fadeinUp_once, .fadeinDown_once { opacity:1; transform:translate(0, 0); }
.main { margin:0; }
.info_area { }
.noprint { display:none; }
.header { position: absolute; padding-left:0; padding-right: 0; }
.hm { display:none !important; position: absolute;  }
.text_area { width:100%; max-width:100%; }
.mean-bar { display:none; }
.article { padding-left:0; padding-right: 0; }
h2.page_title::after { display:none; }

}