@charset "UTF-8";
/*トップページCSS*/
i{font-style:normal;}
a{color:#000;text-decoration:none;transition:0.3s ease-in-out;}
a:hover{opacity:0.85;filter:alpha(opacity=85);}
i,u,em{text-decoration:none;font-style:normal;font-weight:normal;}
em{font-family:"Oswald", sans-serif;font-weight:400;}
q{font-weight:bold;}

img{border-style:none;}
a img{border-style:none;}
html{max-width:100%;min-height:100%;-webkit-text-size-adjust:100%;font-size:16px;} 
body{font-family:"Noto Sans JP",YuGothic, "Yu Gothic",meiryo,"ＭＳ Ｐゴシック",  "ヒラギノ角ゴ Pro W3", sans-serif;font-weight:500;position:relative;overflow-x:hidden;-webkit-text-size-adjust:100%;width:100%;line-height:2.0;background:#fff;}
p{font-family:"Noto Sans JP",YuGothic, "Yu Gothic",meiryo,"ＭＳ Ｐゴシック",  "ヒラギノ角ゴ Pro W3", sans-serif;font-weight:500;font-size:16px;}
body.admin-bar #coverIMG{height:calc(130vh - 32px);}
main{background:#fff;box-sizing:border-box;margin:0 auto;max-width:100%;overflow-x:hidden;}
body{max-width:100%;overflow-x:hidden;}

time{display:block;line-height:15px;font-family:"Oswald", sans-serif;font-weight: 400;font-weight:bold;}
a.link{display: table;margin: 50px auto;min-width: 210px;box-sizing: border-box;background:#4D4D4D;font-size:17px;color: #fff !important;text-shadow:1px 1px 0 rgba(6, 6, 6, .7);text-align:center;padding:.6em 2em;font-weight:500;text-decoration: none !important;position:relative;box-shadow:1.5px 1.5px 3px rgba(0,0,0,0.3);}
a.BTN{display:block;width:350px;padding:15px;margin:0 auto;background-color:#a59759;border-radius:100px;border:3px solid #a59759;font-size:20px;color:#fff;text-align:center;cursor:pointer;}
a.BTN:hover{background:#fff;color:#a59759;opacity:1;}
h2{font-family:"Noto Sans JP",YuGothic, "Yu Gothic",meiryo,"ＭＳ Ｐゴシック",  "ヒラギノ角ゴ Pro W3", sans-serif;font-size:60px;}
h3{font-family:"Noto Sans JP",YuGothic, "Yu Gothic",meiryo,"ＭＳ Ｐゴシック",  "ヒラギノ角ゴ Pro W3", sans-serif;font-size:30px;}
h4{font-family:"Noto Sans JP",YuGothic, "Yu Gothic",meiryo,"ＭＳ Ｐゴシック",  "ヒラギノ角ゴ Pro W3", sans-serif;font-size:25px;}
h5{font-family:"Noto Sans JP",YuGothic, "Yu Gothic",meiryo,"ＭＳ Ｐゴシック",  "ヒラギノ角ゴ Pro W3", sans-serif;font-size:25px;}
li{list-style:none;}
.ls00{letter-spacing:normal;}
.ls01{letter-spacing:0.05em;}
.ls02{letter-spacing:0.1em;}
.humBTN{display:none;}
.spHeader{display:none;}
#humBOX{display:none;}

.pcOnly{display:block!important;}
.spOnly{display:none!important;}

main h2.title{text-align:center;font-size:40px;line-height:1.4;margin-bottom:40px;letter-spacing:0.25em;}
main h2.title em{display:block;font-family:"Oswald", sans-serif;font-size:80px;letter-spacing:0;}
main h3.title{font-family:"Marcellus", sans-serif;}

div.grecaptcha-badge{display:none!important;}
body:has(main#contact-page) div.grecaptcha-badge{display:block!important;}


.imgLEFT,
.imgRIGHT{display:flex;justify-content:space-between;align-items:center;}
.imgRIGHT{flex-direction:row-reverse;}

body.admin-bar header.fixed{top:32px;}
header{position:absolute;height:60px;top:0;right:0;width:100%;z-index:5;transition:0.5s;opacity:0;animation:start02 0.8s ease-out 1 forwards;}
header h1{width:140px;height:150px;position:absolute;left:60px;top:40px;transition:0.5s;}
header h1 > a{display:block;width:100%;height:100%;background:url(../top/logo.webp) no-repeat center center / contain;}
header ul{position:absolute;top:40px;right:0;width:800px;display:flex;flex-wrap:wrap;justify-content:flex-end;align-items:center;transition:0.5s;}
header ul li{height:60px;display:flex;align-items:center;justify-content:center;width:calc(100% / 6 - 20px);transition:0.5s;}
header ul li.gn06{width:calc(100% / 6 + 100px);}
header ul li a{font-size:16px;color:#fff;text-shadow:2px 2px 4px #0000004d;}
header ul li a:hover{opacity:.6;}
header.fixed{position:fixed;background:#000;}
header.fixed h1{width:150px;height:150px;left:0;top:0;margin:0;background-color:#fff;}
header.fixed h1 > a{background:#fff url(../top/logo.webp) no-repeat center center / 100px;}
header.fixed ul{margin:0;top:0;}
header.fixed ul li{width:calc(100% / 6);}
header.fixed ul li a{font-size:15px;}
header.fixed ul li.gn06{background:#a59759;}
header.fixed ul li.gn06 a{width:100%;height:100%;text-align:center;vertical-align:middle;display:flex;justify-content:center;align-items:center;}
header.fixed ul li.gn06:hover{opacity:.8;}

@keyframes start02{0%{opacity:0;}100%{opacity:1;}}

footer{width:100%;position: relative;}
footer .fContainer{width:1200px;margin:0 auto;padding:50px 0;}
footer .fContainer nav.fNavi ul{width:900px;margin:0 auto;display:flex;justify-content:space-between;}
footer .fContainer nav.fNavi ul li{font-size:15px;margin-top:5px;}
footer .fContainer nav.fNavi ul li a{color:#000;}
footer .fContainer div.fLogo{text-align:center;font-size:17px;}
footer .fContainer div.fLogo a.fLogo{display:inline-block;width:100px;height:100px;background:url(../top/logo.webp) no-repeat right center / contain;margin:60px 0 20px 0;}
footer .fContainer div.fLogo address{font-size:13px;color:#000;}
footer .fContainer div.fLogo ul li a{color:#000;}
footer .fContainer nav.fNavi.second ul{width:fit-content;margin:0 auto 30px auto;}
footer .fContainer nav.fNavi.second ul li{padding:0 20px;font-size:12px;position: relative;}
footer .fContainer nav.fNavi.second ul li:last-child::after,
footer .fContainer nav.fNavi.second ul li:before{content:'';display: block;width: 1px;height: 10px;background:#666;position: absolute;left: 0;top: 0;bottom: 0;margin: auto;}
footer .fContainer nav.fNavi.second ul li:last-child::after{left: auto;right: 0;}
/* ページトップへ*/
#pagetop{width:auto;display:block;position:absolute;right:50px;bottom:50px;transition:0s ease-in-out;z-index:4;transition:0s ease-in-out;}
#pagetop a{padding-right:13px;color: #a59759;font-weight:400;font-size:13px;position:relative;}
#pagetop a:after{content:"";display:block;width:1px;height:300px;background-color:#a59759;position:absolute;bottom:0;right:0;margin:auto;right:0;animation:pagetop 3s infinite;}
@keyframes pagetop{
  0%{transform:scale(1, 0);transform-origin:0 100%;}
  50%{transform:scale(1, 1);transform-origin:0 100%;}
  51%{transform:scale(1, 1);transform-origin:0 0;}
  100%{transform:scale(1, 0);transform-origin:0 0;}
}



/*固定ページ（共通？）*/
p.scroll{color:#fff;position:absolute;bottom:150px;left:60px;writing-mode:vertical-lr;}
p.scroll:after{display:block;animation:scroll 2s infinite;background-color:#fff;bottom:-95px;content:"";height:80px;left:0;margin:auto;position:absolute;right:0;width:1px;}
@keyframes scroll{
  0%{transform:scale(1, 0);transform-origin:0 0;}
  50%{transform:scale(1, 1);transform-origin:0 0;}
  51%{transform:scale(1, 1);transform-origin:0 100%;}
  100%{transform:scale(1, 0);transform-origin:0 100%;}
}

section#busLink{background:url(../layout/busLink.webp) no-repeat top center / cover;height:600px;background-attachment:fixed;position:relative;}
section#busLink:before{content:'';display:block;width:100%;height:100%;background:rgba(0,0,0,.5);position:absolute;top:0;bottom:0;left:0;right:0;margin:auto;z-index:1;}
section#busLink .busWrap{display:block;width:fit-content;height:fit-content;padding: 0 20px;position:absolute;top:0;bottom:0;left:0;right:0;margin:auto;z-index:3;}
section#busLink h3{margin-bottom:40px;color:#fff;text-align:center;font-size:30px;line-height:1.5;}
section#busLink h3 em{display:block;margin-top:60px;font-size:60px;}
section#busLink h3 span{display:block;background:#fff;color:#000;width:fit-content;margin:20px auto;padding:10px 25px;border-radius:10px;}
section#busLink a.BTN{border-radius:100px;background:#009fe7;border-color:#009fe7;}
section#busLink a.BTN:hover{background:#fff;color:#009fe7;}
@keyframes fadeUP{100%{opacity:1;transform:translateY(0);}}
@keyframes fadeIN{100%{opacity:1;}}
@keyframes slideIN{100%{transform:translateX(0%);opacity:1;}}

/*固定ページ（会社案内）*/
#titleIMG h2{opacity:0;transform:translateY(50px);animation:fadeUP 1s ease-in-out 0s 1 forwards;}
#company-page #pageField{}
#company-page #com01{}
#company-page #com01 .com01-1{position:relative;}
#company-page #com01 .com01-1 >div{background-color:#a59759;padding:200px 0 50px;position:relative;}
#company-page #com01 .com01-1 h3{text-align:center;color:#fff;line-height:1.2;opacity:0;}
#company-page #com01 .com01-1 h3 em{display:block;font-size:80px;}
#company-page #com01 .com01-1 h4{background-color:#a59759;color:#fff;width:500px;padding:15px 0;text-align:center;margin:80px auto 0;font-size:30px;opacity:0;}
#company-page #com01 .com01-message .com01-1 h4{margin-top:150px;}
#company-page #com01 .com01-1 p{text-align:center;background:#fff;color:#a59759;font-size:30px;font-weight:bold;padding:20px 0;border-bottom:6px solid #a59759;margin-top:50px;}
#company-page #com01 .com01-1 p span{opacity:0;}
#company-page #com01 .com01-1 p.scroll{font-size:15px;color:#fff;background:no-repeat;padding:0;border:none;margin:0;bottom:130px;}
#company-page #com01 .com01-1.fade h3{animation:fadeIN 1s ease-in-out 0s 1 forwards;}
#company-page #com01 .com01-1.fade p span{animation:fadeIN 1s ease-in-out 0s 1 forwards;}
#company-page #com01 .com01-1.fade h4{animation:fadeIN 1s ease-in-out 0s 1 forwards;}

#company-page #com01 .com01-2{display:flex;flex-wrap:nowrap;justify-content:space-between;margin:50px 100px;}
#company-page #com01 .com01-2 div.fadeLeft{width:400px;min-height:460px;background:url(../company/com01-1.webp) no-repeat center right / 400px auto;transform:translateX(-150%);opacity:0;}
#company-page #com01 .com01-message .com01-2 div.fadeLeft{background-image:url(../company/com01-2.jpg);}
#company-page #com01 .com01-2 div.fadeRight{width:calc(100% - 500px);transform:translateX(150%);opacity:0;}
#company-page #com01 .com01-2.fade div.fadeLeft{animation:slideIN 1s ease-in-out 0s 1 forwards;}
#company-page #com01 .com01-2.fade div.fadeRight{animation:slideIN 1s ease-in-out 0.5s 1 forwards;}

#company-page #com01 .com01-2 div p.midashi{font-size:25px;margin-bottom:20px;color:#a59759;font-weight:bold;}
#company-page #com01 .com01-2 div h5{font-size:20px;margin:15px 0 5px;font-weight:bold;display:flex;align-items:center;}
#company-page #com01 .com01-2 div h5:before{content:'';display:inline-block;width:5px;height:20px;background-color:#a59759;margin-right:8px;}
#company-page #com01 .com01-2 div p{margin-bottom:20px;}
#company-page #com01 .com01-2 div p span{font-weight:bold;font-size:20px;border-bottom:1px solid #000;margin:0 5px;}
#company-page #com01 .com01-2 .signature{text-align:right;}
#company-page #com01 .com01-2 .signature span{font-size:25px;margin-left:10px;font-weight:bold;}
#company-page #com02{position:relative;padding:100px;background:linear-gradient(0deg, #333, #000);margin-top:150px;}
#company-page #com02 > div{background:#a5975900;padding:100px;box-sizing:border-box;display:flex;justify-content:space-between;border-radius:30px;}
#company-page #com02 h3{color:#fff;font-size:40px;line-height:1.5;text-align:right;transform:translateX(-150%);opacity:0;}
#company-page #com02 h3 span{display:block;font-size:15px;}
#company-page #com02 table{width:calc(100% - 250px);transform:translateX(150%);opacity:0;}
#company-page #com02 tr{}
#company-page #com02 tr th{background:#333;color:#fff;border-bottom:1px solid #fff;padding:20px;}
#company-page #com02 tr td{background:#fff;color:#333;border-bottom:1px solid #000;padding:20px;}
#company-page #com02 tr td iframe{width:100%;height:220px;margin-bottom:30px;}
#company-page #com02 tr td iframe:last-child{margin-bottom:0;}
#company-page #com02 tr:last-child th , #company-page #com02 tr:last-child td{border:none;}
#company-page #com02.fade > div{animation:com02 0.7s ease-in-out 1.2s 1 forwards;}
#company-page #com02.fade h3{animation:slideIN 1s ease-in-out 0s 1 forwards;}
#company-page #com02.fade table{animation:slideIN 1s ease-in-out 0.5s 1 forwards;}
@keyframes com02{100%{background:#a59759;}}
#company-page #com03{background:linear-gradient(180deg, #333, #000);padding:100px 0;}
#company-page #com03 > *{color:#fff;}
#company-page #com03 h3{text-align:center;font-size:40px;line-height:1.5;}
#company-page #com03 h3 span{display:block;font-size:15px;}
#company-page #com03 .com03_wrap{max-width:1200px;margin:50px auto;display:flex;flex-wrap:wrap;position:relative;}
#company-page #com03 .com03_wrap:before{content:'';display:block;width:1px;height:100%;background-color:#fff;position:absolute;top:20px;left:50%;}
#company-page #com03 .com03_box{width:calc(50% - 100px);opacity:0;transform:translateY(50px);}
#company-page #com03 .com03_box.fade{animation:fadeUP 1s ease-in-out 0s 1 forwards;}
#company-page #com03 .com03_box:nth-of-type(2n - 1){text-align:right;margin-right:100px;}
#company-page #com03 .com03_box:nth-of-type(2n){text-align:left;margin:100px 0 0 100px;}
#company-page #com03 .com03_box .com03_year{color:#a59759;font-size:18px;position:relative;}
#company-page #com03 .com03_box .com03_year span{content:'';display:block;width:90px;height:1px;background-color:#fff;position:absolute;top:0;bottom:0;margin:auto 0;right:-100px;}
#company-page #com03 .com03_box:nth-of-type(2n) .com03_year span{right:auto;left:-100px;}
#company-page #com03 .com03_box .com03_year span:after{content:'';display:block;width:15px;height:15px;border-radius:50%;background-color:#a59759;position:absolute;top:0;bottom:0;right:-8px;margin:auto 0;}
#company-page #com03 .com03_box:nth-of-type(2n) .com03_year span:after{right:auto;left:-7px;}
#company-page #com03 .com03_box .com03_p{font-size:22px;}

#company-page ul.imgContainer li:first-child{width:100%;aspect-ratio:auto;margin-bottom:30px;opacity:0;transform:translateY(50px);}
#company-page ul.imgContainer.fade li:first-child{animation:fadeUP 1.5s ease-in-out 0s 1 forwards;}
.lb-outerContainer{margin:50px auto 0;}

/*固定ページ（お問い合わせ）*/
/*#contact-page #con01 .con01-1{background-color:#000;padding:200px 0 100px;position:relative;}
#contact-page #con01 .con01-1 p{color:#fff;width:1200px;margin:0 auto;}
#contact-page #con01 .con01-1 p span{opacity:0;}
#contact-page #con01 .con01-1 p.scroll{font-size:15px;color:#fff;background:no-repeat;padding:0;margin:0;width:auto;border:none;bottom:250px;}
#contact-page #con01 .con01-1.fade p span{animation:fadeIN 1s ease-in-out 0s 1 forwards;}*/
#contact-page #con02{width:800px;margin:100px auto 200px;}
#contact-page #con02 > p{border-bottom:2px solid #a59759;font-size:20px;}
#contact-page #con02 table{width:100%;margin:50px 0;}
#contact-page #con02 tr{}
#contact-page #con02 tr th{text-align:right;}
#contact-page #con02 tr th p:after{content:"任意";display:inline-block;padding:3px 12px;border-radius:5px;font-weight:bold;line-height:15px;margin-left:10px;font-size:11px;color:#fff;text-align:center;background:#069ee5;}
#contact-page #con02 tr.required th p:after{content:"必須";display:inline-block;padding:3px 12px;border-radius:5px;font-weight:bold;line-height:15px;margin-left:10px;font-size:11px;color:#fff;text-align:center;background:#e50014;}
#contact-page #con02 tr td{background:#fff;color:#333;padding:20px;}
#contact-page #con02 tr td input,
#contact-page #con02 tr td textarea{border:1px solid #a59759;padding:10px;border-radius:5px;width:100%;box-sizing: border-box}
#contact-page #con02 tr.todouhuken td{padding-right:0;}
#contact-page #con02 tr td span[data-name="todouhuken"]{position:relative;}
#contact-page #con02 tr td span[data-name="todouhuken"]:after{content:'';display:block;width:15px;height:12px;clip-path:polygon(0 0, 100% 0%, 50% 100%);background:#e50014;position:absolute;top:0;bottom:0;right:15px;margin:auto 0;}
#contact-page #con02 tr td span[data-name="todouhuken"] select{background:#d8d8d8;border:1px solid #a59759;padding:10px;border-radius:5px;width:calc(100% - 20px);-webkit-appearance:none;appearance:none;}
#contact-page #con02 div.privacy{border:2px solid #a59759;border-radius:10px;padding:50px;margin-bottom:100px;}
#contact-page #con02 div.privacy h3{text-align:center;font-size:22px;border-bottom:2px solid #a59759;margin-bottom:20px;padding-bottom:10px;}
#contact-page #con02 div.privacy > p{}
#contact-page #con02 div.privacy ul{margin-top:25px;}
#contact-page #con02 div.privacy ul li{list-style:inside;}
#contact-page #con02 div.privacy ul li p{display:inline;}
#contact-page #con02 div.privacy a{display:block;font-size:15px;padding:2px 8px;width:fit-content;margin:20px auto;background:#000;color:#fff;border-radius:5px;border:1px solid #000;transition:0.5s;}
#contact-page #con02 div.privacy a:hover{background:#fff;color:#000;}
#contact-page #con02 div.privacy p > span{}
#contact-page #con02 div.privacy p > span:after{content:"必須";display:inline-block;padding:3px 12px;border-radius:5px;font-weight:bold;line-height:15px;margin-left:10px;font-size:11px;color:#fff;text-align:center;background:#e50014;}
#contact-page #con02 div.privacy span[data-name="privacy"]{margin:0 auto;display:block;width:fit-content;}
.mfp_buttons{text-align:center;}
.mfp_buttons input, .mfp_buttons button{display:inline-block;min-width:210px;box-sizing:border-box;background:#a59759;font-size:20px;color:#fff;text-align:center;padding:.4em 2em .6em 2em;font-weight:500;text-decoration:none !important;position:relative;border-radius:25px;border:none;line-height:1.5;cursor:pointer;-webkit-appearance:none;border:1px solid #a59759;transition:0.5s;}
.mfp_buttons input:hover{background:#fff;color:#a59759;}
.mfp_buttons button{background:#b3b8be;border:1px solid #b3b8be;}
.mfp_buttons button:hover{background:#c9ced5;}

/*サンクスページ*/
#thanks-page #pageField{padding:200px 0; text-align:center;background:#333;color:#fff;}
#thanks-page #pageField h3{border-bottom:3px solid #a59759;width:fit-content;margin:0 auto 50px;}
#thanks-page #pageField a.BTN{margin-top:50px;}

/*404ページ*/
#error-page #pageField{padding:200px 0; text-align:center;background:#333;color:#fff;}
#error-page #pageField h3{border-bottom:3px solid #a59759;width:fit-content;margin:0 auto 50px;}
#error-page #pageField a.BTN{margin-top:50px;}

@media screen and (max-width:1400px){
}
@media screen and (max-width:1300px){
}
@media screen and (max-width:1250px){
}
@media screen and (max-width:1200px){
}
@media screen and (max-width:1150px){
}
@media screen and (max-width:1100px){
}
@media screen and (max-width:1000px){
}
@media screen and (max-width:950px){
}
@media screen and (max-width:900px){
}
@media screen and (max-width:800px){
}
@media screen and (max-width:768px){
}
@media screen and (max-width:700px){
}
@media screen and (max-width:650px){
}
@media screen and (max-width:600px){
}
@media screen and (max-width:580px){
}
@media screen and (max-width:500px){
}
@media screen and (max-width:414px){
}
@media screen and (max-width:320px){
}
