@charset "UTF-8";
/* 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:1em}input,button,textarea,select{font:inherit}@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}}


html { overflow-x:clip;  }
body { font-family:"Noto Sans JP", sans-serif; color:#222; background:#fff; position:relative; font-size:1em; font-weight: 400; line-height:2; letter-spacing:0.05rem; overflow-x:hidden; -webkit-text-size-adjust:100%; -ms-text-size-adjust:100%; font-feature-settings:"palt";  width:100vw; overflow-x:clip; }

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


.pc_no, .pc_no2, .dis_no { display:none; }
.sp_no { display:block; }
span.sp_no { display:inline; }
br.sp_no { display:inline; }
br.sp_no2 { display:inline; }
.tc { text-align: center; }
.tr { text-align: right; }
.img_pc { display:block; }
.img_sp { display:none; }
.clear { clear:both; }

.green { color:#7b8d42;}
.red {color:#b35;}
.blue { color:#235;}
.orange { color:#fa0;}

p { margin-bottom: 2rem;}
hr { background: none; border: none; border-top: 1px solid rgba(60, 38, 33, 0.2);}

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

.full { margin-left:calc(50% - 50vw); margin-right:calc(50% - 50vw); }
.full_r { margin-left:0; margin-right:calc(50% - 43vw); }
.full_l { margin-left:calc(50% - 43vw); margin-right:0; }
.full_bg { padding-left:calc(50vw - 50%); padding-right:calc(50vw - 50%); }
.anchor { height:7rem; margin-top:-7rem; position:relative; z-index:-10; width:1px; }
body.logged-in .anchor { height:calc(7rem + 32px); margin-top:calc(-7rem - 32px); }
.sticky { position:sticky; top:7rem; }
body.logged-in .sticky { top:calc(7rem + 32px); }

.flex { display:flex; flex-flow:row wrap; justify-content:space-between; }
.flex.jcfs { justify-content:flex-start; }
.flex.jcsa { justify-content:space-around; }
.flex.jcc { justify-content:center; }
.flex.aifs { align-items:flex-start; }
.flex.aic { align-items:center; } 

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

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

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

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

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


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

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

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

.ma { margin:auto; }

.multiply { mix-blend-mode:multiply; }
.en { font-family: "myriad-pro-semi-condensed", sans-serif; /*font-family:"corporate-a-std-urw-cond", serif;*/ font-weight: 600; font-style: normal; letter-spacing:normal; letter-spacing:-0.04rem; }
.mincho { font-family:"YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif; }



/*--MAIN--*/

.main { padding:0; position: relative; margin:0 calc(50% - clamp(25rem,50vw,60rem)) calc(10vh + clamp(3rem,10vw,6rem)) calc(50% - clamp(25rem,50vw,60rem)); max-width:120rem;}

.main::before { content:""; display:block; position:absolute; right:0; top:0; height:100vh; width:clamp(18rem,80vw,96rem); max-height:60rem; min-height:30rem; background:url(../img/honeycomb01.svg) right -5vw bottom -11vw /35vw no-repeat,linear-gradient(135deg,#fa0 40%,#fd0 100%); z-index:-1;}
.main::after { content:""; display:block; position:absolute; right:-5vw; top:0; height:calc(100vh + 11vw); width:clamp(18rem,80vw,96rem); max-height:calc(60rem + 11vw);  min-height:calc(30rem + 11vw); background:url(../img/honeycomb02.svg) right bottom /35vw no-repeat; z-index:-2;}
.main_img { width:clamp(18rem,80vw,96rem); height:90vh; max-height:54rem; position:relative; z-index:100; overflow:hidden; min-height:27rem; position:relative; }
.main_img::before { content:""; display:block; position:absolute; top:0; right:0; left:0; bottom:0; background: radial-gradient(ellipse at center, rgba(0,51,102,0.05) 50%,rgba(0,51,102,0.25) 100%); z-index:101; mix-blend-mode: multiply; }
.main_img img { width:100%; height:100%; object-fit:cover; }
.main .main_copy { position:absolute; top:calc(50% - clamp(3.5rem,11vw,7rem)); right:7vw; text-align:right; color:#fff; text-shadow:1px 1px 0 rgba(102,51,34,0.7); /*font-size:clamp(2.5rem,8vw,5rem);*/ font-size:clamp(1.5rem,5vw,3rem); line-height:1.3; z-index:1000; }
.main .main_copy .sub {font-size:clamp(1rem,2.4vw,1.5rem); margin-top:clamp(0.5rem,1.6vw,1rem); }
.bg_video{  }



/*--HEADER--*/
.header { position: fixed; z-index:1000; display:flex; align-items: center; justify-content:center; top:0; left:0; right:0;  line-height:1.25; font-size:0.875rem; transition:0.5s;  }
.header .inner { width:100vw; max-width:120rem; display:flex; flex-flow:row wrap; align-items: center; justify-content:space-between; margin:auto; padding:clamp(0.75rem,2vw,1.25rem) clamp(0.75rem,2vw,1.75rem); }
body.logged-in .header { top:calc(32px); }

body.temp .header { background: linear-gradient(to bottom, rgba(255,255,255,1) 30%,rgba(255,255,255,1) 70%,rgba(255,255,255,0.9) 100%); }
.header .t_title img, body.top .header.bg .t_title img.title_w { display:none; transition:0.5s; }
body.top .header .t_title img.title_w { display:block; /*filter: drop-shadow(1px 1px 0.25rem rgba(85,28,102,0.2));*/ }
body.top .header.bg .t_title img.title_k,
body.temp .header .t_title img.title_k { display:block; }

.header.bg, body.top .header.bg { background: linear-gradient(to bottom, rgba(255,255,255,1) 30%,rgba(255,255,255,1) 70%,rgba(255,255,255,0.9) 100%); box-shadow:0 1rem 0.5rem -1rem rgba(0,0,0,0.1); }


.header a:hover, .header a.active { color:#fa0; }





/*--HEADER MENU--*/
.hm { transition:0.25s; position: relative; margin-left: auto; }
.hm ul { margin:auto; padding:0; display:flex; flex-flow:row nowrap; justify-content: center; align-items: center; list-style: none; }
.hm ul > li { display: inline-block; margin: 0; text-align: center; width:auto; position: relative; font-size: 1rem; transition: all 0.4s ease;}
.hm ul > li > a { display: block; font-size:0.875rem; padding:0.5rem 0.75rem; font-weight: 300; text-decoration: none; letter-spacing:0.05rem; }
.hm ul > li > a::after{ content: "."; width: 0; font-size: 0; color: transparent; margin-right: 1px; }
.hm ul > li:hover > a, .hm li.active > a { box-shadow:none; opacity:1; color:#fa0; }
.hm ul > li .contractors { /*margin-right: 0.5rem;*/ }

body.top .header .hm > ul > li, body.top .header .hm > ul > li > a, body.top .header .hm > ul > li.hm_tel a { color:#fff; text-shadow:1px 1px 0 rgba(85,28,0,0.3); }
body.top .header.bg .hm ul > li, body.top .header.bg .hm ul > li > a, body.top .header.bg .hm ul > li.hm_tel a { color:#222; text-shadow:none; }
.header .hm ul > li .tel, body.top .header.bg .hm ul > li .tel { padding-left:1.75rem; background:url(../img/i_tel_k.svg) left 0.5rem center /1rem no-repeat; font-size:1.25rem;}
body.top .header .hm ul > li .tel { background:url(../img/i_tel_w.svg)  left 0.5rem center /1rem no-repeat; }
ul li.hm_tel .tel .en { letter-spacing:normal;}

.hm li .sub {display: none; position:absolute; top:100%; left:calc(50% - 7rem); width:14rem; z-index:100000; box-shadow:0 1rem 0.5rem -1rem rgba(0,0,0,0.1); }
.hm li .sub::after { content:""; position:absolute; left:50%; top:0rem; height:1.5rem; display:block; border-right:1px solid #222;  }
.hm li .sub ul { display:flex; flex-flow:column wrap; margin:0.75rem 0 0 0; padding:0.75rem; text-align: left; background:#f8f4e6; }
.hm li .sub ul li { display: block; width: 100%; margin: 0; }
.hm li .sub ul li a { display:block; width:100%; padding:0.75rem; text-align: left; text-decoration: none; border-bottom:1px solid rgba(0,0,0,0.05); color:#222; text-shadow:none; }
.hm li .sub ul li a:hover { background-color:rgba(255,255,255,0.3); }

.hm li .sub ul li::after { position: absolute; display: block; top:1rem; left:1rem; right:-1rem; bottom:-1rem; background:rgba(255,255,255,0.8); z-index:0; }




/*--SNS/--*/
.sns_box { position: fixed; bottom:0.5rem; right:4rem; display: flex; border-radius:2rem; background:rgba(255,255,255,1); background: linear-gradient(to bottom, rgba(255,255,255,1) 50%,rgba(255,255,255,0.95) 100%);  padding: 0.25rem; }
body.top02 .sns_box { background:rgba(255,253,233,0.9);}
.sns_box a::after { display: none !important;}
.sns_box .sdgs { border-radius:0.5rem; display: flex; align-items: center; text-decoration: none; margin-right:1rem; }
.sns_box .sdgs::before { content: ""; display: inline-block; width: 2.5rem; height:2.5rem; background: url("../img/i_sdgs.svg") center center /1.8rem no-repeat; margin-right:0.25rem; }
.sns_box .fb { width: 2.5rem; height:2.5rem; background: url("../img/i_fb.svg") center center /1.8rem no-repeat; }
.sns_box .ig { width: 2.5rem; height:2.5rem; background: url("../img/i_ig.svg") center center /1.8rem no-repeat; }
.sns_box .line { width: 2.5rem; height:2.5rem; background: url("../img/i_line.svg") center center /1.8rem no-repeat; }
.sns_box .yt { width: 2.5rem; height:2.5rem; background: url("../img/i_yt.svg") center center /1.8rem no-repeat; }
.sns_box .pi { width: 2.5rem; height:2.5rem; background: url("../img/i_pi.svg") center center /1.8rem no-repeat; }


h1, h2, h3, h4, h5, h6 { letter-spacing:0.1rem; line-height:1.5; position: relative; padding:0; }
h1 { font-size:2.4rem;margin-bottom: 1.5rem; }
h2 { font-size:2.0rem; margin-bottom: 1.5rem; }
h3 { font-size:1.6rem; margin-bottom: 0.75rem; position: relative; }
h4 { font-size:1.4rem; margin-bottom: 0.75rem; }
h5 { font-size:1.2rem; margin-bottom: 0.75rem; }
h6 { font-size:1.0rem; margin-bottom: 0.75rem; }

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

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

a.more { width:auto; display:inline-flex; align-items: center; text-decoration:none; position: relative; white-space: nowrap; margin: 0 auto; padding:0.5rem 2rem 0.5rem 0; background: url("../img/i_arrow_r.svg") right center /1rem no-repeat; border-bottom:1px solid #222; }
a.more:hover { border-bottom:1px solid #fa0; }
a.more.yt img { width:1.5rem; height:1.5rem; margin-right:0.5rem;}


body.top h2.en { font-size:clamp(2.5rem,8vw,5rem); position:relative; z-index:20; margin-bottom:0; }
body.top h2.en::after { content:""; display:block; width:clamp(5.5rem,18vw,11rem); height:clamp(5.5rem,18vw,11rem); background:url(../img/hexagon.svg) center center /cover no-repeat; position:absolute; top:calc(50% - clamp(2.75rem,10vw,6rem)); left:clamp(-3rem,-5vw,-1.5rem); z-index:-1; }

body.temp h2.en { font-size:clamp(2rem,6vw,3rem); position:relative; z-index:20; margin-bottom:0; display:flex; align-items:center; }
body.temp h2.en::after { content:""; display:block; width:clamp(3.3rem,8vw,5rem); height:clamp(3.3rem,8vw,5rem); background:url(../img/hexagon.svg) center center /cover no-repeat; position:absolute; top:calc(50% - clamp(1.8rem,4.6vw,2.8rem)); left:clamp(-1.5rem,-3vw,-1rem); z-index:-1; }
body.temp h2.en .jp { margin-left:clamp(0.75rem,2.4vw,1.5rem); font-size:1rem; font-family:"Noto Sans JP", sans-serif; letter-spacing:0.04rem; font-weight:400; color:rgba(0,0,0,0.5); }

/*--INFO--*/
.info_area { padding-bottom:clamp(3rem,10vw,6rem); display:flex; flex-flow:row wrap; align-items:flex-start;  }
.info_area .info_box { flex-grow:2;}


.info_area .slick-list { width:100%; max-width:1200px;  margin: auto; }
.info_area h2 { margin-right:clamp(1.5rem,5vw,3rem);}
.info_area .info_box .index_area { display: flex; flex-flow: column wrap; justify-content:flex-start;  width:100%;  text-align: left; position: relative; z-index: 10;  margin:0 auto;  padding:0.5rem 0; list-style: none; }
.info_area .info_box .index_area .index_box { width:100%; padding:0; margin: 0; }
.info_area .info_box .index_area .index_box a, body.archive .index_area .index_box a { text-decoration: none; line-height: 1.5; position: relative; display:flex; flex-flow:row nowrap; margin:0; padding:0.75rem 0; }
.info_area .info_box .index_area .index_box a:hover, body.archive .index_area .index_box a:hover { opacity: 0.9; transition:0.15s; }
.info_area .info_box .index_area .index_box .photo, body.archive .index_area .index_box .photo { width:100%; aspect-ratio:1; margin-bottom:0.5rem; }
.info_area .info_box .index_area .index_box .photo img, body.archive .index_area .index_box .photo img { width:100%; height:100%; object-fit:cover; }
.info_area .info_box .index_area .index_box .text, body.archive .index_area .index_box .text { flex-grow: 1; background:url(../img/i_arrow_r.svg) left top 0.3rem /1rem no-repeat; padding-left:1.75rem; font-size:1rem; }
.info_area .info_box .index_area .index_box img { margin-bottom: 0.5rem; }
.info_area .info_box .index_area .index_box .date, body.archive .index_area .index_box .date { font-size: 0.9rem; display: block; color:#999; padding:0.1rem 1rem 0 0; }
.info_area .info_box .index_area .index_box .new { display: inline-block; position: absolute; width:2.25rem; height: 2.25rem; text-align: center; line-height:2.25rem; background:#fa0; font-size:0.625rem; left:-2.75rem; top:0.7rem; letter-spacing:normal; }


/*PROJECT*/
.project_area { position:relative; }
.project_area::after { content:""; display:block; background:#f8f4e6; position:absolute; top:clamp(4rem,12vw,8rem); left:clamp(2.5rem,8vw,5rem); right:calc(50% - clamp(25rem,50vw,60rem)); bottom:clamp(6rem,20vw,12rem); z-index:-100;}
.project_area::before { content:"PROJECT"; font-family: "myriad-pro-condensed", sans-serif; /*font-family:"corporate-a-std-urw-cond", serif;*/ font-weight: 600; font-style: normal; letter-spacing:normal; font-size:clamp(6rem,19vw,12rem); line-height:0.9; position:absolute; top:0; right:-3vw; color:#f8f4e6; z-index:-110; }

.intro_box { display:flex; align-items:center; margin-bottom:clamp(2rem,6vw,4rem); }
.intro_box .photo {}
.intro_box .text {}
.intro_box h3 { font-size:clamp(1.25rem,4vw,2.5rem); }
.intro_box h3 .sub { display:block; font-size:clamp(0.75rem,2.4vw,1.5rem); }

.yt_box { margin-bottom:clamp(3rem,10vw,6rem); }
.video_box { width:100%; aspect-ratio:16/9; margin-bottom:0.25rem; }
.video_box iframe { width:100%; height:100%; object-fit:cover; vertical-align:bottom; }

.vr_area { position:relative; margin-bottom:clamp(5rem,16vw,10rem); }
.vr_area .more_box { position:relative; z-index:50; }
.vr_area .more { position:absolute; right:0; top:clamp(-6rem,-10vw,-3.5rem); }
.vr_area::after { content:""; display:block; position:absolute; bottom:clamp(-3rem,-5vw,-1.5rem); left:calc(50% - clamp(1.5rem,50vw,60rem)); right:clamp(2.5rem,8vw,5rem); top:clamp(9rem,30vw,18rem); background:url(../img/honeycomb03.svg) left -5vw bottom -11vw /30vw no-repeat,linear-gradient(135deg,#fa0 40%,#fd0 100%); z-index:-1;  }
.vr_box { position:relative; }
.vr_box .date { position:relative;  }
.vr_box iframe { width:100%; aspect-ratio:16/9; }

.floor_area { position:relative; margin-bottom:clamp(3rem,10vw,6rem); }
.floor_area .more_box { position:relative; z-index:50; }
.floor_area .more { position:absolute; right:0; top:clamp(-6rem,-10vw,-3rem); }



/*COMPANY*/
.company_area { display:flex; flex-flow:row wrap; align-items:flex-start; justify-content:space-between; padding-bottom:clamp(3rem,10vw,6rem);}
.company_area .copy { writing-mode: vertical-rl; line-height:1.4; font-size:clamp(1.5rem,5vw,3rem); font-feature-settings:normal; white-space:nowrap; position:relative; z-index:50; width:clamp(4.5rem,14vw,9rem); margin-top:2rem; left:-2%; }
.company_area .text { width:calc(98% - clamp(4.5rem,14vw,9rem)); }
.company_box { background:url(../img/bg_company.webp) center center /cover no-repeat; color:#fff; padding:clamp(2rem,10vw,6rem) clamp(1.5rem,5vw,3rem); margin-top:clamp(-4rem,-6vw,-2rem); }
.company_box .more { color:#fff; border-bottom:1px solid #fff; background: url("../img/i_arrow_rw.svg") right center /1rem no-repeat; min-width:8rem;}

.staff_box { display:flex; flex-flow:row wrap; justify-content:space-between; margin:0 -1.5%; }
.staff_box h3 { position:relative; font-size:clamp(2rem,6vw,4rem); margin-bottom:clamp(-3rem,-5vw,-1.5rem); z-index:10; }
.staff_box a.staff { width:25%; position:relative; padding:0 1.5% 3% 1.5%; }
.staff_box a.staff .photo { position:relative; }
.staff_box a.staff .photo img {}
.staff_box a.staff .name { position:absolute; display:block; bottom:clamp(0.5rem,1.6vw,1rem); left:clamp(0.5rem,1.6vw,1rem); right:clamp(0.5rem,1.6vw,1rem); color:#fff; border-bottom:1px solid #fff; background: url("../img/i_arrow_rw.svg") right bottom 0.5rem /1rem no-repeat; font-size:clamp(1rem,2.4vw,1.5rem); line-height:1.5; font-weight:500; }
.staff_box a.staff .name .en { display:block; font-size:clamp(0.875rem,1.8vw,1.125rem); font-weight:400; }




.slick-list { }
button.slick-prev, button.slick-next { border: none; background:#222; width:2.5rem; height:2.5rem; overflow: hidden; position: absolute; z-index: 100; text-indent:-20rem; min-width:0; padding:0; margin: 0; border-radius:2rem; }
button.slick-prev:hover, button.slick-next:hover { background:#fa0 ; }
button.slick-prev { top:35%; left:-1rem; }
button.slick-prev::after { content:""; position: absolute; top:0.9rem; left:1rem; width:0.75rem; height:0.75rem; border-top:1.5px solid rgba(255,255,255,0.5); border-left:1.5px solid rgba(255,255,255,0.5); -webkit-transform:rotate(-45deg); transform: rotate(-45deg); }
button.slick-next { top:35%; right:-1rem; }
button.slick-next::after { content:""; position: absolute; top:0.9rem; right:1rem; width:0.75rem; height:0.75rem; border-top:1.5px solid rgba(255,255,255,0.5); border-right:1.5px solid rgba(255,255,255,0.5); -webkit-transform:rotate(45deg); transform: rotate(45deg); }


.b_box { display:flex; flex-flow:row wrap; justify-content:space-between;  }
.b_box a { display:block; width:48%;  margin-bottom:1rem; position:relative; }
.b_box a img { border-radius:0.5rem; }
.b_box a:hover img .b_box a:active img { opacity: 0.8; }




/*--FOOTER--*/
.contact_box { position:relative; background:url("../img/bg_contact.webp") center center /cover no-repeat; color:#fff; padding:clamp(2rem,6vw,4rem); display:flex; flex-flow:row wrap; text-shadow:1px 1px 0 rgba(0,51,102,0.1); /*margin-left:clamp(-3rem,-5vw,-1.5rem);*/ }
.contact_box::before { content:""; display:block; background:rgba(0,51,102,0.2); position:absolute; top:0; right:0; bottom:0; left:0; z-index:5; }
.contact_box::after { content:""; display:block; background:#630; position:absolute; top:10vh; right:calc(50% - 50vw); bottom:0; left:calc(50% - 50vw); z-index:-100; }
body.top .contact_box h2.en, body.temp .contact_box h2.en { font-size:clamp(2rem,6vw,4rem); position:relative; z-index:20; margin-bottom:0; line-height:1; }
body.top .contact_box h2.en::after, body.temp .contact_box h2.en::after { display:none; }
.contact_box .title { position:relative; z-index:10; white-space:nowrap; line-height:1.5; margin-right:clamp(2rem,6vw,4rem); }
.contact_box .title p { font-size:clamp(1rem,2vw,1.25rem); font-weight:500; }

.contact_box ul { position:relative; z-index:10; flex-grow:1; }
.contact_box ul li { } 
.contact_box ul li .tel { line-height:1; margin-bottom:clamp(1rem,3vw,2rem); font-weight:500; }
.contact_box ul li .tel strong { font-size:clamp(2rem,6vw,4rem); font-family: myriad-pro-semi-condensed, sans-serif; /*font-family:"corporate-a-std-urw-cond", serif;*/ font-weight:400; letter-spacing:normal; } 
.contact_box ul li .tel span { font-size:clamp(0.75rem,1.8vw,1.125rem); display: block; margin-bottom:0.5rem; }
.contact_box ul li .tel a { color:#fff; }
.contact_box ul li.mail a { display:block; padding:0.75rem 0.75rem 0.75rem 4.5rem; background:url(../img/i_mail_w.svg) left 1.25rem center /2rem no-repeat, linear-gradient(135deg,#fa0 40%,#fd0 100%); color:#fff; text-decoration:none; text-shadow:none; font-size:clamp(1rem,2.4vw,1.5rem); max-width:30rem; }


.footer { padding-top:4rem; padding-bottom: 5rem; position: relative; background: #630; color: #fff; font-size:0.875rem; }

.fm_box { display: flex; flex-flow: row wrap; justify-content: space-between; align-items: center; margin-bottom:1rem; }
.fm_box .f_logo { display: block; position: relative; color: #fff; text-decoration: none; }
.fm_box .f_logo span { display: block; position:absolute; left:105%; top:calc(50% - 0.875rem); white-space:nowrap;}
.fm_box .f_honten { color:#fff; margin-left:1rem; margin-right:auto; text-decoration:none; }
.fm_box a.f_honten::after { display:none !important; }

.fm_box .fm { padding-bottom:0; display: flex; flex-flow: row wrap; }
.fm_box .fm ul { margin:0; }
.fm_box .fm li { list-style:none; display:inline-block; }
.fm_box .fm li a { color: #fff; display: block; text-decoration: none; padding:0.75rem; }
.fm_box .fm li a::after{ content: "."; width: 0; font-size: 0; color: transparent; margin-right: 1px; }
.fm_box .fm li .contractors { margin-right: 0; padding-right:0; }

.footer .address_box { display: flex; flex-flow: row wrap; justify-content: space-between; align-items: flex-end; padding-top: 1rem; border-top: 1px solid rgba(255,255,255,0.3); }
.footer .address { }
.footer .address strong { font-weight:normal; }
.footer .copyright { font-size:0.7rem; }
.footer .copyright span.saikochiku { font-size:0.9rem; }

.footer .tel a { color:#fff;}

.pagetop { position:fixed; bottom:0; right: 0; width: 4rem; height: 4rem; z-index: 1000000; text-decoration: none; border-radius:50%; }
.pagetop::after { content:""; display: block; position: absolute; width: 1rem; height: 1rem; border-top:1px solid #630; border-left:1px solid #630; top:1.75rem; left:calc(50% - 0.5rem); -webkit-transform: rotate(45deg); transform: rotate(45deg); }
.pagetop::before { content:""; display: block; position: absolute; width: 1rem; height: 1rem; border-top:1px solid #fff; border-left:1px solid #fff; top:1.8rem; left:calc(50% - 0.5rem); -webkit-transform: rotate(45deg); transform: rotate(45deg); }


.footer .b_box { display:flex; flex-flow:row wrap; justify-content:center; margin:clamp(2rem,6vw,4rem) -1% 0  -1%;}
.footer .b_box li {width:20%; padding:1%; } 
.footer .b_box li a { width:100%; padding:0; border:1px solid rgba(255,255,255,0.2); text-align:center; display:flex; align-items:center; justify-content:center; text-decoration:none; line-height:1.5; margin:0; opacity:0.8; }
.footer .b_box li a:hover { opacity:1; border:1px solid rgba(255,255,255,0.3); }
.footer .b_box li a img { width:100%; max-width:15rem; } 
body.temp .footer .b_box { display:none; }

@media (max-width:960px) {
.footer .b_box li {width:25%; } 
}
@media (max-width:480px) {
.footer .b_box li {width:50%; } 
}



/*-- TEMPLARE CONTENTS --*/

body.temp .main { display:none; }


.hero { margin-bottom: 1.5rem; position:relative; }
.hero h1 { display: flex; flex-flow:row nowrap; align-items: center; position: relative; margin-bottom: 0.5rem; }
.hero h1 span { display: inline-block; padding-right:1rem; }
.hero h1 span::after, .hero .comment span::after { content: "."; width: 0; font-size: 0; color: transparent; margin-right: 1px; }
.hero h1::after { content: ""; position: relative; flex-grow:1; margin-left:1rem; border-bottom:0.5rem solid #fd0; }
.hero .comment { }
.hero .comment:empty { display: none; }

h2.bar { display: flex; flex-flow:row nowrap; align-items: center; position: relative; }
h2.bar::after { content: ""; position: relative; flex-grow:1; margin-left:1rem; border-bottom:0.5rem solid #fd0; }


.text_area { width:100%; padding:0; margin:0 auto; /*max-width:70rem;*/ }
.text_area:empty, index_area:empty { display:none; }
.text_area h5:first-of-type { margin-top:0 }


.para, .para_rev { width: 100%; padding-top:66.66%; overflow: hidden; position: relative; }
.para img { width: 100%; position: absolute; top:0; transition:top 0.02s; }
.para_rev img { width: 100%; position: absolute; bottom:0; transition:top 0.02s; }

.big_photo .photo.para, .big_photo .photo.para_rev { padding-top:50% ; }
.big_photo .photo.para img, .big_photo .photo.para_rev img { height: auto; }


.before { margin-bottom:1rem; }
.before::before {content:"BEFORE"; position: absolute; font-size:0.8rem; letter-spacing:0.05rem; line-height:1.25; display: block; padding:0 0.5rem 0.25rem 0; background:#fff;}
.after { margin-bottom:1rem; }
.after::before { content:"AFTER"; position: absolute; font-size:0.8rem; letter-spacing:0.05rem; line-height:1.25; display: block; padding:0 0.5rem 0.25rem 0; background:#fff; }
.construction { margin-bottom:1rem; }
.construction::before { content:"施工中"; position: absolute; font-size:0.8rem; letter-spacing:0.05rem; line-height:1.25; display: block; padding:0 0.5rem 0.25rem 0; background:#fff; }

.after02 { margin-bottom:1rem; position:relative; }
.after02::before { content:"AFTER"; position: absolute; top:-0.25rem; left:-0.5rem; font-size:0.8rem; letter-spacing:0.05rem; line-height:1.25; display: block; padding:0.25rem 0.5rem ; background:#fa0; color:#fff; }

.navibar { z-index:1010; margin:0 0 0.5rem 0; padding:0; }
.navibar ul { display: flex; flex-flow:row wrap; justify-content: flex-end; width:100%; margin:0; padding:0; font-size:0.75em; line-height:1.5; }
.navibar ul li { list-style-type:none; padding:0; display: inline-block; max-height:12rem; max-width: 12rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.navibar ul li em { font-weight:bold; font-style:normal; }
.navibar ul li::before { content:"／"; margin:10px 0; }
.navibar ul li:first-child::before { display:none; }
.navibar a { border:none !important; }
.navibar br { display:none !important; }
.navibar rt { display:none; }


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

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


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

.caption { display:block; font-size:90%; margin-bottom:0.5rem;}
.LR_box img + .caption, .LCR_box img + .caption { margin-top:-1rem; }
img + .caption { background:rgba(0,0,0,0.2); color:#fff; line-height:1.5; margin-top:-1.875rem; padding:0.25rem 0.5rem; margin-bottom:0; position:relative; }

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

ul.page-link { margin-bottom:1.5rem !important; }
ul.page-link li { display: inline-block; padding:0.25em 1em; margin:0; box-sizing:border-box; position:relative; white-space:nowrap; }
ul.page-link a::before { content:""; position:absolute; display:block; left:0; top:0.8rem; width:0.5em; height:0.5em; margin:0; border-top:1px solid #222; border-right:1px solid #222; transform:rotate(135deg); box-sizing:border-box; }
.f_s ul.page-link a::before { top:0.9rem;}

ul.page-link li#post-128 { display:none; } 

body.page-contractors ul.page-link { display:none !important; }


/*-- INDEX --*/
body.temp .index_area { width:105%; -webkit-display:flex; flex-direction:row; display:flex; flex-flow:row wrap; justify-content:flex-start; align-items: flex-start; padding:0; margin:0 -2.5% !important; }

.index_box { display:inline-block; position:relative; width:33.3%; vertical-align:top; box-sizing:border-box; text-align:left; padding:0 2.5% 5% 2.5%; }
.index_box a { display:block; width:100%; padding:0; text-decoration:none !important; color:#222 !important; }
.index_box .photo { width:100%; max-width:100vw; margin:0 0 0.5rem 0; position:relative; aspect-ratio:3/2; }
body.page-property .index_box .photo { aspect-ratio:16/9; }
.index_box .photo img { width:100%; height:100%; object-fit:cover; background:center center /100% no-repeat; transition:1s; }
.index_box a:hover { text-decoration:none; opacity:1; color:#222; }
.index_box a:hover strong { color:#fa0; }
.index_box a:hover .photo img { background:center center /120% no-repeat; }

.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:#f4ede6; background:rgba(242, 235, 227, 0.9); background:#fa0; color:#fff; padding:0 0.5rem; margin:0 0.5rem 0.5rem 0; border-radius:0.25rem; white-space:nowrap; }
/*.index_box .cate_box .cate::after{ content: "."; width:0; font-size:0; color: transparent; margin-right: 1px; }*/
.index_box .new { font-size:0.8rem; display:inline-block; padding:0 0.5rem; background:#ff8e65; color:#fff; text-align:center; z-index:10; }
.index_box .text { display:flex; flex-grow:1; flex-flow:column nowrap; padding:0; }
.index_box .date { font-size:0.8rem; display: none; }
.index_box .comment { font-size:0.8rem; display: block; }
.index_box .title { line-height:1.5; background:url(../img/i_arrow_r.svg) left -0.2rem top 0.4rem /1rem no-repeat; padding-left:1rem; font-size:1.125rem; }
.index_box strong { display:block; /*display:flex; justify-content:space-between;*/ align-items:flex-start; position: relative; font-size:1.125rem; color:#222; line-height:1.75; letter-spacing:0.1rem; font-weight:normal; font-weight: bold; }
.tag { display:flex; flex-flow:row wrap; padding:0.5rem 0 0 0; }
.tag span { font-size:0.7rem; background:#222; color:#fff; padding:0 0.5rem 0.1rem 0.5rem; margin:0.5rem; text-align:center; border-radius:1rem; }


.index_box a[target='_blank'] .title::after,
.LCR_box a[target='_blank']::after,
body.link .article li a[target='_blank']::after,
body.link .article a:link[target='_blank']::after,
.article a:link[target='_blank']::after
 { content:""; position:relative; display:inline-block; vertical-align:middle; width:1.2em; height:1.2em; margin:0 0.25em; 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.6em; line-height:1; width:auto !important; height:auto !important; padding:0.2em 0.5em 0.25em 0.5em ; letter-spacing:normal; color:#e55; font-weight:bold; background:#fff !important; margin:0 0.25em; 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.6em; line-height:1; width:auto !important; height:auto !important; padding:0.2em 0.5em 0.25em 0.5em; letter-spacing:normal; color:#7da52b; font-weight:bold; background:#fff !important; margin:0 0.25em; 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.6em; line-height:1; width:auto !important; height:auto !important; padding:0.2em 0.5em 0.25em 0.5em; letter-spacing:normal; color:#7b8d42; font-weight:bold; background:#fff !important; margin:0 0.5em; 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; }

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


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


body.archive .contents { display: flex; flex-flow:row wrap; justify-content: space-between; /*max-width:1080px;*/ margin:auto; }
body.archive .index_area { width: calc(100% - 10rem); margin:0 0 calc(1rem + 5vw) -1.5% !important; display: inline-flex; flex-flow:row wrap; box-sizing:border-box; } 
body.archive .text_area { width: calc(100% - 10rem); margin:0 0 calc(1rem + 5vw) 0; display: inline-block; box-sizing:border-box; padding-right:2rem; } 
body.archive .side { display: inline-block; vertical-align: top; width: 8rem; } 
body.archive .side h5 { margin-top:0; margin-bottom:0.5rem; }
body.archive .side ul { padding-left:1.0rem; margin:0 0 2rem 0; font-size:0.9rem; }
body.archive .side ul li::marker { color:#ddd; }

body.archive .index_box { width:100%; padding: 0 1.5%; }
body.archive .index_box a { display:flex; }
body.archive .index_box .date { display: inline-block; }
body.archive .index_box strong::after { display: none; }
body.archive .index_box .photo { width: 25vw; min-width: 96px; max-width: 140px; margin-right: 1rem; aspect-ratio:1; }
body.archive .index_box .photo img { width:100%; height:100%; object-fit: cover; font-family:'object-fit:cover;';  }
body.archive .index_box .text { padding:0; }
body.archive .index_box .cate_box { margin-top:0.5rem; }
body.archive .index_box .i_tag { font-size:0.8rem; left:0.5rem; display: none; }




.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; }
.date_box .cate { font-size:0.75rem;  display:inline-block; background:#f4ede6; background:rgba(242, 235, 227, 0.9); background:#fa0; color:#fff; padding:0 0.5rem; margin:0 0.5rem 0.5rem 0; border-radius:0.25rem; white-space:nowrap; }

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

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




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


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



.b_back { display:inline-block; -webkit-appearance:none; overflow:visible; width:auto; background:#ff8e65; position:relative; padding:10px 20px 10px 40px; height:50px; line-height:30px; font-size:1.2em; letter-spacing:0; margin:10px; border:none; color:#222 !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 #222; border-right:2px solid #222; transform:rotate(45deg); box-sizing:border-box; }

.button:hover, input[type="button"]:hover, input[type="submit"]:hover { /*text-decoration:none; background:#fa0; color:#fff;*/ opacity:0.7; }

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

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

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

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:#222 url("../img/i_arrow_rw.svg") right 0.75rem center /1rem no-repeat; color: #fff; border-radius:2rem; }
input.button:hover { /*background:#fa0 url("../img/i_arrow_rw.svg") right 0.75rem center /1rem no-repeat;*/ opacity:0.7; }

.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%; }
.w67 { width: 67%; }
.w66 { width: 66%; }
.w65 { width: 65%; }
.w60 { width: 60%; }
.w55 { width: 55%; }
.w50 { width: 50%; }
.w49 { width: 49%; }
.w48 { width: 48%; }
.w47 { width: 47%; }
.w45 { width: 45%; }
.w40 { width: 40%; }
.w35 { width: 35%; }
.w33 { width: 33.33%; }
.w32 { width: 32%; }
.w30 { width: 30%; }
.w25 { width: 25%; }
.w24 { width: 24%; }
.w20 { width: 20%; }
.w15 { width: 15%; }
.w10 { width: 10%; }
.w5 { width: 5%; }

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



.mt-8 { margin-top: -0.5rem !important; }
.mt0 { margin-top: 0 !important; }
.mt8 { margin-top: 0.5rem !important; }
.mt16 { margin-top: 1rem !important; }
.mt24 { margin-top: 1.5rem !important; }

.mb0 { margin-bottom: 0 !important; }
.mb8 { margin-bottom: 0.5rem !important; }
.mb16 { margin-bottom: 1rem !important; }
.mb24 { margin-bottom: 1.5rem !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; }

.ml0 { margin-left: 0 !important; }
.ml4 { margin-left: 0.25rem !important; }
.ml8 { margin-left: 0.5rem !important; }
.ml16 { margin-left: 1rem !important; }
.ml24 { margin-left: 1.5rem !important; }
.mra { margin-right: auto; }
.mla { margin-left: auto; }


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

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

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

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


.hissu { display: inline-block; background:#b35; color:#fff; font-size:0.7rem; padding:0.1rem 0.25rem; vertical-align: middle; position: relative; margin:-0.1rem 0.15rem 0.25rem 0; }
.ninni {display: inline-block; background:rgba(60, 38, 33, 0.2); color:#fff; font-size:0.7rem; padding:0.1rem 0.25rem; vertical-align: middle; position: relative; margin:-0.1rem 0.15rem 0.25rem 0; }



/*--お問い合わせ--*/
body.contact .contact_box { 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: #924; 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:#924; }
.wpcf7 form .wpcf7-spinner { display:block; margin:auto; }
form.wpcf7-form > br:first-of-type { display:none; }
.wpcf7-list-item { margin:0; }

/*プライバシーポリシー*/
.pp_box { text-align: left; max-height:400px; overflow-y: auto; padding: 1.5rem; border:1px solid #888; line-height:1.7; }
.pp_box ol { /*padding-left:1.5rem;*/ }

.grecaptcha-badge { opacity:0; }

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

ul { }

/*-- リスト/ --*/
ol { counter-reset:step; list-style:none; margin:0 0 2rem 0; padding:0; }
ol li{ padding:0; margin:0 0 1rem 2.4rem; }
ol > li::before { counter-increment:step; content:counter(step); background:#222; vertical-align:middle; display:inline-block; width:1.6rem; line-height:1.6rem; letter-spacing:normal; font-size:0.8rem; font-weight:bolder; text-align:center; border-radius:50%; color:#fff; margin:-0.3rem 0.4rem 0 -2rem; position:relative; }
ol ol { margin:0.5rem 0 1rem 0; }
ol li li { padding:0 0 0 2rem; margin:0 0 0.25rem 0; }
ol li li::before { counter-increment:step; content:counter(step); background: rgba(60, 38, 33, 0.7); vertical-align:middle; display:inline-block; width:1.4rem; line-height:1.4rem; letter-spacing:normal; font-size:0.8rem; font-weight:normal; text-align:center; border-radius:50%; color:#fff; margin:-0.3rem 0.4rem 0 -2rem; }
ol > li h4, ol > li h5, ol > li h6 { vertical-align:top; display:inline-block; margin:0 0 0.5rem 0; line-height:1.5; }
ol li ul { padding:0 0 0 1.2rem; }
ol li ul li { padding:0; margin:0; }
ol li ul li::before { counter-increment:none; content:none; margin:0; }
ol li strong { /*color:#f77;*/ font-size:1.2rem; }
.value { background:#222; vertical-align:middle; display:inline-block; width:1.6rem; line-height:1.6rem; font-size:1rem; font-weight:bolder; text-align:center; border-radius:50%; color:#fff; margin:-0.3rem 0.4rem 0 0; }

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


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 { background:#090; display:inline-block; width:2.4rem; height:2.4rem; line-height:2.2rem; font-weight:bold; text-align:center; border-radius:50%; color:#fff; font-size:1rem; margin:0 0.4rem 0 -2.8rem; }
ol.faq li ol { display:inline-block; vertical-align:top; }
ol.faq >li h6.i_close { color:#e70; }

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

.q { padding-right:2rem; position:relative; }
.q::before { content:"Q. "; display:inline-block; margin-right:0.25rem; transition:0.25s; color:#924; }
.q::after { content:"＋"; position:absolute; right:0; display:inline-block; transition:0.25s; /*color:#924;*/ }
.q.i_close::after { transform:rotate(-45deg); }
.a::before { content:"A. "; display:inline-block; font-weight:bold; margin-right:0.25rem; transition:0.25s; color:#7b8d42; font-size:1.4rem; }


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

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

.table01 { border-bottom:1px dashed rgba(60, 38, 33, 0.2); }
.table01 th, .table01 td { border-top:1px dashed rgba(60, 38, 33, 0.2); }
.table01 thead th { }
.table01 th { /*font-weight:bolder;*/ text-align:left; }
.table01 td { }

.table02 { border-bottom:1px solid rgba(60, 38, 33, 0.2); }
.table02 th, .table02 td { border-top:1px solid rgba(60, 38, 33, 0.2); }
.table02 thead th, .table02 thead td { background: #f4ede6; }
.table02 th { /*font-weight:bolder;*/ text-align:left; white-space:nowrap; }
.table02 td { }
.table02 td.tr { width:auto; }

.table03 { border:1px solid rgba(60, 38, 33, 0.2); border-left:1px dotted rgba(60, 38, 33, 0.2); border-right:1px dotted rgba(60, 38, 33, 0.2); }
.table03 th, .table03 td { border:1px solid rgba(60, 38, 33, 0.2); border-left:1px dotted rgba(60, 38, 33, 0.2); border-right:1px dotted #eee; }
.table03 thead th, .table03 thead td { background: #f4ede6; }
.table03 th { /*font-weight:bolder;*/ text-align:left; }
.table03 td { }

.l_double { border-top:3px double rgba(60, 38, 33, 0.2); }
.l_dashed th, .l_dashed td { border-top:1px dashed rgba(60, 38, 33, 0.2) !important; }
th p, td p { margin:0; }



/*-- 幅の広いテーブルにスクロール表示 --*/
.scroll, #calcResult { overflow:auto; }
.scroll::-webkit-scrollbar, #calcResult::-webkit-scrollbar { height:15px; /*tableにスクロールバーを追加*/}
.scroll::-webkit-scrollbar-track, #calcResult::-webkit-scrollbar-track { background:rgba(0,0,0,0.1); /*tableにスクロールバーを追加*/}
.scroll::-webkit-scrollbar-thumb, #calcResult::-webkit-scrollbar-thumb { background:rgba(110, 185, 43,0.5);/*tableにスクロールバーを追加*/}
.scroll table, #calcResult table { margin-bottom:20px !important; }


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

/*WP管理バー 検索ボタン*/
#wpadminbar .adminbar-button { display:none !important; }


.bg_yonago { width:100vw; height:40vw; margin-bottom:clamp(1.5rem,5vw,3rem);  position:relative; background:url(http://www.bitchuya.co.jp/wp-content/uploads/2025/05/yonago.webp) center center /cover no-repeat; }
.bg_yonago img { width:100%; height:100%; object-fit:cover; }
@media (max-width:640px) {
.bg_yonago { height:60vw; }
}




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

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


/*資格*/
table.shikaku { max-width:600px; margin:auto;}

/*SDGs*/
.flex.sdgs { display: flex; flex-flow:row nowrap; border-radius:0; }
.flex.sdgs .photo { width: 140px; padding-right: 1rem; }
.flex.sdgs .text { width:calc(100% - 140px); }

.index_box.sdgs {}
.index_box.sdgs .icon { display:flex; flex-flow:row wrap; align-items:flex-start; justify-content:center; margin:-20% auto 1rem auto; position:relative; z-index:10; }
.index_box.sdgs .icon img { margin:0 0.5rem; width:35%; min-width:100px; height:auto !important; }

@media (max-width:480px) {
.flex.sdgs .photo { width: 100px; }
.flex.sdgs .text { width:calc(100% - 100px); }
}

.text_area .tel strong { font-size:2.4rem; line-height:1; font-weight: bold; font-family:'Roboto Condensed', sans-serif; }


/*STEP*/
.step_area { counter-reset: count; margin:0; position: relative; }
.step_box { padding: 1rem 0 1rem 4rem; margin: 0; position: relative; }
.step_box::before { content: ""; display: block; width: 3rem; height:3rem; background: #fa0; border-radius: 50%;position: absolute; top: 0.5rem; left: 0;}
.step_box::after {content: ""; display: block; height: calc(100% - 3rem); border-left: solid 2px rgba(34,34,34,0.1); position: absolute; top:3.5rem; left: calc(1.5rem - 1px); }
.step_label { color: #fff; font-weight: bold; font-size: 9px; position: absolute; text-align: center; top: 0.75rem; left:0; width: 3rem; }
.step_label::after { counter-increment: count; content: counter(count); position: absolute; font-size: 1.4rem; text-align: center; line-height: 1.5; top:0.7rem; left: 0; width: 3rem;}
.step_box h4 { }
.step_text { margin-top: 1em; padding: 0 0 2em; border-bottom: dotted 2px rgba(34,34,34,0.2);}
.step_area > :last-of-type::after { display: none;}


#timerex_calendar { }
#timerex_calendar > div { overflow-x: scroll; }
#timerex_calendar > div iframe { overflow-x: scroll; }





@media all and (max-width: 768px) and (orientation:portrait) {
	.hero h1 span::after{ content: "."; width: 0; font-size: 0; color: transparent; margin-right: 1px; white-space:nowrap; }
}
@media all and (max-width: 1024px) and (orientation:landscape) {
	.hero h1 span::after{ content: "."; width: 0; font-size: 0; color: transparent; margin-right: 1px; white-space:nowrap; }
}

.insert-page-8 h2 { display:none; }
.text_inner .hl { text-align:center; }

/*歴史*/
.timeline { max-width:1000px; margin:auto ;}
.timeline .item { position:relative; padding:0; margin:0 auto; vertical-align:top; border-bottom:0; border-left:0; }
.timeline .label, .timeline .text { /*display:block; max-width:70%;*/ margin:0; }
.timeline .label { position:absolute; top:0; left:0.2rem; left:0; text-align:left; padding:0.75rem 0; }
.timeline .text { position:relative; display:inline-block; vertical-align:top; margin:0 0 0 6rem; border-left:2px solid rgba(34,34,34,0.1); padding:0.75rem 1rem 0.75rem 1.75rem ; width: calc(100% - 4.5rem) !important; }
.timeline .text::before { content:'●'; position:absolute; font-size:1.2rem; top:0.5rem; left:-0.65rem; color:#fd0; }
.timeline .item:last-of-type .text { padding-bottom:0; /*border:none;*/ }
.timeline .item:last-of-type .text:before { content:'▼'; position:absolute; font-size:0.8rem; top:auto; bottom:-1.1rem; left:-0.45rem; color:rgba(34,34,34,0.1); }
.timeline img { width:100%; max-width:100vw; }

@media (max-width:960px) {
.timeline .label { font-size:0.8rem; top:0; left:0.2em; left:0; text-align:left; }
.timeline .text { margin:0 0 0 4.5rem; padding:0.75rem 0.5rem 0.75rem 1.5em ; }
}

@media (max-width:480px) {
.timeline img { width:calc(100% + 2rem); max-width:calc(100% + 2rem); margin:0 -1rem; }
}

/*ギャラリースライド*/
.fotorama__thumb-border{ border-color:#fa0; }
.fotorama__stage__shaft { background:#630;}
.fotorama__caption__wrap { background:rgba(102,51,0,0.8);}


/*REFORM コンテンツ*/
/*リフォームの流れ*/
body.page-flow .step { line-height:1.5; min-height:7rem;   }
body.page-flow h3 { display:flex; flex-flow:column wrap; align-items:flex-start; justify-content:center; position:relative; }
body.page-flow h3::after { content:""; position:absolute; display:block; background:#f8f4e6; right:clamp(1rem,3vw,2rem); top:2rem; bottom:-1rem; left:calc(50% - 50vw); z-index:-30;}
body.page-flow .step01 { background:url(../img/i_flow01.svg) center right /7rem no-repeat; }
body.page-flow .step02 { background:url(../img/i_flow02.svg) center right /7rem no-repeat; }
body.page-flow .step03 { background:url(../img/i_flow03.svg) center right /7rem no-repeat; }
body.page-flow .step04 { background:url(../img/i_flow04.svg) center right /7rem no-repeat; }
body.page-flow .step05 { background:url(../img/i_flow05.svg) center right /7rem no-repeat; }
body.page-flow .step strong { display:inline-block; /*background:#f8f4e6; padding:0.5rem 1rem; margin-bottom:0.5rem; color:#fa0;*/ margin-bottom:0.5rem; font-size:1rem; letter-spacing:normal; border-radius:1rem; line-height:1; text-align:center; }
/*body.page-flow .step strong::after { content:""; display:block; width:clamp(4rem,12vw,8rem); height:clamp(4rem,12vw,8rem); background:url(../img/hexagon.svg) center center /cover no-repeat; position:absolute; top:calc(50% - clamp(2.75rem,10vw,6rem)); left:clamp(-3rem,-5vw,-1.5rem); z-index:-1; }*/
body.page-flow .step strong span {display:inline-block;  font-size:4rem; margin:-1rem 0 0  0.25rem; position:relative;  }

.photo3box { position:relative; display:flex;  }
.photo3box .photo:nth-of-type(1) { width:35%; margin:5% 0 0 0;}
.photo3box .photo:nth-of-type(2) { width:35%; margin:20% -10% 0 -10%; z-index:10;}
.photo3box .photo:nth-of-type(3) { width:50% ;}
.photo3box img { border-radius: 0.5rem;}







@media screen and (max-width:960px) {
body { font-size:0.9rem; }
.pc_no { display:block; }
br.pc_no { display:inline-block; }
.sp_no, br.sp_no { display:none; }
span.sp_no { display:none; }
.f_l { font-size:1.2rem }
	
.img_pc { display:none; }
.img_sp { display:block; }
	
.article, body.temp .article { padding-top:6rem; }
.anchor { height:6rem; margin-top:-6rem; z-index:-10; width:1px; }
body.logged-in .anchor { height:calc(6rem + 32px); margin-top:calc(-6rem - 32px); }
.sticky { position:sticky; top:6rem; }
body.logged-in .sticky { top:calc(6rem + 32px); }

.header {}
.header .inner { padding:0.75rem; }	

.hm { display:none; } 	
	
.t_title, .header.bg .t_title {  }
.t_title::after { top:-1rem; text-align: center; font-size:0.65rem; letter-spacing:0.05rem; white-space:nowrap; }

.main { padding:0; position: relative; margin:0 calc(50% - 50vw) calc(10vh + clamp(3rem,10vw,6rem)) calc(50% - 50vw); max-width:120rem;}


/*ヘッダメニュー*/
.sns_box { position: relative; right:0; }
.mean-container .mean-nav ul li.mean-last {  } 
.mean-container .mean-nav ul li.hm_tel .tel { background:url(../img/i_tel_w.svg) left 0.5rem center /1rem no-repeat; font-size:1.5rem; padding-left:1.75rem; color:#fff; letter-spacing:normal; }
.mean-container .mean-nav ul li.hm_tel .tel a { color:#fff; padding-left:0; line-height:1.5;}
.mean-container .mean-nav ul li.hm_tel .tel .en { letter-spacing:normal;}
	
.h_contact, .h_contact.bg, body.logged-in .h_contact, body.logged-in .h_contact.bg { display:-webkit-flex; flex-direction:-webkit-row; flex-wrap:-webkit-nowrap; position: fixed; top:auto; bottom:0; left:0; right:0; background:#fff; background:#222; z-index:1000; height:4rem; width:100vw; max-width:100vw; border-top: 1px solid rgba(255,255,255,0.3); line-height: 1.25; border-radius:0; justify-content:flex-start; }
.h_contact li {display: block; width:25%; }
.h_contact li a { display: block; width:100%; height: 4rem; line-height:1.25; color: #fff; text-decoration: none; text-align:center; font-size: 10px; font-weight:normal; position: relative; letter-spacing: 0; padding:2.5rem 0 0.5rem 0; }
.h_contact li .contact, .h_contact li .contact:hover { background: url("../img/i_mail_w.svg") top 0.35rem center /2.25rem no-repeat; }
.h_contact li .consult, .h_contact li .consult:hover { background: url("../img/i_consult_w.svg") top 0.35rem center /2.25rem no-repeat; }
.h_contact li .shop, .h_contact li .shop:hover { background: url("../img/i_shop_w.svg") top 0.35rem center /2.25rem no-repeat; }
.h_contact li.hm_tel { display:none; }
.h_contact li a::before { display: block; width: 100%; position: absolute; bottom:0.7rem; left: 0; text-align: center; }

.h_contact li a::after { display: none; }
.h_contact li a span { display:inline-block; }

	
/*スクロールナビ*/
.scrollnav > li a:hover { margin-left: 0; background: none; padding-left: 2rem; }


h1, h2, h3, h4, h5 { letter-spacing:0.1rem; position: relative; }
h1 { font-size:1.5rem; }
h2 { font-size:1.4rem; }
h3 { font-size:1.3rem;}
h4 { font-size:1.2rem;}
h5 { font-size:1.1rem;}
h6 { font-size:1.0rem;}

body.temp h2 span { white-space: normal; padding-right: 0.5rem; }

h1 .comment, h2 .comment, h3 .comment, h4 .comment, h5 .comment { font-size:0.8rem; }
.comment::after{ content: "."; width: 0; font-size: 0; color: transparent; margin-right: 1px; white-space:nowrap; }



/*PROJECT*/
.project_area { padding-top:clamp(5rem,16vw,10rem); }
.project_area::after { top:clamp(4rem,12vw,8rem); }
.project_area::before {   }


/*--COMPANY--*/
.staff_box a.staff { width:50%; }

/*--SNS--*/
.sns_widget { max-width:500px; margin: auto; }
.sns_widget ul { flex-flow:column wrap; }
.sns_widget ul li { width:100%; padding:0; }





/*--ABOUT--*/
.coordinate { flex-flow:column wrap; height: auto; min-height: auto; padding:3rem 0 0 0; }

.coordinate h2, .after_follow h2 { font-size:1.4rem; }
.coordinate .text, .after_follow .text { justify-content: flex-start; width:94%; padding:5% 0; height: auto; margin:0 auto; order:2; }
.coordinate .photo { width:100%; margin: 0; /*margin:0 -5.5% 1rem -5.5%; height:25vh;*/ }
.coordinate .photo .p01 { height:40vw; min-height:40vw; }
.coordinate .photo .p02 { height:40vw; min-height:40vw; }
.coordinate .photo .p03 { height:40vw ;min-height:40vw; }

.after_follow { flex-flow:column wrap; height: auto; min-height: auto; padding:0; }
.after_follow .photo { width:100%; margin:0; height:45vw; /*margin:0 auto; background-size:100%;*/ order:1; }
.coordinate .photo img, .after_follow .photo img { width:100%; } 
.after_follow .text div { width:100%; }
.after_follow .text .more { margin:auto; }
	
/*--BUSINESS--*/
.biz_area { padding:2rem 0 0.1rem 0; }
.biz_area h2 { margin-bottom:2rem; }
.biz_area h2::after { height:3rem; bottom: -3.5rem;}
.biz_area .photo { padding-top:50%; }
.biz_area .tatami_box .photo { background:url("../img/biz_tatami.jpg") top 85% center /cover no-repeat; }

.biz_area .text, .biz_area > div:nth-of-type(2n + 0) .text { width:calc(100% - 3rem); top:-2rem; left:1.5rem; padding:3% 5%; }
.biz_area .text strong { font-size:1.2rem; }
.biz_area .text span { font-size:0.8rem; }

.biz_area a::after { top:10vw; left:-5vw; right:-5vw; z-index:-1; padding-top:50%; border-radius:0; }
.biz_area > div:nth-of-type(2n + 0) a::after { top:10vw; left:-5vw; right:-5vw; }



/*--WORKS--*/
.works_area { padding:2rem 0; }
.works_area h2 { margin-bottom:1.5rem;}
.works_area h2::after { display:none; } 


/*--CONTACT_CONSULT--*/
.contact_area { padding: 2rem 5%; background-position: top left; margin-bottom:0; }
.contact_area h2 { font-size: 1.2rem; margin-bottom:1rem; }
.contact_area .tel strong { font-size:2.6rem; }
.contact_area .time { margin-bottom:2rem; }
.contact_area ul { flex-flow:column wrap; justify-content: center; }
.contact_area ul li { width:100%; margin:0.5rem auto ; }
.contact_area ul li a { ; padding:1.25rem 0.5rem 1.25rem 4.5rem ; max-width:20rem; border-radius:4rem; }
.contact_area ul li a strong { display: block; font-size:1.1rem; }
.contact_area ul li a span { font-size:0.75rem; }
.contact_area ul li.mail a { background-size:3.5rem; }
.contact_area ul li.consult a { background-size:3.5rem; }



/*--RECRUIT--*/
.recruit_area { display: flex; flex-flow: column wrap; padding:2rem 0 0 0; }
.recruit_area .photo { height:50vw; max-height: none; border-radius:0.5rem; }
.recruit_area .text { }
.recruit_area .text strong { font-size:1.2rem; }

/*--FOOTER--*/
.contact_box ul { flex-flow: column wrap; }
.contact_box ul li { width:100%; min-width:15rem; max-width:24rem; padding: 0.5rem 0; }
.contact_box ul li::before { width: 3rem; height:3rem; margin-right:0.5rem; }
.contact_box ul li > div, .contact_box ul li a { /*width: calc(100% - 3.25rem);*/ }

.footer { padding-top:3rem; padding-bottom:3rem; }
.fm_box .f_logo { width:10rem; }
.fm_box .f_logo::after { top:-1.5rem; font-size:0.75rem; }
.footer .fm { width:100%; display:none; }
.fm_box .fm { padding-top:1rem; border-top: 1px solid rgba(255,255,255,0.3); }
.fm_box .fm li { width:33%; }
/*.fm_box .fm li:nth-of-type(3n + 0) { width: 48%;}*/
.fm_box .fm li a { color: #fff; text-decoration: none; padding:0.75rem 0.5rem 0.75rem 0; line-height:1.25; }
/*.fm_box .fm li .contractors { letter-spacing:normal; }*/




body.cate .index_area,
body.page .text_area { min-height:auto; }


.navibar { display:none; }
.navibar ul { width:100%; margin:0; padding:0; font-size:0.75em; line-height:1.5;; }



/*お知らせ*/
body.archive .index_area { width:103%; margin:0 -1.5% 1.5rem -1.5% !important; }
body.archive .index_box, body.archive .text_area { width:100%; }
body.archive .side { display: flex; width:100%; margin:0 auto calc(1rem + 5vw) auto; border-top:1px solid rgba(0, 0, 0, 0.3); padding-top:1rem; }
body.archive .side >  div { width:50%; } 

/*-- INDEX --*/
.index_area { width:106%; margin:0 -3%; }

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

body.info .index_box { width:100%; padding:1rem 0; border-top:1px solid rgba(0, 0, 0, 0.1); }
body.info .index_box .photo { width:25vw; max-width:120px; }

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


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



.col2 { column-count:1; }

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

.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;}
.resp68 { width:68% !important; }
.resp67 { width:67% !important; }
.resp66 { width:66% !important;}
.resp65 { width:65% !important;}
.resp60 { width:60% !important;}
.resp55 { width:55% !important;}
.resp50 { width:50% !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;}
.resp5 { width:5% !important;}
.resp0 { width:0% !important;}

.resp49 { width:49% !important;}
.resp32 { width:32% !important;}

.resp_ma { margin:auto; }
.resp_mla { margin-left:auto; }
.resp_mra { margin-right:auto; }


/*リフォームの流れ*/
body.reform .step { background-size:7rem; }


}



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

}


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



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

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

.main { margin-bottom:10vh;}
.main::before { height:calc(60vw + 10vh);}
.main::after { right:-5vw; top:0; height:calc(60vw + 11vw); }
.main_img { width:100vw; height:60vw;}
	
.main .main_copy { top:auto; bottom:1.5rem; }

/*--INFO--*/
.info_area .info_box { width:100%;}

.company_area .copy { left:-4%;}


table th, table td { padding:1rem 0.2rem; }


ul.li_half { flex-flow:column wrap; } 
ul.li_half li { width:100%;} 

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

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

.w32, .w49, .w66  { width: 100%; }
.flex.noresp .w32 { width:32%; }
.flex.noresp .w49 { width:49%; }
.flex.noresp .w50 { width:50%; }
.flex.noresp .w66 { width:66%; }
.resp_w100 { width:100%;  }
.resp_w49 { width:49%; }
.resp_w50 { width:50%; }
.index_box.sdgs { width:100%; }
	
/*WordPress*/
.aligncenter { display:block;margin: 0 auto; text-align: center; }
.alignright { float:none; display:block; margin:0 auto 1rem auto; }
.alignleft { float:none; display:block; margin:0 auto 1rem auto; }
img[class*="wp-image-"],
img[class*="attachment-"] { max-width: 100%; height: auto; }
img.alignright, img.alignleft, .alignright img, .alignleft img { width:100%; max-width:300px; }
.alignright img, .alignleft img { margin: auto; }

.LCR_box, .LCR_box2 { width:100% !important; padding:20px 0; padding:0 0 1.5rem 0;  margin:0; overflow:visible !important; }


}


@media screen and (max-width:480px) {
.index_box .cate_box { font-size:0.7rem; }
	
/*--INFO--*/
.info_area .info_box .index_area .index_box a, body.archive .index_area .index_box a { flex-flow:row wrap; }
.info_area .info_box .index_area .index_box .date, body.archive .index_area .index_box .date { font-size: 0.9rem; display: block; color:#999; padding:0.1rem 1rem 0 0; }
.info_area .info_box .index_area .index_box .text, body.archive .index_area .index_box .text { width:100%; padding-left:1.25rem;}
.info_area .info_box .index_area .index_box .new { background:#fa0; left:-2.75rem; top:0.7rem; letter-spacing:normal; }

}


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

}


@media print{
.article, body.temp .article { padding-top:9rem; } 
.header, .h_contact { position:absolute; }
.main, body.logged-in .main { height:55vw; padding:0 0 4rem 0;  } 
.bg_video { min-width:100%; min-height:50%; }
.fadein, .fadeinUp, .fadeinLeft, .fadeinRight { opacity : 1; transform : translate(0, 0); }
.coordinate .photo .p01, .coordinate .photo .p02, .coordinate .photo .p03 { height:15vw; }

}

.no-support { display:none; line-height:1.5; padding:0.5rem 1rem; background:#f9e3e9; }
html.no-flexbox .no-support, html.no-flexboxlegacy .no-support {display:block;}
html.no-flexbox .header, html.no-flexboxlegacy .header {position:absolute; left:calc(50% - 50vw); right:calc(50% - 50vw);}
html.no-flexbox .h_contact, html.no-flexboxlegacy .h_contact {position:absolute; right:calc(50% - 50vw);}

