@charset "UTF-8";
/*webフォント読み込み*/
@font-face { /*notosansレギュラー*/
font-family: 'Noto Sans JP'; src: url("../fonts/NotoSansJP-Regular.otf"); src: url("../fonts/NotoSansJP-Regular.woff2") format("woff2"), url("../fonts/NotoSansJP-Regular.woff") format("woff"), url("../fonts/NNotoSansJP-Regular.otf") format("truetype"); font-weight: 400; }
@font-face { /*notosansミディアム*/
font-family: 'Noto Sans JP'; src: url("../fonts/NotoSansJP-Medium.otf"); src: url("../fonts/NotoSansJP-Medium.woff2") format("woff2"), url("../fonts/NotoSansJP-Medium.woff") format("woff"), url("../fonts/NotoSansJP-Medium.otf") format("truetype"); font-weight: 500; }
@font-face { /*notosansボールド*/
font-family: 'Noto Sans JP'; src: url("../fonts/NotoSansJP-Bold.otf"); src: url("../fonts/NotoSansJP-Bold.woff2") format("woff2"), url("../fonts/NotoSansJP-Bold.woff") format("woff"), url("../fonts/NotoSansJP-Bold.otf") format("truetype"); font-weight: 700; }
@font-face { /*notosansボールド*/
font-family: 'Noto Sans JP'; src: url("../fonts/NotoSansJP-Black.otf"); src: url("../fonts/NotoSansJP-Black.woff2") format("woff2"), url("../fonts/NotoSansJP-Black.woff") format("woff"), url("../fonts/NotoSansJP-Black.otf") format("truetype"); font-weight: 900; }
@font-face { /*Poppins-Medium*/
font-family: 'pop'; src: url("../fonts/Poppins-Medium.otf"); src: url("../fonts/Poppins-Medium.woff2") format("woff2"), url("../fonts/Poppins-Medium.woff") format("woff"), url("../fonts/Poppins-Medium.otf") format("truetype"); font-weight: 500; }
@font-face { /*Poppins-SemiBold*/
font-family: 'pop'; src: url("../fonts/Poppins-SemiBold.otf"); src: url("../fonts/Poppins-SemiBold.woff2") format("woff2"), url("../fonts/Poppins-SemiBold.woff") format("woff"), url("../fonts/Poppins-SemiBold.otf") format("truetype"); font-weight: 600; }
/* Link
=========================================== */
a:link, a:visited { color: #000000; text-decoration: none; }

a { outline: none; transition: 0.3s; color: #000000; text-decoration: none; }

a img { transition: 0.3s; }

:focus { outline: none; }

/* 共通設定
=========================================== */
.pc { display: none !important; }

body { overflow: hidden; background: #fff; color: #000000; font-size: 16px; line-height: 2; font-family: YakuHanJP,'Noto Sans JP',"メイリオ","Mayryo ","ヒラギノ角ゴ Pro W3","ＭＳ Ｐゴシック","MS PGothic",sans-serif; font-style: normal; font-weight: 400; overflow-wrap: anywhere; /* 収まらない場合に折り返す */ word-break: normal; /* 単語の分割はデフォルトに依存 */ line-break: strict; /* 禁則処理を厳格に適用 */ padding-top: 56px; }

h1, h2, h3, h4, h5, h6 { line-height: 1.5; font-weight: 700; }

body#tinymce { min-width: inherit !important; }

input, select, textarea { font-family: YakuHanJP,'Noto Sans JP',"メイリオ","Mayryo ","ヒラギノ角ゴ Pro W3","ＭＳ Ｐゴシック","MS PGothic",sans-serif; color: #000000; }

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 { opacity: 0; position: absolute; left: 0; top: 60px; z-index: -20; }

/*共通見出し設定*/
.titles01 { margin-bottom: 60px; }
.titles01 .en { font-family: "pop"; font-weight: 600; line-height: 1.2; font-size: 50px; display: block; margin-bottom: 10px; }
.titles01 .jp { font-weight: 700; font-size: 16px; line-height: 1.3; display: block; color: #07B53B; }

.titles02 { margin-bottom: 40px; color: #fff; }
.titles02 .en { font-family: "pop"; font-weight: 600; line-height: 1.2; font-size: 50px; display: block; margin-bottom: 10px; }
.titles02 .jp { font-weight: 700; font-size: 16px; line-height: 1.3; display: block; }

.titles03 { margin-bottom: 40px; }
.titles03 .en { font-family: "pop"; font-weight: 600; line-height: 1.2; font-size: 50px; display: block; margin-bottom: 10px; }
.titles03 .jp { font-weight: 700; font-size: 16px; line-height: 1.3; color: #07B53B; display: block; }

.titles04 { position: relative; line-height: 1.6; font-weight: 700; font-size: 40px; margin-bottom: 40px; padding-left: 24px; }
.titles04 .komoji { font-size: 20px; }

.titles04:before { content: ""; width: 4px; height: 100%; background: #07B53B; border-radius: 10px; position: absolute; left: 0; top: 0; }

.titles05 { margin-bottom: 40px; text-align: center; }
.titles05 .en { font-family: "pop"; font-weight: 600; line-height: 1.6; font-size: 20px; display: block; color: #07B53B; }
.titles05 .jp { font-weight: 700; font-size: 46px; line-height: 1.6; display: block; }

.titles05.white .en { color: #fff; }
.titles05.white .jp { color: #fff; }

/*共通ボタン設定*/
.btn01 { width: 100%; height: 72px; display: table; }
.btn01 a { display: table-cell; text-decoration: none; border: solid 3px #07B53B; text-align: center; vertical-align: middle; background: #fff; position: relative; font-weight: 700; color: #07B53B; border-radius: 60px; line-height: 1.4; }
.btn01 a .arrow { position: absolute; z-index: 2; top: 0; bottom: 0; right: 17px; margin: auto 0; display: flex; flex-wrap: wrap; justify-content: center; align-items: center; background: #07B53B; width: 24px; height: 24px; transition: 0.3s; border-radius: 100%; }
.btn01 a .arrow img { display: block; opacity: 1; transition: 0s; width: 10px; }

.btn02 { width: 100%; height: 84px; display: table; }
.btn02 a { display: table-cell; text-align: left; vertical-align: middle; text-decoration: none; border: solid 3px #07B53B; border-radius: 4px; background: #07B53B; color: #fff; position: relative; line-height: 1.2; padding-left: 24px; padding-right: 50px; font-weight: 700; font-size: 20px; }
.btn02 a span.arrow { position: absolute; z-index: 2; right: 24px; top: 50%; transform: translateY(-50%); }

.arrow img { display: block; opacity: 1; transition: 0s; }

.btn03 a { display: flex; flex-wrap: wrap; align-items: center; text-decoration: none; }
.btn03 a .arrow { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; background: #07B53B; width: 24px; height: 24px; transition: 0.3s; border-radius: 100%; margin-right: 12px; }
.btn03 a .arrow img { display: block; opacity: 1; transition: 0s; width: 8px; }
.btn03 a .text { font-weight: 700; }

.btn04 { width: 360px; height: 60px; display: table; }
.btn04 a { display: table-cell; text-align: left; vertical-align: middle; text-decoration: none; border: solid 3px #07B53B; border-radius: 4px; background: #07B53B; color: #fff; position: relative; line-height: 1.2; padding-left: 28px; padding-right: 50px; font-weight: 700; font-size: 20px; }
.btn04 a .komoji { font-size: 16px; }
.btn04 a span.arrow { position: absolute; z-index: 2; right: 18px; top: 50%; transform: translateY(-50%); display: flex; flex-wrap: wrap; width: 24px; height: 24px; justify-content: center; align-items: center; background: #fff; border-radius: 100%; }

.contact-btn02 { min-width: 100%; height: 66px; display: table; }
.contact-btn02 a { display: table-cell; text-decoration: none; color: #fff; text-align: center; vertical-align: middle; position: relative; font-weight: 700; border-radius: 60px; background: linear-gradient(110deg, #08c440 0%, #0688ea 47%, #08c440 100%); background-position: left top; background-size: 200%; }
.contact-btn02 a .arrow { position: absolute; z-index: 2; top: 0; bottom: 0; right: 20px; margin: auto 0; display: flex; flex-wrap: wrap; justify-content: center; align-items: center; background: #fff; width: 24px; height: 24px; transition: 0.3s; border-radius: 100%; }
.contact-btn02 a .arrow img { display: block; opacity: 1; transition: 0s; }

div#scr-sp.contact-btn02 { position: fixed; z-index: 50; left: 0; bottom: 0; width: 100%; height: 60px; }
div#scr-sp.contact-btn02 a { border-radius: 20px 20px 0 0; }
div#scr-sp.contact-btn02 a .text { width: 240px; display: block; margin: 0 auto; }

/*グラデーション*/
.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.slider01, div.gallery-main, div.gallery-thumbs, div.belt-slider { opacity: 0; transition: opacity .3s linear; }

div#mv-slider.slick-initialized, div.slider01.slick-initialized, div.gallery-main.slick-initialized, div.gallery-thumbs.slick-initialized, div.belt-slider.slick-initialized { opacity: 1; }

/*font*/
.pop { font-family: 'pop'; font-weight: 600; }

.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: #E30606; }

.blue { color: #0572C4; }

.blue02 { color: #0093D6; }

.yellow { color: #F2FF3B; }

.orange { color: #EE5A35; }

.green { color: #74BA26; }

.d-green { color: #005E4B; }

.green02 { color: #01A9AE; }

.navy { color: #374b8e; }

.pink { color: #ff7373; }

.gray { color: #818181; }

.black { color: #0A0A0A; }

/*header
---------------------------------------------------------------*/
div#header { width: 100%; position: fixed; z-index: 200; height: 56px; display: flex; flex-wrap: wrap; align-items: center; box-sizing: border-box; padding: 8px 10px 0; left: 0; top: 0; background: #fff; }
div#header .contact-btn { display: none; }

.logo { width: 126px; }

.head-text { display: none; }

.head-right { display: none; }

.tel-num a { font-family: 'pop'; font-size: 24px; line-height: 1.2; font-weight: 600; }
.tel-num a > span { display: inline-block; padding-left: 30px; background: url("../img/common/ico-tel.svg") no-repeat left top; }

.contact-btn { width: 100%; height: 72px; display: table; }
.contact-btn a { text-decoration: none; display: table-cell; text-align: center; vertical-align: middle; border-radius: 60px; color: #fff; line-height: 1.4; font-weight: 700; background: linear-gradient(110deg, #08c440 0%, #0688ea 47%, #08c440 100%); background-position: left top; background-size: 200%; }
.contact-btn a > span.text { display: inline-block; padding-left: 28px; background: url("../img/common/ico-mail.svg") no-repeat center left; }

/*スクロール追従*/
.fixed div#header { background: #FFFFFF; background-size: cover; box-shadow: 0 0 3px rgba(0, 0, 0, 0.2); }

/* nav
=========================================== */
.sp-tel.sp { width: 40px; position: fixed; z-index: 210; top: 10px; right: 60px; }
.sp-tel.sp a { display: flex; flex-wrap: wrap; width: 40px; height: 40px; border-radius: 100%; background: #093182; justify-content: center; align-items: center; }
.sp-tel.sp a img { display: block; width: 16px; }

.sp-nav-logo { position: absolute; left: 10px; top: 10px; }

.dr-tit { position: relative; font-weight: 700; color: #000; padding: 16px 50px 16px 0; }
.dr-tit .arrow { width: 10px; position: absolute; right: 5px; top: calc(50% - 4px); z-index: 2; }
.dr-tit .arrow img { display: block; transition: 0s; }

.dr-tit.on { color: #07B53B; }
.dr-tit.on .arrow { transform: rotateZ(-180deg); }
.dr-tit.on .arrow img { filter: brightness(0) saturate(100%) invert(48%) sepia(50%) saturate(4524%) hue-rotate(112deg) brightness(100%) contrast(94%); }

html.huopen { overflow: hidden; }
html.huopen .sp-tel.sp a { background: #fff; }
html.huopen .sp-tel.sp a img { filter: brightness(0) saturate(100%) invert(16%) sepia(68%) saturate(2848%) hue-rotate(211deg) brightness(81%) contrast(97%); }

.sp-nav-btn { width: 40px; height: 40px; position: fixed; top: 8px; right: 10px; z-index: 202; box-sizing: content-box; }

.sp-nav-btn span.bar01 { content: ""; width: 32px; height: 2px; position: absolute; top: 11px; right: 4px; transition: 0.3s; border-radius: 1px; }

.sp-nav-btn span.bar03 { content: ""; width: 32px; height: 2px; position: absolute; top: 20px; right: 4px; transition: 0.3s; border-radius: 1px; }

.sp-nav-btn span.bar02 { position: absolute; width: 32px; height: 2px; top: 29px; right: 4px; transition: 0.3s; border-radius: 1px; }

.sp-nav-btn > span { background: #07B53B; }

.sp-nav-btn.opon { background: #fff; }

.sp-nav-btn.opon span.bar02 { opacity: 0; }

.sp-nav-btn.opon span.bar01 { box-shadow: none; transform: rotateZ(45deg); top: 19px; }

.sp-nav-btn.opon span.bar03 { transform: rotateZ(-45deg); top: 19px; }

.overlay-nav { display: none; }

.overlay-nav.opon { z-index: 15; opacity: 1; }

div.navs-list-wrap { position: fixed; width: 100%; height: calc(100dvh - 56px); z-index: 200; top: 56px; box-sizing: border-box; background: #fff; right: calc(-100% - 60px); transition: 0.3s; padding: 1px 5.33vw 50px; }

div.navs-list-wrap.opon { right: 0; }

div.navs-list-wrap span.dr-arrow img { display: none; }

ul.navs-list { height: calc(100dvh - 56px); overflow: auto; box-sizing: border-box; padding: 0 0 95px; width: 100%; }
ul.navs-list li.sp-contact { margin-top: 30px; background: none; width: 100%; border-bottom: none; }

.navs-list > li { width: 100%; border-bottom: solid 1px #ECEDED; }
.navs-list > li > a { display: block; padding: 16px 0; color: #000; font-weight: 700; }
.navs-list > li ul.fs { margin-top: 0; padding-bottom: 16px; padding-left: 20px; }
.navs-list > li ul.fs > li { margin-bottom: 10px; }
.navs-list > li ul.fs > li a { color: #000; font-weight: 700; font-size: 14px; }
.navs-list > li ul.fs > li:before { background: #fff; }
.navs-list > li ul.fs > li:last-child { margin-bottom: 0; }
.navs-list > li .tel-set { text-align: center; }
.navs-list > li .tel-set .tel-num a { font-size: 30px; }
.navs-list > li .tel-set .tel-num a > span { background-position: left top 5px; }
.navs-list > li .tel-set .bh { line-height: 1; }
.navs-list > li .contact-btn { margin-top: 30px; }

ul.head-nav { margin-bottom: 30px; }
ul.head-nav > li { font-size: 14px; font-weight: 700; width: 146px; height: 29px; display: table; margin: 0 auto; }
ul.head-nav > li a { text-decoration: none; display: table-cell; background: #E8E8E8; border-radius: 30px; text-align: center; vertical-align: middle; }

/* contents */
/*-------------------------------------------*/
.bg-blue { background: #F5F9FF; }

/*パンくず
---------------------------------------------------------------*/
div#bread { z-index: 2; position: relative; }
div#bread .wrap { padding: 8px 0; }

#bread ul { display: flex; flex-wrap: wrap; align-items: center; justify-content: flex-end; }

#bread ul li { display: flex; flex-wrap: wrap; align-items: center; font-size: 14px; font-weight: 500; color: #000000; vertical-align: middle; line-height: 1.2; }

ul.bread-list li a { font-size: 14px; color: #000000; }
ul.bread-list li a img { display: block; vertical-align: middle; }

#bread ul.bread-list li:after { content: "／"; display: inline-block; position: relative; vertical-align: middle; margin: 0 9px; }

#bread ul.bread-list li:last-child:after { content: none; }

#bread ul.bread-list li:last-child, #bread ul.bread-list li:last-child a { color: #000000; }

/* メインビジュアル */
/*-------------------------------------------*/
/*TOPページ*/
div#mv { position: relative; z-index: 3; letter-spacing: 0; }

/* footer */
/*-------------------------------------------*/
.ft-map { height: 80vw; }
.ft-map iframe { width: 100%; height: 100%; }

.page-contact div#ftBox01 { padding-bottom: 50px; }

div#ftBox01 { padding: 60px 5.33vw 120px; }

.ft-logo { margin-bottom: 19px; width: 160px; margin-top: 29px; }

.ft-address { margin-top: 10px; line-height: 1.1; }

div.ft-info { margin-bottom: 50px; }
div.ft-info .tel-set { position: relative; }
div.ft-info .tel-set:after { content: "全国対応"; color: #fff; font-size: 16px; font-weight: 700; width: 88px; height: 30px; line-height: 28px; border-radius: 4px; background: #07B53B; display: inline-block; text-align: center; position: absolute; left: 215px; top: -2px; }
div.ft-info .bh { font-size: 16px; margin-top: 10px; }

.ft-text01 { font-size: 13px; line-height: 1.2; }

div.fnavBox { display: flex; flex-wrap: wrap; width: 100%; justify-content: space-between; }

.ft-tit:first-child { margin-top: 0; }

.ft-tit { margin-top: 30px; }
.ft-tit .in-t { font-weight: 700; color: #093182; }

div.fnav { width: 55%; }

div.fnav:nth-child(2) { width: 43%; }

div.fnav:last-child { margin-top: 16px; width: 100%; }
div.fnav:last-child ul.fs { display: flex; flex-wrap: wrap; width: 100%; justify-content: space-between; }
div.fnav:last-child ul.fs > li { width: 55%; }
div.fnav:last-child ul.fs > li:nth-child(2n) { width: 43%; }

ul.fs > li { margin-bottom: 16px; }
ul.fs > li:last-child { margin-bottom: 0; }

div.ft-bottom.flex { width: 100%; border-top: solid 1px #DDDFDE; padding-top: 40px; margin-top: 40px; display: block; }

ul.pp-list { display: flex; flex-wrap: wrap; align-items: center; font-size: 16px; }
ul.pp-list > li { margin-right: 40px; }
ul.pp-list > li:last-child { margin-right: 0; }

.copyright { font-size: 16px; }

div#scr.on { right: -300px; }
div#scr.on .float_close01 { display: none; }
div#scr.on .float_open01 { display: block; }

div#scr { position: fixed; right: 0; bottom: 14px; z-index: 100; transition: 0.3s; }
div#scr .hum { background: url("../img/common/ban-hum.png") no-repeat; width: 152px; height: 189px; background-size: contain; position: absolute; right: 3px; bottom: 0; }
div#scr > .inner { box-sizing: border-box; position: relative; width: 328px; height: 160px; border-top: solid 2px #000; border-bottom: solid 2px #000; border-radius: 10px 0 0 10px; padding: 28px 60px 18px 40px; background: #fff; }
div#scr > .inner .fl-text01 { font-weight: 700; font-size: 14px; line-height: 1.4; margin-bottom: 10px; }
div#scr .contact-btn02 { min-width: 220px; height: 60px; }

.float_close01, .float_open01 { width: 28px; position: absolute; left: 0; top: 0; height: 100%; z-index: 2; color: #fff; font-weight: 700; background: #000000; border-radius: 10px 0 0 10px; text-align: center; box-sizing: border-box; padding-top: 20px; transition: 0.3s; cursor: pointer; }
.float_close01 .scr-text, .float_open01 .scr-text { margin-bottom: 10px; line-height: 1.2; }
.float_close01 .scr-text > span, .float_open01 .scr-text > span { display: block; text-align: center; }
.float_close01 img, .float_open01 img { display: inline-block; vertical-align: top; opacity: 1; }

.float_open01 { display: none; }

/* TOPへ戻る */
/*-------------------------------------------*/
div#top-link { position: absolute; left: 0; top: 0; opacity: 0; z-index: -20; }

div#page-top { position: absolute; right: 5.33vw; top: -25px; opacity: 0; z-index: -3; transition: opacity 0.3s; width: 50px; }

div#page-top a { display: block; width: 50px; height: 50px; border-radius: 100%; text-align: center; box-sizing: border-box; line-height: 1; font-size: 15px; font-weight: 700; text-decoration: none; position: relative; }

.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
------------------------------------------*/
div#mv.home-mv { height: 182.6vw; background: url("../img/main/bg-logo-sp.svg") no-repeat right 5.33vw top 63.2vw; background-size: 40vw; }

div#mv-slider01 { overflow: hidden; width: 100%; position: absolute; right: 0; top: 73.02vw; }
div#mv-slider01 ul.slick-dots { position: absolute; z-index: 5; right: 40px; bottom: 20px; display: none !important; }

ul.slick-dots { text-align: right; }
ul.slick-dots > li { padding: 0; width: 10px; height: 10px; }
ul.slick-dots > li button { width: 10px; height: 10px; border-radius: 100%; box-sizing: border-box; background: #fff; border: solid 1px #000; }
ul.slick-dots > li button:before { content: none; }
ul.slick-dots li.slick-active button { background: #000; }

.mv-slide { position: relative; width: 100vw !important; padding-top: 3.73vw; }

.mv-slide.mv-slider01 .text { position: absolute; z-index: 2; top: 0; right: 5.33vw; width: 24.26vw; }
.mv-slide.mv-slider01 .mv-img { background: url("../img/main/slide01-sp.jpg") no-repeat center; background-size: cover; }

.mv-slide.mv-slider02 .text { position: absolute; z-index: 2; top: 0; right: 5.33vw; width: 37.86vw; }
.mv-slide.mv-slider02 .mv-img { background: url("../img/main/slide02-sp.jpg") no-repeat center; background-size: cover; }

.mv-slide.mv-slider03 .text { position: absolute; z-index: 2; top: 0; right: 5.33vw; width: 24.26vw; }
.mv-slide.mv-slider03 .mv-img { background: url("../img/main/slide03-sp.jpg") no-repeat center; background-size: cover; }

.mv-img { height: 78.93vw; }

.mv-box { position: relative; z-index: 5; padding: 6.4vw 5.33vw 0; height: 182.6vw; box-sizing: border-box; }

.mv-text01 { width: 86.66vw; }

.mv-text02 { margin: 3.66vw 0 3.73vw; }

.mv-cont { position: absolute; width: 89.86vw; left: 0; right: 0; bottom: 0; z-index: 2; margin: 0 auto; }

.belt-text01 { font-size: 100px; font-weight: 500; font-family: "pop"; white-space: nowrap; line-height: 1.2; color: #F8F8F8; width: 1616px; position: absolute; left: 0; top: 30px; }
.belt-text01 > span { padding-right: 20px; display: inline-block; }
.belt-text01 span.text01 { animation: text01 120s -60s linear infinite; }
.belt-text01 span.text02 { animation: text02 120s linear infinite; }

@keyframes text01 { 0% { transform: translateX(100%); }
  to { transform: translateX(-100%); } }
@keyframes text02 { 0% { transform: translateX(0); }
  to { transform: translateX(-200%); } }
div#top-feat { background: #07B53B; color: #fff; position: relative; z-index: 6; padding: 1px 5.33vw 45px; margin-top: 30px; }
div#top-feat .wrap { display: flex; flex-wrap: wrap; }
div#top-feat .wrap:before { content: ""; width: 1px; height: calc(100% - 90px); top: 45px; right: 0; left: 0; border-right: dashed 1px #fff; margin: 0 auto; position: absolute; }
div#top-feat .box { position: relative; width: 50%; box-sizing: border-box; text-align: center; font-weight: 700; line-height: 1.6; font-size: 14px; white-space: nowrap; }
div#top-feat .box .yellow { font-size: 16px; }
div#top-feat .box .ico { margin: -20px auto 6px; width: 58px; }
div#top-feat .box01 { padding-right: 14px; padding-bottom: 20px; }
div#top-feat .box02 { padding-left: 14px; padding-bottom: 20px; }
div#top-feat .box03 { padding-top: 20px; padding-right: 14px; border-top: dashed 1px #fff; }
div#top-feat .box03 .ico { margin-top: 0; }
div#top-feat .box04 { padding-top: 20px; padding-left: 14px; border-top: dashed 1px #fff; }
div#top-feat .box04 .ico { margin-top: 0; }
div#top-feat .box:last-child { border-right: none; }

div#top-news-line { width: 89.34vw; margin: -40px auto 0; box-sizing: border-box; position: relative; z-index: 7; background: rgba(255, 255, 255, 0.7); padding: 30px 20px; border-radius: 10px; backdrop-filter: blur(5px); box-shadow: 0 4px 24px rgba(0, 0, 0, 0.1); }
div#top-news-line .titles03 { margin-bottom: 15px; }
div#top-news-line .titles03 .en { color: #000000; font-size: 28px; margin-right: 14px; display: inline-block; }
div#top-news-line .titles03 .jp { color: #000000; font-size: 14px; font-weight: 500; padding-bottom: 6px; display: inline-block; }

.more01 { margin-top: 20px; display: flex; flex-wrap: wrap; justify-content: flex-end; }
.more01 a { text-decoration: none; height: 36px; align-items: center; font-weight: 500; width: auto; }
.more01 a span.arrow { width: 36px; height: 36px; margin-right: 12px; border-radius: 100%; background: url("../img/common/arrow03.svg") no-repeat center #000000; }

artcle.top-news-art a { align-items: center; text-decoration: none; }
artcle.top-news-art a .n-date { margin-right: 10px; }
artcle.top-news-art a .cate { margin-right: 20px; }
artcle.top-news-art a .text { width: 100%; line-height: 1.6; display: -webkit-box; overflow: hidden; -webkit-line-clamp: 2; -webkit-box-orient: vertical; margin-top: 10px; }

.n-date { font-size: 14px; font-family: "pop"; color: #000000; font-weight: 600; }

.cate { color: #fff; font-weight: 500; padding: 0 10px 1px; border-radius: 2px; line-height: 22px; background: #000; font-size: 14px; }

div#topBox01 { background: #F5F5F5; }
div#topBox01 > .wrap { padding: 60px 5.33vw 80px; }
div#topBox01 > .wrap > .copy { text-align: center; margin-bottom: 40px; line-height: 1.6; font-size: 20px; }
div#topBox01 > .wrap > .copy .big { font-size: 30px; }

.copy { font-weight: 700; line-height: 1.6; margin-bottom: 20px; font-size: 28px; }
.copy .big { font-size: 30px; }

.top-cont01.flex { margin-bottom: 60px; display: block; }
.top-cont01.flex .img { position: relative; margin-bottom: 40px; }
.top-cont01.flex .cont ul.check-list01 { margin-bottom: 20px; }

ul.check-list01 > li { margin-bottom: 10px; box-sizing: border-box; padding: 10px 20px 10px 50px; background: url("../img/common/ico-check01.svg") no-repeat left 16px top 10px, #fff; border-radius: 4px; font-weight: 500; line-height: 1.6; background-size: 24px; }
ul.check-list01 > li:last-child { margin-bottom: 0; }

.topicsBox .titles03 { margin-bottom: 20px; }
.topicsBox .titles03 .en { font-size: 28px; margin-right: 14px; display: inline-block; }
.topicsBox .titles03 .jp { font-size: 14px; padding-bottom: 6px; display: inline-block; }
.topicsBox > .inBox { background: #fff; border-radius: 10px; padding: 30px 20px; }
.topicsBox > .inBox .t-head { margin-bottom: 30px; position: relative; padding-left: 18px; }
.topicsBox > .inBox .t-head .tit01 { font-weight: 700; font-size: 23px; margin-bottom: 10px; line-height: 1.6; }
.topicsBox > .inBox .t-head .tit01 .komoji { font-weight: 400; font-size: 14px; display: block; }
.topicsBox > .inBox .t-head:before { content: ""; width: 4px; height: 100%; background: #07B53B; border-radius: 10px; position: absolute; left: 0; top: 0; }
.topicsBox > .inBox .inner.flex { display: block; }
.topicsBox > .inBox .inner.flex > .img { padding: 0 2.66vw; margin-bottom: 28px; }
.topicsBox > .inBox .inner.flex > .cont .btn01 { margin-top: 40px; }

ul.check-list02 > li { margin-bottom: 16px; padding-left: 34px; background: url("../img/common/ico-check01.svg") no-repeat left top; font-weight: 500; min-height: 26px; font-size: 14px; }
ul.check-list02 > li:last-child { margin-bottom: 0; }
ul.check-list02 > li:last-child span.gren-bg { margin-left: 0; margin-right: 4px; }

span.gren-bg { background: #C3F4D3; padding: 0 4px; font-weight: 700; display: inline-block; border-radius: 2px; margin-left: 4px; }

section#reason-sec { background: #07B53B; }
section#reason-sec h2.titles02 { margin-bottom: 60px; }
section#reason-sec > .wrap { padding: 80px 5.33vw; }
section#reason-sec > .wrap .btn01 { width: calc(100% - 40px); margin: 40px auto 0; }
section#reason-sec .bg-img { display: none; }

.reason-list01.flex > div.box { position: relative; width: 100%; margin-bottom: 53px; background: #fff; border-radius: 6px; }
.reason-list01.flex > div.box .reason-head { position: relative; border-radius: 6px 6px 0 0; background: #136841; text-align: center; color: #fff; font-weight: 700; padding: 15px 0 11px; line-height: 1.6; }
.reason-list01.flex > div.box .reason-head .num { font-size: 26px; width: 40px; text-align: center; position: absolute; left: 0; right: 0; margin: 0 auto; top: -20px; }
.reason-list01.flex > div.box .reason-head h3.tit { font-weight: 700; font-size: 26px; }
.reason-list01.flex > div.box .reason-head:before { content: ""; border-top: solid 16px #136841; border-left: solid 14px transparent; border-right: solid 14px transparent; width: 0; height: 0; margin: 0 auto; left: 0; right: 0; bottom: -10px; position: absolute; }
.reason-list01.flex > div.box .cont { padding: 20px 20px 30px; }
.reason-list01.flex > div.box:last-child { margin-bottom: 0; }

ul.dot-list01 { line-height: 1.6; }
ul.dot-list01 > li { margin-bottom: 6px; padding-left: 14px; position: relative; }
ul.dot-list01 > li .blue { font-weight: 700; font-size: 22px; }
ul.dot-list01 > li:before { content: ""; width: 8px; height: 8px; border-radius: 100%; background: #000000; position: absolute; left: 0; top: 16px; }
ul.dot-list01 > li:last-child { margin-bottom: 0; }

.box.reason02 ul.dot-list01 > li:first-child:before { top: 9px; }

section#tec-sec { padding: 80px 5.33vw; }

.titles01 { position: relative; }

.tec-cont01.flex { margin-bottom: 40px; position: relative; }
.tec-cont01.flex h2.titles01 { margin-bottom: 40px; }
.tec-cont01.flex > .right { box-sizing: border-box; border-radius: 10px; padding: 30px 20px; background: #F1F3F4; margin-left: auto; }
.tec-cont01.flex > .right .cont { margin-bottom: 40px; }
.tec-cont01.flex > .right .cont .sub02 { margin-bottom: 20px; }
.tec-cont01.flex > .right .cont .btn01 { margin-top: 40px; }

.sub02 { line-height: 1.2; font-size: 28px; font-weight: 700; }

.tec-btn-list.flex { display: block; }
.tec-btn-list.flex > .btn02 { margin-bottom: 10px; }
.tec-btn-list.flex > .btn02:last-child { margin-bottom: 0; }

.tec-cont02.flex { margin-top: 40px; box-sizing: border-box; padding: 30px 20px; border-radius: 10px; background: #F1F3F4; display: block; }
.tec-cont02.flex > .img { margin-top: 40px; }
.tec-cont02.flex > .cont .sub01 { color: #07B53B; }
.tec-cont02.flex > .cont .sub01:before { background: #07B53B; }
.tec-cont02.flex > .cont .btn01 { margin-top: 40px; }

.copy03 { font-weight: 700; font-size: 28px; line-height: 1.2; margin-bottom: 30px; }
.copy03 .big { font-size: 50px; }

.gray-bg { background: #F5F5F5; }

section#one-stop-sec { padding: 80px 5.33vw 160px; }
section#one-stop-sec .titles01 { margin-bottom: 40px; }

.onestop-cont01.flex { margin-bottom: 60px; display: block; }
.onestop-cont01.flex > div.left { margin-bottom: 40px; }

.copy02 { font-weight: 700; font-size: 19px; margin-bottom: 22px; line-height: 1.6; }
.copy02 .medi { font-size: 24px; }
.copy02 .big { font-size: 29px; }

.onestop-cases { box-sizing: border-box; background: #fff; border-radius: 10px; padding: 20px 20px 0; width: 100%; }
.onestop-cases .tit { text-align: center; color: #fff; line-height: 24px; border-radius: 4px; background: #000000; margin-bottom: 24px; font-size: 14px; font-weight: 700; }
.onestop-cases .img { text-align: center; }
.onestop-cases img { width: 60vw; }

.onestop-cases.box01 { margin-bottom: 20px; }

.onestop-cases.box02 .tit { background: #07B53B; }

section#works-sec { padding: 80px 5.33vw; z-index: 5; margin-top: -80px; margin-bottom: -80px; }
section#works-sec .wrap { z-index: 3; }

section#works-sec:before { content: ""; height: 100%; width: 100%; border-radius: 40px; background: linear-gradient(180deg, white 0%, white 50%, rgba(255, 255, 255, 0) 150%); backdrop-filter: blur(5px); box-shadow: 0 4px 24px rgba(0, 0, 0, 0.1); position: absolute; right: 0; top: 0; }

.slider01 { margin-bottom: 0 !important; padding-bottom: 88px; }
.slider01 .slick-list { overflow: visible; }
.slider01 article.works-art { margin-right: 5.33vw; pointer-events: none; width: 89.34vw; }

article.works-art a { display: block; box-sizing: border-box; height: 100%; border-radius: 10px; text-decoration: none; background: #fff; position: relative; }
article.works-art a .w-date { position: absolute; z-index: 2; left: 0; top: 0; font-size: 14px; color: #fff; border-radius: 10px 0 10px 0; background: #07B53B; padding: 3px 10px 4px 10px; }
article.works-art a .img { overflow: hidden; border-radius: 10px 10px 0 0; }
article.works-art a .img .in-img { padding-top: 68.15%; transition: 0.3s; border-radius: 9px 9px 0 0; }
article.works-art a .cont { padding: 20px 25px 30px; }
article.works-art a .cont .tit { font-weight: 700; width: 100%; display: -webkit-box; overflow: hidden; -webkit-line-clamp: 2; -webkit-box-orient: vertical; font-size: 22px; margin-bottom: 16px; }
article.works-art a .cont .infos.flex { margin-top: 16px; }

.infos.flex { width: calc(100% + 6px); margin: -6px 0 0 -6px; }
.infos.flex > div { margin: 6px 0 0 6px; line-height: 23px; min-height: 23px; font-size: 14px; font-weight: 500; }
.infos.flex > div.w-cate { color: #07B53B; padding: 0 14px; font-size: 16px; border-radius: 30px; border: solid 1px #07B53B; }

.w-data { margin-top: 20px; }
.w-data dl { margin-bottom: 8px; align-items: flex-start; justify-content: space-between; }
.w-data dl dt { width: 80px; background: #000000; font-weight: 700; color: #fff; text-align: center; border-radius: 2px; line-height: 26px; }
.w-data dl dd { width: calc(100% - 90px); line-height: 1.6; }
.w-data dl:last-child { margin-bottom: 0; }

button.slick-arrow { opacity: 1; z-index: 2; transition: 0s; width: 50px; height: 50px; box-sizing: border-box; border: none; transition: 0.3s; bottom: 0; transform: translateY(0); border-radius: 100%; border: solid 1px #000000; top: auto; }

button.slick-prev.slick-arrow { background: url("../img/top/slide-arrow01.svg") no-repeat center #fff; left: calc(50% - 55px); }

button.slick-next.slick-arrow { background: url("../img/top/slide-arrow02.svg") no-repeat center #fff; right: calc(50% - 55px); }

button.slick-arrow:before { content: none; }

.works-list01.flex { margin-top: 40px; }

section#range-sec { padding: 150px 5.33vw 80px; background: #07B53B; }
section#range-sec .titles02 { margin-bottom: 40px; }
section#range-sec .titles02 .en { font-size: 50px; }
section#range-sec .titles02 .jp { margin-top: 16px; }

.range-list.flex { justify-content: space-between; margin-top: -20px; }
.range-list.flex div.rangeBox { background: #fff; border-radius: 6px; box-sizing: border-box; width: 100%; margin-top: 20px; }
.range-list.flex div.rangeBox h3.tit { text-align: center; color: #fff; border-radius: 6px 6px 0 0; background: #136841; font-size: 20px; font-weight: 700; padding: 12px; }
.range-list.flex div.rangeBox .inner { padding: 20px 20px 30px; }
.range-list.flex div.rangeBox.box02 .text01 { font-weight: 700; }
.range-list.flex div.rangeBox.box02 .text01 .big { font-size: 32px; }
.range-list.flex div.rangeBox.box01 dl.flex.range-dl { display: flex; align-items: center; }
.range-list.flex div.rangeBox.box01 dl.flex.range-dl dt { margin-right: 15px; }

.bikou-text { margin-top: 15px; }
.bikou-text > p { position: relative; padding-left: 15px; position: relative; margin-bottom: 16px; }
.bikou-text > p:last-child { margin-bottom: 0; }
.bikou-text > p:before { content: "※"; position: absolute; left: 0; top: 0; }

dl.flex.range-dl { display: block; padding-top: 8px; margin-top: 8px; border-top: solid 1px #ECEDED; }
dl.flex.range-dl dt { font-size: 18px; font-weight: 700; }

dl.flex.range-dl:first-child { padding-top: 0; margin-top: 0; border-top: none; }

.twin-cont01.flex { justify-content: space-between; }
.twin-cont01.flex > div { padding: 20px; box-sizing: border-box; width: 100%; background: #F9F9F9; border-radius: 6px; margin-bottom: 20px; }
.twin-cont01.flex > div:last-child { margin-bottom: 0; }

ul.mate-list01 > li { padding-bottom: 8px; margin-bottom: 8px; border-bottom: solid 1px #ECEDED; }
ul.mate-list01 > li:last-child { padding-bottom: 0; margin-bottom: 0; border-bottom: none; }

.sub01 { padding-left: 18px; margin-bottom: 20px; position: relative; line-height: 1.2; color: #136841; font-size: 20px; font-weight: 700; }

.sub01:before { content: ""; width: 4px; height: 100%; border-radius: 10px; background: #136841; position: absolute; left: 0; top: 0; }

.haisouBox { padding-bottom: 20px; margin-bottom: 20px; border-bottom: solid 1px #ECEDED; }
.haisouBox dl.line01.flex { align-items: center; margin-bottom: 16px; }
.haisouBox dl.line01.flex dt { color: #fff; font-size: 18px; font-weight: 700; padding: 6px 14px; background: #07B53B; border-radius: 4px; margin-right: 14px; }
.haisouBox dl.line01.flex dd { font-size: 18px; font-weight: 700; }
.haisouBox dl.line02.flex dt { margin-right: 16px; font-weight: 700; font-size: 18px; padding-left: 32px; background: url("../img/top/ico-pin.svg") no-repeat left center; }
.haisouBox dl.line02.flex dd { font-size: 18px; }

div.big-btn { width: 100%; }
div.big-btn a { display: block; padding: 10.66vw 5.33vw  34.13vw; box-sizing: border-box; height: 96.53vw; text-decoration: none; color: #fff; position: relative; font-size: 4.26vw; font-weight: 700; }
div.big-btn a .titles02 { margin-bottom: 10.66vw; }
div.big-btn a .titles02 .en { font-size: 15.46vw; }
div.big-btn a .titles02 .jp { font-size: 5.33vw; }
div.big-btn a .arrow { position: absolute; z-index: 2; width: 18.13vw; height: 18.13vw; right: 5.33vw; bottom: 10.66vw; display: flex; flex-wrap: wrap; justify-content: center; align-items: center; }
div.big-btn a .arrow img { display: block; width: 4.26vw; opacity: 1; position: relative; right: -0.7vw; top: 0.5vw; }
div.big-btn a .arrow .circle { width: 100%; height: 100%; border-radius: 100%; border: solid 2px #fff; position: absolute; left: 0; top: 0; transition: 0.3s; }

div.big-btn.big-btn01 a { background: url("../img/top/big-sp01.jpg") no-repeat center; background-size: cover; }

div.big-btn.big-btn02 a { background: url("../img/top/big-sp02.jpg") no-repeat center; background-size: cover; }

section#news-sec { padding: 80px 5.33vw 0; }
section#news-sec .wrap .btn01 { margin-top: 60px; }

article.top-news-art { margin-bottom: 30px; padding-bottom: 30px; border-bottom: solid 1px #ECEDED; }
article.top-news-art a { text-decoration: none; }
article.top-news-art a .n-date { font-weight: 600 !important; margin-right: 10px; }
article.top-news-art a h3.tit { margin-top: 12px; font-weight: 400; width: 100%; line-height: 1.6; display: -webkit-box; overflow: hidden; -webkit-line-clamp: 2; -webkit-box-orient: vertical; }

article.top-news-art:last-child { margin-bottom: 0; padding-bottom: 0; border-bottom: none; }

aside#aside01 { margin: 80px auto; width: 89.34vw; background: #1C82E0; box-sizing: border-box; padding: 80px 5.33vw; border-radius: 5.33vw; }
aside#aside01 .titles02 { text-align: center; margin-bottom: 40px; }
aside#aside01 .inner01.flex { justify-content: space-between; }
aside#aside01 .inner01.flex ul.service-list01.flex { width: 100%; }
aside#aside01 .inner01.flex > .text { font-weight: 700; color: #fff; }
aside#aside01 .inner01.flex > .text p { display: inline; }

ul.service-list01.flex { margin-top: -1.06vw; justify-content: space-between; margin-bottom: 20px; }
ul.service-list01.flex > li { background: #0069CA; border-radius: 0.53vw; padding: 1.6vw 2.66vw; font-size: 4.8vw; line-height: 6.4vw; margin-top: 1.06vw; font-weight: 700; color: #fff; box-sizing: border-box; }
ul.service-list01.flex > li:first-child { width: 38.93vw; text-align: center; }
ul.service-list01.flex > li:nth-child(2) { width: 38.93vw; text-align: center; }
ul.service-list01.flex > li:nth-child(3) { width: 100%; text-align: center; }
ul.service-list01.flex > li:last-child { width: 100%; }

.contact-types.flex { margin-top: 40px; justify-content: space-between; }
.contact-types.flex > .box { width: 100%; background: #fff; box-sizing: border-box; border-radius: 10px; padding: 30px 15px; text-align: center; margin-bottom: 20px; }
.contact-types.flex > .box .tel-num a { font-size: 34px; line-height: 1; }
.contact-types.flex > .box .tel-num a > span { padding-left: 0; background: none; }
.contact-types.flex > .box .fax-num { font-size: 34px; line-height: 1; font-weight: 600; font-family: "pop"; }
.contact-types.flex .box03 > .text { font-size: 14px; margin-top: 4px; }
.contact-types.flex > .box:last-child { margin-bottom: 0; }

h3.c-tit { margin-bottom: 8px; font-weight: 700; font-size: 20px; padding-top: 66px; background: url("../img/common/ico-tel02.svg") no-repeat center top; }

.box02 h3.c-tit { background-image: url("../img/common/ico-fax.svg"); }

.box03 h3.c-tit { background-image: url("../img/common/ico-mail02.svg"); }

.copy01 { font-size: 28px; font-weight: 700; margin-bottom: 30px; line-height: 1.6; }
.copy01 .blue { font-size: 42px; }

section#rec-sec { background: #F1F3F4; overflow: hidden; padding-bottom: 21.33vw; }
section#rec-sec div#vslide01 { width: 520.52vw; height: 73.33vw; position: relative; display: flex; flex-wrap: wrap; }
section#rec-sec .cont { padding: 80px 5.33vw 60px; }
section#rec-sec .cont .text p { display: inline; }
section#rec-sec .cont .btn01 { margin-top: 40px; }

.vslide-wrapper { padding-left: 5.33vw; display: flex; flex-wrap: wrap; width: 260.26vw; box-sizing: border-box; }

.vslide-list.vs01 { width: 81.6vw; }

.vslide-list.vs02 { padding-left: 5.33vw; width: 41.6vw; padding-top: 19.73vw; }

.vslide-list.vs03 { padding-left: 5.33vw; width: 57.6vw; padding-top: 6.13vw; }

.vslide-list.vs04 { width: 58.13vw; padding-left: 5.33vw; padding-top: 17.6vw; }

.vslider01 .vslide-wrapper:first-child { animation: loop 90s -45s linear infinite; }

.vslider01 .vslide-wrapper:last-child { animation: loop2 90s linear infinite; }

@keyframes loop { 0% { transform: translateX(100%); }
  to { transform: translateX(-100%); } }
@keyframes loop2 { 0% { transform: translateX(0); }
  to { transform: translateX(-200%); } }
@keyframes loop3 { 0% { transform: translateX(-100%); }
  to { transform: translateX(100%); } }
@keyframes loop4 { 0% { transform: translateX(-200%); }
  to { transform: translateX(0); } }
section { position: relative; }

.ovh { overflow: hidden; }

/*02 選ばれる理由
----------------------------------*/
div#umv { padding: 20px 5.33vw 30px; }
div#umv div#bread { text-align: left; margin-top: 10px; }
div#umv div#bread ul { justify-content: flex-start; }

.mv-tit > span { display: block; line-height: 1.6; }
.mv-tit .en { color: #07B53B; font-family: "pop"; text-transform: capitalize; font-weight: 600; font-size: 20px; }
.mv-tit .jp { font-weight: 700; font-size: 40px; }
.mv-tit .jp .komoji { font-size: 16px; }

.page-reason .titles04 { margin-bottom: 30px; font-size: 28px; }

div#p02Box01 { padding: 60px 5.33vw 100px; background: #F1F3F4; }

.reason-list01 ul.check-list01 { display: flex; flex-wrap: wrap; margin-top: -10px; width: calc(100% + 10px); margin-bottom: 40px; }
.reason-list01 ul.check-list01 > li { margin: 10px 0 0 0; background-color: #DFEFE4; }
.reason-list01 ul.check-list01:last-child { margin-bottom: 0; }
.reason-list01 .basicBox { margin-bottom: 60px; }
.reason-list01 .basicBox:last-child { margin-bottom: 0; }
.reason-list01 .btn01 { margin-top: 40px; }
.reason-list01 .tec-cont02.flex { display: block; }
.reason-list01 .tec-cont02.flex > .cont .sub01 { font-size: 20px; color: #000; }
.reason-list01 .tec-cont02.flex > .cont .btn03 { margin-top: 20px; }
.reason-list01 .tec-cont02.flex > .cont .img02 { margin-bottom: 20px; }
.reason-list01 .tec-cont02.flex > .img { display: none; }

dl.r-dl02 dt { font-weight: 700; }

.basicBox { background: #fff; border-radius: 10px; }
.basicBox > .tit { text-align: center; color: #fff; border-radius: 10px 10px 0 0; background: #136841; font-size: 32px; font-weight: 700; padding: 9px 12px; line-height: 1.6; }
.basicBox > .tit .komoji { font-size: 16px; }
.basicBox > .inner { padding: 50px 20px 60px; }
.basicBox .setBox01 { padding-bottom: 60px; margin-bottom: 60px; background: url("../img/p02/line01.svg") repeat-x left bottom; }
.basicBox .setBox01:last-child { padding-bottom: 0; margin-bottom: 0; background: none; }

.twinBox01.flex { position: relative; display: block; margin-bottom: 30px; }
.twinBox01.flex .num { z-index: 3; position: absolute; right: -10px; top: -10px; border-radius: 100%; background: #fff; display: flex; flex-wrap: wrap; align-items: center; justify-content: center; text-align: center; width: 60px; height: 60px; border: solid 2px; font-weight: 500; font-size: 20px; border-radius: 100%; color: #136841; }
.twinBox01.flex .right { position: relative; margin-bottom: 40px; }

.twinBox01.twinBox01-2.flex { display: block; }

.ang-tit { position: absolute; left: 0; top: 0; z-index: 2; background: #DFEFE4; padding: 10px 20px; border-radius: 8px 0 8px 0; font-weight: 700; color: #136841; }

.graph01, .graph02 { border-radius: 10px; border: solid 1px #eee; padding: 65px 19px 29px; }
.graph01 > .box, .graph02 > .box { margin-bottom: 20px; }
.graph01 > .box:last-child, .graph02 > .box:last-child { margin-bottom: 0; }

.k-text { font-weight: 700; margin-bottom: 20px; }

.graph01 .i-tit { font-weight: 700; margin-bottom: 6px; color: #0572C4; }
.graph01 .box .line01 { color: #fff; background: #0572C4; text-align: center; border-radius: 4px; font-weight: 500; height: 33px; line-height: 33px; box-sizing: border-box; margin-bottom: 4px; }
.graph01 .box .line02 { color: #0572C4; text-align: center; border-radius: 4px; font-weight: 500; height: 33px; line-height: 33px; box-sizing: border-box; position: relative; background-size: contain; border: dashed 1px #0572C4; }
.graph01 .box .line02:before { content: ""; width: 21px; height: calc(100% + 2px); border-radius: 4px 0 0 4px; background: #0572C4; position: absolute; left: -1px; top: -1px; }
.graph01 .box .line02.line02-2 { text-align: left; padding-left: 31px; }
.graph01 .box .line02.line02-2 span.in02 { color: #000; margin-left: 15px; font-size: 11px; vertical-align: 2px; }

.graph02 .box .line01 { display: flex; flex-wrap: wrap; justify-content: space-between; }
.graph02 .box .line01 > span.blc1 { width: calc(14.28% - 6px); padding-top: calc(14.28% - 6px); border-radius: 4px; background: #0572C4; }
.graph02 .box .line01 > span.blc1.blc2 { opacity: 0.1; }
.graph02 .box .line02 { color: #0572C4; text-align: center; font-weight: 700; margin-top: 6px; }

/*03 精密板金
----------------------------------*/
div#p03Box01 { padding: 60px 5.33vw 100px; background: #F1F3F4; }
div#p03Box01 .p03-text01 { text-align: center; }
div#p03Box01 .p03-text01 span.gren-bg { color: #fff; background: #069330; font-weight: 700; font-size: 23px; padding: 5px 20px 8px; line-height: 1; border-radius: 4px; }
div#p03Box01 .copy { font-size: 36px; margin: 10px 0 40px; }
div#p03Box01 .copy .big { font-size: 40px; }
div#p03Box01 ul.check-list01 { display: flex; flex-wrap: wrap; width: calc(100% + 10px); margin: -10px 0 40px -10px; }
div#p03Box01 ul.check-list01 > li { background-color: #DFEFE4; margin: 10px 0 0 10px; }

section#p03Box02 { padding: 100px 5.33vw; background: #136841; }
section#p03Box02 .titles05 { margin-bottom: 40px; }

.feat-list03.flex { margin-top: -30px; }
.feat-list03.flex > div.box { background: #fff; border-radius: 6px; margin: 30px 0 0 0; width: 100%; }
.feat-list03.flex > div.box > .tit { text-align: center; font-size: 22px; position: relative; border-radius: 5px 5px 0 0; line-height: 1.6; color: #fff; background: #07B53B; padding: 18px 10px; }
.feat-list03.flex > div.box > .tit:before { content: ""; width: 0; height: 0; border-top: solid 11px #07B53B; border-left: solid 11px transparent; border-right: solid 11px transparent; position: absolute; left: 0; right: 0; top: calc(100% - 1px); margin: 0 auto; z-index: 2; }
.feat-list03.flex > div.box > .cont { padding: 20px 20px 40px; }
.feat-list03.flex > div.box > .cont .btn03 { margin-top: 15px; }
.feat-list03.flex > div.box:nth-child(3n) { margin-right: 0; }

section#p03Box03 { padding: 100px 5.33vw; }

.ex-list01.flex { margin-top: 5.33vw; justify-content: space-between; }
.ex-list01.flex > div.box { width: 42.13vw; margin: 5.33vw 0 0 0; }
.ex-list01.flex > div.box > .img { margin-bottom: 2.66vw; }
.ex-list01.flex > div.box > .img img { border-radius: 1.6vw; }
.ex-list01.flex > div.box .text { text-align: center; line-height: 1.6; font-size: 4.26vw; }
.ex-list01.flex > div.box .text br { display: none; }

section#p03Box04 { padding: 100px 5.33vw; background: #F1F3F4; }

/*04 24時間レーザーパンチ加工
----------------------------------*/
div#p04Box01 { padding: 60px 5.33vw 100px; background: #F1F3F4; }
div#p04Box01 .copy { margin: 0 0 40px; font-size: 36px; }
div#p04Box01 .copy .big { font-size: 40px; }
div#p04Box01 .wrap > ul.check-list01 { margin-bottom: 40px; }
div#p04Box01 .basicBox { margin-top: 60px; }
div#p04Box01 .basicBox > .tit { text-align: left; }
div#p04Box01 .basicBox .titles04 { font-size: 28px; margin-bottom: 40px; }
div#p04Box01 .basicBox ul.check-list01.type02 { margin-bottom: 30px; }
div#p04Box01 .basicBox .setBox01 { padding-bottom: 40px; margin-bottom: 40px; }
div#p04Box01 .basicBox .setBox01:last-child { padding-bottom: 0; margin-bottom: 0; }
div#p04Box01 article.faci-art { display: flex; flex-wrap: wrap; flex-direction: row-reverse; justify-content: space-between; padding: 0; width: 100%; margin: 0; }
div#p04Box01 article.faci-art .img { width: 100%; order: 2; margin-top: 30px; }
div#p04Box01 article.faci-art .img .in-img { border-radius: 6px; padding-top: 83.33%; }
div#p04Box01 article.faci-art .cont { width: 100%; padding: 0; order: 1; }
div#p04Box01 article.faci-art .cont .faciTBL { padding-left: 22px; }

.scr-wrap00 { width: calc(94.67vw - 20px); overflow: auto; padding-bottom: 20px; }

.rangeTBL01.hikakuTBL { width: 570px; font-size: 16px; }
.rangeTBL01.hikakuTBL .line01 { width: calc(100% - 460px); padding: 14px 10px 14px 0; }
.rangeTBL01.hikakuTBL .line02 { width: 170px; text-align: left; justify-content: flex-start; padding: 14px 10px 14px 20px; }
.rangeTBL01.hikakuTBL .line03 { width: 280px; text-align: left; justify-content: flex-start; padding: 14px 10px 14px 20px; }
.rangeTBL01.hikakuTBL div.rt-head.flex .line02 { background: #EEEEEE; color: #000; }
.rangeTBL01.hikakuTBL div.rt-body.flex { border-bottom: none; position: relative; }
.rangeTBL01.hikakuTBL div.rt-body.flex .line03 { background: url("../img/p04/line.svg") repeat-x left bottom #DFEFE4; border-color: #07B53B !important; color: #136841; font-weight: 700; }
.rangeTBL01.hikakuTBL div.rt-body.flex:last-child .line03 { background-image: none; }
.rangeTBL01.hikakuTBL div.rt-body.flex:before { content: ""; border-bottom: none; position: relative; width: calc(100% - 286px); height: 1px; background: #EEEEEE; position: absolute; left: 0; bottom: 0; }
.rangeTBL01.hikakuTBL div.rt-body.flex:last-child:before { content: none; }

.p04Box02 .feat-list03.flex { margin-top: -20px; }
.p04Box02 .feat-list03.flex > div.box { margin-top: 20px; }
.p04Box02 .sub-tit:before { top: 1px; }

section#works-sec-un.p24-w { padding-top: 100px; }

/*05 溶接・YAGレーザー溶接
----------------------------------*/
div.anq-btns.flex { justify-content: center; margin-top: 30px; }
div.anq-btns.flex > div { margin-bottom: 10px; width: 100%; }
div.anq-btns.flex > div .arrow img { width: 8px; }
div.anq-btns.flex > div:last-child { margin-bottom: 0; }

section#p05Box01 { padding: 60px 5.33vw 100px; background: #F1F3F4; }
section#p05Box01 .wrap > ul.check-list01.type02 { margin-bottom: 40px; }
section#p05Box01 .basicBox { margin-top: 60px; }
section#p05Box01 .basicBox > .tit { padding-top: 19px; padding-bottom: 19px; }
section#p05Box01 .basicBox .inner { padding-top: 40px; }
section#p05Box01 .setBox01.twinBox02.flex { padding-bottom: 30px; margin-bottom: 30px; }
section#p05Box01 .setBox01.twinBox02.flex:last-child { padding-bottom: 0; margin-bottom: 0; }

ul.check-list01.type02 { display: flex; flex-wrap: wrap; margin-left: -10px; }
ul.check-list01.type02 > li { background-color: #DFEFE4; margin-left: 10px; }

.twinBox02.flex { display: block; }
.twinBox02.flex .img { margin-bottom: 30px; }

.tw-tit { font-weight: 700; line-height: 1.6; font-size: 24px; margin-bottom: 10px; }

section#p05Box02 { padding: 95px 5.33vw 80px; }
section#p05Box02 ul.check-list01.type02 { margin-bottom: 40px; }

.twinBox03.flex { display: block; }
.twinBox03.flex > .cont { margin-bottom: 40px; }
.twinBox03.flex > .imgs .img01 { margin-bottom: 2.66vw; }

.in-imgs.flex { justify-content: space-between; align-items: flex-start; }
.in-imgs.flex > div { position: relative; width: 43.46vw; }
.in-imgs.flex > div .cap { position: absolute; z-index: 2; width: 100%; text-align: center; left: 0; top: 38.13vw; }
.in-imgs.flex > div .cap > span > span { display: inline-block; margin-bottom: 1vw; font-weight: 700; color: #fff; background: #000000; border-radius: 0.53vw; padding: 0.53vw 2.66vw 0.8vw; font-size: 3.73vw; }
.in-imgs.flex > div .cap > span > span:last-child { margin-bottom: 0; }
.in-imgs.flex > div.img03 .cap > span > span { background: #0572C4; }
.in-imgs.flex > div.img03.img04 { width: 100%; }
.in-imgs.flex > div.img03.img04 .cap { box-sizing: border-box; left: 0; text-align: center; padding-bottom: 2px; }
.in-imgs.flex > div.img03.img04 .cap > span > span { display: inline; border-radius: 0.53vw 0 0 0.53vw; }
.in-imgs.flex > div.img03.img04 .cap > span > span:last-child { border-radius: 0 0.53vw 0.53vw 0; }

.copy05 { margin-bottom: 30px; font-size: 28px; line-height: 1.6; font-weight: 700; margin-bottom: 30px; }

.box-list01 { margin-top: calc(60px + 13.06vw); }
.box-list01 > div.box { margin-bottom: 60px; }
.box-list01 > div.box:last-child { margin-bottom: 0; }

.titles04.gray-t { font-size: 34px; }

.titles04.gray-t:before { background: #CCCCCC; }

.merit-list01.flex { margin-top: -20px; }
.merit-list01.flex .merit-box { width: 100%; box-sizing: border-box; padding: 29px 19px 39px; border: solid 1px #EEEEEE; border-radius: 6px; margin: 20px 0 0 0; }

.num-tit { margin-bottom: 20px; display: flex; flex-wrap: wrap; align-items: flex-start; justify-content: center; }
.num-tit .num { width: 40px; height: 40px; border-radius: 100%; box-sizing: border-box; font-size: 14px; color: #136841; border: solid 2px #136841; justify-content: center; align-items: center; font-weight: 500; display: flex; flex-wrap: wrap; margin: 0 auto 10px; }
.num-tit .text { width: 100%; line-height: 1.6; font-size: 22px; font-weight: 700; text-align: center; }

.item-list.flex > div { width: 100%; margin-bottom: 40px; }
.item-list.flex > div .img { margin-bottom: 20px; }
.item-list.flex > div > .tit { text-align: center; font-weight: 700; line-height: 1.6; margin-bottom: 10px; }
.item-list.flex > div:last-child { margin-bottom: 0; }

ul.dot-list > li { line-height: 1.6; position: relative; padding-left: 16px; margin-bottom: 4px; }
ul.dot-list > li:last-child { margin-bottom: 0; }
ul.dot-list > li:before { content: "・"; position: absolute; left: 0; top: 0; }

.range-list02.flex { margin-top: -25px; }
.range-list02.flex .rangeBox { width: 100%; margin: 25px 0 0 0; box-sizing: border-box; border-radius: 10px; border: solid 1px #136841; background: #fff; }
.range-list02.flex .rangeBox .tit { border-radius: 8px 8px 0 0; text-align: center; color: #fff; font-weight: 700; font-size: 20px; background: #136841; line-height: 1.6; padding: 12px; }
.range-list02.flex .rangeBox .inner-un { padding: 20px; width: 100%; box-sizing: border-box; display: flex; flex-wrap: wrap; align-items: center; justify-content: center; text-align: center; min-height: 97px; }

section#works-sec-un { padding: 0 5.33vw 0; }
section#works-sec-un .titles05 { text-align: left; }
section#works-sec-un .btn01 { margin: 40px auto 0; width: calc(100% - 40px); }

.case-list-un.flex { padding-bottom: 80px; }
.case-list-un.flex article.works-art { width: 89.34vw; margin-right: 5.33vw; }
.case-list-un.flex article.works-art:last-child { margin-right: 0; }

/*06 曲げ加工（ベンダー加工）・表面処理・組立
----------------------------------*/
section#p06Box01 { padding: 60px 5.33vw 100px; background: #F1F3F4; }
section#p06Box01 .basicBox { margin: 80px 0; }
section#p06Box01 .basicBox .inner { padding-top: 30px; padding-bottom: 20px; }

.in-list.in-list01 { margin-top: 60px; }

.in-list > div.box { margin-bottom: 60px; }
.in-list > div.box:last-child { margin-bottom: 0; }

.ex-list02.flex { justify-content: space-between; margin-top: -20px; }
.ex-list02.flex > .box { width: calc(50% - 5px); text-align: center; margin-top: 20px; }
.ex-list02.flex > .box > h4 { font-weight: 700; line-height: 1.6; margin-bottom: 1.33vw; font-size: 5.33vw; }
.ex-list02.flex > .box > .img { margin-bottom: 1.33vw; }
.ex-list02.flex > .box > .text { line-height: 1.6; font-size: 4.26vw; text-align: left; }
.ex-list02.flex > .box > .text br { display: none; }

.rangeTBL01 { width: 100%; line-height: 1.6; font-size: 4.26vw; }
.rangeTBL01 div.rt-head.flex .line02, .rangeTBL01 div.rt-head.flex .line03 { text-align: center; color: #fff; font-weight: 700; background: #07B53B; padding: 2.3vw; box-sizing: border-box; border-radius: 2.3vw 2.3vw 0 0; }
.rangeTBL01 div.rt-body.flex { border-bottom: solid 1px #DDDDDD; }
.rangeTBL01 div.rt-body.flex .line01 { padding: 3.5vw 1.5vw; font-weight: 700; }
.rangeTBL01 div.rt-body.flex .line02 { background: #fff; padding: 2.3vw 3vw; border-left: solid 1px #EEEEEE; border-right: solid 1px #EEEEEE; }
.rangeTBL01 div.rt-body.flex .line03 { background: #fff; padding: 2.3vw 3vw; border-left: solid 1px #EEEEEE; border-right: solid 1px #EEEEEE; }
.rangeTBL01 div.rt-body.flex:last-child { border-bottom: none; }
.rangeTBL01 div.rt-body.flex:last-child .line02, .rangeTBL01 div.rt-body.flex:last-child .line03 { border-radius: 0 0 2.3vw 2.3vw; border-bottom: solid 1px #EEEEEE; }
.rangeTBL01 .line01 { width: 27.38%; box-sizing: border-box; }
.rangeTBL01 .line02 { width: 35.7%; margin-left: auto; box-sizing: border-box; display: flex; flex-wrap: wrap; align-items: center; justify-content: center; }
.rangeTBL01 .line03 { width: 35.7%; margin-left: 1.09%; box-sizing: border-box; display: flex; flex-wrap: wrap; align-items: center; justify-content: center; }

section#p06Box02 { padding: 100px 5.33vw; }
section#p06Box02 ul.check-list01.type02 { margin-bottom: 30px; }
section#p06Box02 ul.check-list01.type02 > li { background-position: left 16px center; }
section#p06Box02 .basicBox { margin-top: 60px; border: solid 1px #136841; }
section#p06Box02 .basicBox .inner { padding-top: 40px; padding-bottom: 40px; }
section#p06Box02 .setBox01.twinBox02.flex { padding-bottom: 30px; margin-bottom: 30px; }
section#p06Box02 .setBox01.twinBox02.flex .img { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: center; }
section#p06Box02 .setBox01.twinBox02.flex .img > img { width: 40vw; }
section#p06Box02 .setBox01.twinBox02.flex .img > .tw-tit { width: calc(100% - 48vw); margin-bottom: 0; font-size: 6.4vw; line-height: 1.6; }
section#p06Box02 .setBox01.twinBox02.flex:last-child { padding-bottom: 0; margin-bottom: 0; }

section#p06Box03 { padding: 100px 5.33vw; background: #F1F3F4; }
section#p06Box03 .twinBox03.flex { display: block; }
section#p06Box03 .twinBox03.flex .cont { margin-bottom: 40px; }
section#p06Box03 ul.check-list01.type02 { margin-bottom: 30px; }

/*07 品質管理
----------------------------------*/
.page-quality .copy03 { line-height: 1.6; }

div#p07Box01 { padding: 60px 5.33vw 100px; background: #F1F3F4; }
div#p07Box01 .copy { font-size: 40px; line-height: 1.6; margin-bottom: 28px; }
div#p07Box01 .copy .big { font-size: 50px; }
div#p07Box01 ul.check-list01.type02 { margin-bottom: 60px; }

.titles04.white { color: #fff; }

section#p03Box02.p07Box02 .wrap > .text { color: #fff; margin-bottom: 40px; }

.f-name { line-height: 1.6; font-weight: 700; margin-bottom: 16px; }

section#p07Box03 { padding: 100px 5.33vw; }
section#p07Box03 .scr-wrap { width: 94.67vw; overflow: auto; padding-bottom: 20px; }

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

/*テーブルスクロールバー設定*/
.simplebar-track.simplebar-horizontal { height: 4px !important; background: #DFEFE4; border-radius: 2px; margin: 0 auto; }

.simplebar-scrollbar { height: 4px !important; background: #07B53B; border-radius: 2px; top: 0; }

div.c-flow-list.flex { margin-top: 40px; justify-content: space-between; width: 1100px; }
div.c-flow-list.flex > div.box { position: relative; border: solid 1px #136841; border-radius: 10px; box-sizing: border-box; padding: 55px 19px 38px; }
div.c-flow-list.flex > div.box .ang-tit { background: #136841; color: #fff; font-size: 20px; line-height: 1.6; padding-top: 4px; padding-bottom: 4px; }
div.c-flow-list.flex > div.box ul.dot-list { margin-top: 16px; font-size: 14px; line-height: 1.4; }
div.c-flow-list.flex > div.box .ico img { width: auto; }
div.c-flow-list.flex > div.box.box01 { width: 620px; height: 375px; }
div.c-flow-list.flex > div.box.box01 .text01 { margin-top: 14px; text-align: center; }
div.c-flow-list.flex > div.box.box02 { width: 182px; height: 375px; }
div.c-flow-list.flex > div.box.box02 .in-flow-list.flex > div.inBox .tit { height: 39.19px; }
div.c-flow-list.flex > div.box.box03 { width: 182px; }
div.c-flow-list.flex > div.box.box04 { width: 86px; display: flex; flex-wrap: wrap; align-items: center; text-align: center; justify-content: center; line-height: 1.6; color: #fff; background: #136841; font-weight: 700; padding: 0; }
div.c-flow-list.flex > div.box.box04 .big { font-size: 20px; }
div.c-flow-list.flex > div.box.box04 .komoji { font-size: 12px; }

.in-flow-list.flex { justify-content: space-between; }
.in-flow-list.flex > div.inBox { position: relative; box-sizing: border-box; width: 142px; border-radius: 6px; background: #DFEFE4; padding: 20px 15px; text-align: center; }
.in-flow-list.flex > div.inBox .num { position: absolute; z-index: 2; font-size: 11px; font-weight: 500; line-height: 1; position: absolute; left: 11px; top: 12px; color: #136841; }
.in-flow-list.flex > div.inBox .tit { font-size: 14px; line-height: 1.4; margin-bottom: 20px; color: #136841; font-weight: 700; }
.in-flow-list.flex > div.inBox > .text { font-size: 14px; line-height: 1.4; margin-top: 10px; }

.blue-bg-text { text-align: center; color: #fff; margin-top: 6px; border-radius: 6px; background: #0572C4; font-weight: 500; padding: 4px; line-height: 1.6; }

section#p07Box04 { padding: 100px 5.33vw; background: #F1F3F4; }
section#p07Box04 .twinBox03.flex .img { position: relative; background: #fff; box-sizing: border-box; padding: 66px 20px 40px; border-radius: 10px; }
section#p07Box04 .twinBox03.flex .img .ang-tit { background: #136841; color: #fff; line-height: 1.6; }
section#p07Box04 .twinBox03.flex .img .text.sp { margin-top: 20px; }

.whiteBox.subBox01 { margin-top: 40px; }

.whiteBox { padding: 40px 20px; border-radius: 6px; background: #fff; }

.sub-tit { position: relative; line-height: 1.6; font-weight: 700; font-size: 22px; margin-bottom: 20px; padding-left: 18px; }

.sub-tit:before { content: ""; width: 4px; height: 100%; background: #136841; border-radius: 10px; position: absolute; left: 0; top: 0; }

/*08 ワンストップ総合加工
----------------------------------*/
div#p08Box01 { padding: 60px 5.33vw 100px; background: #F1F3F4; }
div#p08Box01 .copy { font-size: 40px; margin-bottom: 40px; }
div#p08Box01 ul.check-list01.type02 { margin-bottom: 60px; }
div#p08Box01 ul.check-list01.type02 > li { background-image: url("../img/p08/ico-check.svg"); background-color: #CFE7F8; }
div#p08Box01 .onestop-cont01.flex { margin-bottom: 60px; }
div#p08Box01 .onestop-cont01.flex .copy02 { font-size: 30px; }
div#p08Box01 .onestop-cont01.flex .copy02 .blue { display: block; font-size: 40px; }
div#p08Box01 .p08-onestop .copy { margin-bottom: 30px; }

.p08-onestop > .text { margin-bottom: 40px; }

section#p08Box02 { padding: 100px 5.33vw 1px; }
section#p08Box02 .box-list01 { margin-top: 60px; }
section#p08Box02 ul.check-list01.type02 { margin-bottom: 60px; }

.twinBox04.flex { display: block; }
.twinBox04.flex > .img { margin-top: 40px; }

.sub03 { line-height: 1.6; font-weight: 700; font-size: 20px; margin-bottom: 20px; }

.box-list01.box-list02 > .box { margin-bottom: 60px; }
.box-list01.box-list02 > .box:last-child { margin-bottom: 0; }
.box-list01.box-list02 > .box.box02 .sub03 { margin-bottom: 40px; }

.type-com.flex { padding-bottom: 20px; margin-bottom: 20px; border-bottom: solid 1px #EEEEEE; display: block; }
.type-com.flex > h4 { box-sizing: border-box; font-weight: 700; margin-bottom: 20px; }
.type-com.flex > .cont { width: 100%; margin-left: -40px; display: flex; flex-wrap: wrap; align-items: flex-start; line-height: 30px; margin-top: -10px; }
.type-com.flex > .cont dl.in-data { display: flex; flex-wrap: wrap; align-items: center; margin: 10px 0 0 40px; }
.type-com.flex > .cont dl.in-data dt { font-weight: 500; color: #136841; background: #DFEFE4; padding: 0 20px; border-radius: 20px; }
.type-com.flex > .cont dl.in-data dd { margin-left: 14px; }

.type-com.flex:last-child { margin-bottom: 0; }

.whiteBox.subBox02 { margin-top: 60px; background: #F6F6F6; }

/*09 会社案内
----------------------------------*/
section#p09Box01 { padding: 60px 5.33vw 100px; background: #F1F3F4; }
section#p09Box01 h2.titles04 { margin-bottom: 40px; }

.twinBox09.flex { justify-content: space-between; }
.twinBox09.flex > div { width: 100%; }

.TBL09:first-child tr:first-child th, .TBL09:first-child tr:first-child td { padding-top: 0; }

.TBL09 th, .TBL09 td { box-sizing: border-box; position: relative; line-height: 1.6; vertical-align: top; padding: 20px 0; }
.TBL09 tr { border-bottom: solid 1px #DDDDDD; }
.TBL09 th { width: 160px; padding-left: 10px; font-weight: 700; }
.TBL09 th:before { content: ""; width: 10px; height: 1px; background: #07B53B; position: absolute; left: 0; bottom: -1px; }

section#p09Box02 { padding: 100px 5.33vw; }
section#p09Box02 h2.titles04 { margin-bottom: 60px; }

.twinBox10.flex { display: block; }
.twinBox10.flex > .cont { margin-bottom: 60px; }
.twinBox10.flex > .map { width: 100%; height: 122.66vw; }
.twinBox10.flex > .map iframe { width: 100%; height: 100%; }

.acBox { margin-bottom: 60px; }

.acBox:last-child { margin-bottom: 0; }

.in-ac dl { margin-bottom: 40px; }
.in-ac dl dt { font-weight: 700; margin-bottom: 14px; font-size: 20px; }

section#p03Box02.p09Box03 { color: #fff; }
section#p03Box02.p09Box03 .titles04 { color: #fff; margin-bottom: 40px; }
section#p03Box02.p09Box03 .text01, section#p03Box02.p09Box03 .text02 { font-weight: 700; font-size: 18px; }
section#p03Box02.p09Box03 .text01 { margin-bottom: 40px; }
section#p03Box02.p09Box03 .text02 { margin-top: 30px; }
section#p03Box02.p09Box03 ul.dot-list02 { display: flex; flex-wrap: wrap; justify-content: space-between; }
section#p03Box02.p09Box03 ul.dot-list02 > li { width: 100%; margin-bottom: 10px; }
section#p03Box02.p09Box03 ul.dot-list02 > li:last-child { margin-bottom: 0; }

ul.dot-list02 > li { background: #fff; padding: 24px 30px; border-radius: 6px; line-height: 1.6; margin-bottom: 10px; color: #000; box-sizing: border-box; }
ul.dot-list02 > li .tit { font-weight: 700; font-size: 20px; padding-left: 22px; position: relative; }
ul.dot-list02 > li .tit:before { content: ""; width: 10px; height: 10px; background: #07B53B; border-radius: 100%; position: absolute; left: 0; top: 12px; }
ul.dot-list02 > li:last-child { margin-bottom: 0; }

section#p09Box04 { padding: 100px 5.33vw; background: #F1F3F4; }
section#p09Box04 .titles04 { margin-bottom: 40px; }
section#p09Box04 .name01 { font-size: 18px; line-height: 1.06; font-weight: 700; margin-top: 30px; }
section#p09Box04 .img { margin-top: 60px; }

.twinBox11.flex { display: block; }
.twinBox11.flex > .cont .copy02 { font-size: 28px; margin-bottom: 40px; }
.twinBox11.flex > .img { margin-top: 60px; }

section#p09Box05 { padding: 100px 5.33vw; }
section#p09Box05 .name02 { margin-top: 40px; text-align: right; line-height: 1.6; }

.phBoxs > div.box { margin-bottom: 40px; }
.phBoxs > div.box h3 { font-size: 24px; font-weight: 700; line-height: 1.6; margin-bottom: 10px; }
.phBoxs > div.box:last-child { margin-bottom: 0; }

ul.num-list01 > li { list-style: decimal; margin-bottom: 4px; margin-left: 15px; }
ul.num-list01 > li:last-child { margin-bottom: 0; }

section#p09Box06 { padding: 100px 5.33vw; background: #136841; color: #fff; }
section#p09Box06 .titles04 { color: #fff; margin-bottom: 40px; }

ul.dot-list02.dot-list03 { margin-top: 30px; }
ul.dot-list02.dot-list03 > li { padding: 30px 20px; }
ul.dot-list02.dot-list03 > li .tit { box-sizing: border-box; width: 100%; margin-bottom: 10px; }
ul.dot-list02.dot-list03 > li .text { width: 100%; }

section#p09Box07 { padding: 100px 5.33vw; background: #F1F3F4; }

.licBox { width: 100%; display: flex; flex-wrap: wrap; justify-content: space-between; padding-bottom: 41px; margin-bottom: 40px; background: url("../img/p09/line01.svg") no-repeat left bottom; }
.licBox .cont { width: 100%; }
.licBox .cont h3 { font-weight: 700; line-height: 1.6; font-size: 28px; margin-bottom: 6px; }
.licBox .cont h3 .komoji { font-size: 18px; display: block; }
.licBox .cont .age01 { line-height: 1.6; font-weight: 700; margin-bottom: 20px; }
.licBox .img { width: 64vw; margin: 30px auto 0; }
.licBox .img .in-img { padding-top: 91.6%; border-radius: 10px; }

.licBox:last-child { background: none; padding-bottom: 0; margin-bottom: 0; }

section#p09Box08 { padding: 100px 5.33vw 0; }
section#p09Box08 .titles04 { margin-bottom: 40px; }

.history-box { display: flex; flex-wrap: wrap; align-items: flex-start; padding-bottom: 20px; margin-bottom: 20px; position: relative; border-bottom: solid 1px #DDDDDD; }
.history-box .age { width: 100%; box-sizing: border-box; font-weight: 700; }
.history-box .cont { width: 100%; }

.history-box:before { content: ""; width: 10px; height: 1px; background: #07B53B; position: absolute; left: 0; bottom: -1px; }

/*10 採用情報
----------------------------------*/
div#p10Box01 { padding: 60px 5.33vw 100px; background: #F1F3F4; }
div#p10Box01 .copy { font-size: 40px; margin-bottom: 40px; }
div#p10Box01 ul.check-list01.type02 { margin-bottom: 40px; box-sizing: border-box; }

.twinBox12.flex { display: block; }
.twinBox12.flex .img { margin-bottom: 40px; }

section#p03Box02.p10Box02 .titles04 { color: #fff; margin-bottom: 40px; }
section#p03Box02.p10Box02 .f-name { font-size: 20px; }
section#p03Box02.p10Box02 .feat-list03.flex { margin-top: -20px; }
section#p03Box02.p10Box02 .feat-list03.flex > .box { margin-top: 20px; }

section#p10Box03 { padding-bottom: 1px; }
section#p10Box03 .wrap { padding: 100px 5.33vw; }
section#p10Box03 .titles04 { margin-bottom: 60px; }

.rec-datas.flex { margin-top: -19px; }
.rec-datas.flex > .box { box-sizing: border-box; position: relative; padding: 95px 20px 30px; width: 100%; height: 240px; border-radius: 10px; text-align: center; border: solid 1px #136841; margin-top: 19px; }
.rec-datas.flex > .box > .text { margin-top: 25px; }
.rec-datas.flex > .box.box01 { padding-top: 69px; }
.rec-datas.flex > .box.box01 > .text { margin-top: 15px; }
.rec-datas.flex > .box.box02 .numBox01 span.text:first-child { margin-right: 4px; }
.rec-datas.flex > .box.box05 { padding-top: 80px; }
.rec-datas.flex > .box.box05 .numBox01 span.num { font-size: 44px; }
.rec-datas.flex > .box.box05 > .text { margin-top: 20px; }
.rec-datas.flex > .box.box06 { padding-top: 80px; }
.rec-datas.flex > .box.box06 > .text { margin-top: 20px; }
.rec-datas.flex > .box:nth-child(3n) { margin-right: 0; }
.rec-datas.flex .ang-tit { font-size: 20px; line-height: 1.6; color: #fff; padding: 4px 30px; background: #136841; }

.numBoxs.flex { justify-content: center; }

.numBox01 { text-align: center; color: #136841; }
.numBox01 .num { line-height: 1; font-weight: 500; font-size: 50px; margin-right: 4px; font-family: "pop"; }
.numBox01 span.text { font-weight: 700; font-size: 22px; line-height: 1.6; }

.numBox02 { text-align: center; color: #136841; margin-top: 10px; }
.numBox02 .num { line-height: 1; font-weight: 500; font-size: 30px; margin-right: 4px; font-family: "pop"; }
.numBox02 span.text { font-weight: 700; font-size: 16px; line-height: 1.6; }

div.belt-slider { position: relative; z-index: 3; margin-bottom: -22.93vw; }

.sl01 { width: 80vw; margin-right: 5.33vw; }

section#p10Box04 { padding: calc(22.93vw + 100px) 5.33vw 100px; background: #F1F3F4; }
section#p10Box04 .titles04 { margin-bottom: 40px; }

.sepa { border-collapse: separate; }

article.rec-art { background: #fff; border-radius: 6px; }

article.rec-art.on { border: solid 1px #136841; }

.rec-head.flex.on { margin-bottom: -10px; }
.rec-head.flex.on span.opcl-ico { background: #136841; }
.rec-head.flex.on span.opcl-ico:before { background: #fff; }
.rec-head.flex.on span.opcl-ico:after { transform: rotateZ(-90deg); background: #fff; }

.rec-head.flex { position: relative; padding: 40px 55px 40px 20px; transition: 0.3s; box-sizing: border-box; cursor: pointer; }
.rec-head.flex .sub01 { margin-bottom: 0; font-size: 22px; color: #000; }
.rec-head.flex span.opcl-ico { width: 40px; height: 40px; display: block; z-index: 2; position: absolute; right: 10px; top: 50%; transform: translateY(-50%); background: #DFEFE4; border-radius: 100%; }
.rec-head.flex span.opcl-ico:before { content: ""; width: 15px; height: 1px; background: #136841; position: absolute; left: 0; right: 0; top: 0; bottom: 0; margin: auto; }
.rec-head.flex span.opcl-ico:after { content: ""; width: 1px; height: 15px; background: #136841; position: absolute; left: 0; right: 0; top: 0; bottom: 0; margin: auto; transition: 0.5s; }

.opcl-cont { display: none; }
.opcl-cont > div { padding: 1px 20px 40px; }
.opcl-cont > div .btn01 { margin: 40px auto 0; }
.opcl-cont .infos.flex { margin-bottom: 10px; margin-left: -10px; }
.opcl-cont .infos.flex .w-cate { margin-left: 10px; color: #136841; border-color: #DFEFE4; background: #DFEFE4; padding: 0 20px; line-height: 34px; }
.opcl-cont .TBL09 tr { display: block; position: relative; }
.opcl-cont .TBL09 th, .opcl-cont .TBL09 td { display: block; }
.opcl-cont .TBL09 th { width: auto; padding-left: 0; padding-bottom: 5px; position: static; }
.opcl-cont .TBL09 td { display: block; padding-top: 0; }

section#p10Box05 { padding: 100px 5.33vw 1px; }
section#p10Box05 .titles04 { margin-bottom: 70px; }

.rec-flow.flex { margin: 0 auto 40px; max-width: 263px; }
.rec-flow.flex > div.box { position: relative; width: 100%; box-sizing: border-box; border: solid 1px #136841; border-radius: 0 10px 10px 10px; display: table; height: 74px; margin-bottom: 46px; }
.rec-flow.flex > div.box > span { font-weight: 700; text-align: center; vertical-align: middle; display: table-cell; }
.rec-flow.flex > div.box .step-tit { font-weight: 500; font-size: 14px; border-radius: 10px 10px 0 0; background: #136841; line-height: 1.6; padding: 4px 20px; position: absolute; left: -1px; bottom: 100%; color: #fff; }
.rec-flow.flex > div.box:last-child { margin-bottom: 0; }

/*11 設備紹介
----------------------------------*/
div#p11Box01 { padding: 60px 5.33vw 100px; background: #F1F3F4; }

div.faci-list.flex { margin-top: -20px; justify-content: space-between; }

article.faci-art { box-sizing: border-box; margin-top: 20px; background: #fff; padding: 20px 20px 25px; border-radius: 10px; width: 100%; }
article.faci-art .img { margin-bottom: 40px; }
article.faci-art .img .in-img { padding-top: 64%; border-radius: 5px; }

.faci-tit { font-weight: 700; line-height: 1.6; font-size: 30px; position: relative; padding-left: 22px; margin-bottom: 15px; }
.faci-tit span.bikou { font-size: 16px; }

.faci-tit:before { content: ""; width: 8px; height: 8px; border-radius: 100%; background: #07B53B; position: absolute; left: 0; top: 23px; }

.faciTBL th, .faciTBL td { box-sizing: border-box; padding: 16px 0; line-height: 1.6; vertical-align: top; }
.faciTBL th { width: 136px; font-size: 18px; line-height: 1.42; }
.faciTBL tr { border-bottom: solid 1px #ECEDED; }
.faciTBL tr:last-child { border-bottom: none; }

div#p11Box02 { padding: 100px 5.33vw 0; }
div#p11Box02 .titles04 { margin-bottom: 60px; }

section.o-faci { margin-bottom: 60px; }
section.o-faci > h3 { font-size: 24px; font-weight: 700; line-height: 1.6; margin-bottom: 20px; }

section.o-faci:last-child { margin-bottom: 0; }

.scr-wrap01 { width: 94.67vw; overflow: auto; padding-bottom: 20px; }

.faciTBL02 { width: 587px; }
.faciTBL02 th, .faciTBL02 td { border: solid 1px #DDDDDD; line-height: 1.6; padding: 12px 20px; }
.faciTBL02 thead th { background: #EEEEEE; }
.faciTBL02 .col01 { width: 290px; }
.faciTBL02 .col02 { width: 230px; }
.faciTBL02 .col03 { width: 480px; }
.faciTBL02 .col04 { width: 97px; }

/*12 実績紹介
----------------------------------*/
.case-list-all { width: 100%; }
.case-list-all article.works-art { margin-bottom: 20px; width: 100; }
.case-list-all article.works-art:last-child { margin-bottom: 0; }

/*詳細*/
div#p12sBox01 { padding: 60px 5.33vw 100px; background: #F1F3F4; }

div#two-side { margin-top: 40px; }

article.singleBox01 { background: #fff; padding: 40px 20px 60px; border-radius: 10px; }
article.singleBox01 .infos.flex { margin-bottom: 60px; }
article.singleBox01 .infos.flex .n-date { font-size: 14px; width: 100%; }
article.singleBox01 .w-data { margin-top: 40px; margin-bottom: 40px; }

h1.titles04.sw-tit01 { margin-bottom: 20px; font-size: 28px; }

.works-cont01.flex { display: block; }
.works-cont01.flex .gallery-main { width: 100%; margin-bottom: 8vw; }
.works-cont01.flex .gallery-thumb.flex { width: 100%; margin-top: -4px; justify-content: space-between; }
.works-cont01.flex .gallery-thumb.flex .slick-track { transform: none !important; width: 100% !important; display: flex; flex-wrap: wrap; }

.g-main { text-align: center; }
.g-main .cap { line-height: 1.6; margin-top: 14px; }

.g-main-img a { position: relative; text-decoration: none; display: block; }
.g-main-img a .in-img { border-radius: 10px; padding-top: 76.47%; }
.g-main-img a:before { content: ""; background: url("../img/p12/ico-lens.svg") no-repeat; width: 30px; height: 30px; z-index: 2; position: absolute; right: 10px; bottom: 10px; transition: 0.3s; }

.g-thumb { width: calc(29.78vw - 18px); border-radius: 6px; position: relative; margin-top: 4px; margin-right: 4px; cursor: pointer; transition: 0.3s; }
.g-thumb .in-img { border-radius: 6px; padding-top: 75.86%; }

.g-thumb.slick-current { opacity: 0.4; }

.g-thumb:nth-child(3n) { margin-right: 0; }

.w-repeat { margin-top: 60px; }
.w-repeat .w-repeatBox { margin-bottom: 60px; }
.w-repeat .w-repeatBox:last-child { margin-bottom: 0; }
.w-repeat .titles04.gray-t { margin-bottom: 20px; font-size: 26px; }

.wt-text01 { margin-bottom: 40px; }

.bfafBox.flex { margin-bottom: 40px; }

.wt-text01:last-child, .bfafBox.flex:last-child { margin-bottom: 0; }

.bfafBox.flex { justify-content: center; }
.bfafBox.flex .ang-tit { display: none; }
.bfafBox.flex > div.img { width: 100%; margin-bottom: 16vw; position: relative; }
.bfafBox.flex > div.img .in-img { border-radius: 10px; padding-top: 70.58%; }
.bfafBox.flex > div.img:last-child { margin-bottom: 0; }

.bfafBox.flex.bfaf .ang-tit { display: block; line-height: 1.6; font-size: 5.33vw; font-weight: 500; font-family: "pop"; padding: 1.06vw 5.33vw; color: #fff; background: #AAAAAA; }
.bfafBox.flex.bfaf .af .ang-tit { background: #07B53B; }
.bfafBox.flex.bfaf > div.img.bf:before { content: ""; width: 0; height: 0; border-top: solid 5.06vw #07B53B; border-left: solid 3.73vw transparent; border-right: solid 3.73vw transparent; position: absolute; left: 0; right: 0; margin: 0 auto; top: calc(100% + 5.33vw); }

.sideBox { margin-bottom: 20px; position: relative; background: #fff; border-radius: 10px; padding: 54px 20px 40px; border: solid 1px #136841; }
.sideBox .ang-tit { font-weight: 700; color: #fff; padding: 4px 30px; line-height: 1.6; background: #136841; }

.sideBox:last-child { margin-bottom: 0; }

.side-tit { font-size: 20px; font-weight: 700; padding-left: 20px; position: relative; line-height: 1.5; margin-bottom: 24px; color: #093182; }

.side-tit:before { content: ""; width: 4px; height: 100%; background: #093182; position: absolute; left: 0; top: 0; }

.sideBox.side-archive { padding-bottom: 20px; }

li.side-li { margin-bottom: 6px; }
li.side-li a { text-decoration: none; display: block; padding-left: 27px; line-height: 1.6; background: url("../img/p12/side-arrow.svg") no-repeat left top 4px; }

li.side-li:last-child { margin-bottom: 0; }

.side-inner select { display: block; width: 100%; border-radius: 0; padding: 5px 47px 5px 20px; box-sizing: border-box; height: 46px; background: url("../img/p12/select-arrow.svg") no-repeat center right 16px #DFEFE4; font-size: 16px; font-weight: 400; cursor: pointer; border: none; -webkit-appearance: none; appearance: none; border-radius: 4px; }

/*ページャー*/
div#pager00 { text-align: center; }

div#pager00 .wp-pagenavi { margin-top: 50px; }

.wp-pagenavi > span, .wp-pagenavi > a { display: inline-block; margin: 4px; text-decoration: none; width: 40px; height: 40px; text-align: center; line-height: 40px; font-size: 16px; font-weight: 500; color: #136841; background: #fff; box-sizing: border-box; border-radius: 100%; font-family: "pop"; }

.wp-pagenavi a.page { position: relative; }

.wp-pagenavi span.extend { background: none; color: #136841; box-shadow: none; border: none; }

.wp-pagenavi a.previouspostslink { color: transparent; background: url("../img/p12/arrow02.svg") no-repeat center #fff; margin-left: 0; }

.wp-pagenavi a.nextpostslink { color: transparent; background: url("../img/p12/arrow03.svg") no-repeat center #fff; margin-right: 0; }

.wp-pagenavi span.current { color: #fff; background: #136841; }

.wp-pagenavi a.first { border: solid 1px #136841; background: url("../img/p12/arrow01.svg") no-repeat center #fff; color: transparent; }

.wp-pagenavi a.last { border: solid 1px #136841; background: url("../img/p12/arrow04.svg") no-repeat center #fff; color: transparent; }

.wp-pagenavi span.pages { display: none; }

.post-navigation ul { margin-top: 40px; display: flex; flex-wrap: wrap; align-items: center; justify-content: center; }
.post-navigation ul > li { margin-right: 20px; }
.post-navigation ul > li .btn01 { width: 200px; }
.post-navigation ul > li:last-child { margin-right: 0; }
.post-navigation ul li.prev, .post-navigation ul li.next { width: 40px; }
.post-navigation ul li.kara { opacity: 0; pointer-events: none; display: flex; flex-wrap: wrap; }
.post-navigation ul li.prev.kara { opacity: 0; pointer-events: none; display: flex; flex-wrap: wrap; }
.post-navigation ul li.next.kara { opacity: 0; pointer-events: none; display: flex; flex-wrap: wrap; }
.post-navigation ul li.next.kara .arrow { argin-left: 20px; }
.post-navigation ul li.prev a { display: block; height: 40px; background: url("../img/p12/arrow-prev.svg") no-repeat center #07B53B; border-radius: 100%; }
.post-navigation ul li.next a { display: block; height: 40px; background: url("../img/p12/arrow-next.svg") no-repeat center #07B53B; border-radius: 100%; }
.post-navigation ul li.blog-back { width: 200px; height: 50px; display: table; }
.post-navigation ul li.blog-back > a { display: table-cell; text-align: center; vertical-align: middle; text-decoration: none; border: solid 2px #093182; background: #fff; color: #093182; border-radius: 40px; font-weight: 700; }

/*13 お問い合わせ
----------------------------------*/
div#p13Box01 { padding: 60px 5.33vw 100px; background: #F1F3F4; }
div#p13Box01 .text01 { font-weight: 700; font-size: 16px; margin-bottom: 40px; }
div#p13Box01 ul.check-list01.type02 { box-sizing: border-box; }
div#p13Box01 .contact-types.flex { justify-content: center; }
div#p13Box01 .contact-types.flex .box { box-shadow: 0 4px 24px rgba(0, 0, 0, 0.04); }

div#p13Box02 { padding: 80px 5.33vw 100px; border-bottom: solid 4px #07B53B; }
div#p13Box02 .wrap > .bikou-text { margin-top: 20px; }
div#p13Box02 .wrap > .bikou-text t > p { display: inline-block; }

.contactTBL.TBL09 .wpcf7-list-item { margin: 0 10px 10px 0 !important; }
.contactTBL.TBL09 th, .contactTBL.TBL09 td { display: block; padding-left: 0; }
.contactTBL.TBL09 th { padding-top: 30px; padding-bottom: 10px; width: auto; }
.contactTBL.TBL09 td { padding-bottom: 30px; position: relative; }
.contactTBL.TBL09 th:before { content: none; }
.contactTBL.TBL09 td:before { content: ""; width: 10px; height: 1px; background: #07B53B; position: absolute; left: 0; bottom: -1px; }
.contactTBL.TBL09 th { position: relative; padding-right: 50px; }
.contactTBL.TBL09 th .hissu { position: absolute; top: 30px; right: 0; }
.contactTBL.TBL09 tr:first-child th { padding-top: 30px; }
.contactTBL.TBL09 tr.line01-tr th { padding-top: 0; }
.contactTBL.TBL09 tr.line01-tr th .hissu { top: 0; }
.contactTBL.TBL09 tr:last-child td { padding-bottom: 0; }
.contactTBL.TBL09 tr:last-child td:before { content: none; }
.contactTBL.TBL09 .bikou-text > p { font-size: 14px; margin-bottom: 0; }
.contactTBL.TBL09 tr.check-tr { border-bottom: none; }
.contactTBL.TBL09 tr.check-tr td { padding-bottom: 0; }

.form-c01 { margin: 0 0 20px 0; }

.form-c01:last-child { margin-bottom: 0; }

/*フォーム*/
.file-bikou { font-size: 14px; }

ul.contact-state { display: flex; flex-wrap: wrap; justify-content: space-between; margin: 40px 0 40px; }

ul.contact-state > li { display: table; width: 32%; height: 64px; position: relative; }

ul.contact-state > li > span { display: table-cell; text-align: center; vertical-align: middle; color: #07B53B; font-size: 16px; font-weight: 700; border: solid 1px #07B53B; border-radius: 5px; opacity: 0.4; position: relative; }
ul.contact-state > li > span .text { display: inline-block; padding-top: 30px; }

ul.contact-state > li.state01 { margin-left: 0; }

ul.contact-state > li.state01 > span { opacity: 1; }

ul.contact-state > li > span span.num { position: absolute; left: 0; right: 0; top: 10px; margin: 0 auto; display: block; width: 24px; height: 24px; text-align: center; line-height: 24px; background: #07B53B; color: #fff; border-radius: 100%; font-size: 14px; font-family: "pop"; }

ul.contact-state.contact-state02 { display: flex; flex-wrap: wrap; justify-content: space-between; }

ul.contact-state.contact-state02 > li.state02 > span { opacity: 1; }

a.green { text-decoration: underline; color: #07B53B; }

span.hissu { display: inline-block; color: #fff; padding: 2px 10px; background: #07B53B; box-sizing: border-box; font-size: 14px; font-weight: 700; border-radius: 4px; line-height: 1.6; }

span.nini { display: inline-block; padding: 0px 6px; font-size: 14px; font-weight: 700; border-radius: 4px; background: #E6E6E6; }

input.wpcf7-number, input.wpcf7-date, input.wpcf7-text { box-sizing: border-box; height: 46px; border: solid 1px #EEEEEE; padding: 5px 10px; font-size: 16px; background: #F6F6F6; width: 100%; border-radius: 4px; }

input.wpcf7-date { padding: 5px 10px; border-radius: 4px; }

select.wpcf7-select { box-sizing: border-box; height: 46px; border: solid 1px #EEEEEE; padding: 5px 40px 5px 10px; font-size: 16px; width: 100%; border-radius: 4px; background: url("../img/p12/select-arrow.svg") no-repeat center right 10px #F6F6F6; font-size: 16px; cursor: pointer; border: none; -webkit-appearance: none; appearance: none; }

select { background: #F6F6F6; border-radius: 4px; }

textarea.wpcf7-textarea { box-sizing: border-box; height: 160px; border: solid 1px #EEEEEE; padding: 10px 10px; font-size: 16px; background: #F6F6F6; width: 100%; border-radius: 4px; }

input#com-name, input#busho { width: 100%; }

.wpcf7-checkbox input[type="checkbox"] { display: none; }
.wpcf7-checkbox span.wpcf7-list-item-label { display: inline-block; padding-left: 24px; background: url("../img/p13/check01.svg") no-repeat left top 3px; padding-bottom: 2px; cursor: pointer; }
.wpcf7-checkbox input[type="checkbox"]:checked ~ span.wpcf7-list-item-label { background-image: url("../img/p13/check02.svg"); }

.wpcf7-radio input[type="radio"] { display: none; }
.wpcf7-radio span.wpcf7-list-item-label { display: inline-block; padding-left: 24px; background: url("../img/p13/radio01.svg") no-repeat left top 3px; padding-bottom: 2px; cursor: pointer; }
.wpcf7-radio input[type="radio"]:checked ~ span.wpcf7-list-item-label { background-image: url("../img/p13/radio02.svg"); }

#doui span.wpcf7-list-item-label { color: transparent; margin-right: -2px; }

.contactTBL .select-con .wpcf7-list-item { display: block; margin-right: 10px !important; }

.select-con { margin-bottom: 15px; }

input.wpcf7-form-control.ip400 { width: 100%; }

.cours-area { margin-top: 5px; }

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: solid 1px #eeeeee; border-radius: 0; background: #F6F6F6; padding: 20px 10px 30px; border-radius: 4px; }

.contactArea .codedropz-upload-inner { color: #1C1C1C; line-height: 1.5; font-size: 16px; font-weight: 500; }

.contactArea .codedropz-upload-inner h3 { font-size: 16px; font-weight: 500; margin: 0; }

a.cd-upload-btn { width: 240px; height: 40px; display: inline-block; line-height: 35px; background: #000000; border: solid 1px #000000; border-radius: 4px; padding-top: 3px; font-size: 16px; margin-top: 8px; color: #fff; }

.contact-submit.flex { margin-top: 40px; 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 3px #07B53B; color: #07B53B; width: 100%; height: 72px; font-size: 16px; font-weight: 700; position: relative; z-index: 3; background: url("../img/p13/arrow01.svg") no-repeat center right 18px #fff; text-align: center; border-radius: 40px; }

.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: #07B53B; background-image: url("../img/p13/arrow02.svg"); background-position: left 18px center; }

.form-btn input { transition: 0.3s; cursor: pointer; }

span.zip-mark { margin-right: 10px; font-size: 14px; }

span.zip-bikou { margin-left: 15px; font-size: 13px; }

.zip_list > div { margin-bottom: 10px; }
.zip_list > div:last-child { margin-bottom: 0; }
.zip_list .zip00.zip02 > div { margin-bottom: 10px; }
.zip_list .zip00.zip02 > div:last-child { margin-bottom: 0; }

.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: #CCCCCC; 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.TBL09 th .hissu { top: auto; }

.contactArea.che .contactTBL tr { border-bottom: solid 1px #000; }

.contactArea.che .contactTBL th, .contactArea.che .contactTBL td { padding-top: 5px !important; padding-bottom: 5px !important; 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] ~ 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] ~ 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; }

/*14  ブログ
----------------------------------*/
.btn01.pdf-btn span.text-pdf { position: absolute; display: inline-block; color: #fff; border-radius: 4px; background: #07B53B; width: 51px; height: 25px; line-height: 25px; font-size: 18px; font-weight: 700; z-index: 2; right: 40px; top: 50%; transform: translateY(-50%); transition: 0.3s; }

.pdf-cont { position: relative; box-sizing: border-box; margin: 0 auto 40px; }

article.blog-art { margin-bottom: 20px; }
article.blog-art a { text-decoration: none; display: flex; flex-wrap: wrap; width: 100%; background: #fff; border-radius: 10px; }
article.blog-art a .img { width: 100%; overflow: hidden; border-radius: 10px 10px 0 0; }
article.blog-art a .img .in-img { padding-top: 75%; transition: 0.3s; border-radius: 10px 10px 0 0; }
article.blog-art a .cont { padding: 20px 20px 30px; width: 100%; box-sizing: border-box; }
article.blog-art a .cont h2.tit { font-weight: 700; font-size: 18px; width: 100%; line-height: 25px; display: -webkit-box; overflow: hidden; -webkit-line-clamp: 2; -webkit-box-orient: vertical; margin-top: 8px; }
article.blog-art a .cont .n-date { font-weight: 400; }

article.blog-art:last-child { margin-bottom: 0; }

/*詳細*/
div.witerBox { position: relative; background: #F1F3F4; border-radius: 10px; padding: 20px; margin-top: 50px; }
div.witerBox .titles04 { font-size: 20px; }
div.witerBox .inner { position: relative; }
div.witerBox .inner > h2 { font-size: 20px; line-height: 1.6; margin-bottom: 4px; }
div.witerBox .inner .team-name { font-weight: 700; line-height: 1.6; color: #136841; }
div.witerBox .inner .wr-detail { line-height: 1.6; margin-top: 7px; margin-bottom: 20px; }
div.witerBox .inner .img { width: 100px; margin: 0 auto 20px; }
div.witerBox .inner .img .in-img { border-radius: 100%; padding-top: 100%; }

.case-tit02 { font-size: 18px; font-weight: 700; line-height: 1.6; margin-bottom: 15px; position: relative; padding-left: 28px; color: #093182; }

.case-tit02:before { content: ""; width: 16px; height: 1px; background: #093182; position: absolute; left: 0; top: 14px; }

.blog-tit02 { font-size: 18px; font-weight: 700; line-height: 1.6; margin-bottom: 20px; color: #093182; border-bottom: solid 2px; padding-bottom: 14px; }

article.singleBox01 .box01 p:first-child, article.singleBox01 .box02 p:first-child, .blog-text p:first-child { margin-top: 0; }
article.singleBox01 .box01 p:first-child img, article.singleBox01 .box02 p:first-child img, .blog-text p:first-child img { margin-top: 0; }
article.singleBox01 .box01 img:first-child, article.singleBox01 .box02 img:first-child, .blog-text img:first-child { margin-top: 0; }
article.singleBox01 .box01 img[class*="wp-image-"], article.singleBox01 .box02 img[class*="wp-image-"], .blog-text img[class*="wp-image-"] { margin: 20px 0; }
article.singleBox01 .box01 iframe, article.singleBox01 .box02 iframe, .blog-text iframe { max-width: 100%; }
article.singleBox01 .box01 div, article.singleBox01 .box02 div, .blog-text div { max-width: 100%; }
article.singleBox01 .box01 a, article.singleBox01 .box02 a, .blog-text a { max-width: 100%; text-decoration: underline; }

article.singleBox01.singleBox01-blog div.witerBox { margin-top: 40px; }
article.singleBox01.singleBox01-blog div#toc_container { box-sizing: border-box; width: 100%; background: #EEEEEE; border: none; padding: 20px 20px 12px; margin-bottom: 40px; }
article.singleBox01.singleBox01-blog div#toc_container p.toc_title { text-align: left; line-height: 1.6; font-size: 16px; font-weight: 700; color: #093182; margin-bottom: 14px; position: relative; padding-left: 12px; }
article.singleBox01.singleBox01-blog div#toc_container p.toc_title:before { content: ""; width: 4px; height: 4px; background: #093182; border-radius: 100%; position: absolute; left: 0; top: 11px; }
article.singleBox01.singleBox01-blog div#toc_container p.toc_title:after { content: ""; width: 4px; height: 4px; background: #093182; border-radius: 100%; position: absolute; left: 52px; top: 11px; }
article.singleBox01.singleBox01-blog div#toc_container ul.toc_list { margin-top: 0 !important; }
article.singleBox01.singleBox01-blog div#toc_container ul.toc_list > li { font-size: 16px; font-weight: 500; margin-bottom: 8px; }
article.singleBox01.singleBox01-blog div#toc_container ul.toc_list > li a { display: inline-block; position: relative; }
article.singleBox01.singleBox01-blog div#toc_container ul.toc_list > li > a { padding-left: 18px; }
article.singleBox01.singleBox01-blog div#toc_container ul.toc_list > li > ul { margin-top: 8px; }
article.singleBox01.singleBox01-blog div#toc_container ul.toc_list > li > ul > li { margin-bottom: 8px; }
article.singleBox01.singleBox01-blog div#toc_container ul.toc_list > li > ul > li > a { padding-left: 36px; }
article.singleBox01.singleBox01-blog div#toc_container ul.toc_list > li > ul > li > ul { margin-top: 8px; }
article.singleBox01.singleBox01-blog div#toc_container ul.toc_list > li > ul > li > ul > li { margin-bottom: 8px; }
article.singleBox01.singleBox01-blog div#toc_container ul.toc_list > li > ul > li > ul > li > a { padding-left: 52px; }
article.singleBox01.singleBox01-blog div#toc_container ul.toc_list > li span.toc_number { display: inline-block; font-size: 16px; font-family: "robo"; color: #093182; vertical-align: -2px; margin-right: 10px; position: absolute; left: 0; top: 0; }
article.singleBox01.singleBox01-blog div#toc_container ul.toc_list > li span.toc_number:after { content: "."; }

.blog_word_box { margin-top: 60px; }
.blog_word_box > .tit { color: #0A0A0A; font-weight: 700; line-height: 1.6; margin-bottom: 10px; font-size: 16px; position: relative; padding-left: 28px; }
.blog_word_box > .tit:before { content: ""; width: 16px; height: 1px; background: #0A0A0A; position: absolute; left: 0; top: 13px; }

ul.word_list.flex { margin-top: -10px; margin-left: -10px; width: calc(100% + 10px); }
ul.word_list.flex > li { margin: 10px 0 0 10px; font-weight: 500; }

/*100 thanksページ等
----------------------------------*/
div#p100Box01 { padding: 60px 5.33vw 100px; text-align: center; background: #F1F3F4; }
div#p100Box01 .btn01 { margin: 40px auto 0; }

div#ppBox01 { text-align: left; }

.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: #07B53B; margin-top: 50px; }

.pp-title02:before { content: ""; width: 5px; height: 65%; background: #07B53B; position: absolute; left: 0; top: 0; bottom: 0; margin: auto 0; }

/*デバイス幅ごとの調整（必要な幅があれば追加して調整）*/
@media screen and (min-width: 0px) and (max-width: 470px) { span.inb.inb02 { max-width: 150px; vertical-align: top; } }
