/* 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}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 { scroll-behavior:auto; overflow-x:clip; }
body { font-family:"urw-din", "Noto Sans JP", sans-serif; color:#555; position:relative; font-size: clamp(0.9rem, 1.6vw, 1rem); line-height:2.2; letter-spacing:0.04rem; overflow-x:clip; margin:0; padding:0; -webkit-text-size-adjust:100%; -ms-text-size-adjust:100%; font-feature-settings:"palt"; box-sizing:border-box; }
.article::after { content:""; display:block; position:fixed; top:0; left:0; z-index:-1; width:100%; height:100vh; background: #fff url(../img/logo.svg) bottom right /60vw no-repeat; opacity: 0.03; }

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


.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; }
span.fw_n { font-weight:normal; }
.lh100 { line-height: 1; } 
.lh125 { line-height: 1.25; } 
.lh150 { line-height: 1.5; } 
.lh200 { line-height: 2; } 
.lsn { letter-spacing:normal; }

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


.yellow {color:#fc6;}
.red {color:#c35;}
.blue { color:#1d2088;}
.purple { color:#6355a1; }
.gray { color:gray;}

p { margin-bottom: 2rem; }
p:empty { display:none; }
hr { background: none; border: none; border-bottom: 1px solid #333; }
ul { padding:0 0 0 1.25rem; margin:0 0 1rem 0; }

.full { margin-left:calc(50% - 50vw); margin-right:calc(50% - 50vw); }
.full02 { margin-left:calc(50% - 45vw); margin-right:calc(50% - 45vw); }
.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:13rem; margin-top:-13rem; position:relative; z-index:-10; width:1px; }
body.logged-in .anchor { height:15rem; margin-top:-15rem; }

.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; }
.mb64 { margin-bottom:4rem !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; }
.mt-8 { margin-top:-0.5rem !important; }

.ma { margin: auto; }

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


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



.article { width:100%; max-width:90rem; padding:6rem clamp(1rem, 12vw, 10rem) 0 clamp(5rem, 12vw, 10rem); margin:0 auto; box-sizing:border-box; position:relative; }
body.top .article { padding-top:0;}
body.archive .article, body.single .article, body.error404 .article,
body.page-isharyo_test .article { padding-top:clamp(6.5rem,12vw,13rem); }


/*--HEADER--*/
.header { height:6rem; margin:0 auto; position: fixed; top:0; left:0; right:0; transition:0.2s; z-index: 1000; background:rgba(255,255,255,1); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); padding:1.25rem clamp(3rem,10vw,6rem); display:flex; flex-flow: row wrap; justify-content: flex-end; box-sizing: border-box; align-items:center; }
.header .title { width:25%; max-width:calc(20rem + clamp(5rem,12vw,6rem)); min-width:10rem; position: absolute; padding:clamp(1rem,2.8vw,1.75rem) clamp(1rem,2.8vw,1.75rem) clamp(1rem,2.8vw,1.75rem) clamp(5rem,12vw,6rem); top:0; left:0; background:#fff; }
.tel, .fax { display:block; position: relative; line-height:1.25; }
.header .tel { line-height: 1; margin-top:-0.2rem; }
.tel strong, .fax strong { font-size:clamp(1.4rem, 3vw, 1.8rem); font-weight: normal; }
.tel .tel_hours { font-size: 0.8125rem; margin-top: 0.5rem; }

.header .tel { /*margin-right: 5rem;*/ }

.rsv_box { flex-flow:row wrap; justify-content: space-between; width:100%; }
.rsv_box .b_rsv { background:rgba(3,7,122,0.9); position: relative; display: flex; align-items: center; padding:0 clamp(1.5rem,3vw,2rem) 0 clamp(0.75rem,1.6vw,1rem); color:#fff; text-decoration: none; font-size:clamp(0.8125rem,1.6vw,1rem); height:4rem; cursor:pointer; line-height:1.4; }
.header .rsv_box { width:calc(100% - 3.5rem); max-width:9rem; margin-left:1rem; margin-right:1.5rem; /*position: fixed; top:clamp(1rem,2.8vw,1.75rem); right:18rem; z-index: 1100;*/ }
.header .rsv_box > li { width:100%; }
.header .rsv_box .b_rsv { height:3.25rem; border-top:1px solid #fff; border-bottom:1px solid #fff; }
.rsv_box .b_rsv::before, .rsv_box a::before { content:""; display: block; width:0.7rem; height: 0.7rem; border-top: 1px solid #fff; border-right: 1px solid #fff; transform: rotate(45deg); position: absolute; right:1rem; top:calc(50% - 0.35rem); }
.rsv_box a::after { display:none !important; }

.b_rsv.b_tel { display:none; }

body.logged-in .header {top:32px;}
body.logged-in .header + .rsv_box {top:calc(clamp(1rem,2.8vw,1.75rem) + 32px);}


/*--HEADER MENU--*/
.hm { /*position: fixed; top:1.75rem; left:50%; transform: translate(-50%, 0); */ margin-left:auto; z-index: 100000; }

.hm > ul { padding:0; margin:0; display:flex; flex-flow:row nowrap; align-items: center; list-style: none; }
.hm > ul > li { display:block; margin: 0; position: relative; transition:0.25s;}
.hm > ul > li > a { display: flex; flex-flow: row nowrap; justify-content: center; align-items: center; padding:0.5rem 0.75rem; width:100%; font-weight: 400; text-decoration: none; letter-spacing:0.05rem; position: relative; font-feature-settings:normal; transition:0.25s; white-space: nowrap; font-size:0.9375rem; }
.hm > ul > li > a::after { content: ""; width:0; height:0; position: absolute; top:80%; left:50%; right:50%; margin: auto; border-bottom:1.25px solid #1d2088; transition:0.5s; }
.hm > ul > li:hover > a, .um > ul > li.active > a, .hm > ul > li.active > a { color:#1d2088; }
.hm > ul > li:hover > a::after, .um > ul > li.active > a::after, .hm > ul > li.active > a::after { width: auto; right:0.75rem; left:0.75rem; }

.hm li .sub, .rsv_box .sub { visibility: hidden; opacity: 0; position:absolute; top:4rem; left:calc(50% - 6.5rem); 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:100%; }
.hm li:hover .sub::before { content: ""; display: block; height:8rem; width:0.25rem; position: absolute; top:-2.5rem; left: calc(50% - 2px); }
.hm li .sub > ul, .rsv_box .sub ul { display:flex; flex-flow:column wrap; margin:0; padding:0.5rem 0; text-align: left; background:rgba(3,7,122,0.9); /*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, .rsv_box .sub ul a { display: block; width:100%; padding:0.75rem 1rem 0.75rem 2.5rem; text-align: left; text-decoration: none; position:relative; line-height: 1.5; color:#fff; font-size:0.9375rem; border:none; background:none; }
.hm li .sub ul li a::after /*, .rsv_box .sub ul a::before*/ { content:""; display: block; width:0.6rem; height: 0.6rem; border-top: 1px solid #fff; border-right: 1px solid #fff; transform: rotate(45deg); position: absolute; left:1rem; top:calc(50% - 0.3rem); }
.hm li .sub ul li a:hover { color:#fff; }
.um li .sub ul li a.active { position: relative; color:#1d2088; font-weight: 500; }
.hm li .sub ul li a[target='_blank']::after { top:-0.1rem; }

.hm > ul > li.um_contact { margin-left: 2rem; }

.hm > ul > li.hm_contact > a, 
.hm > ul > li.hm_lang > a, 
.hm > ul > li.sns_fb > a, 
.hm > ul > li.sns_ig > a { padding:1rem 0.5rem ; }
.hm_contact img,
.hm_lang img,
.sns_fb img,
.sns_ig img { width: 2rem; }

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

a.nolink { pointer-events: none; }

.rsv_box .sub { left:0; width:12rem; }
.rsv_box .sub ul a { padding:0.75rem 2.5rem 0.75rem 1rem;}
.rsv_box > li:hover .sub, .rsv_box .b_rsv.active .sub { visibility: visible; opacity:1; top:100%; z-index: 1000; box-shadow:none; }


/*--MAIN--*/
.main { position: relative; margin-top:6rem; }
.main .inner { position: relative; width:calc(100% - clamp(6rem,20vw,12rem)); height:calc(100vh - clamp(6rem,20vw,12rem)); max-height:calc((100vw/16)*9); min-height:45vw; margin: auto; }
.main .inner .main_img { height:100%; overflow: hidden; }
.main .inner .main_img video { width:100%; height:100%; object-fit: cover; object-position: center; font-family: 'object-fit: cover;'; filter: hue-rotate(10deg), contrast(200%); }
.main .inner .main_img img { width: 100%; height: 100%; object-fit: cover; object-position: center; max-width:100vw; position: relative; z-index: 0; }

.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 .info_box { width: 90%; max-width:24rem; position: absolute; bottom:2rem; left:clamp(-6rem,-10vw,-3rem); padding: 0; z-index: 100;}
.main .info_box a { display: flex; padding: 1rem clamp(1rem,3vw,2rem); color: #fff; font-size:0.875rem; background: rgba(0,0,0,0.8); text-decoration: none; position: relative; }
.main .info_box a::after { content:""; display: block; width:0.7rem; height: 0.7rem; border-top: 1px solid #fff; border-right: 1px solid #fff; transform: rotate(45deg); position: absolute; right:1rem; top:calc(50% - 0.35rem); }
.main .info_box a .date { letter-spacing: 0.1rem; margin-right:clamp(1rem,3vw,2rem); }
.main .info_box a .title { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.main .info_box a:hover .title { text-decoration: underline; }

.main .hours_box { width: 90%; max-width:24rem; position: absolute; bottom:2rem; right:clamp(-6rem,-10vw,-3rem); padding: clamp(1rem, 4.8vw, 2rem); z-index:10; }
.main .hours_box img { width: 100%; /*fill:#fff;*/ filter: brightness(0) saturate(100%) invert(100%) sepia(0%) saturate(0%) hue-rotate(0deg) brightness(100%) contrast(100%); }
.main .hours_box::before { display: block; content: ""; position: absolute; top:0; right:0; left:0; bottom:0; /*background: rgba(0,88,165,0.9);*/ background:rgba(3,7,122,0.9) url(../img/logo_w.svg) bottom right /60vw no-repeat fixed; mix-blend-mode: multiply; z-index: -1; }

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-weight:400; }
h1 { font-size:clamp(1.5rem, 3.2vw, 2.25rem); margin-bottom:clamp(1rem, 3.2vw, 2rem); font-weight:300;}
h2 { font-size:clamp(1.4rem, 3.2vw, 2rem); margin-bottom:clamp(1rem, 3.2vw, 2rem); position: relative; display: flex; align-items: center; flex-flow: row nowrap; }
h3 { font-size:clamp(1.3rem, 2.8vw, 1.75rem); margin-bottom:clamp(1rem, 3.2vw, 2rem); position: relative; display: flex; align-items: center; flex-flow: row nowrap; }
h4 { font-size:clamp(1.2rem, 2.4vw, 1.5rem); margin-bottom:clamp(0.5rem, 1.6vw, 1rem); position: relative; display: flex; align-items: center; flex-flow: row nowrap;}
h5 { font-size:clamp(1.1rem, 2vw, 1.25rem); margin-bottom:clamp(0.5rem, 1.2vw, 0.75rem); position: relative; display: flex; align-items: center; flex-flow: row nowrap; }
h6 { font-size:clamp(1.0rem, 1.6vw, 1rem);; margin-bottom: 0.5rem; }


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.cate_title + .date, h3.page_title + .date { display: block; text-align: right; margin-top:clamp(-2rem,-3vw,-1rem); color: #1d2088; }
h2.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; }


h3.flex.jcc.tc, .blue_box h3 { margin-bottom: 3rem; }
h3.flex.jcc.tc::after { content: ""; width:2rem; border-bottom:1px solid #333; position: absolute; left:calc(50% - 1rem); bottom:clamp(-1.25rem,-2.5rem,0.6rem); }
.blue_box h3::after { content: ""; width:2rem; border-bottom:1px solid #fff; position: absolute; left:0; bottom:-1.25rem; }
.blue_box h3.flex.jcc.tc::after {border-bottom:1px solid #fff; }

a.more { text-decoration:none; }

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

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


h3 hr, h4 hr, h5 hr { border-bottom: 1px solid rgba(29,32,136,0.2); }
.blue_box h3 hr, .blue_box h4 hr, .blue_box h5 hr { border-bottom: 1px solid rgba(255,255,255,0.2); }

.sticky h2 { margin: auto; width:100%; white-space: nowrap; }

.section { display: flex; flex-flow: row wrap; align-items: flex-start; }
.section h2 { writing-mode: vertical-rl; }


.about_box { padding: clamp(2rem,10vw,8.75rem) 0; letter-spacing:0.15rem; }
.about_box .photo img { width:100%; max-width: 100vw; }
.about_box .text { font-size:clamp(0.8125rem,1.4vw,0.875rem); display: flex; flex-flow: column wrap; justify-content:center; }
.about_box .text h2 { font-size:clamp(1.5rem,3vw,1.875rem); line-height: 1.8; }
.about_box .text p { margin-bottom:clamp(2rem,8vw,5rem); }
.about_box .text a.more { width: auto; position: relative; }
.about_box .text a.more .en { font-size: 1.75rem; display:inline-block; line-height: 1.5; letter-spacing:0.2rem; padding-right:7rem; background: url("../img/arrow_r.svg") center right /5.625rem no-repeat; position: relative; }
.about_box .text a.more .ja { position: relative; }
.about_box .text a.more .en::after { content: ""; display: block; z-index:1; width:3rem; height:3rem; border:2px solid rgba(29,32,136,0.1); position: absolute; right:-1.3rem; bottom:-0.4rem; border-radius: 2rem; }

.treat_box { padding-bottom:clamp(1rem,5vw,4.75rem); position: relative; }
.treat_box .inner { position: relative; }
.treat_box .title_box { position: absolute; top:0; left:clamp(-9rem,-10vw,-4rem); writing-mode: vertical-rl; color:#1d2088; display: flex; flex-flow: column wrap; align-items: flex-start; justify-content:center; line-height: 1.5; }
.treat_box .title_box .ja { font-size: clamp(1.25rem,3vw,2.5rem); order: 2; margin-left: auto; display: block; letter-spacing: 0.3rem; }
.treat_box .title_box .en { display: none; }
.treat_box .index_box .title_box { aspect-ratio:3/2; display: flex; flex-flow: row wrap; align-items: center; justify-content: center; writing-mode: vertical-rl; line-height: 1.5; padding:clamp(1rem,2.5vw,3rem); }
.treat_box .index_box { padding:clamp(0.5rem,2vw,1.5rem); margin-bottom:clamp(0.5rem,2vw,1.5rem); }
.treat_box .index_box a { padding:0; display: flex; flex-flow: row wrap; justify-content: space-between; position: relative; }
.treat_box .index_box a img { aspect-ratio:3/2; width:100%; height:100%; max-width:100vw; object-fit: cover; }
.treat_box .index_box .title { }
.treat_box .index_box .title .ja { display: block; font-size:clamp(0.9375rem,2vw,1.375rem); }
.treat_box .index_box .title .en { font-size: clamp(0.6875rem,1.6vw,1rem); } 
.treat_box .index_box .more { display: block; position: absolute; right:-0.5rem; bottom:0; height:1rem; width:4rem; background: url("../img/arrow_r.svg") center right /5.625rem no-repeat; text-align: right; margin-top: auto; margin-bottom:0.25rem; }
.treat_box .index_box .more::after { content: ""; display: block; z-index:1; width:3rem; height:3rem; border:2px solid rgba(29,32,136,0.1); position: absolute; right:-1.3rem; bottom:-1.2rem; border-radius: 2rem; }


.parts_box { padding-top:clamp(1.5rem,5vw,4.75rem); padding-bottom:clamp(1.5rem,5vw,4.75rem); background:rgba(208,222,240,0.5); }
.parts_box .inner { position: relative; }
.parts_box h2 { color:#1d2088; }
.parts_box .title_box .ja { font-size: clamp(1.25rem,3vw,2.5rem); order: 2; margin-left: auto; display: block; letter-spacing: 0.3rem; }
.parts_box .icon { width: 100%; padding:5%; aspect-ratio:1; border-radius: 50%; background:#fff; }
h4 .icon { width:4rem; padding:0; aspect-ratio:1; border-radius: 50%; background:#fff; margin-right:0.5rem; box-sizing:border-box; }
h4 .icon img { width:4rem;}

/*気になる箇所*/
.parts_icon { text-align: center; margin:0 -1.5%; }
.parts_icon ul { }
.parts_icon ul li { text-align: center; width: 12.5%; padding:0 clamp(0.25rem,1vw,0.5rem); margin-bottom:clamp(0.5rem,1.6vw,1rem); }



.condi_box { padding: clamp(1rem,5vw,4.75rem) 0; }
.condi_box .inner { position: relative; }
.condi_box .title_box { position: absolute; top:0; left:clamp(-9rem,-10vw,-4rem); writing-mode: vertical-rl; color:#1d2088; display: flex; flex-flow: column wrap; align-items: flex-start; justify-content:center; line-height: 1.5; }
.condi_box .title_box .ja { font-size: clamp(1.25rem,3vw,2.5rem); order: 2; margin-left: auto; display: block; letter-spacing: 0.3rem; }
.condi_box .title_box .en { display: none; }
.condi_box ul { display: flex; flex-flow: row wrap; justify-content: space-between; list-style: none;}
.condi_box ul li { margin-bottom:clamp(1rem,5vw,4rem); }
.condi_box ul li a { display: block; color:#0058a5; text-align: center;}
.condi_box ul li .icon { border-radius: 10rem; background:rgba(208,222,240,0.5); margin-bottom:clamp(0.25rem,0.8vw,0.5rem); padding:15%; }
.condi_box ul li .icon img { width: 100%; }

body.temp .condi_box { padding: clamp(1.5rem,5vw,3rem) 0; }


.faci_box { padding-top: clamp(2rem,10vw,8.75rem); padding-bottom:clamp(1rem,5vw,4.75rem); /*background:rgba(3,7,122,0.9) url(../img/logo_w.svg) bottom right /60vw no-repeat fixed;*/ position: relative; display: flex; flex-flow: row wrap; justify-content: space-between; color:#fff; clip-path: inset(0 0 0 0); }
.faci_box::after { content:""; position:fixed; top:0; left:0; width:100%; height:100vh; background:rgba(3,7,122,0.9) url("../img/logo_w.svg") bottom right /60vw no-repeat; z-index:-1; }
.faci_box .inner { position: relative; }
.faci_box .title_box { position: absolute; top:0; left:clamp(-9rem,-10vw,-4rem); writing-mode: vertical-rl; color:#fff; display: flex; flex-flow: column wrap; align-items: flex-start; justify-content:center; line-height: 1.5; }
.faci_box .title_box .ja { font-size: clamp(1.25rem,3vw,2.5rem); order: 2; margin-left: auto; display: block; letter-spacing: 0.3rem; }
.faci_box .title_box .en { font-size: clamp(0.75rem,1.5vw,1.75rem); order: 1; margin-right: auto; display: none; }

.faci_box .index_area { justify-content:space-between;}
.faci_box .index_box a { display: flex; flex-flow: column wrap; color:#fff; position: relative; }
.faci_box .index_box a:hover {color:#fff; }
.faci_box .index_box .title { color:#fff;}
.faci_box .index_box.blt {}
.faci_box .index_box.blt .photo { }
.faci_box .index_box .photo img { /*aspect-ratio:12/5;*/ width: 100%;}
.faci_box .index_box .title { width:100%; font-size:clamp(1.25rem,3vw,2rem); }
.faci_box .index_box .comment { width:100%; display: flex; flex-flow: row wrap; align-items:center; font-size:clamp(0.75rem,2vw,1.25rem); }
.faci_box .more { display: block; height:1rem; width:4rem; background: url("../img/arrow_rw.svg") center right /5.625rem no-repeat; text-align: right; /*margin-top:clamp(-2rem,-3vw,-1.75rem); margin-bottom:0.25rem;*/ margin-left: auto; }
.faci_box .more::after { content: ""; display: block; z-index:1; width:3rem; height:3rem; border:2px solid rgba(255,255,255,0.2); position: absolute; right:-1.3rem; bottom:-0.75rem; border-radius: 2rem; }


/*施設紹介 イメージビューワー*/
.smartphoto { z-index:100000; background:none; }
.smartphoto::after { content:""; display:block; position:fixed; top:0; left:0; z-index:-99999; width:100%; height:100vh; background:rgba(0,0,0,0.85) url(../img/logo_w.svg) bottom right /60vw no-repeat; }
.smartphoto-header { padding:0.5rem; height:4rem; background:none; }
.smartphoto-caption { top:0.5rem; font-size:1rem; line-height:3rem; }
.smartphoto-count{ font-size:0.8125rem; line-height:3rem; padding:0 0.5rem; }
.smartphoto-dismiss { top:0; min-width:3rem; width:3rem; height:3rem; right:0; }
.smartphoto-arrow-right, .smartphoto-arrow-left { background:none; }

/*Instagram*/
.skyblue_box.ig_box h3 img { width:50%; max-width:15rem; margin:auto; }
h3 .icon_ig { width:2rem; height:2rem; margin-right:0.75rem; }
h3 .icon_ig img { width:100%; height:100%; }




.info_box { padding-top: clamp(2rem,10vw,8.75rem); padding-bottom: clamp(2rem,10vw,8.75rem); position: relative; }
.info_box .inner { position: relative; min-height:12rem; }
.info_box .title_box { position: absolute; top:0; left:clamp(-9rem,-10vw,-4rem); writing-mode: vertical-rl; color:#1d2088; display: flex; flex-flow: column wrap; align-items: flex-start; justify-content:center; line-height: 1.5; min-height:12rem;}
.info_box .title_box .ja { font-size: clamp(1.25rem,3vw,2.5rem); order: 2; margin-left: auto; display: block; letter-spacing: 0.3rem; }
.info_box .title_box .en { font-size: clamp(0.75rem,1.5vw,1.75rem); order: 1; margin-right: auto; display: none; }

.info_box ul { list-style: none; border-top:1px solid #555; margin:0; padding:0; }
.info_box ul li { border-bottom:1px solid #555;} 
.info_box ul li a { display: flex; padding:clamp(1rem,3vw,2rem) 1.5rem; text-decoration: none; position: relative; }
.info_box ul li a::after { content:""; position: absolute; right:1rem; top:calc(50% - 0.5rem); width:4.5rem; height: 1rem; background: url("../img/arrow_r02.svg") center right /3.5rem no-repeat; text-align: right; margin-top: auto; }
.info_box ul li a .date { margin-right:clamp(1rem,3vw,2rem); color:#1d2088;}
.info_box ul li a .title { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; flex-grow: 1; padding-right:3rem; }
.info_box ul li a:hover .title { text-decoration: underline; }
.info_box .more { padding:1rem; text-align: right; display:block; }


.access_box { position: relative; }
.access_box .inner { position: relative; }
.access_box .title_box { position: absolute; top:0; left:clamp(-9rem,-10vw,-4rem); writing-mode: vertical-rl; color:#1d2088; display: flex; flex-flow: column wrap; align-items: flex-start; justify-content:center; line-height: 1.5;}
.access_box .title_box .ja { font-size: clamp(1.25rem,3vw,2.5rem); order: 2; margin-left: auto; display: block; letter-spacing: 0.3rem; }
.access_box .title_box .en { font-size: clamp(0.75rem,1.5vw,1.75rem); order: 1; margin-right: auto; display: none; }

.access_box .map_box { margin-bottom:clamp(1rem,8vw,5rem);}
.access_box .rsv_box { max-width: 40rem; margin:0 0 clamp(0.5rem,2vw,1rem) 0; }
.access_box .tel { font-size:clamp(1.25rem,2.5vw,1.75rem); /*margin-bottom:clamp(0.5rem,2vw,1rem);*/ }
.access_box .tel strong { font-size:clamp(2rem,3.5vw,2.75rem); }
.access_box .tel_hours { font-size: clamp(0.75rem,1.4vw,0.8125rem); line-height: 1.7; margin-bottom:clamp(1rem,3vw,1.5rem);}
.access_box .hours_box img, .footer .hours_box img { width: 100%; /*fill:#333;*/ filter: invert(32%) sepia(0%) saturate(3%) hue-rotate(223deg) brightness(96%) contrast(89%);}
body.top .footer .rsv_tel { display: none; }




.youtube { width:100%; max-width:60rem; background:#fff; aspect-ratio:16/9; border-radius:0; overflow: hidden; margin-bottom:clamp(0.5rem,1.2vw,0.75rem); }
.youtube iframe{ aspect-ratio:16/9; width:100%; height:100%; filter: brightness(1.1) saturate(120%);}
.youtube::before { content: "SAMPLE"; color: rgba(255,255,255,0.4); position: absolute; right:0; bottom:0; z-index: 30; font-size:clamp(1rem,5vw,3rem); font-weight: bold; line-height: 1; }

/*--FOOTER--*/
.footer { line-height: 1.5; /*margin-top:clamp(3rem,9.6vw,6rem);*/ padding-top:clamp(2rem,8vw,4rem); position: relative; display:flex; flex-flow:column wrap; justify-content: center; align-items:center; border-top:1px solid rgba(208,222,240,0.5); }
.footer .title { width:50%; max-width:15rem; margin-bottom:clamp(2rem,6vw,4rem); }
.footer .logo img { width: 100%; height: auto; }
.footer .address { font-size: 0.8125rem; }


.fm { margin:0 0 3rem 0 !important; padding:0; }
.fm li { display: inline-block; }
.fm li a { display: block; text-decoration: none; padding:0.5rem; }
.fm li a::after { /*content: "/ "; margin:0 0.5rem; font-weight: 200;*/ }
.fm li:last-child a::after { display: none; }

.copyright { 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; padding-bottom:clamp(1.5rem,5vw,3rem); }

.footer a.link { display: block; padding:0.75rem 0.75rem 0.75rem 1.5rem; text-decoration: none; }
.footer a.link::before { content:""; position:absolute; display:block; left:0; top:calc(50% - 0.3rem); width:0.6rem; height:0.6rem; margin:0; border-top:2px solid #1d2088; border-right:2px solid #1d2088; transform:rotate(45deg); box-sizing:border-box; }



.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"; text-shadow:1px 1px 0 rgba(255,255,255,0.8); }
.pagetop::after { content:""; position:absolute; top:1.25rem; left:1.5rem; bottom:0; margin-top:2rem; border-right:1px solid rgba(0,34,51,1); box-shadow:1px 0 0 rgba(255,255,255,0.8); }
.pagetop:hover { opacity: 0.7; }



/*-- TEMPLARE CONTENTS --*/
.hero { width:100%; max-width:68rem; display:flex; flex-flow:row wrap; justify-content:space-between; position: relative; margin:0 auto clamp(2rem,6vw,4rem) auto; z-index: 50; }
.hero .photo { width:100%; aspect-ratio:3/2; }
.hero .photo img { width:100%; max-width: 100vw; aspect-ratio:3/2; object-fit: cover;}
.hero h2.cate_title { background:rgba(3,7,122,0.9); margin-left: calc(50% - 50vw); padding:1rem 1.75rem 1rem calc(48vw - 50%); position: absolute; top:clamp(9rem,30vw,20rem); color: #fff; }
.hero h2.page_title { flex-flow: row wrap; border-left: 0.25rem solid #555; padding:clamp(2rem,6vw,4rem) 0 0 clamp(1rem,3vw,2rem); width:100%; margin-bottom:0; }
.hero h2.page_title .ja { width: 100%; }
.hero h2.page_title .en { width: 100%; font-size: clamp(0.75rem,1.8vw,1.125rem); order: 1; margin-right: auto; letter-spacing: normal; }

/*body.info h2.cate_title { color:#1d2088; }*/
body.info h2.cate_title { background:rgba(3,7,122,0.9); margin-left: calc(50% - 50vw); padding:1rem 1.75rem 1rem calc(50vw - 50%); display:inline-block; color: #fff; }

body.page-isharyo_test h2.cate_title { position:relative; top:0;}

.text_area { width:100%; max-width:75rem; margin: auto; }

.skyblue_box { background:rgba(208,222,240,0.5); padding-top:clamp(2rem,6vw,4rem); padding-bottom: clamp(2rem,6vw,4rem); position: relative; clip-path: inset(0 0 0 0); }
.blue_box { /*background:rgba(3,7,122,0.9) url(../img/logo_w.svg) bottom right /60vw no-repeat fixed;*/ color:#fff; padding-top:clamp(2rem,6vw,4rem); padding-bottom: clamp( 2rem,6vw,4rem); position: relative; clip-path: inset(0 0 0 0); }
.blue_box::after { content:""; position:fixed; top:0; left:0; width:100%; height:100vh; background:rgba(3,7,122,0.9) url("../img/logo_w.svg") bottom right /60vw no-repeat; z-index:-1; }

.blue_box a { color:#fff; }
.blue_box a .more { display: block; height:1rem; width:4rem; background: url("../img/arrow_rw.svg") center right /5.625rem no-repeat; text-align: right; margin-top: auto; margin-bottom:0.25rem; }

.dummy_photo { aspect-ratio:3/2; background: #eee; display: flex; justify-content: center; align-items: center; }
.dummy_photo.tate { aspect-ratio:2/3; }
.hero .dummy_photo { aspect-ratio:2/1; }

.navibar { padding:0; margin-bottom:1rem;}
.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(1.5rem,5vw,3rem); }
.col3 { column-count:3; column-gap:clamp(1.5rem,5vw,3rem); }
.col4 { column-count:4; column-gap:clamp(1.5rem,5vw,3rem); }


.caption { color: #777; line-height: 1.5; font-size: clamp(0.8125rem,1.4vw,0.9rem); padding-top:0.5rem; letter-spacing:0.025rem; }
.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; }
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 #555; border-right:1px solid #555; 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:#c35; }
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 auto 2rem auto !important; padding:0.5rem 0; display:flex; flex-flow:row wrap; justify-content:flex-start; position: relative; z-index: 0; transition:0.25s; width:100%; overflow-x: auto; }
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:#1d2088;} 
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 #555; border-right:1px solid #555; transform:rotate(45deg); box-sizing:border-box; }
ul.page-link li.active a::before { }
.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:70rem; 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:#1d2088; }
ul.page-link li a.index::before { display: none; }

ul.page-link.bg { position: sticky; top:8rem; z-index: 900; background:rgba(255,255,255,0.8); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); flex-flow:row nowrap; width:100%; }
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 --*/
.index_area { display:flex; flex-flow:row wrap; justify-content:flex-start; align-items: flex-start; padding:0; margin:0 clamp(-1.5rem,-2vw,-0.5rem); position: relative; }

.index_box { position:relative; width:50%; vertical-align:top; box-sizing:border-box; text-align:left; padding:0 clamp(0.5rem,2vw,1.5rem); margin-bottom:clamp(1.5rem,5vw,3rem); 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: 100%; min-width: 10rem; margin-bottom: 1rem; }
.index_box .photo img { width:100%; aspect-ratio:3/2; object-fit: cover; font-family:'object-fit:cover;'; transition:0.15s; }
.index_box a:hover { text-decoration:none; opacity:1; color:#555; }


.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:#1d2088; 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; background:#ff8e65; color:#fff; text-align:center; z-index:10; }
.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); /*color: #1d2088;*/ display: none; }
.index_box .comment { font-size:clamp(0.75rem, 1.5vw, 0.9rem); display: block; line-height: 1.7; margin-top:0.5rem; }
.tag { display:flex; flex-flow:row wrap; padding:0.5rem 0 0 0; }
.index_box .title { display:block; align-items:flex-start; position: relative; color:#555; line-height:1.5; font-weight:normal; font-size:clamp(1.25rem, 2vw, 1.375rem); }
.tag span { font-size:0.7rem; background:#555; 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:#128649; 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:#1b61c3; 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;*/ }

.news_box ul li a[href*='.pdf']::after,
.news_box ul li a[href*='.xlsx']::after,
.news_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, .index_area.info { border-top: 1px solid #555; margin:0 0 2rem 0; }
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; margin-right: 2rem; }
body.info .side ul li::marker { color:rgba(99,85,161,0.2); }

body.info .index_box, body.event .index_box, .index_area.info .index_box { width:100%; margin:0; padding:0; border-bottom: 1px solid #555; }
body.info .index_box a, body.event .index_box a, .index_area.info .index_box a { display:flex; align-items:center; padding: clamp(1rem,3vw,2rem) 1.5rem; /*border-top:1px solid rgba(34,34,34,0.2);*/ }
body.info .index_box a::after, .index_area.info .index_box a::after { content:""; position: absolute; right:1rem; top:calc(50% - 0.5rem); width:4.5rem; height: 1rem; background: url("../img/arrow_r02.svg") center right /3.5rem no-repeat; text-align: right; margin-top: auto; }

body.info .index_box .date, body.event .index_box .date, .index_area.info .index_box .date { display:block; margin-right: clamp(1rem,3vw,2rem); color: #1d2088; font-size: clamp(0.9rem, 1.6vw, 1rem); }
body.info .index_box .title, body.event .index_box .title, .index_area.info .index_box .title { font-size: clamp(0.9rem, 1.6vw, 1rem); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; flex-grow: 1; padding-right:3rem; }
body.info .index_box strong::after, body.event .index_box strong::after, .index_area.info .index_box strong::after { display: none; }
body.info .index_box .photo, body.event .index_box .photo, .index_area.info .index_box .photo { width: 25vw; height: auto; min-width: 5rem; max-width: 10rem; margin-right: 1rem; margin-bottom: 0; position: relative; }
body.info .index_box .text, body.event .index_box .text, .index_area.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(99,85,161, 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 #555; border-right:1px solid #555; transform:rotate(45deg); box-sizing:border-box; }

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

ul.disc { list-style: disc; padding-left: 1rem; }
ul.disc li { line-height:1.5; padding:0.25rem 1rem 0.25rem 0.25rem; }

.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:10rem; 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 #555; border-right:1px solid #555; 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 #555; border-left:1px solid #555; 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:#555; 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:rgba(3,7,122,0.9); 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 !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; 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: url("../img/arrow_rw.svg") right 0.75rem center /1.25rem no-repeat, linear-gradient(to right, rgb(99,85,161) 0%,rgb(143,194,31) 100%); ;}
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:#555 !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 #555; border-right:2px solid #555; transform:rotate(45deg); box-sizing:border-box; }

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 #1d2088;}

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:#1d2088 url("../img/arrow_rw.svg") right 0.75rem center /1.25rem no-repeat; color: #fff; border-radius:0.25rem; }
input.button:hover { background:#1d2088 url("../img/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 #555; 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:#1d2088; border-radius:50%; z-index:10; transition:0.25s; opacity:0; }
input[type="radio"]:checked + span, input[type="checkbox"]:checked + span { color:#1d2088; }
input[type="radio"]:checked + span::before { border:1px solid #1d2088; }
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:#1d2088; 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 #1d2088; border-right:2px solid #1d2088; 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:#555;}
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:#c35; }*/
div.error { background:rgba(238,102,102, 0.1); padding:0 0.5rem; margin:0; color:#c35; }
span.error { background:rgba(238,102,102, 0.1); padding:0 0.5rem; color:#c35; display:block; }

td.error input[type="text"], 
td.error textarea,
td.error select,
td.error label { border:1px solid #c35; color:#555; 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 #c35;}

.example { color:#777; white-space:nowrap; }


.hissu { display: inline-block; background:#c35; 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(171,220,246,0.1); background: rgba(99,85,161,0.1); */ background: linear-gradient(135deg, rgba(99,85,161,0.07) 0%,rgba(171,220,246,0.1) 100%); padding: 1rem 1.5rem; }
.notice.red_box { background: rgba(204,51,85,0.05);}
.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: #c35; 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:#c35; }
.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 #555; 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%; }
.w31 { width: 31%; }
.w30 { width: 30%; }
.w25 { width: 25%; }
.w24 { width: 24%; }
.w22 { width: 22%; }
.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:#555; 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:#1d2088; } 

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:#be3455; }
.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:#1d2088;}
.q.i_close { /*font-weight: bold;*/ color:#1d2088; }
.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:#1d2088; 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); }
.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.25rem, 1.2vw, 0.75rem) 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(208,222,240,0.5); }
.table02 th, .deco-tb th { text-align:left; /*white-space:nowrap;*/ background:rgba(208,222,240,0.5); }
.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.1); }
.table03 th, .table03 td { border-right:1px dashed rgba(0,0,0,0.1); border-bottom:1px solid rgba(0,0,0,0.1); vertical-align: top; }
.table03 thead th { background:rgba(208,222,240,0.5); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); }
.table03 thead td { background:rgba(208,222,240,0.5); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); }
.table03 tbody tr:last-of-type th, .table03 tbody tr:last-of-type td { border-bottom: none; }
.table03 tbody th { text-align:left; border:1px solid #ddd; background:rgba(208,222,240,0.5); color:#555; }
.table03 tbody td { border:1px solid #ddd; letter-spacing:normal; }

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



/*-- TABLE ヘッダ・カラム固定 --*/
thead tr[class*="fixed-header-"] th { position: -webkit-sticky; position: sticky; z-index:2; white-space: nowrap; border:1px solid #ddd; }
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; border:1px solid #ddd; }

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


.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:clamp(1rem, 2.3vw, 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; }


#colorbox.teacher { width:100% !important; height:100% !important; max-width:58rem !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:58rem !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:56rem !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:0.5rem; 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: #555; font-size:0.9rem; line-height:calc(2.5rem - 2px); font-weight: normal; letter-spacing:normal; border:1px solid #555; 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: #555; color: #FFF; border-color: #555; 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: #555; }
.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; }



.note { /*background: #eef5e7;*/ background: rgba(0,136,102,0.05); padding:1rem; }
.bg_blue { background: rgba(30,80,162,0.2); }
.bg_orange { background: rgba(241,141,95,0.2); }
.bg_red { background: rgba(190,52,85,0.2); }


noprint { pointer-events: none; }


.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: #555; /* border-color:rgba(143,194,31,1); color: #1d2088;*/ 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; }


.site_preview { background: rgba(99,85,161,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; }


/*気になる箇所はありませんか？*/
ul.check_list {}
ul.check_list li { padding:0.3rem 0 0.3rem 1.5rem; position: relative; line-height: 1.5; }
ul.check_list li::before { content: ""; display: block; position: absolute; left:0.15rem; top:0.6rem; width:1rem; height: 0.5rem; border-left: 3px solid #1d2088; border-bottom: 3px solid #1d2088; transform: rotate(-45deg); z-index: 10; }
ul.check_list li::after { content: ""; display: block; width:1rem; height: 1rem; background: #fff; border-radius: 0.25rem; position: absolute; left:0rem; top:0.6rem; z-index: 0; }
ul.check_list.f_l li::before { top:clamp(0.6rem,1.4vw,0.9rem); }
ul.check_list.f_l li::after { top:clamp(0.6rem,1.4vw,0.9rem); }

.flow_arrow { height:1.5rem; border-top: 1px dashed #ccc; position: relative; margin-top:1.5rem; }
.flow_arrow::after { content: "▼"; color: #ccc; position: absolute; top:-0.8rem; left:calc(50% - 0.5rem); }

ul.flow_box {}
ul.flow_box li { display: flex; flex-flow: row wrap; align-items: flex-start; position: relative; padding-left: 2.5rem; padding-bottom:2rem; }
ul.flow_box li::after { content: ""; height:100%; position: absolute; left:calc(1rem - 2px); border-left: 4px solid rgba(208,222,240,0.5); z-index: 1; }
ul.flow_box li h4 { }
ul.flow_box li::before { content: ""; width: 2rem; height: 2rem; position: absolute; left:0; top:0.1rem; border-radius: 4rem; background:#1d2088; z-index: 10; }
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; }


/*機器紹介*/
.dis_list { display:flex; flex-flow:row wrap; justify-content:space-between; }
.dis_list li { display:flex; flex-flow:column wrap; align-items:center; justify-content:center; width:calc(33.3% - 1rem); background:#fff; text-align:center; padding:1rem 0.5rem; margin:0.5rem; line-height:1.5; font-size:clamp(1.1rem, 2vw, 1.25rem); color:#1d2088; }
.dis_list li .f_s { margin-top:0.5rem; color:#555; }
.dis_list li:empty { background:none;}


/*自由診療(美容など)*/
body.page-pmt {}
body.page-pmt .hero::after { content:""; display:block; position:absolute; right:0; bottom:clamp(1rem, 3.2vw, 2rem); width:clamp(12rem,26vw,16rem); height:clamp(3rem,6.4vw,4rem); background:url(../img/logo_beauty.png) center center /contain no-repeat; }
body.page-pmt .blue_box h3::after { display:none; } 
/*body.page-pmt h3 .logo { width:clamp(8rem,20vw,12rem); height:clamp(2rem,5vw,3rem); background:url(../img/logo_beauty.png) center center /contain no-repeat; vertical-align:middle; margin-right:1rem; }
body.page-pmt h3 .logo img { width:100%; }*/
ul.fee_list.disc { padding:0; }
ul.fee_list.disc li { display:flex; justify-content:space-between; border-bottom: 1px dashed #ccc; padding:1rem 0; }
ul.fee_list.disc li .parts {}
ul.fee_list.disc li .price { text-align:right; }
ul.fee_list.mens .price { color:#1d2088; }
ul.fee_list.womens .price { color:#be3455; }



#wpadminbar #adminbarsearch { display:none !important;}



/*医療脱毛ページCSSここから*/
body.page-beauty { background:#fff;  }
.beauty_box {font-family: "Zen Old Mincho", serif; font-optical-sizing: auto; font-style: normal; font-weight: 400; }
body.page-beauty .article::after { display:none; }
body.page-beauty .hero { display:none;}

body.page-beauty .index_area.info { border-top:1px solid rgba(0,0,0,0.2);}
body.page-beauty .index_area.info .index_box { border-bottom:1px solid rgba(0,0,0,0.2);}
body.page-beauty .index_area.info .index_box .date { color: #8494b5; }

.beauty_box{ }
.beauty_box h1{ margin-top: 20px; color: #8494b5; font-weight: 700; 	font-size: clamp(1.3rem, 2.8vw, 1.75rem); }
.beauty_box h1.flex.jcc.tc::after { content: ""; width: 2rem; border-bottom: 2px solid #cbb876; position: absolute; left: calc(50% - 1rem); bottom: clamp(-1.25rem, -2.5rem, 0.6rem); }
.mainfull{ margin: 0 calc(50% - 50vw); width: 100vw; position:relative; z-index:-2; }
.beauty_box h2 { font-size: clamp(1.3rem, 2.8vw, 1.75rem); margin-bottom: clamp(1rem, 4vw, 4rem); position: relative; display: flex; align-items: center; flex-flow: row nowrap; margin-top: 30px; color: #7a4e9b; font-weight: 500; }
.beauty_box h2 hr{ border-bottom: 1px solid #cbb876; margin-left: 10px; }
.beauty_main { background: url("../img/bg_beauty.webp") top center /cover no-repeat; /*height: 60vh; overflow: hidden;*/ text-align:center; }
.beauty_main .sp_no { max-width:90rem; margin:auto; }
.bgp_box { background: url("../img/bg_beauty.webp") top center /cover no-repeat; /*overflow: hidden;*/ padding-bottom: clamp(2rem, 6vw, 4rem); }
.btn_box{ padding-top: clamp(2rem, 6vw, 4rem); padding-bottom: clamp(2.5rem, 8vw, 5rem); }
.btn_box div{ text-align: center; font-size: 1.5rem; color: #7a4e9b; font-weight: bold; }

.original-button { display: flex; align-items: center; justify-content: center; line-height: 1; text-decoration: none; color: #fff !important; font-size: 22px; border-radius: 40px; width:clamp(20rem,60vw,40rem); height: 70px; font-weight: bold; transition: 0.3s; background: radial-gradient(circle at 100% 0%, rgba(173, 127, 180, 1), rgba(108, 95, 166, 1)); margin: 0 auto; }
.original-button::after { display:none !important;}
.cv_btn { animation: anime1 1.5s ease 0s infinite alternate; transform-origin:center; }
@keyframes anime1 { 
from { transform: scale(0.9,0.9); }
to { transform: scale(1,1); }
}
.original-button:hover { opacity:0.5; }

.beauty_box .worry { width:90%; }

.p_purple_box { background-color: #f9f7ff; padding-top: clamp(2rem, 6vw, 4rem); padding-bottom: clamp(2rem, 6vw, 4rem); position: relative; clip-path: inset(0 0 0 0); }
.fs_b{ font-size: 1.3rem; }
.nayami{ /*background-color: #8494b5;*//*background-image: linear-gradient(0deg, rgba(196, 182, 197, 1), rgba(35, 117, 163, 1));*/ padding-top: clamp(2rem, 6vw, 4rem); padding-bottom: clamp(2rem, 6vw, 4rem); 	 margin-bottom: 3rem; border-radius: 40px; }
.nayami ul{ padding: 15px; }
ul.fs_b li{ margin-bottom: 1rem; font-size: 110%; color: #fff; }
.nayami ul.check_list li::before{ top: 0.9rem; }
.nayami ul.check_list li::after{ top: 0.9rem; }
.omoi img{ width: 100%; height: 60vh; object-fit: cover; }
.omoi_right{ object-position: 50% 100%; }
.machine_list ul{ list-style-type: none!important; }
.machine_list li { background-color: #FFF; padding: 0.8em; border-radius: 6px; border: solid 1px #e2dbed; /* 内側の線になる一本線の枠線をひく*/
	outline: solid 1px #e2dbed; /* 外側の線になる一本線の枠線をひく*/
	outline-offset: 2px;  /* 外側の線と内側の線の空き具合を調整*/
	margin: 3px;   	/* 外側の線を広げた分、要素の大きさを調整する*/
	margin-bottom: 20px; }
.machine_list li span{ display: block; margin-bottom: 6px; font-weight: bold; font-size: 19px; line-height: 1.7; letter-spacing: 0.075em; border-bottom: 1px solid #cab973; color: #6c5fa6; padding-bottom:0.5rem; }
.machine_list li span em{  display: inline-block; margin-right: 8px; margin-bottom: 5px; padding: 6px 8px 5px; font-size: 16px; line-height: 1; letter-spacing: 0.1em; color: #fff; background-color: #cab973; border-radius: 3rem; font-weight: normal; }
.riyu5 h4{ padding: 10px; background-image: linear-gradient(90deg, rgba(108, 95, 166, 1), rgba(162, 181, 214, 1)); color: #fff; font-size: 1.2rem!important; }
.riyu5 h4 span{ font-size: 1.8rem!important; margin-right: 10px; margin-left: 5px; }
.riyu5box{ background-color: #fff; border-radius: 6px; }
.riyu5 div p{ padding: 0 15px 10px 15px; }
tr.tigai th,tr.tigai td{ color: #fff; font-weight: bold; }
tr.tigai { background-image: linear-gradient(90deg, rgba(108, 95, 166, 1), rgba(162, 181, 214, 1))!important; }
/*tr.tigai th{ background-color: #7469a3!important; }*/

.table04 { border-spacing: 0; border-bottom:1px solid rgba(0,0,0,0.1); /* background:rgba(255,255,255,0.5); border:1px solid rgba(0,0,0,0.1); width: 100%; white-space:nowrap;*/ margin:0 0 1rem 0;}
.table04 th, .table04 td { border-right:1px dashed rgba(0,0,0,0.1); /*border-bottom:1px solid rgba(0,0,0,0.1); vertical-align: top;*/ padding: 10px 5px!important;}
.table04 thead th { background:rgba(208,222,240,0.5); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); }
.table04 tbody th.tl { text-align:left; }
.table04 thead td { background:rgba(208,222,240,0.5); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); }
.table04 tbody tr:last-of-type th, .table04 tbody tr:last-of-type td { border-bottom: none; }
.table04 tbody th { border-bottom:1px solid rgba(0,0,0,0.1); text-align:center; /*border:1px solid #ddd; background:rgba(208,222,240,0.5);*/ color:#555; }
.table04 tbody td { border-bottom:1px solid rgba(0,0,0,0.1); letter-spacing:normal; text-align: center;
vertical-align: middle;}
.table04 th.vm, .table04 td.vm, .table04 tr.vm th, .table04 tr.vm td { vertical-align: middle; }
.table04 tr.women { background-color: #eb6ea5; }
.table04 tr.women th ,.table04 tr.men th { color: #fff; font-size: 90%; }
.table04 tr.men { background-color: #38a1db; }

#hikaku table{ font-weight: 700; }
/*#hikaku table thead th:first-child { position: relative; background-color: #a2a2a4; }
#hikaku table td:first-child { background-color: #F2F2F5; }*/
.hikakutaitle{ background-color: #8396b2!important; color: #fff; }
.gray{ background-color: #e6eae3; }
.gold1{ background-color: #bdb76b!important; }
.gold2{ background-color: #fff8dc; padding:clamp(0.75rem,2.4vw,1.5rem); margin-bottom:1rem; }
.purplesell{ background-color: #f5ecf4; color: #ad7fb4; }
.whitesell{ background: #fff; }

.stepbar { margin: 0 auto; width: 80%; }
.stepbar .stepbarwrap { margin:0 0 2em 0; position: relative; }
.stepbar .stepbarwrap .steptitle { display: inline-flex; align-items: center; }
.stepbar .stepbarwrap .steptitle .stepcircle { display: inline-block; width: 3em; height: 3em; content: ""; border-radius: 50%; background-color: #7a4e9b; color: #fff; text-align: center; z-index: 2; }
.stepbar .stepbarwrap .steptitle .stepcircle span { display: inline-block; line-height: 2.2em; font-size: 1.5em; font-weight: bold; position: relative; top: -0.15em; }
.stepbar .stepbarwrap .steptitle .title { margin: 0.5em; font-weight: bold; font-size: 1.2em; color: #7469a3; }
.stepbar .stepbarwrap .steptxt { padding-left: 3.5em; }
.stepbar .stepbarwrap .steptxt .txt { font-size: 0.9em; }
.stepbar .stepbarwrap .stepline { width: 1px; height: calc(100% + 1em); background-color: #8397b2; position: absolute; top: 2.3em; left: 1.5em; z-index: 0; }

.beauty_box .q, .q_open { margin-bottom: 10px; padding: 0.75rem 2rem 1rem 1rem; position: relative; border-top: 1px solid rgba(0, 0, 0, 0.1); cursor: pointer; background-image: linear-gradient(90deg, rgba(108, 95, 166, 1), rgba(162, 181, 214, 1)); color: #fff; line-height:1.5; }
.beauty_box .q::before, .q_open::before { content: "Q. "; display: inline-block; font-weight: bold; margin-right: 0.25rem; color: #fff; font-size: 1.2rem; }
.beauty_box .q::after { content: "＋"; position: absolute; right: 0.75rem; display: inline-block; transition: 0.1s; font-size: clamp(0.9rem, 1.8vw, 1.125rem); top: 1.3rem; line-height: 1; color: #1d2088; }
.beauty_box .a, .a_open, .t, .t_open { display: none; margin-bottom: 1.5rem; padding: 0 1rem; }
.tab-wrap { display: flex; flex-wrap: wrap; margin:20px 0; position:relative; }
.tab-wrap > div { display: flex; flex-wrap: wrap; margin:20px 0; position:absolute; top:0; left:0; }
.tab-wrap:after { content: ''; width: 100%; height: 1px; background: LightGray; display: block; order: -1; }
.tab-label { color: White; background: LightGray; font-weight: bold; text-shadow: 0 -1px 0 rgba(0,0,0,.2); white-space: nowrap; text-align: center; padding: 10px .5em; order: -1; position: relative; z-index: 1; cursor: pointer; border-radius: 5px 5px 0 0; display:block; width:50%; }
.tab-label:not(:last-of-type) { margin-right: 5px; }
.tab-label + P { display:none; }
.tab-content { width: 100%; /*height: 0; overflow: hidden; opacity: 0;*/ }

.beauty_box .tab { display:flex; flex-flow:row wrap; justify-content:space-between; }
.beauty_box .tab li { background:#ddd; width:calc(50% - 1px); border:none; border-radius:0.5rem 0.5rem 0 0; text-shadow: 0 -1px 0 rgba(0,0,0,0.2); font-weight:bolder; text-align:center; color:#fff; margin:0; font-size:1.25rem; } 
.beauty_box .tab li.select.tab01 { background: #eb6ea5; }
.beauty_box .tab li.select.tab02 { background: #38a1db; }

/* アクティブなタブ */
/*.tab-switch:checked+.tab-label[for="TAB-01"] { background: #eb6ea5; }
.tab-switch:checked+.tab-label[for="TAB-02"] { background: #38a1db; }
.tab-switch:checked+.tab-label + p + .tab-content { height: auto; overflow: auto; padding: 15px; opacity: 1; transition:0.5s opacity; box-shadow: 0 0 3px rgba(0,0,0,.2); }*/

/* ラジオボタン非表示 */
.tab-switch { display: none; }
.stepbarbox, .mosyukibox{ background-color: #fff; padding:clamp(1rem,3vw,2rem); }

@media screen and (max-width: 960px) { 
.original-button { font-size: 1rem; width: 100%; }
.table-wrap { overflow-x: scroll; margin-bottom: 2rem; }
.beauty_box .worry { width:110%; margin:0 -5%; max-width:200%; }
.stepbar { width: 100%; }
}

/*医療脱毛ページCSSここまで*/


/*美容ページCSSここまで*/

.b_beauty,
.rsv_box .fm_beauty, 
.rsv_box .w49 br, 
.pc_no .rsv_box .fm_beauty a br { display:none; }
.pc_no .rsv_box .w49 { width:28% !important; font-weight:bolder;}

.b_beauty { background:#cab973; color:#fff; writing-mode: vertical-rl; font-size:1.125rem; text-decoration: none; position: fixed; top:8rem; right:0; padding:1.5rem 0.5rem; width:3rem; display:flex; justify-content: center; align-items: center; letter-spacing:0.1rem; }
/*
body.test .b_beauty { position: fixed; writing-mode:vertical-rl; top:12rem; right:0; padding:1rem 0.5rem; width:3rem; display:flex; justify-content: center; align-items: center; border-radius:0.5rem 0 0 0.5rem; z-index: 10000; color:#fff !important; border:2px solid rgba(255,255,255,0.8); border-right: 0px solid transparent; white-space: nowrap; font-size:1.2rem;  }
*/
.pc_no .rsv_box .fm_beauty { display:block; width:42%; background:#cab973; color:#fff; position: relative; display: flex; align-items: center; padding:0 clamp(1.5rem,3vw,2rem) 0 clamp(0.75rem,1.6vw,1rem); color:#fff; text-decoration: none; font-size:clamp(0.8125rem,1.6vw,1rem); height:4rem; cursor:pointer; border: 1px solid rgba(255,255,255,0.5); }
.pc_no .rsv_box .fm_beauty a { color:#fff; text-decoration:none; font-weight:bolder; }
@media screen and (max-width: 960px) { 
.b_beauty, body.beauty .scroll::before  { display:none; }
}
@media screen and (max-width: 640px) { 
body.beauty .scroll::before { display:block;}
}
@media screen and (max-width: 480px) { 
.pc_no .rsv_box .w49 br, .pc_no .rsv_box .fm_beauty a br { display:inline-block;}
}
/*美容ページCSSここまで*/

/*交通事故診療ここから*/

/* --- 基本設定と共通スタイル --- */ :root {
  --color-dark-teal: #004d40; /* 6つのSTEPセクションの背景色（濃い緑/青）*/
  --color-accent-red: #c00; /* キャッチコピーの赤文字 */
  --color-accent-orange: #ff8c00; /* 0円などの強調色 */
  --color-text-dark: #333;
  --color-text-white: #fff;
  --color-light-bg: #f7f7f7;
  --font-base: 'Hiragino Kaku Gothic Pro', 'メイリオ', Meiryo, sans-serif;
}
body.page-trafficaccident_medical div.hero{display:none;}
.trafficaccident_medical {
  margin: 0;
  padding: 0;
  font-family: var(--font-base);
  color: var(--color-text-dark);
  line-height: 1.7;
}

.trafficaccident_medical h2, h3 {
  line-height: 1.4;
  font-weight: bold;
}
.content-box {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
}

/* --- 1. ヒーローセクション --- */
.section-hero {
  padding: 60px 0 0;
  background-color: #fff;
}
.section-hero h1 {
  font-size: 4.4rem;
  color: #006d67;
  margin-bottom: 10px;
  line-height: 1;
  font-weight: bold;
}
.section-hero h1 span {
  font-size: 3.5rem;
}
.section-hero strong {
  font-weight: bold;
  font-size: 2rem;
  color: #00bbbb;
}
.section-hero .sub-text {
  font-size: 1.2rem;
  color: #555;
  margin-bottom: 10px;
	line-height: 1.4;
}
.taitlebox {
  padding-top: 3rem;
  width: 50%;
}
.hero-mainimg {
  width: 50%
}
.article div.zero-yen-wrap a:link[target='_blank']::after ,.article div.herosp a:link[target='_blank']::after{background: none;}
/* --- 2. 痛みへの寄り添いセクション --- */
.section-approach {
  padding: 40px 0;
  background-image: url('img/traffic00.jpeg');
  /* セクション全体を覆うように画像を拡大・縮小（最も推奨される設定） */
  background-size: cover;
  /* 画像を中央に配置 */
  background-position: center center;
  /* 画像が繰り返されないように設定 */
  background-repeat: no-repeat;
  /* ※重要: セクションの高さ（コンテンツが少ない場合に必要） */
  /* 画像を表示するために最低限の高さを設定するか、コンテンツで高さを確保してください */
  min-height: 700px; /* 例として高さを指定 */
}
.section-approach h2 {
  font-size: 2.8rem;
  margin-bottom: 40px;
  color: #006d67;
}
.approach-item {
  background-color: #fff;
  padding: 1.5rem;
  margin-bottom: 1.5rem;
  border-top-left-radius: 30px;
  border-bottom-right-radius: 30px;
}
.approach-item h3 {
  color: #00bbbb;
  margin-bottom: 10px;
}
.approach-item p {
  margin-bottom: 0;
}
/* --- 3. 6つのSTEPセクション --- */
.section-steps {
  background-color: #006d67;
  padding: 40px 0 60px;
  color: var(--color-text-white);
}
.steps-header {
  text-align: center;
  margin-bottom: 30px;
}
.steps-header h2 {
  justify-content: center;
}
.steps-container {
  display: flex;
  flex-wrap: wrap;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
  gap: 20px; /* カード間のスペース */
  justify-content: center;
}
.step-card {
  padding: 70px 20px 10px 20px;
  width: calc(33.333% - 13.333px); /* 基本の3列表示 */
  box-sizing: border-box;
  position: relative;
  border-top-left-radius: 30px;
  border-bottom-right-radius: 30px;
  display: block;
  font-size: 0.9rem;
  margin-bottom: 5px;
  background-color: #fff;
}
.step-number {
  /* display: block;
    font-weight: bold;
    color: var(--color-accent-orange);
    font-size: 0.9rem;
    margin-bottom: 5px;*/
  font-family: serif;
  position: absolute;
  top: 0;
  left: 0;
  background-color: var(--color-accent-orange);
  color: white;
  font-weight: bold;
  font-size: 0.9rem;
  padding: 2px 12px;
  border-bottom-right-radius: 30px;
  border-top-left-radius: 30px;
  z-index: 10;
  display: inline-block;
}
.step-number span {
  font-size: 1.8rem;
}
.step-card h3 {
  font-size: 1.5rem;
  font-weight: bold;
  margin-top: 0;
  margin-bottom: 10px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.2); /* 画像の区切り線 */
  padding-bottom: 5px;
  color: #006d67;
}
.step-card p {
  color: var(--color-text-dark);
  margin-bottom: 5px;
}
.step-card ul li {
  color: var(--color-text-dark);
}
/* --- 4. 選ばれる理由セクション --- */
.section-features {
  padding: 60px 20px;
  text-align: center;
  background-color: #e2f6f5;
}
.section-features h2 {
  font-size: 2.5rem;
  margin-bottom: 30px;
  justify-content: flex-start;
  color: #006d67;
  text-align: left;
}
.features-container {
  display: flex;
  justify-content: center;
  gap: 20px;
  flex-wrap: wrap;
  max-width: 1200px;
}
.feature-item {
  width: 500px;
  background-color: #fff;
  text-align: start;
  padding: 20px;
  border-top-left-radius: 30px;
  border-bottom-right-radius: 30px;
}
.feature-item .icon img {
  height: 50px;
  margin-bottom: 15px;
}
.feature-item h3 {
  font-size: 1.1rem;
  margin-top: 0;
  margin-bottom: 10px;
  color: #006d67;
  font-weight: bold;
}
.feature-item p {
  font-size: 0.85rem;
  color: #555;
  margin-bottom: 0;
}
.info-section h2, .examination-section h2 {
  font-size: 2.5rem;
  margin-bottom: 3rem;
  justify-content: center;
  color: #006d67;
  text-align: center;
  flex-wrap: wrap;
}
.features-container table {
  max-width: 1200px;
}
.features-container thead tr th.grbg {
  background-color: #006d67;
  color: #fff;
}
.features-container thead tr th.bgg {
  background-color: #cce2e1 !important;
}
.features-container tr th, .features-container tr td.seikotu {
  /*text-align: center!important;*/
  background-color: #ebf9f8;
}
.features-container tr td.tra_seikei {
  background-color: #fff !important;
}
/* --- 変数の再利用または定義 --- */ :root {
  --color-main-bg: #407b74; /* 周りの濃い緑色（ティール系） */
  --color-point-orange: #ff8c42; /* Pointタグのオレンジ色 */
  --color-text-dark: #333;
  --color-zero-yen: #44807a; /* 0円の文字色（画像中央の緑色） */
}
/* カードを配置するセクション全体の背景 */
.info-section {
  background-color: #dceae2;
  padding: 80px 20px; /* カードの上部と下部に十分なスペースを確保 */
}
.info-section hr {
  border-bottom: 1px solid #dcdddd;
}
/* 1. カード全体のコンテナ設定 */
.card-container {
  max-width: 1020px;
  margin: 0 auto;
  /* Pointタグをabsoluteで配置するための基準点 */
  position: relative;
}
/* 2. 白い本文エリアの設定 */
.card-body, .card-body02 {
  border-top-left-radius: 30px;
  border-bottom-right-radius: 30px;
  /* box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);*/
  min-height: 180px; /* 内容が少ない場合の最小の高さ */
  margin-bottom: 1rem;
}
.card-body {
  padding: 40px;
  background-color: rgba(0, 109, 103, 0.05);
}
.card-body02 {
  background-color: #fff;
  padding: 20px;
}
/* 3. Pointタグ（オレンジのボックス）の設定 */
.point-tag {
  /* 白いカードの左上基準で配置 */
  position: absolute;
  top: 0;
  left: 0;
  background-color: var(--color-point-orange);
  color: white;
  text-align: center;
  width: 100px; /* Pointタグの幅 */
  height: 90px; /* Pointタグの高さ */
  padding-top: 10px;
  /* 画像を参考に、上と左だけ角を保ち、他は直角または白いカードに合わせて丸くする */
  border-top-left-radius: 30px;
  border-bottom-right-radius: 30px; /* 白いカードの角丸に合わせて調整 */
  /* コンテンツより手前に表示 */
  z-index: 2;
}
.point-label {
  display: block;
  font-size: 1.1rem;
  font-weight: bold;
  line-height: 1;
}
.point-number {
  display: block;
  font-size: 3rem; /* 数字を大きく */
  font-weight: bold;
  line-height: 1;
}
/* 4. タイトルと本文のスタイル */
.card-title {
  font-weight: bold;
  margin-top: 0;
  color: #006d67;
}
.card-title02 {
  /*background: var(--color-point-orange);*/
  border-bottom: 1px solid #dcdddd;
  padding: 0 0 8px 0;
  margin-bottom: 20px;
}
.card-title02 h3 {
  margin-bottom: 0;
  color: #FF8C42;
  font-size: 1.5rem;
}
.card-title h3 {
  font-size: 1.5rem;
  align-items: flex-end;
  margin-bottom: 0;
  flex-wrap: wrap;
  color: #434141;
}
.fs_bt {
  font-size: 2.2rem;
}
.card-list {
  list-style: none; /* デフォルトのリストマークを非表示 */
  padding-left: 0;
  margin: 0;
}
.card-list li {
  font-size: 1rem;
  margin-bottom: 10px;
  position: relative;
  padding-left: 1.5em; /* リストマーク分のスペースを空ける */
}
.card-list li::before {
  content: '●'; /* 黒丸を擬似要素で作成 */
  color: #FF8C42; /* リストマークの色 */
  font-size: 0.8rem;
  position: absolute;
  left: 0;
  top: 0;
}
/*ステップ*/
/* --- 変数の定義（前のCSSから流用） --- */ :root {
  --color-main-bg: #407b74; /* 周りの濃い緑色（ティール系） */
  --color-point-orange: #ff8c42; /* 円形バッジのオレンジ色 */
  --color-text-dark: #333;
  --color-accent: #44807a; /* リストマークや強調色 */
}
/* セクション全体の背景とパディング */
.examination-section {
  background-color: #efe3d5;
  padding-top: 4rem;
  padding-bottom: 3rem;
}
/* 1. カード全体のコンテナ設定 */
.info-card {
  max-width: 1200px;
  margin: 0 auto;
  /* バッジを絶対配置するための基準点 */
  position: relative;
  /* 白いカード本体の背景色と角丸 */
  background-color: white;
  border-radius: 8px;
  /*box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);*/
  /* バッジがはみ出す分のマージンを左に設定 */
  margin-left: 50px;
}
/* 2. 円形バッジの設定 */
.round-badge {
  position: absolute;
  font-family: serif;
  /* 垂直方向の中央に配置 */
  top: 20%;
  transform: translateY(-50%); /* 高さに依存せず、正確に中央に移動 */
  /* 左側の位置（カードの縁から外側へ） */
  left: -35px;
  width: 60px;
  height: 60px;
  line-height: 60px; /* テキストを垂直中央に配置 */
  background-color: #FF8C42;
  color: white;
  font-size: 2.5rem;
  font-weight: bold;
  text-align: center;
  /* 完全な円形にする */
  border-radius: 50%;
  z-index: 10;
}
/* 3. カードのコンテンツとレイアウト */
.card-content {
  display: flex;
  align-items: center; /* 垂直方向の中央揃え */
  padding: 20px 20px 20px 40px;
  gap: 30px;
  max-width: 1200px;
  margin-bottom: -1px;
}
/* 中央揃え用（先ほどと同じです） */
.container_a {
  display: flex;
  justify-content: center; /* 横方向の中央 */
  align-items: center; /* 縦方向の中央 */
  margin-bottom: 16px;
  margin-top: -1px;
}
/* ▼本体 */
.triangle-solid {
  width: 0;
  height: 0;
  /* 左右を透明にして幅を確保 */
  border-left: 25px solid transparent; /* ▲この数値で「幅」が変わります */
  border-right: 25px solid transparent; /* ▲左右は同じ数値にします */
  /* 上に色をつけて▼の形にする */
  border-top: 30px solid #fff; /* ▲この数値で「高さ」と「色」が変わります */
  /* border-topの色を変えるだけで、好きな色の▼になります */
}
.text-area {
  flex: 1; /* 残りのスペースを全て使用 */
}
.main-title {
  font-size: 1.8rem;
  color: #006d67;
  margin-top: 0;
  margin-bottom: 5px;
}
.sub-title {
  font-size: 1.2rem;
  color: #006d67;
  margin-top: 0;
  margin-bottom: 20px;
  font-weight: bold;
}
/* リストのスタイル */
.check-list {
  list-style: none;
  padding-left: 0;
  margin-top: 15px;
}
.check-list li {
  position: relative;
  padding-left: 1.5em;
  margin-bottom: 8px;
  font-size: 0.95rem;
}
.check-list li::before {
  content: '●';
  color: var(--color-point-orange); /* オレンジ色のリストマーク */
  font-size: 0.7rem;
  position: absolute;
  left: 0;
  top: 0.3em;
}
/* 4. 画像のプレースホルダー */
.image-placeholder {
  width: 300px;
  flex-shrink: 0; /* 縮小されないようにする */
}
/* 1. 親要素でカウンターをリセット */
.number-container {
  /* カウンター名を 'item-count' としてリセット */
  counter-reset: item-count;
  max-width: 1200px;
}
/* 2. 連番を振りたい要素でカウンターをインクリメント（+1） */
.numbered-item {
  /* 要素が表示されるたびにカウンターを増やす */
  counter-increment: item-count;
  /* 後の擬似要素の基準にする */
  position: relative;
  /* 各項目が縦に並ぶように（spanはデフォルトでインライン要素のため） */
  display: block;
  margin-bottom: 50px;
  padding-left: 30px; /* マーカー分のスペースを確保 */
}
/* 3. ::before 擬似要素でカウンターの値を表示し、装飾する */
.numbered-item::before {
  /* カウンターの値（1, 2, 3...）を表示 */
  content: counter(item-count);
  /* ❶ の装飾 */
  position: absolute;
  left: 43%; /* numbered-item の左端に配置 */
  top: 0;
  /* 丸を作成するスタイル */
  display: inline-flex; /* 数字のセンタリングに便利 */
  justify-content: center;
  align-items: center;
  width: 35px;
  height: 35px;
  line-height: 20px; /* 必要に応じて調整 */
  border: 2px solid #FF8C42; /* 枠線 */
  border-radius: 50%; /* 丸にする */
  /* テキストのスタイル */
  background-color: #FF8C42;
  color: white;
  font-weight: bold;
  font-size: 1rem;
}
.tf_ll {
  font-size: clamp(1.7rem, 3vw, 2.2rem);
}
.point-container {
  font-family: serif;
  /* 親要素として中央揃えや配置の基準に使う */
  display: inline-block; /* 必要に応じて block に変更 */
  text-align: center;
  line-height: 1; /* 行の高さを詰める */
}
.point-text {
  /* POINT のスタイル */
  display: block; /* 独立した行にする */
  font-size: 1.5rem; /* サイズ調整 */
  font-weight: bold;
  color: #FF8C42; /* 薄いベージュ系の色 (POINT) */
}
.point-number02 {
  /* 01 のスタイル */
  display: block;
  font-size: 4rem; /* POINT よりもはるかに大きくする */
  font-weight: bold;
  color: #FF8C42; /* 薄いベージュ系の色 (01)#ffc29a */
  letter-spacing: -0.1em;
  /* フォントによっては 'sans-serif' などを指定して調整してください */
}
.wline {
  font-size: 4rem;
  position: relative;
  z-index: 0;
  display: inline-block;
}
.wline::before {
  content: "";
  width: 100%;
  height: 2vw;
  background-color: #e2f6f5;
  position: absolute;
  left: 0;
  bottom: -5px;
  z-index: -1;
}
/* より繊細な調整のための例 (POINTと01の間のスペース調整) */
/*.point-text {
  margin-bottom: -0.5rem; 
}*/
.boder_r {
  box-shadow: 3px 3px 0 0 #ffc29a;
}
/* --- レスポンシブ対応 --- */
@media (max-width: 768px) {
  .info-card {
    margin-left: 0; /* スマホではバッジのオフセットを解除 */
    border-radius: 0; /* 角丸も解除して画面幅いっぱいにする場合 */
    padding-top: 40px; /* バッジが上に来るためのスペースを確保 */
  }
  .card-content {
    flex-direction: column-reverse; /* 画像を上に、テキストを下にする */
    padding: 20px;
    gap: 20px;
  }
  .round-badge {
    left: 15%; /* 中央に移動 */
    top: 0;
    /* 中央揃えと上へのオフセットを調整 */
    transform: translate(-50%, -50%);
  }
  .image-placeholder {
    width: 100%; /* 画像を横幅いっぱいに */
  }
  .container_a {
    margin-bottom: 60px;
  }
  .wline::before {
    bottom: -5px;
    height: 3vw;
  }
}
.cp_qa03 .cp_actab {
  position: relative;
  width: 100%;
  margin: 0 0 1em 0;
  color: #1b2538;
}
.cp_qa03 .cp_actab input {
  display: none;
}
/* 質問 */
.cp_qa03 .cp_actab label {
  color: #00838f;
  ;
  font-weight: bold;
  line-height: 1.6em;
  position: relative;
  display: block;
  margin: 0 0 0 0;
  padding: 1em 2em 1em 2.5em;
  cursor: pointer;
  text-indent: 1em;
  border-radius: 0.5em;
  background: #fff;
}
.cp_qa03 .cp_actab label::before {
  content: 'Q';
  font-family: serif;
  font-size: 1.5em;
  margin-left: -2em;
  padding-right: 0.5em;
}
.cp_qa03 .cp_actab label:hover {
  color: #00838f;
  transition: all 0.3s;
}
/* --質問の＋アイコン */
.cp_qa03 .cp_actab label::after {
  position: absolute;
  top: 0;
  right: 0;
  content: '+';
  font-size: 1.7em;
  font-weight: bold;
  line-height: 2em;
  display: inline-block;
  width: 2em;
  height: 2em;
  transition: transform 0.3s;
}
/* 答え */
.cp_qa03 .cp_actab .cp_actab-content {
  position: relative;
  overflow: hidden;
  max-height: 0;
  padding: 0 0 0 2.5em;
  border-radius: 0 0 0.5em 0.5em;
  transition: max-height 0.2s;
}
.cp_qa03 .cp_actab .cp_actab-content::before {
  position: absolute;
  content: 'A';
  font-family: serif;
  font-size: 1.5em;
  margin: 0.4em 0 0 -1em;
  padding: 0;
}
.cp_qa03 .cp_actab .cp_actab-content p {
  margin: 1em 1em 1em 0;
}
/* 質問を開いた時の仕様 */
/* --答えの高さ */
.cp_qa03 .cp_actab input:checked ~ .cp_actab-content {
  max-height: 40em;
  /*border: 10px solid #e2f6f5;*/
  /*background: #fff;*/
}
/* 質問をクリックした時のアイコンの動き */
.cp_qa03 .cp_actab input:checked ~ label {
  color: #00838f;
  border-radius: 0.5em;
}
/* 質問をクリックした時の+の動き */
.cp_qa03 .cp_actab input[type=checkbox]:checked + label::after {
  transform: rotateZ(45deg);
  transform-origin: 50% 50%;
}
.calculation_content {
  max-width: 600px;
  margin: 0 auto;
  position: relative;
  background: #fff;
  border-radius: 30px;
  padding: 20px;
}
.tr_greeting h3 {
  justify-content: flex-start;
}
/* --- レスポンシブ対応 (簡易版) --- */
@media (max-width: 1024px) {
  .step-card {
    width: calc(50% - 10px); /* タブレットサイズで2列表示 */
  }
}
@media (max-width: 1300px) {
  .section-hero {
    padding: 35px 0 0;
  }
}
@media (max-width: 1100px) {
  .section-hero h1 {
    font-size: 3.5rem;
    color: #006d67;
    margin-bottom: 10px;
    line-height: 1;
  }
  .section-hero h1 span {
    font-size: 2.8rem;
  }
  .section-hero strong {
    font-size: 1.5rem;
  }
  br.md_no {
    display: none;
  }
  .taitlebox {
    padding-top: 0.5rem;
  }
  .hero-mainimg {
    width: 50%
  }
  .section-hero {
    padding: 30px 0 0;
  }
	.section-features h2 {
justify-content: center;
}
}
@media (max-width: 838px) {
  .section-hero h1 {
    font-size: 2.2rem;
  }
  .section-hero h1 span {
    font-size: 2rem;
  }
  .tr_greeting h3 {
    justify-content: center;
    font-size: 1.5rem;
    text-align: center;
  }
}
@media (max-width: 960px) {
  .hero-btnbox {
    width: 60%;
    margin: 0 auto;
  }
}
@media (max-width: 600px) {
	.section-steps {padding: 20px 0 30px;}
  .section-hero {
    padding: 10px 0 0;
  }
  .section-hero h1 {
    font-size: 2.5rem;
  }
  .section-hero h1 span {
    font-size: 2.2rem;
  }
  .taitlebox {
    margin-bottom: 0;
    padding-top: 0;
    width: 340px;
    margin: 0 auto;
  }
  .section-hero .sub-text {
    font-size: 1rem;
  }
  .hero-mainimg {
    width: 80%
  }
  .section-hero strong {
    font-size: 1.3rem;
  }
  .yen-badge .yen-amount {
    font-size: 3rem;
  }
  .step-card {
    width: 100%; /* スマホサイズで1列表示 */
  }
  .section-approach h2, .section-features h2, .info-section h2 {
    font-size: 2rem;
    margin-bottom: 30px;
    justify-content: center;
    text-align: center;
  }
  .examination-section h2 {
    font-size: 2rem;
    justify-content: center;
    text-align: center;
  }
  .features-container {
    gap: 14px;
  }
  .feature-item {
    width: 90%;
    padding: 14px;
  }
  .item_rw50 {
    width: 90% !important;
  }
  .info-section, .examination-section {
    padding: 40px 20px;
  }
  .card-body {
    padding: 20px 15px;
  }
  .card-title h3 {
    font-size: 1.2rem;
  }
  .fs_bt {
    font-size: 1.8rem;
  }
  .point-label {
    font-size: 0.8rem;
  }
  .point-number {
    font-size:
      1.8rem;
  }
  .point-tag {
    height: 55px;
    width: 80px;
  }
  .card-body02 {
    padding: 25px 18px 5px;
  }
  .container_a {
    margin-bottom: 20px;
  }
  .features-container table {
    width: 460px;
  }
  .hero-btnbox {
    width: 100%;
    margin: 0 auto;
  }
  .resp_ml20 {
    margin-left: 20px;
  }
  .wline {
    font-size: 2.5rem;
  }
}
.tool { max-width:30rem; margin:auto;}
.price01 { font-size:clamp(1.5rem,5vw,3rem); color:#006d67;}
.price02 { font-size:clamp(1.5rem,5vw,3rem); color:#FF8C42;}
/*交通事故診療ここまで*/


/*自由診療*/
body.page-pmc {}
body.page-pmc .page-link { justify-content:flex-end; display:none; }
body.page-pmc .index_area, body.parent-pageid-577 .index_area { width:103%; margin:0 -1.5%; }
body.page-pmc .index_box, body.parent-pageid-577 .index_box { width:50%; padding:0 1.5%;}
body.page-pmc .index_box .photo, body.parent-pageid-577 .index_box .photo { margin-bottom:0.5rem;}
body.page-pmc .hero .photo,
body.page-pmc .hero .photo img { aspect-ratio:2/1; object-position:center 20%;}
body.parent-pageid-577 .hero .photo,
body.parent-pageid-577 .hero .photo img { aspect-ratio:2/1;}
body.page-pmc .insert-page-692 h3 { display:none; }
.sticky_menu { position:sticky; top:clamp(7rem,15vw,15rem);}
ul.sub_list { margin-bottom:2rem; }
ul.sub_list li { }
ul.sub_list li a { padding:0 1rem; position:relative; }
ul.sub_list li a::before { content:""; display: block; width:0.5rem; height: 0.5rem; border-top: 1px solid rgba(3,7,122,0.9); border-right: 1px solid rgba(3,7,122,0.9); transform: rotate(45deg); position: absolute; left:0; top:calc(50% - 0.25rem); }

@media screen and (max-width:1200px) {
body.page-pmc .index_box { /*width:25%;*/ }
}
@media screen and (max-width:960px) {
body.page-pmc .index_box, body.parent-pageid-577 .index_box { /*width:33.3%;*/ }
.sticky_menu { position:relative; top:0; }
}
@media screen and (max-width:640px) {
body.page-pmc .index_box, body.parent-pageid-577 .index_box { width:50%; }
body.page-pmc .hero .photo img { aspect-ratio:3/2; object-position:center 20%;}
body.parent-pageid-577 .hero .photo,
body.parent-pageid-577 .hero .photo img { aspect-ratio:3/2;}
}





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

.article, body.temp .article { padding:5rem 1.25rem 1.25rem 1.25rem; }
body.single .article, body.info .article { padding:6rem 1.25rem 1.25rem 1.25rem; }

body.temp .article::before { }
.anchor { height:7rem; margin-top:-7rem; }
body.logged-in .anchor { height:9rem; margin-top:-9rem; }

.header { height:5rem; }
.header .inner { padding:1rem; }
.header .title { width: 10rem; padding:1rem; }
.header .tel { display: none; }

.header .rsv_box { display: none; }
.b_rsv.b_tel { display:flex; }

.hm { display:none; }

/*--MAIN--*/
.main { margin-top:4.5rem; margin-bottom: clamp(10rem,40vw,16rem ); height: auto; }
.main .inner { width:100%; max-height:calc((100vw/4)*3); margin:0; }
.main .inner .main_img { /*height: auto;*/ }
.main .inner .main_img video { aspect-ratio:4/3;}

.main .info_box { left:50%; bottom:0; padding: 0; z-index: 100; transform:translate(-50%,0); width:calc(100% - 2.5rem); }
.main .info_box a { padding:0.5rem 2rem 0.5rem 1rem; height:3rem; }

.main .hours_box { bottom:auto; top:100%; right:auto; left:50%; border-top: 1px solid #fff; transform:translate(-50%,0); width:calc(100% - 2.5rem); }


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



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

.parts_icon ul li { width: 25%; }

.sticky h2 { }


/*--ABOUT--*/
.about_box { padding-top:0; }
.about_box .text { order:2; }
.about_box .photo { order:1; }
.about_box .text h2 { text-align: center; justify-content: center; }
.about_box .text p { text-align: center; }
.about_box .text .more { text-align: center; padding:0; }
.about_box .text a.more .en { font-size: 1.75rem; padding-right:0; background: none; }
.about_box .text a.more .en::after { display: none; }
.about_box .text a.more .ja { padding-bottom:2rem; background: url("../img/arrow_r.svg") center bottom /5.625rem no-repeat;}
.about_box .text a.more .ja::after { content: ""; display: block; z-index:1; width:2.5rem; height:2.5rem; border:2px solid rgba(29,32,136,0.1); position: absolute; right:-0.7rem; bottom:-1.1rem; border-radius: 2rem; }
.about_text::after { width:100vw; margin-left:calc(clamp(-3rem,-5vw,-1.5rem) - 11%); }

.treat_box .title_box,
.faci_box .title_box,
.info_box .title_box,
.access_box .title_box { position: relative; writing-mode: horizontal-tb; left: 0; display: block; margin-bottom:1rem; min-height:0; }

.treat_box .index_box .title .en { letter-spacing: normal; }
.treat_box .index_box .more { width: 2.5rem; right:0.5rem; }
.treat_box .index_box .more::after { width:2.5rem; height:2.5rem; right:-1.05rem; bottom:-0.95rem; border-radius: 2rem; }


.access_box .w40.resp100.mb24 { max-width:30rem; margin:auto; }
	

/*--FOOTER--*/
.footer { padding-bottom:4rem; }
.footer .logo { display: block; width:2.5rem; min-width:2.5rem; margin-right: 1rem; }
.copyright { position: relative; text-align: left; padding:1rem 0 0 0; }

.footer .rsv_box { position: fixed; width:auto; bottom:0; top:auto; right: 3rem; left:0.5rem; margin: 0; z-index:10000; }
.footer .rsv_box .b_rsv { height: 4rem; border:1px solid rgba(255,255,255,0.5); }
.footer .rsv_tel { display:flex; height:auto; max-width:28rem; margin:auto; }
body.top .footer .rsv_tel { display:flex; height:0; }
body.top .footer .rsv_tel .tel, body.top .footer .rsv_tel .address, body.top .footer .rsv_tel .hours_box { display:none;}

.footer .rsv_box li .sub a { height:auto;}
.footer .rsv_box li .sub { top:auto; bottom:0; visibility:hidden; opacity:0; z-index:-1; }
.footer .rsv_box li.active .sub { bottom:4.25rem; visibility: visible; opacity:1; }
	
ul.page-link { padding:0.5rem 0; }
ul.page-link.bg { top:5rem; padding-right:0; }
ul.page-link li a { }
ul.page-link li a::before { top:0.8rem; }

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

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

.hero h2.cate_title { padding:1rem 1.75rem 1rem calc(50vw - 50%); }


.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:#555; color:#fff; padding:0 0.25rem 0 0.45rem; margin-left:0.5rem; text-align:center; line-height:1.8; }


body.news .index_box, body.event .index_box { width:100%; padding:0; }
body.news .index_box a, body.event .index_box a { padding: 1rem 0; }
body.news .index_box .photo, body.event .index_box .photo { width:25vw; max-width:120px; 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, .check_list.col2 { column-count:2 !important; }



/*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; }
.resp95 { width:95% !important; }
.resp90 { width:90% !important; }
.resp85 { width:85% !important; }
.resp80 { width:80% !important; }
.resp75 { width:75% !important; }
.resp70 { width:70% !important; }
.resp65 { width:65% !important; }
.resp60 { width:60% !important; }
.resp55 { width:55% !important; }
.resp50 { width:50% !important; }
.resp48 { width:48% !important; }
.resp47 { width:47% !important; }
.resp45 { width:45% !important; }
.resp40 { width:40% !important; }
.resp35 { width:35% !important; }
.resp30 { width:30% !important; }
.resp25 { width:25% !important; }
.resp20 { width:20% !important; }
.resp15 { width:15% !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_mb8 { margin-bottom:0.5rem !important; }
.resp_mb16 { margin-bottom:1rem !important; }
.resp_mb24 { margin-bottom:1.5rem !important; }
.resp_ma { margin:auto !important; }
.resp_column { flex-flow: column wrap; }
.resp_tl { text-align:left; }
.resp_tc { text-align:center; }
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: 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; }

/*機器紹介*/
.dis_list li { width:calc(50% - 0.5rem); margin:0.25rem; }

}



@media screen and (max-width:782px) {
body.logged-in .header { top:46px; }
body.logged-in .anchor { height:calc(7rem + 46px); margin-top:calc(-7rem - 46px); }
}



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

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

.article::after { background: #fff url(../img/logo.svg) bottom right /90vw no-repeat; }
.faci_box::after { background:rgba(3,7,122,0.9) url("../img/logo_w.svg") bottom right /90vw no-repeat; }
.blue_box::after { background:rgba(3,7,122,0.9) url("../img/logo_w.svg") bottom right /90vw no-repeat; }


/*--INFO--*/
.info_box ul li a, body.info .index_box a, .index_area.info .index_box a { padding: 1rem 0; }
.info_box ul li a::after, body.info .index_box a::after, .index_area.info .index_box a::after { right:0; width: 2rem; }
.info_box .more { padding: 1rem 0; }
.info_box ul li a .title, body.info .index_box a .title, .index_area.info .index_box a .title { padding-right: 2.5rem; }
.index_box { width: 100%; }
	


ul.flow_box li::before { top: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%; }


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



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


}


@media screen and (max-width:600px) {
#wpadminbar { position:fixed !important; }
}


@media screen and (max-width:480px) {
/*自由診療*/
body.page-pmt .hero { padding-bottom:4rem; }
body.page-pmt .hero::after { left:0; bottom:0; }
	
.fm li { width: 100%; }
.fm li a { text-align: center; }
}


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

}
.mailtop{
	font-size:1.5rem;
}
@media screen and (max-width: 960px) {
	.mailtop{
		font-size:1.2rem;
	}
}
/* マウスなどがあるデバイスでは電話リンクを無効化 */
@media (pointer: fine), (hover: hover) {
  a[href^="tel:"] {
    pointer-events: none;
  }
}
/* すべての電話番号リンクから下線を消す */
a[href^="tel:"] {
  text-decoration: none;
}

/* 男性脱毛 */
body.page-men_beauty div.hero{display:none;}
.men_beauty {
    font-family: "Zen Old Mincho", serif;
    font-optical-sizing: auto;
    font-style: normal;
    font-weight: 400;
}
.men_beauty_main {
    background-color: #000a14;
    text-align: center;
	height: auto;
}

.men_beauty h2{
	display: inline-block;
  position: relative;
  color: #cbb386; /* 上品なシャンパンゴールド */
  font-size: clamp(1.8rem, 1.545rem + 1.27vw, 2.5rem);
  font-weight: 400;
  letter-spacing: 0.1em;
  margin: 0;
  padding: 20px 0; /* 上下線との余白 */
  
  /* 上下の線 */
  border-top: 1px solid #cbb386;
  border-bottom: 1px solid #cbb386;
}
.bg_men{
	background: url("https://ysoc.jp/wp-content/uploads/2026/03/menb_bg01.jpg")top center / cover no-repeat;
	padding-top: clamp(2rem, 0.909rem + 5.45vw, 5rem);
	
}
.men_bg_box {
     background-image: linear-gradient(90deg, rgba(0, 7, 96, 1), rgba(17, 21, 50, 1));
    padding-top: clamp(2rem, 6vw, 4rem);
    padding-bottom: clamp(2rem, 6vw, 4rem);
    position: relative;
    clip-path: inset(0 0 0 0);
}
.men_bg_box p{
	color: #FFF;
}
.menbtnbg{

background: linear-gradient(90deg,rgba(173, 140, 72, 1) 0%, rgba(227, 201, 116, 1) 70%, rgba(212, 188, 111, 1) 100%);
color: #051024!important;
}
.menbnr_bg_box{
	background: url(https://ysoc.jp/wp-content/uploads/2026/03/menbnr_bg.jpg) center / cover no-repeat;
}
.menb_grbg{
	background: url(https://ysoc.jp/wp-content/uploads/2026/03/menb_grbg.jpg) center / cover no-repeat;
    padding-top: clamp(2rem, 6vw, 4rem);
    padding-bottom: clamp(2rem, 6vw, 4rem);
    position: relative;
    clip-path: inset(0 0 0 0);
}
.menb_grbg02{
	background: url(https://ysoc.jp/wp-content/uploads/2026/03/menb_grbg02.jpg) center / cover no-repeat;
    padding-top: clamp(2rem, 6vw, 4rem);
    padding-bottom: clamp(2rem, 6vw, 4rem);
    position: relative;
    clip-path: inset(0 0 0 0);
}
.machine_list li span{
	line-height: 1.5;
color: #0d2f5c !important;
}
.bluesell{
	background-color: #ddecff;
    color: #0d2f5c;
}
.riyumen h4{
	    background: linear-gradient(90deg, rgba(173, 140, 72, 1) 0%, rgba(227, 201, 116, 1) 70%, rgba(212, 188, 111, 1) 100%)!important;
	color: #0d2f5c !important;
	font-weight: bold;
	line-height: 1.5;
}
.riyumenbox{
	border-radius: 0px!important;
}
.menstep{
	background-color: #0d2f5c!important; 
}
.mentitle{
	color: #0d2f5c!important; 
}
.menb_grbg03{
	background-color: #f5f6f8;
    padding-top: clamp(2rem, 6vw, 4rem);
    padding-bottom: clamp(2rem, 6vw, 4rem);
    position: relative;
    clip-path: inset(0 0 0 0);
}
.menb_grbg02 .q, .q_open{background-image: linear-gradient(90deg, #021732, #11417d);}
.menb_grbg02 .q::after {color:#fff;}