@charset "UTF-8";
/*webフォント読み込み*/
@font-face { /*ZenKakuGothicNew-Bold*/
font-family: 'zem'; src: url("../fonts/ZenMaruGothic-Bold.ttf"); src: url("../fonts/ZenMaruGothic-Bold.woff2") format("woff2"), url("../fonts/ZenMaruGothic-Bold.woff") format("woff"), url("../fonts/ZenMaruGothic-Bold.ttf") format("truetype"); font-weight: 700; }
@font-face { /*ZenKakuGothicNew-Medium*/
font-family: 'zem'; src: url("../fonts/ZenMaruGothic-Medium.ttf"); src: url("../fonts/ZenMaruGothic-Medium.woff2") format("woff2"), url("../fonts/ZenMaruGothic-Medium.woff") format("woff"), url("../fontsZenMaruGothic-Medium.ttf") format("truetype"); font-weight: 500; }
/* Link
=========================================== */
a:link, a:visited { color: #1F1F1F; text-decoration: none; }

a { outline: none; transition: 0.3s; color: #1F1F1F; text-decoration: none; }

a img { transition: 0.3s; }

:focus { outline: none; }

/* 共通設定
=========================================== */
.pc { display: none !important; }

html.showPage body.home { min-width: inherit; background: url("../img/common/bg01-sp.png") no-repeat center top #fff; background-size: 100%; }

body { overflow: hidden; background-color: #fff; color: #1F1F1F; font-size: 16px; line-height: 1.6; font-family: 'zem',"メイリオ","Mayryo ","ヒラギノ角ゴ Pro W3","ＭＳ Ｐゴシック","MS PGothic",sans-serif; font-style: normal; font-weight: 500; overflow-wrap: anywhere; /* 収まらない場合に折り返す */ word-break: normal; /* 単語の分割はデフォルトに依存 */ line-break: strict; /* 禁則処理を厳格に適用 */ }

h1, h2, h3, h4, h5, h6 { line-height: 1.5; font-weight: 700; }

body#tinymce { min-width: inherit !important; }

input, select, textarea { font-family: 'zem',"メイリオ","Mayryo ","ヒラギノ角ゴ Pro W3","ＭＳ Ｐゴシック","MS PGothic",sans-serif; font-weight: 500; color: #000; letter-spacing: 0; }

select { border-radius: 0; color: #000; background: #fff; }

table { width: 100%; }

img { max-width: 100%; height: auto; width: 100%; }

.no-pc { display: inline-block; text-decoration: none !important; }

.inb { display: inline-block; }

.block { display: block; }

.wrap { position: relative; }

div#f-trigger { z-index: -2; top: 60px; position: absolute; width: 100%; }

/*共通見出し設定*/
.titles01 { font-weight: 700; line-height: 1.6; text-align: center; margin-bottom: 40px; padding-bottom: 30px; background: url("../img/common/tit-ico01.svg") no-repeat center bottom; }
.titles01 .en { color: #259EA7; font-size: 20px; }
.titles01 .jp { font-size: 40px; display: block; }

.titles02 { font-weight: 700; line-height: 1.6; text-align: center; margin-bottom: 40px; padding-bottom: 30px; background: url("../img/common/tit-ico02.svg") no-repeat center bottom; color: #fff; }
.titles02 .en { font-size: 20px; }
.titles02 .jp { font-size: 40px; display: block; }

.titles03 { margin-bottom: 8px; font-size: 18px; font-weight: 700; position: relative; padding-left: 18px; }

.titles03:before { content: ""; width: 8px; height: 8px; border-radius: 100%; position: absolute; left: 0; top: 11px; border-radius: 100%; background: #259EA7; }

/*共通ボタン設定*/
.btn01 { width: 100%; height: 70px; display: table; }
.btn01 a { display: table-cell; text-align: left; vertical-align: middle; text-decoration: none; color: #fff; padding: 5px 58px 5px 40px; border-radius: 40px; background: #EE6318; border: solid 1px #EE6318; position: relative; font-weight: 700; }
.btn01 a .arrow { position: absolute; z-index: 2; right: 25px; top: 50%; transform: translateY(-50%); width: 20px; height: 20px; border-radius: 100%; display: flex; flex-wrap: wrap; justify-content: center; align-items: center; background: #fff; border: solid 1px #EE6318; transition: 0.3s; }
.btn01 a .arrow img { width: 10px; display: block; opacity: 1; transition: 0.3s; }

.btn01.contact-btn { width: 100%; height: 100px; }
.btn01.contact-btn a { padding-left: 0; padding-right: 0; text-align: center; font-size: 24px; border-radius: 50px; }
.btn01.contact-btn a .ico { position: absolute; z-index: 2; right: 25px; top: 50%; transform: translateY(-50%); width: 50px; height: 50px; border-radius: 100%; display: flex; flex-wrap: wrap; justify-content: center; align-items: center; background: #fff; border: solid 1px #EE6318; transition: 0.3s; }
.btn01.contact-btn a .ico img { width: 18px; display: block; opacity: 1; }
.btn01.contact-btn a:hover .ico { background: #EE6318; }
.btn01.contact-btn a:hover .ico img { filter: brightness(0) saturate(100%) invert(100%) sepia(100%) saturate(0%) hue-rotate(288deg) brightness(102%) contrast(102%); }

/*グラデーション*/
.gra-bg { display: inline-block; padding: 5px 12px; background: linear-gradient(120deg, #D80000 0%, #D80000 20%, #D85E00 100%); color: #fff; border-radius: 10px; }

.gra-text { background: linear-gradient(180deg, #D80000 0%, #D85E00 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; display: inline-block; }

/*スライダー　ふわっ*/
div#mv-slider, div.item-mains, div.item-thumbs, div.item-slider.flex, div.slider02, div.slider03, div.des-slider, div.gallery-slider, div.gallery-thumbs { opacity: 0; transition: opacity .3s linear; }

div#mv-slider.slick-initialized, div.item-mains.slick-initialized, div.item-thumbs.slick-initialized, div.item-slider.flex.slick-initialized, div.slider02.slick-initialized, div.slider03.slick-initialized, div.des-slider.slick-initialized, div.gallery-thumbs.slick-initialized, div.gallery-slider.slick-initialized { opacity: 1; }

/*font*/
.zem { font-family: 'zem'; }

.tright { text-align: right; }

.tleft { text-align: left; }

.tcenter { text-align: center; }

.flL { float: left; }

.flR { float: right; }

.bold { font-weight: bold; }

.inb { display: inline-block; }

.block { display: block; }

.red { color: #C90714; }

.red02 { color: #ff0000; }

.blue { color: #0075A4; }

.blue02 { color: #0093D6; }

.brown { color: #C07E23; }

.yellow { color: #FFD400; }

.orange { color: #EE6318; }

.green { color: #259EA7; }

.d-green { color: #005E4B; }

.green02 { color: #01A9AE; }

.navy { color: #374b8e; }

.pink { color: #ff7373; }

.gray { color: #818181; }

/*header
---------------------------------------------------------------*/
div#header { position: fixed; left: 0; top: 0; width: 100%; z-index: 210; height: 60px; }

div#header .logo { width: 222px; position: absolute; z-index: 230; left: 5.33vw; top: 10px; height: 50px; box-sizing: border-box; }
div#header .logo img { width: 222px; max-width: none; display: block; }

div#gnav { display: none; }

.fixed div#header { background: #fff; box-shadow: 0 0 6px rgba(0, 0, 0, 0.6); }

/* nav
=========================================== */
html.huopen { overflow: hidden; }

.sp-nav-btn { width: 50px; height: 50px; position: fixed; top: 10px; right: 5.33vw; z-index: 232; box-sizing: content-box; background: url("../img/common/menu-open.svg") no-repeat center bottom 4px; background-size: auto 9px; }

.sp-nav-btn span.bar01 { content: ""; width: 46%; height: 3px; position: absolute; top: 7px; right: 27%; transition: 0.3s; background: #EE6318; border-radius: 3px; }

.sp-nav-btn span.bar03 { content: ""; width: 46%; height: 3px; position: absolute; top: 21px; right: 27%; transition: 0.3s; background: #EE6318; border-radius: 3px; }

.sp-nav-btn span.bar02 { position: absolute; width: 46%; height: 3px; top: 14px; right: 27%; transition: 0.3s; background: #EE6318; border-radius: 3px; }

.sp-nav-btn.opon { background-image: url("../img/common/menu-close.svg"); background-size: auto 11px; }

.sp-nav-btn.opon span.bar02 { opacity: 0; }

.sp-nav-btn.opon span.bar01 { box-shadow: none; transform: rotateZ(45deg); top: 14px; }

.sp-nav-btn.opon span.bar03 { transform: rotateZ(-45deg); top: 14px; }

.overlay-nav { display: none; }

.overlay-nav.opon { z-index: 15; opacity: 1; }

div.navs-list-wrap { position: fixed; width: 100%; height: 100%; z-index: 220; top: 0; box-sizing: border-box; background: url("../img/common/sp-nav-bg.jpg") repeat-y center top; background-size: 100%; right: calc(-100% - 60px); transition: 0.3s; padding: 90px 5.33vw 50px; }

div.navs-list-wrap.opon { right: 0; }

ul.navs-list { height: calc(100vh - 90px); overflow: auto; box-sizing: border-box; padding: 0 0 50px; position: relative; }

ul.navs-list > li { background: url("../img/common/line01.svg") repeat-x left bottom; }
ul.navs-list > li > a { display: block; padding: 20px 13px; }
ul.navs-list > li > a > div { display: flex; flex-wrap: wrap; align-items: center; }
ul.navs-list > li > a > div .ico { width: 34px; text-align: center; margin-right: 24px; }
ul.navs-list > li > a > div .ico img { width: auto; height: 30px; }
ul.navs-list > li > a > div .text { width: calc(100% - 58px); font-size: 20px; font-weight: 700; }
ul.navs-list > li.nav02 > a > div .ico img { height: 26px; }
ul.navs-list > li.snav-contact { padding: 0; background: none; }
ul.navs-list > li.snav-contact .contact-set.flex { margin-top: 30px; }
ul.navs-list .tel-num a { color: #1F1F1F; }

/* contents */
/*-------------------------------------------*/
.bg-blue { background: #F5F9FF; }

/*パンくず
---------------------------------------------------------------*/
div#bread { z-index: 2; position: relative; padding: 15px 5.33vw 0; }

#bread ul li { display: inline-block; font-size: 14px; font-weight: 500; color: #1F1F1F; line-height: 1.4; }

ul.bread-list li a { font-size: 14px; color: #259EA7; }

ul.bread-list li:after { content: "-"; margin-left: 10px; margin-right: 5px; display: inline-block; position: relative; color: #259EA7; }

ul.bread-list li:last-child:after { content: none; }

/* メインビジュアル */
/*-------------------------------------------*/
/*TOPページ*/
div#mv { position: relative; z-index: 3; }

/* footer */
/*-------------------------------------------*/
aside#aside01 { padding: 1px 5.33vw 100px; color: #fff; background: #259EA7; }

.contact-set.flex { margin-top: 60px; justify-content: center; }
.contact-set.flex .btn01 { margin-bottom: 40px; }

.aside-telBox .tit { padding-left: 68px; font-size: 18px; margin-bottom: 5px; }
.aside-telBox .tel-num a { padding-left: 68px; font-size: 46px; background-size: 50px; color: #fff; line-height: 1; padding-bottom: 10px; }
.aside-telBox .bh { text-align: right; font-size: 16px; }

div#footer { padding-top: 50.66vw; background: url("../img/common/bg04-sp.png") no-repeat center top; background-size: 100%; }

div.ft-inner { background: #fff; padding: 60px 5.33vw 50px; }
div.ft-inner .wrap { width: 100%; }

div#ftBox01 { padding-bottom: 60px; }
div#ftBox01 .wrap .ft-info { margin-bottom: 60px; }

h2.ft-logo { max-width: 290px; margin: 0 auto 30px; }

.ft-address { margin-bottom: 10px; }

.ft-tel-set .tel-set { display: flex; flex-wrap: wrap; align-items: center; }
.ft-tel-set .tel-set .bh { margin-left: 10px; }

.tel-num a { font-weight: 700; font-size: 20px; padding-left: 40px; background: url("../img/common/tel-ico02.svg") no-repeat left center; background-size: 30px; }

.bh { font-size: 11px; font-weight: 700; }

div#fnav { display: flex; flex-wrap: wrap; justify-content: space-between; }
div#fnav > div { width: calc(50% - 20px); }
div#fnav > div:last-child { width: 100%; margin-top: 15px; }
div#fnav > div:last-child ul.fs { display: flex; flex-wrap: wrap; justify-content: space-between; }
div#fnav > div:last-child ul.fs > li { width: calc(50% - 20px); margin-bottom: 0; }

ul.fs > li { margin-bottom: 15px; }
ul.fs > li:last-child { margin-bottom: 0; }

div.ft-bottom .wrap { padding: 30px 0 0; background: url("../img/common/line01.svg") no-repeat left top; }
div.ft-bottom .wrap .copyright { font-size: 12px; text-align: center; margin-top: 40px; }

ul.pp-list.flex { width: auto; justify-content: center; }
ul.pp-list.flex li { font-size: 14px; }
ul.pp-list.flex > li:after { content: "　／　"; }
ul.pp-list.flex > li:last-child:after { content: none; }

/* TOPへ戻る */
/*-------------------------------------------*/
div#top-link { position: absolute; left: 0; top: 0; opacity: 0; z-index: -20; }

div#page-top { position: fixed; right: 20px; bottom: 50px; opacity: 0; z-index: -3; transition: opacity 0.3s; width: 80px; }

div#page-top a { display: block; width: 80px; height: 80px; border-radius: 100%; background: #fff; border: solid 2px #000000; text-align: center; box-sizing: border-box; padding-top: 16px; line-height: 1; font-size: 15px; font-weight: 700; text-decoration: none; position: relative; }

div#page-top a .text { display: block; margin-top: 3px; font-size: 19px; font-weight: 700; }

div#page-top a:before { content: ""; background: url("../img/common/char01.png") no-repeat; background-size: 87px; width: 87px; height: 110px; transition: 0.3s; position: absolute; bottom: 0; right: 63px; }

.fixed div#page-top { opacity: 1; z-index: 6; }

/* iOSでのデフォルトスタイルをリセット */
input[type="password"], textarea, input[type="text"], input[type="submit"], input[type="button"] { border-radius: 0; -webkit-box-sizing: content-box; -webkit-appearance: button; appearance: button; box-sizing: border-box; cursor: pointer; }

input[type="password"]::-webkit-search-decoration, textarea::-webkit-search-decoration, select::-webkit-search-decoration, input[type="text"]::-webkit-search-decoration, input[type="submit"]::-webkit-search-decoration, input[type="button"]::-webkit-search-decoration { display: none; }

input[type="password"]::focus, textarea::focus, select::focus, input[type="text"]::focus, input[type="submit"]::focus, input[type="button"]::focus { outline-offset: -2px; }

select { color: #222; padding: 5px; box-sizing: border-box; }

/* TOP
------------------------------------------*/
.home div#mv { padding: calc(60px + 13.33vw) 5.33vw 5.33vw; box-sizing: border-box; min-height: 639px; }

div.mv-set01 { position: relative; }
div.mv-set01 .textBox { position: relative; z-index: 2; }
div.mv-set01 .textBox .text { font-size: 4.8vw; font-weight: 700; }
div.mv-set01 .img { width: 82.66vw; margin-left: auto; margin-top: 6.4vw; }

.mv-copy01 { font-size: 10.66vw; font-weight: 700; margin-bottom: 5.33vw; line-height: 1.4; }

.mv-set02 { margin: 0 auto; position: relative; margin-top: -8.63vw; }
.mv-set02 .top-news { margin-bottom: 5.33vw; }
.mv-set02 .top-news h2.news-tit { width: 29.86vw; background: #259EA7; border-radius: 10.13vw; color: #fff; box-sizing: border-box; line-height: 10.13vw; text-align: center; font-size: 4.8vw; font-weight: 700; margin: 0 auto -5.06vw; z-index: 2; position: relative; }
.mv-set02 .top-news .news-area { width: 100%; background: #fff; border-radius: 2.66vw; box-sizing: border-box; padding: 10.66vw 5.33vw 8vw; box-shadow: 0 4px 4px rgba(0, 0, 0, 0.025), 6px 6px 30px rgba(0, 0, 0, 0.06); }

article.top-news-art { width: 100%; }
article.top-news-art a { text-decoration: none; align-items: center; display: block; position: relative; }
article.top-news-art a .n-date { font-size: 4.26vw; margin-bottom: 1.6vw; }
article.top-news-art a .n-tit { width: 100%; line-height: 1.6; display: -webkit-box; overflow: hidden; -webkit-line-clamp: 2; -webkit-box-orient: vertical; font-size: 4.26vw; }
article.top-news-art a span.arrow { margin-left: auto; width: 5.33vw; height: 5.33vw; background: #EE6318; border-radius: 100%; display: flex; flex-wrap: wrap; align-items: center; justify-content: center; border: solid 1px #EE6318; transition: 0.3s; position: absolute; right: -2.66vw; bottom: -5.33vw; z-index: 2; }
article.top-news-art a span.arrow img { width: 2.66vw; display: block; opacity: 1; }

div.situation { background: #fff; border: solid 1px #EE6318; box-sizing: border-box; border-radius: 10px; box-shadow: 0 4px 4px rgba(0, 0, 0, 0.025), 6px 6px 30px rgba(0, 0, 0, 0.06); }
div.situation h2.tit { text-align: center; color: #fff; font-size: 4.26vw; font-weight: 700; border-radius: 8px 8px 0 0; background: #EE6318; padding: 8px; }
div.situation .inner { padding: 8vw 5.33vw; }
div.situation .inner .mainBox.room_0 span.text { top: 0; white-space: nowrap; }
div.situation .inner .mainBox.room_0 + .link-text { text-align: center; font-size: 4.26vw; }
div.situation .inner .mainBox { width: 100%; display: flex; flex-wrap: wrap; align-items: center; justify-content: center; margin-bottom: 2.66vw; }
div.situation .inner .mainBox span.state { width: 13.56vw; line-height: 6.93vw; height: 6.93vw; background: #EE6318; text-align: center; color: #fff; font-weight: 700; font-size: 3.73vw; border-radius: 8vw; }
div.situation .inner .mainBox span.text { max-width: calc(100% - 16.53vw); margin-left: 2.66vw; line-height: 5.33vw; position: relative; top: -3px; }
div.situation .inner .mainBox span.text .orange { font-size: 5.33vw; font-weight: 700; }
div.situation .inner .mainBox span.text .orange .num { font-size: 8vw; }
div.situation .inner .link-text { font-size: 3.73vw; max-width: 100%; }
div.situation .inner .link-text a { display: flex; flex-wrap: wrap; align-items: center; position: relative; }
div.situation .inner .link-text a span.arrow { width: 5.33vw; height: 5.33vw; background: #EE6318; border-radius: 100%; display: flex; flex-wrap: wrap; align-items: center; justify-content: center; border: solid 1px #EE6318; transition: 0.3s; position: absolute; right: -2.66vw; bottom: -5.33vw; }
div.situation .inner .link-text a span.arrow img { width: 2.66vw; display: block; opacity: 1; }

section#about-sec { position: relative; z-index: 2; padding: 80px 5.33vw 1px; }
section#about-sec .titles01 { margin-bottom: 40px; }
section#about-sec .titles01 .jp br { display: none; }
section#about-sec .btn01 { margin: 40px auto 0; }

.top-cont02.flex { display: block; }
.top-cont02.flex .img { margin-top: 8vw; width: 90.33vw; margin-right: -8vw; margin-left: auto; }

.feats-box { position: relative; margin-top: -20.8vw; }
.feats-box .inner { background: #fff; position: relative; z-index: 2; border-radius: 10px; border: solid 1px #259EA7; padding: 13.33vw 5.33vw 10.66vw; box-shadow: 0 4px 4px rgba(0, 0, 0, 0.025), 6px 6px 30px rgba(0, 0, 0, 0.06); }

.feats-box:after { content: ""; background: url("../img/top/img02.png") no-repeat; width: 333px; height: 301px; background-size: contain; position: absolute; right: -80px; bottom: -171px; }

.sub-tit { text-align: center; font-size: 4.8vw; font-weight: 700; position: relative; z-index: 3; margin-bottom: -22px; }
.sub-tit > span { display: inline-block; padding: 1.6vw 5.33vw; background: #259EA7; border-radius: 5.66vw; color: #fff; }

.tri-list01.flex { display: block; }
.tri-list01.flex > div.box { width: 100%; text-align: center; margin-bottom: 10.66vw; }
.tri-list01.flex > div.box .img { margin: 0 auto 5.33vw; width: 64.8vw; }
.tri-list01.flex > div.box > h4 { font-weight: 700; font-size: 4.8vw; margin-bottom: 2.66vw; }
.tri-list01.flex > div.box .text { font-size: 3.73vw; }
.tri-list01.flex > div.box:last-child { margin-bottom: 0; }

div.bg02-box { background: url("../img/top/bg02-sp.png") no-repeat center top; padding: 210px 0 1px; margin-top: -110px; margin-bottom: 56.53vw; background-size: 100%; position: relative; }

div.bg02-box:after { content: ""; width: 100%; height: 56.53vw; background: url("../img/top/bg02-sp-b.png") no-repeat center bottom; background-size: 100%; position: absolute; left: 0; top: 100%; }

section#voice-sec { padding-bottom: 100px; overflow: hidden; }

div.slider01 { margin-bottom: 0 !important; padding-bottom: 90px; }
div.slider01 .slick-list { overflow: visible; }
div.slider01 .slick-track { display: flex; flex-wrap: wrap; }
div.slider01 article.voice-art { opacity: 0; pointer-events: none; transition: 0.3s; height: auto !important; }
div.slider01 article.voice-art.slick-active { opacity: 1; pointer-events: auto; }
div.slider01 article.voice-art.slick-active + article.voice-art { opacity: 1; pointer-events: auto; }

article.voice-art { width: 89.6vw; margin-right: 5.33vw; }
article.voice-art a { display: block; height: 100%; box-sizing: border-box; padding: 5.33vw 5.33vw 10.66vw; text-decoration: none; box-shadow: 0 4px 4px rgba(0, 0, 0, 0.025), 6px 6px 30px rgba(0, 0, 0, 0.06); background: #fff; border-radius: 10px; }
article.voice-art a .img { margin-bottom: 5.33vw; border-radius: 2.66vw; overflow: hidden; }
article.voice-art a .img .in-img { padding-top: 64.1%; border-radius: 2.66vw; transition: 0.3s; }
article.voice-art a .cont { padding: 0 2.66vw; }
article.voice-art a .cont h3 { font-weight: 500; font-size: 4.26vw; }
article.voice-art a .cont .infos.flex { margin-top: 2.66vw; width: calc(100% + 3.73vw); margin-left: -3.73vw; align-items: center; }
article.voice-art a .cont .infos.flex > div { margin-left: 3.73vw; }
article.voice-art a .cont .cate01, article.voice-art a .cont .cate02, article.voice-art a .cont .cate03 { padding: 0 3.2vww; border-radius: 8vw; color: #fff; font-size: 3.73vw; font-weight: 700; text-align: center; line-height: 6.93vw; }
article.voice-art a .cont .reki { display: flex; flex-wrap: wrap; line-height: 6.93vw; align-items: center; }
article.voice-art a .cont .reki > div { margin-right: 2.13vw; }
article.voice-art a .cont .reki > div.text { font-weight: 700; font-size: 4.26vw; }
article.voice-art a .cont .reki > div:last-child { margin-right: 0; }

.cate01, .cate02, .cate03 { padding: 0 12px; border-radius: 30px; color: #fff; font-size: 14px; font-weight: 700; text-align: center; line-height: 26px; }

.cate01 { background: #7C7C7C; }

.cate02 { background: #259EA7; }

.cate03 { background: #EE6318; }

.reki { display: flex; flex-wrap: wrap; line-height: 26px; align-items: center; }
.reki > div { margin-right: 8px; }
.reki > div.text { font-weight: 700; font-size: 16px; }
.reki > div:last-child { margin-right: 0; }

button.slick-arrow { opacity: 1; z-index: 2; transition: 0s; width: 70px; height: 70px; box-sizing: border-box; border: none; transition: 0.3s; top: auto; transform: translateY(0); bottom: 0; }

button.slick-prev.slick-arrow { background: url("../img/top/slide-arrow01.svg") no-repeat center left 26px #259EA7; left: calc(50% - 77px); border-radius: 100%; }

button.slick-next.slick-arrow { background: url("../img/top/slide-arrow02.svg") no-repeat center right 26px #259EA7; right: calc(50% - 77px); border-radius: 100%; }

button.slick-arrow:before { content: none; }

section#service-sec { background: #EBF7F8; padding: 100px 5.33vw 1px; position: relative; z-index: 3; }

.top-cont03.flex { display: block; }
.top-cont03.flex .img { margin-top: 60px; width: 104.2vw; margin-left: -8vw; margin-bottom: -34.66vw; }
.top-cont03.flex .cont .btn01 { margin-top: 40px; }

.copy01 { margin-bottom: 30px; font-size: 30px; font-weight: 700; }

div#linkbtn-box { padding: 0 5.33vw 100px; }

.link-btn { width: 100%; margin-bottom: 8vw; }
.link-btn a { display: block; text-align: center; text-decoration: none; }
.link-btn a .img { position: relative; margin: 0 auto 5.33vw; width: 64.8vw; }
.link-btn a .img img { display: block; position: relative; z-index: 2; }
.link-btn a .link-text { text-align: center; position: relative; z-index: 3; }
.link-btn a .link-text span { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; font-weight: 700; font-size: 4.8vw; }
.link-btn a span.arrow { margin-left: 2.66vw; width: 5.33vw; height: 5.33vw; background: #EE6318; border-radius: 100%; display: flex; flex-wrap: wrap; align-items: center; justify-content: center; border: solid 1px #EE6318; transition: 0.3s; }
.link-btn a span.arrow img { width: 2.66vw; display: block; opacity: 1; }

.link-btn:last-child { margin-bottom: 0; }

.link-btn.link-btn01 .img:before { content: ""; background: url("../img/top/bc01.svg") no-repeat; width: 64.53vw; height: 65.6vw; position: absolute; right: -5.86vw; top: 0; background-size: contain; }

.link-btn.link-btn02 { margin-bottom: 10.66vw; }
.link-btn.link-btn02 .img:before { content: ""; background: url("../img/top/bc02.svg") no-repeat; width: 61.33vw; height: 62.4vw; position: absolute; right: -5.6vw; top: 13.6vw; background-size: contain; }

.link-btn.link-btn03 .img:before { content: ""; background: url("../img/top/bc03.svg") no-repeat; width: 70.13vw; height: 63.46vw; position: absolute; left: -9.06vw; top: -5.06vw; }

.bg03Box { padding-top: 16vw; padding-bottom: 290px; background: url("../img/top/bg03-sp.png") no-repeat center top; margin-bottom: -350px; background-size: 100%; }

section#access-sec { position: relative; z-index: 2; padding: 0 5.33vw; }
section#access-sec .gmap { width: 100%; margin: 0 auto 5.33vw; height: 133.3vw; }
section#access-sec .gmap iframe { width: 100%; height: 100%; border-radius: 2.66vw; }
section#access-sec .wrap { padding-top: 1px; }

div.access-datas { position: relative; z-index: 2; padding: 40px 20px 20px; background: #fff; border-radius: 10px; }

.addressBox .line01 { margin-bottom: 10px; }
.addressBox .line02 { font-size: 14px; }
.addressBox .line02 a.gmap-link { display: inline-block; padding-left: 18px; background: url("../img/top/ico-pin.svg") no-repeat left center; }

.access-method { display: flex; flex-wrap: wrap; align-items: center; background: #F6F6F6; border-radius: 10px; padding: 40px 20px; box-sizing: border-box; justify-content: center; }
.access-method .ac-tit { margin-bottom: 20px; }
.access-method > .cont { width: 100%; }

.access-method.method01 { margin-top: 30px; }

.access-method.method02 { margin-top: 10px; text-align: center; }
.access-method.method02 .ac-tit { background-image: url("../img/top/ico-train.svg"); }
.access-method.method02 .text p { margin-bottom: 12px; }
.access-method.method02 .text p:last-child { margin-bottom: 0; }

.ac-tit { box-sizing: border-box; font-weight: 700; font-size: 18px; padding-left: 42px; background: url("../img/top/ico-car.svg") no-repeat center left; line-height: 34px; }

section#recruit-sec { position: relative; }
section#recruit-sec .img05 { background: url("../img/top/img04.png") no-repeat; background-size: contain; width: 286px; height: 281px; position: absolute; right: -154px; top: -34px; }
section#recruit-sec .wrap { padding: 100px 5.33vw 1px; position: relative; margin-bottom: -32vw; }
section#recruit-sec .wrap .img { margin-left: -16vw; width: 114.93vw; margin-top: 60px; }
section#recruit-sec .wrap .cont .btn01 { margin-top: 60px; }

/* 02 グループリビング
--------------------------------*/
html.showPage body:not(.home) { background: url("../img/p02/umv-sp.png") no-repeat center top #fff; background-size: 100%; }

div#umv { height: 64vw; box-sizing: border-box; padding-top: 26.66vw; }
div#umv .mv-tit { width: 89.34vw; margin: 0 auto; font-weight: 700; line-height: 1; }
div#umv .mv-tit span.en { font-size: 5.33vw; display: flex; flex-wrap: wrap; align-items: center; min-height: 8vw; line-height: 8vw; margin-bottom: 10px; }
div#umv .mv-tit span.en span.ico { margin-right: 1.06vw; height: 8vw; width: 8vw; background: url("../img/common/nav01.svg") no-repeat center; background-size: auto 5.33vw; }
div#umv .mv-tit span.jp { font-size: 8.53vw; display: block; }

div#p02Box01 { padding: 40px 5.33vw 0; position: relative; z-index: 3; }
div#p02Box01 .situation { position: relative; z-index: 3; margin-bottom: 40px; box-shadow: 6px 6px 30px rgba(0, 0, 0, 0.06); }

.p02-cont01.flex { display: block; }
.p02-cont01.flex .img { width: 106.6vw; margin-left: -8.63vw; margin-top: 40px; }
.p02-cont01.flex .cont { position: relative; }
.p02-cont01.flex .cont .text { line-height: 1.6; }
.p02-cont01.flex .cont > h2, .p02-cont01.flex .cont > div { position: relative; z-index: 2; }
.p02-cont01.flex .cont h2.sub-tit { text-align: left; margin-bottom: 8px; }
.p02-cont01.flex .cont h2.sub-tit > span { padding: 5px 16px; font-size: 16px; font-weight: 700; }
.p02-cont01.flex .cont .greenBox01 { margin-top: 30px; }
.p02-cont01.flex .cont:before { content: ""; background: url(../img/p02/bg-ico01.png) no-repeat; width: 200px; height: 164px; background-size: contain; position: absolute; right: calc(-5.33vw - 60px); bottom: 131px; }

.copy02 { font-size: 21px; margin-bottom: 24px; font-weight: 700; line-height: 1.6; }
.copy02 span.green { font-size: 30px; }
.copy02 span.dot { background: url("../img/p02/dot01.svg") repeat-x left bottom; padding-bottom: 2px; }

.greenBox01 { border: solid 1px #259EA7; border-radius: 10px; background: #fff; box-shadow: 6px 6px 30px rgba(0, 0, 0, 0.06); }
.greenBox01 > .tit { text-align: center; background: #259EA7; color: #fff; font-weight: 700; border-radius: 8px 8px 0 0; padding: 10px; font-size: 18px; }
.greenBox01 > .inner { padding: 20px 20px; }

ul.dot-list01 > li { line-height: 20px; margin-bottom: 12px; padding-left: 15px; position: relative; font-weight: 700; line-height: 1.2; }
ul.dot-list01 > li:last-child { margin-bottom: 0; }
ul.dot-list01 > li:before { content: ""; width: 10px; height: 10px; border-radius: 100%; background: #259EA7; position: absolute; left: 0; top: 5px; border-radius: 100%; }

.p02-cont02 { margin-top: 80px; box-shadow: 6px 6px 30px rgba(0, 0, 0, 0.06); border-radius: 10px; background: #FFF6F2; padding: 40px 20px; }
.p02-cont02 .tit-head .text { margin-top: 24px; }

.tit-head { margin-bottom: 24px; display: block; }

.sub-tit02 { line-height: 1.35; font-weight: 700; font-size: 24px; }

.scroll-hint-text { font-size: 0 !important; }

.scroll-hint-text:before { content: "スクロールできます"; font-size: 12px !important; }

.scroll-hint-icon { height: 90px !important; width: 150px !important; top: 80px !important; }

.TBL01 thead { display: none; }
.TBL01 table { border-collapse: separate; border-spacing: 0; }
.TBL01 th, .TBL01 td { box-sizing: border-box; display: block; }
.TBL01 thead th { background: #EE6318; color: #fff; font-weight: 700; text-align: left; vertical-align: middle; }
.TBL01 thead th.col01 { border-radius: 10px 0 0 0; border-right: solid 1px #FEE8E7; }
.TBL01 thead th.col02 { border-right: solid 1px #FEE8E7; }
.TBL01 thead th.col03 { border-radius: 0 10px 0 0; }
.TBL01 tbody td.col01 { font-weight: 700; background: #ffe9dd; border-bottom: solid 1px #fff; }
.TBL01 tbody td.col02 { border-bottom: solid 1px #eee; }
.TBL01 tbody td.col03 { border-bottom: solid 1px #EE6318; }
.TBL01 tbody td { padding: 15px 15px 15px 95px; position: relative; box-sizing: border-box; background: #fff; border-right: solid 1px #EE6318; border-left: solid 1px #EE6318; }
.TBL01 tbody td:before { content: "施設名"; color: #fff; background: #EE6318; width: 80px; height: calc(100% + 1px); position: absolute; left: 0; top: 0; box-sizing: border-box; padding: 15px 15px; border-bottom: solid 1px #fff; font-weight: 700; }
.TBL01 tbody td.col02:before { content: "対象"; }
.TBL01 tbody td.col03:before { content: "特徴"; }
.TBL01 tbody tr:last-child td.col03 { border-radius: 0 0 10px 10px; }
.TBL01 tbody tr:last-child td.col03:before { border-radius: 0 0 0 8px; border-bottom: solid 1px #EE6318; }
.TBL01 tbody tr:first-child td.col01 { border-radius: 10px 10px 0 0; border: solid 1px #EE6318; border-bottom: solid 1px #fff; }
.TBL01 tbody tr:first-child td.col01:before { border-radius: 8px 0 0 0; }

section#p02Box02 { padding: 48vw 5.33vw 26.66vw; background: url("../img/p02/bg01-sp-top.png") no-repeat center top -1px, url("../img/p02/bg01-sp-bottom.png") no-repeat center bottom -1px, url("../img/p02/bg01-sp.png") repeat-y center top; margin-top: -32vw; background-size: 100%; }

.liv-list > div.box { margin-bottom: 40px; background: #fff; padding: 30px 20px; border-radius: 10px; box-shadow: 6px 6px 30px rgba(0, 0, 0, 0.06); box-sizing: border-box; }
.liv-list > div.box:last-child { margin-bottom: 0; }
.liv-list > div.box.liv01 > .img { margin-top: 35px; }
.liv-list > div.box.liv02 .liv-tit > .ico { background-image: url("../img/p02/ico02.svg"); }
.liv-list > div.box.liv03 .liv-tit > .ico { background-image: url("../img/p02/ico03.svg"); }
.liv-list > div.box.liv04 > .img { margin-top: 24px; }
.liv-list > div.box.liv04 .liv-tit > .ico { background-image: url("../img/p02/ico04.svg"); }
.liv-list > div.box.liv05 .liv-tit > .ico { background-image: url("../img/p02/ico05.svg"); }
.liv-list > div.box.liv05 .inner { margin-top: 24px; }
.liv-list > div.box.liv05 .inner dl { margin-bottom: 24px; }
.liv-list > div.box.liv05 .inner dl dt { font-weight: 700; line-height: 1; padding-left: 15px; position: relative; margin-bottom: 10px; }
.liv-list > div.box.liv05 .inner dl dt:before { content: ""; width: 10px; height: 10px; background: #EE6318; border-radius: 100%; position: absolute; left: 0; top: 3px; }
.liv-list > div.box.liv05 .inner dl dd { line-height: 1.35; }
.liv-list > div.box.liv05 .inner dl:last-child { margin-bottom: 0; }

.liv-tit { margin-bottom: 24px; text-align: center; }
.liv-tit > .ico { display: block; width: 64px; height: 64px; margin: 0 auto 15px; background: url("../img/p02/ico01.svg") no-repeat center left; }
.liv-tit > .text { font-weight: 700; font-size: 29px; line-height: 1; }

div.ex-list01.flex { justify-content: space-between; margin-top: -24px; }
div.ex-list01.flex > div.exBox { width: calc(50% - 8px); margin-top: 24px; text-align: center; }
div.ex-list01.flex > div.exBox > p { font-weight: 700; font-size: 18px; line-height: 1.35; margin-top: 5px; }
div.ex-list01.flex > div.exBox:last-child { margin-right: 0; }

div.ex-list02.flex { margin-top: 24px; }
div.ex-list02.flex > div.ex-box { width: 100%; margin-bottom: 10px; box-sizing: border-box; background: #FFF6F2; border-radius: 10px; padding: 15px 20px 20px; font-weight: 700; }
div.ex-list02.flex > div.ex-box .num-text { display: flex; flex-wrap: wrap; justify-content: flex-start; align-items: center; margin-bottom: 8px; }
div.ex-list02.flex > div.ex-box .num-text > span.left { color: #EE6318; font-size: 19px; }
div.ex-list02.flex > div.ex-box .num-text > span.num { background: #EE6318; color: #fff; width: 24px; height: 24px; line-height: 22px; text-align: center; border-radius: 100%; margin-left: 2px; font-size: 20px; }
div.ex-list02.flex > div.ex-box > .text { line-height: 1.35; font-size: 18px; }
div.ex-list02.flex > div.ex-box:last-child { margin-bottom: 0; }

section#p02Box03 { padding: 20px 5.33vw 50px; }

article.faq-art { background: #fff; border-radius: 10px; box-shadow: 0 0 8px rgba(0, 0, 0, 0.08); margin-bottom: 20px; background: #fff; border: solid 1px #259EA7; }

article.faq-art:has(h3.on) { box-shadow: 0 0 0 rgba(0, 0, 0, 0.08); }

article.faq-art:last-child { margin-bottom: 0; }

span.opcl-ico { width: 20px; height: 20px; box-sizing: border-box; position: absolute; display: flex; flex-wrap: wrap; justify-content: center; align-items: center; right: 15px; top: 50%; z-index: 2; transform: translateY(-50%); }
span.opcl-ico > span { width: 100%; height: 100%; position: relative; }
span.opcl-ico > span:before { content: ""; width: 100%; height: 1px; background: #259EA7; transition: 0.3s; position: absolute; left: 0; top: calc(50% - 1px); }
span.opcl-ico > span:after { content: ""; width: 1px; height: 100%; background: #259EA7; transition: 0.3s; position: absolute; left: calc(50% - 1px); top: 0; }

.opcl { cursor: pointer; }

.opcl.on span.opcl-ico > span:before { background: #fff; }
.opcl.on span.opcl-ico > span:after { opacity: 0; }

.q-tit { padding: 15px 50px 15px 45px; position: relative; font-weight: 700; line-height: 1.3; color: #259EA7; font-size: 16px; }

.q-tit:before { content: "Q"; color: #259EA7; font-size: 24px; line-height: 1; position: absolute; left: 15px; top: 12px; font-weight: 700; }

.q-tit.on { background: #259EA7; color: #fff; border-radius: 8px 8px 0 0; }

.q-tit.on:before { color: #fff; }

div.a-text { padding: 15px 15px 15px 45px; border-radius: 10px; position: relative; }

div.a-text:before { content: "A"; color: #EE6318; font-size: 24px; line-height: 1; position: absolute; left: 15px; top: 14px; font-weight: 400; }

.opcl-cont { display: none; }

section#p02Box04 { padding: 18.66vw 5.33vw calc(80px + 11.2vw); background: url("../img/p02/bg02-sp.png") no-repeat center top; background-size: 100%; }

div.flow-list01.flex { justify-content: space-between; margin-top: -5.33vw; }
div.flow-list01.flex > .box { width: 42.66vw; background: #fff; border-radius: 2.66vw; position: relative; box-shadow: 0 1.06vw 1.06vw rgba(0, 0, 0, 0.025); padding: 4vw 4vw 5.33vw; box-sizing: border-box; text-align: center; margin-top: 5.33vw; }
div.flow-list01.flex > .box .num { position: absolute; left: 0; top: 0; width: 8.53vw; height: 8.53vw; border-radius: 2.66vw 0 2.66vw 0; color: #fff; text-align: center; line-height: 8vw; font-size: 5.33vw; background: #EE6318; }
div.flow-list01.flex > .box .img { margin-bottom: 4.26vw; }
div.flow-list01.flex > .box > p { font-weight: 700; font-size: 5.33vw; }
div.flow-list01.flex > .box:last-child { margin-right: 0; }
div.flow-list01.flex > .box:after { content: ""; background: url("../img/p02/flow-arrow.svg") no-repeat; width: 2.13vw; height: 4.26vw; position: absolute; left: calc(100% + 1.06vw); top: 50%; transform: translateY(-50%); background-size: contain; }
div.flow-list01.flex > .box:nth-child(2n):after { content: none; }
div.flow-list01.flex > .box:last-child:after { content: none; }

body:not(.home) div#footer { background: none; padding-top: 80px; position: relative; background: #259EA7; }
body:not(.home) div#footer:before { content: ""; background: url("../img/p02/aside-bg-head-sp.png?ver=1.0.0") no-repeat center top; background-size: 100%; width: 100%; height: 11.2vw; position: absolute; left: 0; bottom: calc(100% - 1px); }

/* 03 訪問介護
--------------------------------*/
.page-homecare div#umv .mv-tit span.en span.ico { margin-right: 0; height: 8vw; width: 56vw; background: url(../img/p03/smile-logo.svg) no-repeat center #fff; border-radius: 8vw; background-size: 47.2vw; }

div#p03Box01 { padding: 40px 5.33vw 1px; position: relative; z-index: 3; }

.p03-cont01.flex { display: block; }
.p03-cont01.flex .cont .copy02 .line03 { padding-top: 7px; display: inline-block; }
.p03-cont01.flex .img { margin-top: 30px; width: 106.6vw; margin-left: -11.99vw; }

.p03-box01 { position: relative; z-index: 2; margin-top: -9vw; }
.p03-box01 .sub-tit { margin-bottom: -21px; }
.p03-box01 .sub-tit > span { background: #EE6318; font-size: 18px; padding: 6px 20px; }
.p03-box01 .inner { background: #fff; border-radius: 10px; border: solid 1px #EE6318; padding: 35px 19px 19px; }

section#p03Box02 { padding: 48vw 5.33vw 32vw; background: url("../img/p02/bg01-sp-top.png") no-repeat center top -1px, url("../img/p02/bg01-sp.png") no-repeat center top; background-size: 100%,100% 100%; margin-top: -16vw; }
section#p03Box02 .greenBox01 { margin-bottom: 40px; }
section#p03Box02 .greenBox01 > .inner { padding: 19px; }
section#p03Box02 .greenBox01 .tit { font-size: 20px; padding-top: 13px; padding-bottom: 13px; }
section#p03Box02 .greenBox01:last-child { margin-bottom: 0; }

.greenBox01.orangeBox01 { border-color: #EE6318; }
.greenBox01.orangeBox01 .tit { background: #EE6318; }
.greenBox01.orangeBox01 .TBL-list.flex .in-tit { background: #FFF6F2; }

.TBL-list.flex { margin-bottom: 24px; display: block; }
.TBL-list.flex .in-tit { font-weight: 700; text-align: center; border-radius: 30px; height: 40px; line-height: 38px; background: #EBF7F8; }
.TBL-list.flex > .cont { padding-top: 8px; }
.TBL-list.flex > .cont ul.dot-list01 { margin-top: 15px; }

.TBL-list.flex:last-child { margin-bottom: 0; }

/* 04 料金表
--------------------------------*/
.page-price div#umv .mv-tit span.en span.ico { background-image: url("../img/common/nav03.svg"); }

section#p04Box01 { padding: 40px 5.33vw 1px; position: relative; z-index: 3; }
section#p04Box01 h2.titles01 span.gl { background: url("../img/p04/gl.svg") no-repeat center; height: 18px; display: block; background-size: contain; }
section#p04Box01 .greenBox01 { margin-top: 50px; }
section#p04Box01 .greenBox01 > .tit { font-size: 20px; padding-top: 13px; padding-bottom: 13px; }
section#p04Box01 .greenBox01 .inner { padding: 19px; }
section#p04Box01 .greenBox01 .price-listBox > div { width: 100%; }

.bikouBox { margin-top: 40px; }
.bikouBox > h4 { font-size: 20px; line-height: 1.35; margin-bottom: 15px; }

.price-listBox { display: flex; flex-wrap: wrap; justify-content: space-between; }
.price-listBox > div { width: 100%; }
.price-listBox > div .price-TOTAL.flex .tit .small { margin-left: -5px; }

.price-TBL.flex { padding-bottom: 8px; margin-bottom: 16px; border-bottom: dashed 1px #EEEEEE; align-items: center; justify-content: space-between; }
.price-TBL.flex .tit { width: 120px; font-weight: 700; text-align: center; border-radius: 60px; line-height: 1.2; background: #EBF7F8; padding: 6px 15px; box-sizing: border-box; }
.price-TBL.flex > .cont { max-width: calc(100% - 130px); text-align: right; font-weight: 700; }
.price-TBL.flex > .cont span.num { font-size: 24px; }
.price-TBL.flex > .cont span.tani { font-size: 16px; }

section#p04Box01 .greenBox01 .inner .price-TBL.flex { border-bottom: none; padding-bottom: 0; }
section#p04Box01 .greenBox01 .inner .price-TBL.flex .tit { width: 160px; text-align: left; }

.price-TOTAL.flex { justify-content: space-between; align-items: center; }
.price-TOTAL.flex .tit { font-size: 20px; font-weight: 700; }
.price-TOTAL.flex .tit .small { font-size: 16px; }
.price-TOTAL.flex .cont { font-weight: 700; font-size: 32px; }
.price-TOTAL.flex .cont .tani { font-size: 16px; font-weight: 500; }

section#p04Box02 { padding: 42.66vw 5.33vw 24vw; background: url("../img/p04/bg01-sp-top.png") no-repeat center top -1px, url("../img/p04/bg01-sp-bottom.png") no-repeat center bottom -1px, url("../img/p04/bg01-sp.png") no-repeat center top; background-size: 100%,100%,100% 100%; margin-top: -40px; }
section#p04Box02 h2.titles01 span.sm { background: url("../img/p03/smile-logo.svg") no-repeat center #fff; width: 209px; height: 30px; display: inline-block; background-size: 177px; border-radius: 30px; }
section#p04Box02 h2.titles01 .jp { font-size: 44px; }
section#p04Box02 .greenBox01 { margin-top: 25px; }
section#p04Box02 .greenBox01 > .tit { font-size: 20px; padding-top: 13px; padding-bottom: 13px; }
section#p04Box02 .greenBox01 .inner { padding: 20px 19px 19px; }
section#p04Box02 .p02-cont02 { margin-top: 0; padding: 20px; }

div#p04Box03 { padding: 30px 5.33vw 80px; }
div#p04Box03 .wrap .ptw-box { box-shadow: 6px 6px 30px rgba(0, 0, 0, 0.06); box-sizing: border-box; border-radius: 10px; background: #EBF7F8; padding: 30px 30px 40px; margin-bottom: 20px; }
div#p04Box03 .wrap .ptw-box:last-child { margin-bottom: 0; padding-left: 10px; padding-right: 10px; }

ul.dot-list02 > li { line-height: 1.2; margin-bottom: 8px; padding-left: 21px; position: relative; }
ul.dot-list02 > li:before { content: "・"; position: absolute; left: 0; top: 0; }
ul.dot-list02 > li:last-child { margin-bottom: 0; }

.num-texts04 { text-align: center; line-height: 1; }
.num-texts04 .right { font-weight: 700; font-size: 40px; margin-left: 4px; }
.num-texts04 .right .small { font-size: 16px; font-weight: 500; }

body.page-price div#footer:before, body.page-recruit div#footer:before { content: none; }

/* 05 施設紹介
--------------------------------*/
.page-facility div#umv .mv-tit span.en span.ico { background-image: url("../img/common/nav04.svg"); }

div#p05Box01 { padding: 40px 5.33vw 50px; }

.p05-cont01.flex .cont { width: 100%; padding-top: 30px; order: 2; }
.p05-cont01.flex .img { width: 106.66vw; margin-left: -8.66vw; margin-right: -8.66vw; order: 1; }

section#p05Box02 { padding: 18.66vw 5.33vw 16vw; background: url("../img/p05/bg01-sp-bottom.png") no-repeat center bottom -1px, url("../img/p05/bg01-sp-bottom02.png") no-repeat center bottom, url("../img/p05/bg01-sp.png") no-repeat center top; background-size: 100%,100% 100%; }
section#p05Box02 .p02-cont02 .tit-head .text { margin-top: 15px; }

div.p02-cont02.p05-2 { margin-top: 0; padding-top: 40px; }

.p05-cont02.flex { justify-content: space-between; flex-direction: row-reverse; }
.p05-cont02.flex .img { width: 100%; order: 1; margin-bottom: 15px; }
.p05-cont02.flex .cont { width: 100%; order: 2; }
.p05-cont02.flex .cont .sub32 { margin-bottom: 7px; }
.p05-cont02.flex .cont .size-text01 { margin-bottom: 30px; }

.sub32 { font-weight: 700; line-height: 1.35; font-size: 28px; }

.sub24 { font-weight: 700; line-height: 1; font-size: 24px; margin-bottom: 24px; }

.size-text01 { font-weight: 700; font-size: 20px; line-height: 1; }
.size-text01 .num { font-size: 30px; }

.p05-inner01.flex { margin-top: 30px; justify-content: space-between; }
.p05-inner01.flex > div.greenBox01.orangeBox01 { width: 100%; margin-bottom: 20px; }
.p05-inner01.flex > div.greenBox01.orangeBox01 > .inner { padding: 20px 19px 19px; }
.p05-inner01.flex > div.greenBox01.orangeBox01:last-child { margin-bottom: 0; }

div.room-ex { width: 100%; overflow: hidden; margin-top: 40px; }
div.room-ex h4.sub24 { text-align: center; }

.room-ex-slider { margin-bottom: 0; height: 72vw; }
.room-ex-slider button.slick-arrow { width: 9.06vw; height: 9.06vw; top: auto; transform: translateY(0); bottom: 0; border-radius: 100%; }
.room-ex-slider button.slick-prev.slick-arrow { background: url("../img/top/slide-arrow01.svg") no-repeat center left 3vw #EE6318; left: calc(50% - 10.4vw); background-size: 2.13vw; }
.room-ex-slider button.slick-next.slick-arrow { background: url("../img/top/slide-arrow02.svg") no-repeat center right 3vw #EE6318; right: calc(50% - 10.4vw); background-size: 2.13vw; }

div.room-slide .img .in-img { padding-top: 72.72%; border-radius: 10px; margin: 0 10px; }

div.p02-cont02.p05-3 { margin-top: 40px; background: #EBF7F8; }
div.p02-cont02.p05-3 .tit-head { margin-bottom: 20px; }

div.tri-list02.flex { display: block; }
div.tri-list02.flex > div.box { margin-bottom: 6.4vw; text-align: center; }
div.tri-list02.flex > div.box .tit { text-align: center; font-size: 5.33vw; line-height: 1.35; font-weight: 700; margin-top: 2.13vw; }
div.tri-list02.flex > div.box .tit .komoji { font-size: 4.26vw; display: block; }
div.tri-list02.flex > div.box:last-child { margin-bottom: 0; }

div.photo-gallery { padding-bottom: 14.4vw; position: relative; }

div.gallery-main { margin-bottom: 1.6vw; }
div.gallery-main button.slick-arrow { width: 9.06vw; height: 9.06vw; top: auto; transform: translateY(0); bottom: -34.4vw; border-radius: 100%; }
div.gallery-main button.slick-prev.slick-arrow { background: url("../img/top/slide-arrow01.svg") no-repeat center left 3vw #259EA7; left: calc(50% - 10.4vw); background-size: 2.13vw; }
div.gallery-main button.slick-next.slick-arrow { background: url("../img/top/slide-arrow02.svg") no-repeat center right 3vw #259EA7; right: calc(50% - 10.4vw); background-size: 2.13vw; }

div.gallery-thumbs { width: 100%; }

.gallery-img { width: 100%; }
.gallery-img a { display: block; position: relative; text-decoration: none; }
.gallery-img a:after { content: ""; position: absolute; right: 0; bottom: 0; z-index: 2; background: url("../img/p05/ico-lens.svg") no-repeat center, rgba(0, 0, 0, 0.5); width: 40px; height: 40px; }
.gallery-img p { text-align: center; margin-top: 10px; line-height: 1.5; }

.gallery-photo { padding-top: 66.66%; border-radius: 10px; }

.gallery-thumb { width: 28.8vw; margin: 0 1.6vw 0 0; cursor: pointer; position: relative; }
.gallery-thumb .thumb-photo { padding-top: 70%; border-radius: 5px; }

.gallery-thumb:after { content: ""; background: #000; width: 100%; height: 100%; z-index: 2; position: absolute; left: 0; top: 0; opacity: 0; transition: 0.3s; border-radius: 5px; }

.gallery-thumb:hover:after, .gallery-thumb.slick-current:after { opacity: 0.6; }

section#p05Box03 { padding: 20px 5.33vw 21.33vw; }

/* 06 会社案内・アクセス
--------------------------------*/
.page-company div#umv .mv-tit span.en span.ico { background-image: url("../img/common/nav05.svg"); }

section#p06Box01 { padding: 40px 5.33vw 1px; }

.comTBLs.flex { display: block; }
.comTBLs.flex > div { margin-bottom: 24px; }
.comTBLs.flex > div:last-child { margin-bottom: 0; }
.comTBLs.flex > div:last-child .TBL-list.flex:last-child { margin-bottom: 0; padding-bottom: 0; border-bottom: none; }
.comTBLs.flex .TBL-list.flex { align-items: flex-start; display: flex; padding-bottom: 24px; border-bottom: dashed 1px #EEEEEE; justify-content: space-between; }
.comTBLs.flex .TBL-list.flex .in-tit { width: 100px; background: #F8F8F8; }
.comTBLs.flex .TBL-list.flex > .cont { width: calc(100% - 108px); padding-top: 6px; }

.bgBox01 { padding: 21.33vw 5.33vw; background: url("../img/p04/bg01-sp-top.png") no-repeat center top, url("../img/p06/bg01-sp.png") no-repeat center top; background-size: 100%,100% 100%; }

section#p06Box02 { margin-bottom: 100px; }

.p02-cont02.p06-2 { margin-top: 0; background: #EBF7F8; padding: 30px 20px 40px; }
.p02-cont02.p06-2 .inner06.flex { display: block; }
.p02-cont02.p06-2 .inner06.flex > .cont { margin-bottom: 40px; }
.p02-cont02.p06-2 .inner06.flex .left-map { width: 100%; height: 53.33vw; }
.p02-cont02.p06-2 .inner06.flex .left-map iframe { width: 100%; height: 100%; }

.access-list06 > div.box { margin-bottom: 24px; }
.access-list06 > div.box:last-child { margin-bottom: 0; }
.access-list06 > div.box02 h3.ac-tit02 { background-image: url("../img/p06/ico-train.svg"); }

h3.ac-tit02 { line-height: 29px; padding-left: 38px; font-size: 18px; font-weight: 700; margin-bottom: 8px; background: url("../img/p06/ico-car.svg") no-repeat left center; }

section#p06Box03 .tit-head { margin-bottom: 30px; }
section#p06Box03 .tit-head .titles01 { margin-bottom: 30px; }

.p06-list03.flex > div.box { width: 100%; margin-bottom: 40px; }
.p06-list03.flex > div.box .img { margin-bottom: 16px; }
.p06-list03.flex > div.box h3.tit { line-height: 1.2; font-size: 24px; font-weight: 700; text-align: center; white-space: nowrap; margin-bottom: 16px; }
.p06-list03.flex > div.box h3.tit .small { font-size: 20px; }
.p06-list03.flex > div.box:last-child { margin-bottom: 0; }

/* 07 お知らせ
--------------------------------*/
div#umv .mv-tit span.en span.ico.news-ico { background-image: url("../img/common/nav07.svg"); }

div#p07Box01 { padding: 40px 5.33vw calc(80px + 11.2vw); }

div#two-cont div#two-side { margin-top: 80px; }

article.news-art01 { margin-bottom: 20px; }
article.news-art01 a { text-decoration: none; padding: 20px; border-radius: 10px; box-sizing: border-box; justify-content: space-between; box-shadow: 6px 6px 30px rgba(0, 0, 0, 0.06); display: block; }
article.news-art01 a .img { overflow: hidden; margin-bottom: 20px; }
article.news-art01 a .img .in-img { padding-top: 80%; transition: 0.3s; }
article.news-art01 a .cont .tit { font-size: 18px; line-height: 1.4; margin-bottom: 16px; font-weight: 700; width: 100%; display: -webkit-box; overflow: hidden; -webkit-line-clamp: 2; -webkit-box-orient: vertical; }
article.news-art01 a .cont .w-date { font-size: 15px; color: #a4a4a4; }
article.news-art01 a .infos.flex { margin: -8px 0 8px -8px; }
article.news-art01 a .infos.flex > div { margin: 8px 0 0 8px; }

article.news-art01:last-child { margin-bottom: 0; }

h2.side-tit.side-tit01 { text-align: center; border-radius: 30px; font-weight: 700; font-size: 18px; color: #fff; line-height: 40px; background: #259EA7; }

ul.side-links > li { border-bottom: solid 1px #DFDFDF; }
ul.side-links > li a { display: flex; flex-wrap: wrap; background: #fff; line-height: 1.2; padding: 24px 15px; align-content: center; justify-content: space-between; text-decoration: none; }
ul.side-links > li a span.text { max-width: calc(100% - 30px); }
ul.side-links > li:last-child { border-bottom: none; }

/*詳細*/
.whiteBox01 { padding: 40px 20px; border-radius: 10px; background: #fff; box-shadow: 6px 6px 30px rgba(0, 0, 0, 0.06); }
.whiteBox01 .infos.flex { margin: -8px 0 8px -8px; width: calc(100% + 8px); }
.whiteBox01 .infos.flex > div { margin: 8px 0 0 8px; }
.whiteBox01 div.w-date { font-size: 15px; color: #a4a4a4; margin-bottom: 40px; }

h1.blog-tit { font-size: 22px; font-weight: 700; line-height: 1.4; margin-bottom: 24px; }

.blog-text p:first-child { margin-top: 0; }
.blog-text p:first-child img { margin-top: 0; }
.blog-text img:first-child { margin-top: 0; }
.blog-text img[class*="wp-image-"] { margin: 20px 0; }
.blog-text iframe { max-width: 100%; }
.blog-text div { max-width: 100%; }
.blog-text a { max-width: 100%; }

/*ページャー*/
div#pager00 { text-align: center; }

div#pager00 .wp-pagenavi { margin-top: 60px; }

.wp-pagenavi > span, .wp-pagenavi > a { display: inline-block; margin: 4px; text-decoration: none; width: 48px; height: 48px; text-align: center; line-height: 46px; font-size: 18px; font-weight: 700; color: #EE6318; background: #fff; border: solid 1px #EE6318; box-sizing: border-box; border-radius: 100%; }

.wp-pagenavi a.page { position: relative; }

.wp-pagenavi span.extend { background: none; color: #EE6318; box-shadow: none; border: none; }

.wp-pagenavi a.previouspostslink { color: transparent; background: url("../img/p07/arrow02.svg") no-repeat center #fff; margin-left: 0; }

.wp-pagenavi a.nextpostslink { color: transparent; background: url("../img/p07/arrow03.svg") no-repeat center #fff; margin-right: 0; }

.wp-pagenavi span.current { color: #fff; background: #EE6318; }

.wp-pagenavi a.first { color: transparent; background: url("../img/p07/arrow01.svg") no-repeat center #fff; }

.wp-pagenavi a.last { color: transparent; background: url("../img/p07/arrow04.svg") no-repeat center #fff; }

.wp-pagenavi span.pages { display: none; }

.post-navigation ul { justify-content: space-between; align-items: center; margin-top: 60px; }

.post-navigation ul > li { margin-right: 10px; }

.post-navigation ul > li a { text-decoration: none; font-weight: 700; color: #fff; }

.post-navigation ul > li.prev, .post-navigation ul > li.next { width: 48px; height: 48px; display: table; }

.post-navigation ul > li.prev a, .post-navigation ul > li.next a { font-weight: 700; display: table-cell; position: relative; border-radius: 5px; color: #EE6318; text-align: center; vertical-align: middle; border: solid 1px #EE6318; }

.post-navigation ul > li.prev a > span { display: none; }

.post-navigation ul > li.next a > span { display: none; }

.post-navigation ul > li.prev a { background: url("../img/p07/arrow02.svg") no-repeat center; }

.post-navigation ul > li.next a { background: url("../img/p07/arrow03.svg") no-repeat center; }

.post-navigation ul > li.blog-back { width: 160px; height: 48px; display: table; }

.post-navigation ul > li.blog-back a { display: table-cell; text-align: center; vertical-align: middle; background: #EE6318; border-radius: 5px; order: solid 1px #EE6318; }

.post-navigation ul > li.blog-back a:hover { color: #EE6318; background-color: #fff; }

.post-navigation ul > li.kara { z-index: -2; pointer-events: none; opacity: 0; }

.post-navigation ul > li:last-child { margin-right: 0; }

/* 08 採用情報
--------------------------------*/
.page-recruit div#umv .mv-tit span.en span.ico { background-image: url("../img/common/nav06.svg"); }

div#p08Box01 { padding: 40px 5.33vw 1px; position: relative; z-index: 3; }

.p08-text01 { font-weight: 700; font-size: 25px; margin-bottom: 40px; line-height: 1.6; }

.rec-info-list.flex { justify-content: space-between; }
.rec-info-list.flex .box { box-sizing: border-box; padding: 5.33vw; border-radius: 2.66vw; background: #EBF7F8; box-shadow: 0 1.06vw 1.06vw rgba(0, 0, 0, 0.025), 1.6vw 1.6vw 8vw rgba(0, 0, 0, 0.06); width: 100%; display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; margin-bottom: 5.33vw; }
.rec-info-list.flex .box .img { width: 26.66vw; }
.rec-info-list.flex .box > .tit { width: 46.66vw; font-weight: 700; line-height: 1.6; }
.rec-info-list.flex .box > .tit .big { font-size: 5.86vw; }
.rec-info-list.flex .box > .tit .medi { font-size: 4.26vw; }
.rec-info-list.flex .box .text { width: 100%; margin-top: 3.73vw; font-size: 4.26vw; }
.rec-info-list.flex .box:last-child { margin-bottom: 0; }

section#p08Box02 { background: url("../img/p04/bg01-sp-top.png") no-repeat center top, url("../img/p06/bg01-sp.png") no-repeat center top; background-size: 100%; padding: 48vw 5.33vw 24vw; margin-top: -16vw; }

article.rec-art { border-radius: 10px; background: #fff; box-shadow: 6px 6px 30px rgba(0, 0, 0, 0.06); }
article.rec-art .rec-head { border-radius: 10px 10px 0 0; background: #FFF6F2; padding: 24px 20px; display: flex; flex-wrap: wrap; align-items: center; }
article.rec-art .rec-head .cate03 { margin-right: 16px; width: 90px; box-sizing: border-box; font-size: 16px; height: 27px; line-height: 25px; }
article.rec-art .rec-head h3 { font-size: 24px; font-weight: 700; width: 100%; margin-top: 8px; }

.rec-inner > div { padding: 20px; }
.rec-inner > div .btn01 { margin: 43px auto 0; }
.rec-inner .TBL-list.flex .in-tit { background: #F8F8F8; }

section#p08Box03 { padding: 30px 5.33vw 80px; background: url("../img/p04/bg01-bottom.png") no-repeat center top; }

div.flow-list01.flow-list02.flex > .box { background: #EBF7F8; padding-top: 5.33vw; }
div.flow-list01.flow-list02.flex > .box .num { background: #259EA7; }
div.flow-list01.flow-list02.flex > .box .img { width: 16vw; margin: 0 auto 4.26vw; }
div.flow-list01.flow-list02.flex > .box .komoji { font-size: 4.26vw; }
div.flow-list01.flow-list02.flex .box:after { background-image: url("../img/p08/flow-arrow.svg"); }

/* 09 お問い合わせ
--------------------------------*/
html.showPage body.page-contact { background-color: #F9F9F9; }

body.page-contact div#footer { padding-top: 0; background: none; }
body.page-contact div#footer:before { content: none; }

div#umv .mv-tit span.en span.ico.ico-mail-mv { background-image: url("../img/p09/ico-mail-mv.svg"); }

div#p09Box01 { padding: 40px 5.33vw 100px; }

div.contactBoxs { box-sizing: border-box; box-shadow: 6px 6px 30px rgba(0, 0, 0, 0.06); padding: 8vw 8vw 12vw; background: #fff; border-radius: 2.66vw; margin-bottom: 40px; }
div.contactBoxs .tel-set { text-align: center; }
div.contactBoxs .tel-set .tel-num span.fax-in, div.contactBoxs .tel-set .tel-num a { padding-left: 0; background: none; font-size: 12.26vw; line-height: 1; display: inline-block; font-weight: 700; }
div.contactBoxs .tel-set .bh { font-size: 4.26vw; margin-top: 3.2vw; }

div.contactBoxs:last-child { margin-bottom: 0; }

div.contactBoxs.contactBoxs02 .con-tit { background-image: url("../img/p09/ico-fax.svg"); }

div.contactBoxs.contactBoxs03 { margin-top: 40px; width: 100%; padding: 30px 20px 40px; }
div.contactBoxs.contactBoxs03 .con-tit { background-image: url("../img/p09/ico-mail.svg"); margin-bottom: 35px; }

.con-tit { font-size: 24px; text-align: center; line-height: 1; padding-top: 70px; background: url("../img/p09/ico-tel.svg") no-repeat center top; margin-bottom: 8px; }

.contact-text01 > p { padding-left: 20px; position: relative; }
.contact-text01 > p:before { content: "※"; position: absolute; left: 0; top: 0; }

/*フォーム*/
.file-bikou { font-size: 14px; }

ul.contact-state { display: flex; flex-wrap: wrap; justify-content: space-between; margin: 40px 0 10px; }

ul.contact-state > li { display: table; width: 32%; height: 48px; position: relative; }

ul.contact-state > li > span { display: table-cell; text-align: center; vertical-align: middle; background: #D4D4D4; color: #737373; font-size: 16px; font-weight: 700; }

ul.contact-state > li.state01 { margin-left: 0; }

ul.contact-state > li.state01 > span { background: #259EA7; color: #fff; }

ul.contact-state > li > span span.num { margin-right: 2px; }

ul.contact-state > li.state01:after { border-left-color: #259EA7; }

ul.contact-state.contact-state02 { display: flex; flex-wrap: wrap; justify-content: space-between; }

ul.contact-state.contact-state02 > li.state02 > span { background: #259EA7; color: #fff; }

span.num-circle { margin-right: 2px; }

a.green { text-decoration: underline; color: #259EA7; }

.contactTBL th, .contactTBL td { display: block; box-sizing: border-box; font-size: 16px; padding: 20px 0; color: #000000; line-height: 1.66; }
.contactTBL th { padding-bottom: 15px; }
.contactTBL td { padding-top: 0; }
.contactTBL .wpcf7-list-item { margin-left: 0; display: block; margin-bottom: 10px; }
.contactTBL input[type="checkbox"], .contactTBL input[type="radio"] { transform-origin: left center; transform: scale(1.5); margin-right: 8px; }

span.hissu { display: inline-block; color: #fff; padding: 0px 7px; background: #EE1818; margin-right: 8px; box-sizing: border-box; font-size: 14px; font-weight: 700; border-radius: 5px; }

span.nini { display: inline-block; padding: 0px 6px; margin-right: 8px; font-size: 14px; font-weight: 700; border-radius: 5px; background: #DEDEDE; }

input.wpcf7-number, input.wpcf7-date, input.wpcf7-text { box-sizing: border-box; height: 40px; border: solid 1px #D4D4D4; padding: 5px 20px; font-size: 16px; background: #fff; width: 100%; border-radius: 0; }

input.wpcf7-date { padding: 5px 10px; }

select.wpcf7-select { box-sizing: border-box; height: 40px; border: solid 1px #D4D4D4; padding: 5px 20px; font-size: 16px; background: #fff; width: auto; }

select { background: #fff; border-radius: 0; }

textarea.wpcf7-textarea { box-sizing: border-box; height: 120px; border: solid 1px #D4D4D4; padding: 10px 10px; font-size: 16px; background: #fff; width: 100%; }

input#com-name, input#busho { width: 500px; }

.okomari-list span.wpcf7-list-item { display: block; }

.radio-list span.wpcf7-list-item { display: block; }

.pop-btn.opcl-btn { margin-bottom: 0; width: 320px; height: 60px; border-radius: 30px; padding: 14px 20px; }
.pop-btn.opcl-btn .inner { justify-content: center; }
.pop-btn.opcl-btn .inner .text { width: calc(100% - 32px); font-size: 16px; padding-left: 32px; box-sizing: border-box; text-align: center; }
.pop-btn.opcl-btn .inner .plus:after { content: ""; width: 15px; height: 1px; background: #fff; position: absolute; left: 0; right: 0; top: 50%; margin: 0 auto; opacity: 0; }

.pop-btn.opcl-btn.on:hover .plus:after { background: #004798; }

.pop-btn.opcl-btn.on { margin-bottom: 40px; }
.pop-btn.opcl-btn.on .plus img { opacity: 0; }
.pop-btn.opcl-btn.on .plus:after { opacity: 1; }

.opcl-wrap { display: none; }

div.opcl-inBox { background: #F8F8F8; padding: 1px 40px 40px; }

.hyo-de { margin-top: 10px; }
.hyo-de .tit { margin-bottom: 5px; }

.contactTBL .select-con .wpcf7-list-item { display: inline-block; margin-right: 10px !important; }

.select-con { margin-bottom: 15px; }

.cours-area { margin-top: 5px; }

input.wpcf7-text.tel01, input#zip01 { width: 180px; }

select#pref3 { width: auto; }

span.form-bikou { display: block; }

ul.address-list > li { margin-bottom: 30px; }
ul.address-list > li:last-child { margin-bottom: 0; }
ul.address-list .th { font-size: 14px; margin-bottom: 5px; }

.contactArea .codedropz-upload-container { padding: 0; }

.contactArea .codedropz-upload-handler { border: none; border-radius: 0; background: #fff; padding: 0; }

.contactArea .codedropz-upload-inner { color: #1C1C1C; line-height: 1.5; font-size: 16px; font-weight: 500; }

.contactArea .codedropz-upload-inner h3 { display: none; }

.contactArea .codedropz-upload-inner h3 + span { display: none; }

a.cd-upload-btn { width: 100%; height: 48px; display: block; line-height: 35px; background: url("../img/p09/ico-file-w.svg") no-repeat center right calc(50% + 60px) #000000; border: solid 1px #000000; border-radius: 0; font-size: 16px; margin-top: 8px; color: #fff; box-sizing: border-box; font-weight: 700; padding-top: 5px; padding-left: 20px; }

.contact-submit.flex { margin-top: 20px; justify-content: center; flex-direction: row-reverse; position: relative; }

.contact-submit.flex > p { width: 100%; text-align: center; margin-top: 30px; }

.inb { display: inline-block; }

.form-btn { width: 100%; position: relative; }

.form-btn input[type="submit"], .form-btn input[type="button"] { transition: 0.3s; border: solid 1px #EE6318; color: #fff; width: 100%; height: 70px; font-size: 16px; font-weight: 700; position: relative; z-index: 3; background: url("../img/p09/arrow01.svg") no-repeat center right 25px #EE6318; border-radius: 38px; padding-left: 40px; text-align: left; }

.form-btn.form-btn02 { margin-top: 10px; }

.form-btn.form-btn02 input[type="submit"], .form-btn.form-btn02 input[type="button"] { background-color: #fff; color: #EE6318; text-align: right; padding-right: 40px; background-image: url("../img/p09/arrow02.svg"); background-position: left 25px center; }

.form-btn input { transition: 0.3s; cursor: pointer; }

.form-btn input:hover { background-image: url("../img/p09/arrow01h.svg"); color: #EE6318; background-color: #fff; }

.form-btn.form-btn02 input:hover { opacity: 0.7; }

.wpcf7-spinner { position: absolute !important; top: -10px !important; }

/*入力内容確認時にフォーム上部へスクロールするがナビゲーションが追従の場合フォームとナビゲーションが重なるのでそのためのオフセット設定*/
form.wpcf7-form { padding-top: 120px; margin-top: -120px; }

.wpcf7c-conf { background-color: #e8f0fe !important; }

input:-webkit-autofill, input:-internal-autofill-selected { -webkit-appearance: none; -webkit-box-shadow: 0 0 0px 1000px #e8f0fe inset !important; box-shadow: 0 0 0px 1000px #e8f0fe inset !important; }

::placeholder { font-size: 16px; color: #B2B2B2; line-height: 1.5; }

/*確認画面*/
.contactArea.che { background: #eee; padding: 30px; }
.contactArea.che .pop-btn.opcl-btn.on { pointer-events: none; }
.contactArea.che .opcl-wrap { display: block !important; }
.contactArea.che div.opcl-inBox { padding-top: 20px; }

.contactArea.che .contactTBL tr { border-bottom: solid 1px #000; }

.contactArea.che .contactTBL th, .contactArea.che .contactTBL td { padding-top: 5px; padding-bottom: 5px; vertical-align: middle; }

.contactArea.che .dnd-upload-status .dnd-upload-details .remove-file, .contactArea.che .codedropz-upload-handler, .contactArea.che .bikou-text01, .contactArea.che span.dnd-progress-bar, .contactArea.che input[type=checkbox] { display: none; }

.contactArea.che input[type=checkbox]:checked { display: inline-block; }

.contactArea.che input[type=checkbox] ~ span.wpcf7-list-item-label { display: none; }

.contactArea.che input[type=checkbox]:checked ~ span.wpcf7-list-item-label { display: inline-block; font-weight: 700; }

.contactArea.che input[type=radio] { display: none; }

.contactArea.che input[type=radio]:checked { display: inline-block; }

.contactArea.che input[type=radio] ~ span.wpcf7-list-item-label { display: none; }

.contactArea.che input[type=radio]:checked ~ span.wpcf7-list-item-label { display: inline-block; font-weight: 700; }

.contactArea.che textarea.wpcf7-textarea, .contactArea.che input.wpcf7-number, .contactArea.che input.wpcf7-date, .contactArea.che input.wpcf7-text, .contactArea.che select { font-weight: 700; }

/* thanksページ等
----------------------------------*/
div#p100Box01 { padding: 50px 5.33vw calc(80px + 11.2vw); }
div#p100Box01 .btn01 { margin: 50px auto 0; }

.pp-title01 { font-size: 22px; border-bottom: solid 2px; margin-bottom: 25px; padding-bottom: 10px; }

.pp-title02:first-child { margin-top: 0; }

.pp-title02 { font-size: 18px; padding-left: 15px; position: relative; color: #259EA7; margin-top: 50px; }

.pp-title02:before { content: ""; width: 5px; height: 65%; background: #259EA7; position: absolute; left: 0; top: 0; bottom: 0; margin: auto 0; }

/*デバイス幅ごとの調整（必要な幅があれば追加して調整）*/
