@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 { /*Roboto-Medium*/
font-family: 'robo'; src: url("../fonts/Roboto-Medium.otf"); src: url("../fonts/Roboto-Medium.woff2") format("woff2"), url("../fonts/Roboto-Medium.woff") format("woff"), url("../fonts/Roboto-Medium.otf") format("truetype"); font-weight: 500; }
@font-face { /*Roboto-Bold*/
font-family: 'robo'; src: url("../fonts/Roboto-Bold.otf"); src: url("../fonts/Roboto-Bold.woff2") format("woff2"), url("../fonts/Roboto-Bold.woff") format("woff"), url("../fonts/Roboto-Bold.otf") format("truetype"); font-weight: 700; }
/* 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; padding-top: 56px; background: #fff; color: #000000; font-size: 16px; line-height: 1.6; 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; /* 禁則処理を厳格に適用 */ }

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: #141414; }

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: 30px; font-weight: 700; margin-bottom: 30px; }
.titles01 .en { color: #1E008B; font-size: 16px; line-height: 1; display: block; position: relative; z-index: 2; text-transform: uppercase; margin-bottom: 10px; }
.titles01 .en > span { display: inline-block; position: relative; }
.titles01 .en > span:before { content: ""; background: url("../img/common/tit-ico01.svg") no-repeat; width: 30px; height: 30px; background-size: contain; z-index: -1; left: -15px; top: -5px; position: absolute; }
.titles01 .jp { font-size: 32px; line-height: 1.4; display: block; }

.titles01.type02 { text-align: center; }
.titles01.type02 .en { color: #fff; }
.titles01.type02 .en > span:before { left: 0; right: 0; margin: 0 auto; background-image: url("../img/common/tit-ico01-w.svg"); }
.titles01.type02 .jp { color: #FFFFFF; }

.titles02 { margin-bottom: 30px; font-weight: 700; font-size: 26px; }
.titles02 > span { display: inline-block; padding-left: 35px; background: url("../img/common/tit-ico02.svg") no-repeat left center; }

.titles03 { text-align: center; color: #fff; position: relative; font-weight: 700; margin-bottom: 40px; }
.titles03 .en { display: block; opacity: 0.08; font-size: 108px; line-height: 1; text-transform: uppercase; white-space: nowrap; position: relative; left: 50%; transform: translateX(-50%); width: 510px; }
.titles03 .jp { line-height: 1.6; font-size: 40px; position: absolute; left: 0; top: 50%; width: 100%; transform: translateY(-50%); z-index: 2; }

.titles05 { margin-bottom: 20px; font-weight: 700; font-size: 22px; position: relative; }

.titles05:before { content: ""; width: 20px; height: 2px; background: #1E008B; position: absolute; top: 15px; left: -30px; }

/*共通ボタン設定*/
.btn01 { min-width: 100%; height: 72px; display: table; }
.btn01 a { display: table-cell; text-decoration: none; color: #fff; border: solid 1px #1E008B; border-radius: 40px; position: relative; text-align: center; vertical-align: middle; padding: 5px 55px 5px 40px; background: #1E008B; font-size: 16px; line-height: 1.2; font-weight: 700; transition: 0s; }
.btn01 a span.arrow { position: absolute; right: 19px; top: 50%; transform: translateY(-50%); z-index: 2; display: flex; flex-wrap: wrap; justify-content: center; align-items: center; width: 40px; height: 24px; border-radius: 20px; background: #fff; }
.btn01 a span.arrow img { display: block; transition: 0s; width: 12px; }

/*グラデーション*/
.gra01 { display: inline-block; padding: 4px 10px; background: linear-gradient(120deg, #1E008B 0%, #5391EE 100%); color: #fff; }

.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*/
.en, .robo, .num { font-family: 'robo'; }

.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: #1E008B; }

.blue02 { color: #494AE9; }

.yellow { color: #FFD400; }

.orange { color: #EE5A35; }

.green { color: #74BA26; }

.d-green { color: #005E4B; }

.green02 { color: #01A9AE; }

.navy { color: #374b8e; }

.pink { color: #ff7373; }

.gray { color: #818181; }

/*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: 10px 5.33vw 0; left: 0; top: 0; background: #fff; }

.head-text { display: none; }

.logo a { display: block; height: 35px; text-decoration: none; display: inline-block; padding-left: 48px; background: url("../img/common/logo-mark.svg") no-repeat left top; background-size: 35px; padding-top: 6px; }
.logo a img { display: block; width: 105px; }

.head-right { display: none; }

.c-feat { margin-left: 20px; text-align: center; display: none; }
.c-feat > div { border: solid 1px; font-size: 12px; line-height: 1; padding: 5px; box-sizing: border-box; width: 92px; border-radius: 2px; margin-bottom: 4px; }
.c-feat > div:last-child { margin-bottom: 0; }

div.head-right { margin-left: auto; }
div.head-right .tel-set.tel-set01 { display: flex; flex-wrap: wrap; align-items: center; }
div.head-right .tel-set.tel-set01 .tel-num a { display: inline-block; padding-left: 30px; font-size: 26px; font-weight: 500; font-family: "robo"; background: url("../img/common/ico-tel-w.svg") no-repeat left center; }
div.head-right .tel-set.tel-set01 .bh { font-size: 14px; font-weight: 500; margin-left: 10px; }
div.head-right div.box01 { display: flex; flex-wrap: wrap; align-items: center; justify-content: flex-end; }

.tel-set .bh { font-size: 14px; font-weight: 500; }

.tel-num a { font-family: 'robo'; font-size: 26px; line-height: 1; font-weight: 500; }

.fax-num { font-family: 'robo'; font-size: 26px; line-height: 1; font-weight: 500; }

/*スクロール追従*/
.fixed div#header { background: #FFFFFF; background-size: cover; box-shadow: 0 0 3px rgba(0, 0, 0, 0.2); padding-top: 10px; }

/* nav
=========================================== */
.sp-tel.sp { width: 40px; position: fixed; z-index: 210; top: 8px; right: 60px; }
.sp-tel.sp a { display: flex; flex-wrap: wrap; width: 40px; height: 40px; background: url("../img/common/sp-tel.svg") no-repeat center; justify-content: center; align-items: center; }
.sp-tel.sp a img { display: block; width: 16px; }

html.huopen { overflow: hidden; }

.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: #000000; }

.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 0 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: 60px; background: none; width: 100%; border-bottom: none; box-sizing: border-box; padding: 0 5.33vw 30px; }
ul.navs-list li.sp-contact .tel-set.tel-set01 { text-align: center; }
ul.navs-list li.sp-contact .tel-set.tel-set01 .tel-num a { font-size: 40px; display: inline-block; padding-left: 44px; background: url("../img/common/ico-tel.svg") no-repeat left center; background-size: 34px; }
ul.navs-list li.sp-contact .tel-set.tel-set01 .bh { font-size: 18px; margin-top: 10px; }
ul.navs-list li.sp-contact .btn01.contact-btn { width: calc(100% - 40px); margin: 30px auto 0; }
ul.navs-list li.sp-contact .btn01.contact-btn a { border-radius: 4px; }
ul.navs-list li.sp-contact .btn01.contact-btn a span.ico { width: 18px; display: inline-block; }

.navs-list > li { width: 100%; border-bottom: solid 1px #ECEDED; }
.navs-list > li > a { display: block; padding: 22px calc(5.33vw + 30px) 22px 5.33vw; color: #000; font-weight: 700; line-height: 1; background: url("../img/common/sp-arrow01.svg") no-repeat center right 5.33vw; }
.navs-list > li > .dr-tit { display: block; padding: 22px calc(5.33vw + 30px) 22px 5.33vw; color: #000; font-weight: 700; line-height: 1; background: url("../img/common/sp-open.svg") no-repeat center right 5.33vw; }
.navs-list > li > .dr-tit .arrow { display: none; }
.navs-list > li > .dr-tit.on { background-image: url("../img/common/sp-close.svg"); }
.navs-list > li ul.nav-sub { background: #EBF6FF; }
.navs-list > li ul.nav-sub > li { border-bottom: solid 1px #B8DFFF; }
.navs-list > li ul.nav-sub > li .arrow { display: none; }
.navs-list > li ul.nav-sub > li a { padding: 22px 5.33vw 22px calc(5.33vw + 12px); text-decoration: none; background: url("../img/common/sp-arrow02.svg") no-repeat center left 5.33vw; display: block; font-weight: 400; }
.navs-list > li ul.nav-sub > li:last-child { border-bottom: none; }

/* contents */
/*-------------------------------------------*/
.bg-blue { background: #F5F9FF; }

/*パンくず
---------------------------------------------------------------*/
div#bread { z-index: 2; position: relative; padding: 10px 5.33vw 0; }

#bread ul { display: flex; flex-wrap: wrap; align-items: center; }

#bread ul li { display: flex; flex-wrap: wrap; align-items: center; font-size: 14px; font-weight: 500; color: #1E1E1E; vertical-align: middle; }

ul.bread-list li a { font-size: 14px; color: #1E1E1E; }
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; color: #1E1E1E; }

#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: #1E1E1E; }

/* メインビジュアル */
/*-------------------------------------------*/
/*TOPページ*/
div#mv { position: relative; z-index: 3; letter-spacing: 0; }

/* footer */
/*-------------------------------------------*/
div#sp-scr { position: fixed; z-index: 110; left: 0; bottom: 0; width: 100%; }
div#sp-scr .btn01.contact-btn a { border-radius: 0; font-weight: 700; }
div#sp-scr .btn01.contact-btn .ico { width: 20px; display: inline-block; position: relative; top: -2px; }

div#footer { padding-bottom: 60px; }

.page-contact div#footer { padding-bottom: 0; }

aside#aside01 { background: url("../img/common/aside-bg-sp.jpg") no-repeat center top; background-size: cover; }
aside#aside01 .wrap { padding: 83px 5.33vw 55.73vw; }

.u-text01 { text-align: center; font-weight: 700; color: #fff; }

.contact-types.flex { justify-content: space-between; position: relative; z-index: 3; }
.contact-types.flex > div.box { background: #FFFFFF; border-radius: 10px; padding: 30px 20px; box-sizing: border-box; width: 100%; text-align: center; margin-bottom: 10px; }
.contact-types.flex > div.box .ico { margin: 0 auto 10px; width: 48px; }
.contact-types.flex > div.box h3.tit { margin-bottom: 10px; font-weight: 700; color: #1E008B; font-size: 20px; }
.contact-types.flex > div.box .btn01 { width: 100%; min-width: 260px; }
.contact-types.flex > div.box .tel-set01 { text-align: center; }
.contact-types.flex > div.box .tel-num { display: block; line-height: 1; }
.contact-types.flex > div.box .tel-num a { font-size: 40px; }
.contact-types.flex > div.box .fax-num { line-height: 1; font-size: 40px; }
.contact-types.flex > div.box .bh { font-size: 14px; font-weight: 500; text-align: center; }
.contact-types.flex > div.box .tel-num .cap { display: none; }
.contact-types.flex > div.box:last-child { margin-bottom: 0; }

.c-bikou { font-weight: 500; margin-top: 10px; }

.aside-textBox { color: #fff; margin-bottom: 25px; }
.aside-textBox > .text { font-weight: 700; }
.aside-textBox > .text p { display: inline; }

ul.feat-list01.flex { width: calc(100% + 6px); margin: -6px 0 18px -6px; }
ul.feat-list01.flex > li { padding: 0 8px; border-radius: 20px; background: #1E008B; font-size: 16px; font-weight: 700; line-height: 31px; margin: 6px 0 0 6px; }
ul.feat-list01.flex > li:last-child { margin-right: 0; }

.ilu-sb { width: 89.34vw; height: 47.73vw; position: absolute; right: 5.33vw; bottom: 0; background: url("../img/common/ilu-aside.svg") no-repeat right bottom; background-size: 38.4vw; }
.ilu-sb .sb { background: url("../img/common/aside-sb.png") no-repeat; width: 66.66vw; height: 21.86vw; display: table; margin-top: 16.53vw; background-size: 100%; }
.ilu-sb .sb > span { display: table-cell; padding-left: 6.33vw; vertical-align: middle; font-size: 3.73vw; line-height: 1.5; font-weight: 700; }

div#ftMap { height: 90.66vw; }
div#ftMap iframe { width: 100%; height: 100%; }

div#ftBox01 { padding: 60px 5.33vw; overflow: hidden; }
div#ftBox01 > .wrap .left { margin: 60px auto 0; width: 245px; }
div#ftBox01 .tel-num a:before { content: "TEL."; }
div#ftBox01 .fax-set01 { margin-top: 20px; }
div#ftBox01 .fax-num:before { content: "FAX."; }

h2.ft-logo { margin: 0 0 30px; width: 230px; }

div#fnav { display: flex; flex-wrap: wrap; justify-content: space-between; margin-top: -38px; }
div#fnav > div { width: 50%; margin-top: 38px; }
div#fnav > div:nth-child(2n) { width: 40%; }
div#fnav > div:last-child { margin-right: 0; }

.fnav.fnav03 .ft-tit:first-child, .fnav.fnav04 .ft-tit:first-child { margin-top: 0; }
.fnav.fnav03 .ft-tit, .fnav.fnav04 .ft-tit { margin-top: 14px; }

.ft-tit:first-child { margin-top: 0; }

.ft-tit { font-weight: 700; margin-top: 30px; line-height: 1.6; }
.ft-tit .in-t { display: flex; flex-wrap: wrap; align-items: center; text-decoration: none; }
.ft-tit .in-t span.arrow { margin-left: 10px; width: 6px; }
.ft-tit .in-t span.arrow img { display: block; opacity: 1; }

ul.fs { margin-top: 10px; }
ul.fs > li { margin-bottom: 14px; font-size: 14px; line-height: 1; padding-left: 13px; position: relative; font-weight: 400; background: url("../img/common/fs-ico.svg") no-repeat left center; }
ul.fs > li a { text-decoration: none; }
ul.fs > li:last-child { margin-bottom: 0; }

.ft-address { font-size: 16px; margin-bottom: 20px; }

.yokosuka-mark { margin-top: 25px; display: flex; flex-wrap: wrap; align-items: center; font-size: 12px; }
.yokosuka-mark .img { width: 91px; margin: 0 3px 0 -15px; }

.ft-bottom.flex { justify-content: space-between; padding-top: 40px; border-top: solid 1px #E0E0E0; align-items: center; margin: 60px auto 0; width: 89.34vw; }

ul.pp-list { display: flex; flex-wrap: wrap; font-size: 14px; justify-content: center; width: 100%; order: 2; }
ul.pp-list > li { margin-right: 20px; }
ul.pp-list > li:last-child { margin-right: 0; }

.copyright { font-size: 14px; order: 1; width: 100%; text-align: center; margin-bottom: 30px; }

/* 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
------------------------------------------*/
body.home div#mv { height: 200vw; background: url("../img/main/sp-mv01.jpg") no-repeat center top; background-size: cover; overflow: hidden; }
body.home div#f-trigger { top: 200vw; }

.mv-cont01 { width: 100%; color: #fff; position: absolute; z-index: 5; top: 69vw; left: 0; box-sizing: border-box; padding-left: 5.33vw; font-size: 4.26vw; }
.mv-cont01 .line01 { font-weight: 700; line-height: 1.4; font-size: 8.53vw; }
.mv-cont01 .line02 { font-weight: 900; line-height: 1.4; font-size: 12vw; }
.mv-cont01 .line02 > span { display: inline-block; position: relative; }
.mv-cont01 .line02 > span:before { content: ""; width: 89.6vw; height: 1px; background: #fff; position: absolute; left: 0; bottom: 0; }
.mv-cont01 .line02 .medi { font-weight: 700; font-size: 10.13vw; }
.mv-cont01 .line03 { font-weight: 700; line-height: 1.4; font-size: 7.46vw; margin-top: 3.2vw; }
.mv-cont01 .line03 span.blue-bg { font-weight: 900; padding: 0 10px 4px; display: inline-block; }

.mv-text02 { margin-top: 20px; font-weight: 500; }

.belt-text { width: 842.06vw; position: absolute; left: 0; bottom: 6.26vw; display: flex; flex-wrap: wrap; }
.belt-text > span { padding-right: 10vw; display: inline-block; }
.belt-text span.text01 { animation: text01 120s -60s linear infinite; }
.belt-text span.text02 { animation: text02 120s linear infinite; }
.belt-text img { width: auto; height: 47.46vw; }

.mv-text03 { font-size: 5.33vw; font-weight: 700; margin: 5.33vw 0 2.66vw; line-height: 1.6; }

.mv-cont01 .btn01 { width: 85.33vw; height: 19.2vw; min-width: 0; }
.mv-cont01 .btn01 a { text-align: left; line-height: 1.4; font-size: 4.26vw; }
.mv-cont01 .btn01 a span.arrow { right: 5.33vw; width: 10.66vw; height: 6.4vw; border-radius: 5.33vw; }
.mv-cont01 .btn01 a span.arrow img { width: 3.2vw; }

span.blue-bg { background: rgba(30, 0, 139, 0.6); }

@keyframes text01 { 0% { transform: translateX(100%); }
  to { transform: translateX(-100%); } }
@keyframes text02 { 0% { transform: translateX(0); }
  to { transform: translateX(-200%); } }
.tri-feats.flex { width: 89.34vw; margin: -44px auto 0; position: relative; z-index: 6; justify-content: space-between; display: block; }
.tri-feats.flex > div.box { box-sizing: border-box; background: #fff; border-radius: 4px; padding: 20px; box-shadow: 0 0 15px rgba(26, 115, 240, 0.08); margin-bottom: 10px; }
.tri-feats.flex > div.box .tit { line-height: 45px; padding-bottom: 10px; margin-bottom: 10px; border-bottom: solid 1px #E0E0E0; padding-left: 58px; color: #1E008B; font-size: 22px; font-weight: 700; background: url("../img/top/ico01.svg") no-repeat top left; padding-top: 3px; }
.tri-feats.flex > div.box .inner01 { display: flex; flex-wrap: wrap; justify-content: space-between; width: 100%; }
.tri-feats.flex > div.box .inner01 .inBox { box-sizing: border-box; text-align: center; background: url("../img/top/ico-check.svg") no-repeat center top 2.66vw, #F2F1F1; padding: 8vw 2.16vw 2.13vw; line-height: 1.3; font-size: 3.73vw; width: 32.43%; background-size: 5.33vw; }
.tri-feats.flex > div.box .inner01 .inBox span.blue { font-weight: 700; }
.tri-feats.flex > div.box .inner01 .inBox:last-child span.blue { font-size: 3.6vw; }
.tri-feats.flex > div.box .inner03 { display: flex; flex-wrap: wrap; justify-content: space-between; width: 100%; }
.tri-feats.flex > div.box .inner03 > .inBox { width: calc(50% - 3px); background: #F2F1F1; box-sizing: border-box; padding: 18px; text-align: center; line-height: 1; }
.tri-feats.flex > div.box .inner03 > .inBox .line01 { display: flex; flex-wrap: wrap; justify-content: center; }
.tri-feats.flex > div.box .inner03 > .inBox .line01 .left { font-weight: 500; font-size: 18px; line-height: 1.1; font-size: 18px; }
.tri-feats.flex > div.box .inner03 > .inBox .line01 .right { font-weight: 700; font-size: 46px; position: relative; top: -6px; }
.tri-feats.flex > div.box .inner03 > .inBox .line01 .right .komoji { font-size: 14px; }
.tri-feats.flex > div.box.box02 .tit { background-image: url("../img/top/ico02.svg"); }
.tri-feats.flex > div.box.box02 .inner02 { position: relative; }
.tri-feats.flex > div.box.box02 .inner02 span.nado { display: block; text-align: right; }
.tri-feats.flex > div.box.box03 { margin-bottom: 0; }
.tri-feats.flex > div.box.box03 .tit { background-image: url("../img/top/ico03.svg"); }

div#top-news { padding: 30px 5.33vw 40px; }
div#top-news h2.tit { font-family: "robo"; line-height: 1.4; font-size: 24px; font-weight: 700; color: #1E008B; margin-bottom: 16px; }
div#top-news .more-btn { position: absolute; right: 0; top: 0; }

.top-news-area { width: 100%; }

article.top-news-art.flex { align-items: center; }
article.top-news-art.flex .n-date { font-size: 14px; font-family: "robo"; width: 100%; margin-bottom: 10px; }
article.top-news-art.flex h3 { max-width: 100%; font-weight: 400; padding-bottom: 5px; }
article.top-news-art.flex h3 a { display: block; white-space: nowrap; text-overflow: ellipsis; overflow: hidden; }

.arrow img { opacity: 1; display: block; transition: 0s; width: 12px; }

.more-btn a { text-decoration: none; align-items: center; display: flex; flex-wrap: wrap; align-items: center; }
.more-btn a .arrow { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; width: 40px; height: 24px; border-radius: 20px; background: #1E008B; box-sizing: border-box; border: solid 1px #1E008B; margin-left: 8px; }

section { position: relative; }

section#about-sec { background: url("../img/top/bowa01.png") no-repeat top -46.9vw left 5.33vw, #EBF6FF; overflow: hidden; background-size: 242.66vw; padding: 80px 5.33vw; }
section#about-sec .wrap { box-sizing: border-box; z-index: 1; }
section#about-sec .circle01 { position: absolute; left: 183px; top: 14px; z-index: -1; width: 226px; }
section#about-sec .img01 { position: relative; padding-bottom: 19.73vw; margin-top: 40px; }
section#about-sec .img01 .img01-2 { position: absolute; right: 0; bottom: 0; width: 45.3vw; }
section#about-sec .img02 { display: none; }

.copy01 { margin-bottom: 26px; font-weight: 700; font-size: 24px; }
.copy01 .medi { font-size: 28px; line-height: 1; }
.copy01 .big { font-size: 37px; line-height: 1; }

.bg-area01 { padding: 80px 0 1px; background: url("../img/p02/sp-bowa.png") no-repeat top 53px left 27.73vw; background-size: 106.13vw; }

section#reason-sec { padding: 0 5.33vw 100px; background: url("../img/p02/sp-bowa.png") no-repeat bottom right 21.6vw; background-size: 106.13vw; }
section#reason-sec .titles01 { margin-bottom: 40px; }
section#reason-sec .btn01 { margin: 40px auto 0; }

.reason-list01.flex { display: block; }
.reason-list01.flex div.box { margin-bottom: 50px; }
.reason-list01.flex div.box .img { margin-bottom: 15px; }
.reason-list01.flex div.box:last-child { margin-bottom: 0; }

.num-tit { position: relative; line-height: 1.4; margin-bottom: 20px; font-size: 20px; }
.num-tit span.num { font-weight: 700; font-size: 60px; line-height: 1; position: absolute; right: 0; top: 0; color: #EDEAF5; }
.num-tit span.text { position: relative; z-index: 2; }
.num-tit span.text .big { font-size: 26px; }

.case-area { margin-top: 80px; position: relative; }
.case-area h3.titles02 { margin-bottom: 44px; }
.case-area .llu01 { position: absolute; z-index: 2; right: 39px; top: -42px; width: 102px; }

.case-list01.flex { display: block; }
.case-list01.flex > div.box { box-sizing: border-box; margin-bottom: 34px; background: #F0F1F6; border-radius: 10px; position: relative; padding: 36px 20px 30px; }
.case-list01.flex > div.box > .tit { font-size: 20px; font-weight: 700; line-height: 1.6; margin-bottom: 10px; width: calc(100% + 10px); }
.case-list01.flex > div.box > .tit .gra01 { margin-left: 8px; font-size: 18px; }
.case-list01.flex > div.box > .text { font-size: 20px; }
.case-list01.flex > div.box > .text .blue { font-weight: 700; }
.case-list01.flex > div.box:last-child { margin-bottom: 0; }
.case-list01.flex .case-sub { position: absolute; left: 0; z-index: 2; top: -14px; }

.case-sub { background: #fff; padding: 8px 9px 6px; color: #1E008B; border: solid 1px #1E008B; border-radius: 4px 4px 0 4px; box-shadow: 0 0 15px rgba(26, 115, 240, 0.15); font-weight: 700; font-size: 14px; font-family: "robo"; line-height: 1; }

.mateBox:before { content: ""; background: url("../img/top/ilu02.png") no-repeat; width: 104px; height: 83px; position: absolute; z-index: 2; top: -50px; right: 0; background-size: contain; }

.mateBox { position: relative; }
.mateBox .titles01 { margin-bottom: 40px; }

section#mate-sec { margin-bottom: -296px; position: relative; z-index: 3; padding: 0 5.33vw; }

.mate-list.flex { display: block; box-sizing: border-box; background: #494AE9; padding: 40px 20px; position: relative; border-radius: 20px; }
.mate-list.flex .mate-btn { margin-bottom: 5.33vw; }
.mate-list.flex .mate-btn a { text-decoration: none; position: relative; color: #fff; }
.mate-list.flex .mate-btn a img { opacity: 1; }
.mate-list.flex .mate-btn a .text-box { position: absolute; z-index: 2; box-sizing: border-box; width: 100%; padding-right: 16vw; padding-left: 5.33vw; bottom: 5.33vw; font-size: 3.73vw; line-height: 1.6; }
.mate-list.flex .mate-btn a .text-box .text02 { font-weight: 700; font-size: 5.33vw; }
.mate-list.flex .mate-btn a .text-box .text02 .medi { font-size: 4.26vw; }
.mate-list.flex .mate-btn a .arrow { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; width: 13.86vw; height: 8.53vw; border-radius: 8vw; background: #fff; box-sizing: border-box; position: absolute; right: 0.33vw; bottom: -0.93vw; z-index: 2; }
.mate-list.flex .mate-btn a .arrow img { width: 3.73vw; }
.mate-list.flex .mate-btn:last-child { margin-bottom: 0; }

section#pro-sec { padding: 376px 5.33vw 120px; background: url("../img/top/bowa05.png") no-repeat left 16.53vw top 76px, linear-gradient(0deg, white 0%, rgba(235, 246, 255, 0.9) 10%, rgba(235, 246, 255, 0.9) 90%, white 100%); background-size: 181.06vw; }

.tit-head.flex { margin-bottom: 60px; display: block; }
.tit-head.flex .text p { display: inline; }

.flow-list01.flex { justify-content: space-between; margin-top: -46px; }
.flow-list01.flex > div.box:before { content: ""; width: 100px; height: 100px; border-radius: 100%; background: #fff; position: absolute; left: 0; right: 0; top: -26px; margin: 0 auto; }
.flow-list01.flex > div.box { width: calc(50% - 10px); position: relative; background: #fff; border-radius: 5px; box-sizing: border-box; margin-top: 46px; padding: 0 20px 18px; }
.flow-list01.flex > div.box .num { font-size: 14px; font-weight: 700; color: #9483C4; line-height: 1; position: absolute; left: 12px; top: 12px; z-index: 2; }
.flow-list01.flex > div.box .ico { position: relative; z-index: 2; text-align: center; margin-top: -6px; margin-bottom: 4px; width: 50px; margin-left: auto; margin-right: auto; }
.flow-list01.flex > div.box .tit { text-align: center; position: relative; z-index: 2; font-weight: 700; font-size: 18px; }
.flow-list01.flex > div.box .text { margin-top: 4px; position: relative; z-index: 2; line-height: 1.2; font-size: 14px; text-align: center; }
.flow-list01.flex > div.box:after { content: ""; background: url("../img/top/flow-arrow.svg") no-repeat; width: 24px; height: 17px; background-size: contain; position: absolute; top: 50%; right: -26px; z-index: 3; transform: translateY(-50%); }
.flow-list01.flex > div.box:nth-child(2n):after { content: none; }

.pro-block { margin-bottom: 80px; }

.pro-block:last-child { margin-bottom: 0; }

.pro-block.pro01 .titles02 { margin-bottom: 58px; }

.method-list01.flex > div.box { width: 100%; margin-bottom: 20px; }
.method-list01.flex > div.box a { text-decoration: none; background: #fff; border-radius: 10px; padding: 20px 20px 72px; z-index: 2; display: block; position: relative; box-sizing: border-box; height: 100%; }
.method-list01.flex > div.box a .arrow { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; width: 60px; height: 32px; border-radius: 20px; background: #1E008B; box-sizing: border-box; position: absolute; right: 20px; bottom: 20px; z-index: 2; border: solid 1px #1E008B; }
.method-list01.flex > div.box a .arrow img { filter: brightness(0) saturate(100%) invert(100%) sepia(100%) saturate(0%) hue-rotate(288deg) brightness(102%) contrast(102%); width: 18px; }
.method-list01.flex > div.box a .img { margin-bottom: 16px; }
.method-list01.flex > div.box a .img .in-img { padding-top: 68%; border-radius: 2.66vw; }
.method-list01.flex > div.box a > .tit { text-align: center; font-weight: 700; font-size: 24px; line-height: 1.6; margin-bottom: 16px; }
.method-list01.flex > div.box:last-child { margin-bottom: 0; }

.pro-block.pro03 { width: 100%; position: relative; }
.pro-block.pro03 .btn01 { margin: 40px auto 0; }

ul.pro-list02.flex { margin-top: 22px; }
ul.pro-list02.flex > li { margin: 8px 8px 0 0; text-align: center; border-radius: 4px; background: rgba(194, 226, 254, 0.6); padding: 10px; text-align: center; font-weight: 700; line-height: 1.6; box-sizing: border-box; width: calc(50% - 4px); display: flex; flex-wrap: wrap; justify-content: center; align-items: center; }
ul.pro-list02.flex > li:nth-child(2n) { margin-right: 0; }

section#works-sec { padding: 120px 5.33vw; position: relative; overflow: hidden; }
section#works-sec .wrap:before { content: ""; background: url("../img/top/ilu03.svg") no-repeat; width: 114px; height: 79px; position: absolute; top: 6px; left: 156px; background-size: contain; }
section#works-sec .btn01 { margin: 40px auto 0; }

.home section#works-sec { padding: 0 5.33vw 0; }

.works-list01.flex.slider01 { margin-top: 30px; }

.slider01 { padding-bottom: 80px; }
.slider01 article.works-art, .slider01 article.blog-art01 { margin-right: 5.33vw; width: 89.34vw; }
.slider01 .slick-list { overflow: visible; }
.slider01 .slick-track { display: flex; flex-wrap: wrap; }
.slider01 article.works-art, .slider01 article.blog-art01 { pointer-events: none; height: auto !important; }

button.slick-arrow { opacity: 1; z-index: 2; transition: 0s; width: 76px; height: 40px; box-sizing: border-box; transition: 0s; top: auto; bottom: 0; transform: translateY(0); border-radius: 100%; border: solid 1px #1E008B; border-radius: 20px; }

button.slick-prev.slick-arrow { background: url("../img/common/slide-arrow01.svg") no-repeat center; left: calc(50% - 86px); }

button.slick-next.slick-arrow { background: url("../img/common/slide-arrow02.svg") no-repeat center; right: calc(50% - 86px); }

button.slick-arrow:before { content: none; }

button.slick-arrow.slick-disabled { background-color: transparent; }

article.works-art { width: 340px; }
article.works-art a { display: block; text-decoration: none; box-sizing: border-box; height: 100%; padding: 20px 20px 65px; position: relative; background: #fff; border-radius: 4px; box-shadow: 0 0 15px rgba(26, 115, 240, 0.08); }
article.works-art a .img { position: relative; overflow: hidden; margin-bottom: 20px; border-radius: 5px; }
article.works-art a .img .in-img { padding-top: 68%; transition: 0.3s; border-radius: 5px; }
article.works-art a .tit { font-size: 20px; font-weight: 500; line-height: 1.4; width: 100%; display: -webkit-box; overflow: hidden; -webkit-line-clamp: 2; -webkit-box-orient: vertical; }
article.works-art a .w-data { padding-top: 20px; border-top: solid 1px #E3E5EC; margin-top: 10px; margin-bottom: 16px; }
article.works-art a .w-data dl.flex { align-items: flex-start; margin-bottom: 10px; }
article.works-art a .w-data dl.flex dt { font-weight: 500; color: #1E008B; width: 62px; }
article.works-art a .w-data dl.flex dd { width: calc(100% - 62px); }
article.works-art a .w-data dl.flex:last-child { margin-bottom: 0; }
article.works-art a .a-date { padding-top: 20px; line-height: 1.6; font-size: 16px; color: #9A9A9A; text-align: right; position: absolute; right: 20px; bottom: 30px; }

article.blog-art01 { width: 340px; }
article.blog-art01 a { display: block; text-decoration: none; box-sizing: border-box; height: 100%; padding: 20px 20px 65px; position: relative; background: #fff; border-radius: 4px; box-shadow: 0 0 15px rgba(26, 115, 240, 0.08); }
article.blog-art01 a .img { position: relative; overflow: hidden; margin-bottom: 20px; border-radius: 5px; }
article.blog-art01 a .img .in-img { padding-top: 68%; transition: 0.3s; border-radius: 5px; }
article.blog-art01 a .tit { font-size: 20px; font-weight: 500; line-height: 1.4; width: 100%; display: -webkit-box; overflow: hidden; -webkit-line-clamp: 2; -webkit-box-orient: vertical; margin-bottom: 20px; }
article.blog-art01 a .a-date { padding-top: 20px; line-height: 1.6; font-size: 16px; color: #9A9A9A; text-align: right; position: absolute; right: 20px; bottom: 30px; }

.infos.flex { width: calc(100% + 4px); margin: -6px 0 0 -4px; }
.infos.flex .w-cate { margin: 6px 0 0 4px; color: #1E008B; font-size: 14px; padding: 1px 10px 3px; border-radius: 15px; background: #EFEBFF; font-weight: 500; }

section#range-sec { position: relative; z-index: 3; margin-bottom: -237px; padding: 80px 5.33vw 0; }

.range-cont { box-sizing: border-box; background: #494AE9; border-radius: 20px; padding: 40px 20px 60px; }
.range-cont > .text { color: #fff; font-weight: 500; }

.range-list01.flex { margin-top: 40px; display: block; }
.range-list01.flex > div { margin-bottom: 20px; }
.range-list01.flex > div:last-child { margin-bottom: 0; }

.rangeBox { text-emphasis-position: right; background: #fff; border-radius: 10px; padding: 70px 20px 30px; position: relative; margin-bottom: 20px; }

.rangeBox:last-child { margin-bottom: 0; }

.ang-tit01 { position: absolute; left: 0; top: 0; color: #fff; font-weight: 700; padding: 4px 20px 6px; background: #1E008B; border-radius: 8px 0 8px 0; font-size: 18px; }

.bikou01 > p { position: relative; padding-left: 15px; }
.bikou01 > p:before { content: "※"; position: absolute; left: 0; top: 0; }

.range-num-text.flex { margin-bottom: 20px; align-items: center; justify-content: center; }
.range-num-text.flex .text01 { font-weight: 700; margin-bottom: 16px; width: 100%; text-align: center; }
.range-num-text.flex .text01 .big { font-size: 24px; }
.range-num-text.flex .text02 { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; border: solid 2px #1E008B; color: #1E008B; font-size: 20px; border-radius: 40px; height: 52px; box-sizing: border-box; padding-left: 60px; background: url("../img/top/ico-japan.svg") no-repeat left 20px center; font-weight: 700; padding-right: 22px; }

.rangeTBL { margin-bottom: 5px; }
.rangeTBL tr { border-bottom: solid 1px #E0E0E0; }
.rangeTBL tr:last-child { border-bottom: none; }
.rangeTBL tr:first-child th, .rangeTBL tr:first-child td { padding-top: 0; }
.rangeTBL th, .rangeTBL td { vertical-align: top; box-sizing: border-box; padding-bottom: 14px; padding-top: 14px; }
.rangeTBL th { font-weight: 700; width: 94px; }

.in-mates { margin-bottom: 20px; }
.in-mates > div.box { margin-bottom: 14px; border-radius: 4px; background: #EFEBFF; padding: 20px 20px 30px; }
.in-mates > div.box:last-child { margin-bottom: 0; }
.in-mates .nado { text-align: right; font-weight: 500; margin-top: -24px; }

.sq-tit { font-size: 18px; position: relative; padding-left: 18px; font-weight: 700; margin-bottom: 14px; }

.sq-tit:before { content: ""; background: #1E008B; width: 8px; height: 8px; border-radius: 1px; position: absolute; left: 0; top: 10px; }

ul.mate-list10.flex { margin: -6px 0 0 -6px; width: calc(100% + 6px); }
ul.mate-list10.flex > li { background: #fff; color: #1E008B; font-size: 14px; border-radius: 20px; padding: 1px 10px; margin: 6px 0 0 6px; font-weight: 500; }

section#support-sec { background: #EBF6FF; padding: 317px 5.33vw calc(80px + 24vw); }
section#support-sec .wrap:before { content: ""; background: url("../img/top/ilu04.svg") no-repeat; width: 114px; height: 157px; position: absolute; right: 0; top: -56px; background-size: contain; }

.trou-box.flex { margin-bottom: 60px; background: #fff; border-radius: 10px; box-sizing: border-box; display: block; padding: 40px 20px; }
.trou-box.flex > .tit { position: relative; box-sizing: border-box; text-align: center; padding-bottom: 21.33vw; background: url("../img/top/shikiri-sp.svg") no-repeat center bottom; font-weight: 700; font-size: 20px; line-height: 1.8; background-size: 100%; margin-bottom: 30px; }

ul.check-list01.flex { display: block; }
ul.check-list01.flex > li { margin-bottom: 14px; padding-left: 27px; background: url("../img/top/ico-check01.svg") no-repeat left top 4px; font-weight: 700; line-height: 24px; }
ul.check-list01.flex > li .blue { font-size: 20px; font-weight: 700; }
ul.check-list01.flex > li:last-child { margin-bottom: 0; }

.conBox { position: relative; }
.conBox > .img { margin-top: 40px; }
.conBox > .text { margin-top: 24px; }
.conBox .btn01 { margin-top: 40px; }

ul.feat-list01.feat-list02.flex > li { background: #fff; color: #1E008B; border: solid 1px #E5E1F2; padding: 0 14px; }

h3.con-tit { font-size: 40px; font-weight: 700; margin-bottom: 24px; line-height: 1.4; }

.con-copy01 { font-weight: 700; font-size: 24px; line-height: 1.4; }
.con-copy01 span.gra01 { font-weight: 700; font-size: 32px; line-height: 1; padding: 8px 10px; margin-top: 10px; }

.whiteBox { position: relative; background: #fff; border-radius: 10px; padding: 30px; }

.whiteBox.conBox02 { margin-top: 60px; }

div#btn-box { margin-top: -24vw; position: relative; z-index: 2; padding: 0 5.33vw; }

.bans.flex { justify-content: space-between; }

.big-btn { width: 100%; margin-bottom: 5.33vw; }
.big-btn a { text-decoration: none; position: relative; display: block; background: url("../img/top/ban-bg-sp.png") no-repeat; background-size: contain; height: 52.26vw; box-sizing: border-box; padding-top: 19.73vw; padding-left: 12.26vw; }
.big-btn a .arrow { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; width: 16.53vw; height: 8.53vw; border-radius: 8vw; background: #1E008B; box-sizing: border-box; position: absolute; right: 2.13vw; bottom: -0.53vw; z-index: 2; border: solid 1px #1E008B; }
.big-btn a .arrow img { filter: brightness(0) saturate(100%) invert(100%) sepia(100%) saturate(0%) hue-rotate(288deg) brightness(102%) contrast(102%); width: 4.8vw; }
.big-btn a .titles01 { margin-bottom: 0; }
.big-btn a .titles01 .en { font-size: 4.8vw; margin-bottom: 1.6vw; }
.big-btn a .titles01 .jp { font-weight: 500; font-size: 9.6vw; }

section#blog-sec { padding: 80px 5.33vw; box-sizing: border-box; overflow: hidden; }
section#blog-sec .btn01 { margin: 40px auto 0; }

/*02 セラミック加工
----------------------------------*/
div#umv { background: url("../img/main/sp-umv01.jpg") no-repeat center top; height: 46.93vw; background-size: cover; box-sizing: border-box; padding-top: 13.33vw; }

.mv-tit { text-align: center; }

.titles01.mv-tit .en { font-weight: 700; font-size: 4.26vw; margin-bottom: 4.53vw; }
.titles01.mv-tit .en > span:before { left: 0; right: 0; margin: 0 auto; width: 8vw; height: 8vw; top: -1.86vw; position: absolute; }
.titles01.mv-tit .jp { font-size: 6.93vw; }

section#p02Box01 { padding: 70px 5.33vw 80px; background: url("../img/p02/sp-bowa.png") no-repeat bottom -13.33vw right 41.6vw; background-size: 106.13vw; }

.p02-cont01:before { content: ""; background: url("../img/top/ilu04.svg") no-repeat; background-size: contain; width: 80px; height: 110px; position: absolute; right: 0; top: -32px; }

.p02-cont01 { margin-bottom: 80px; position: relative; }
.p02-cont01 .copy01 { font-size: 24px; line-height: 1.4; margin-bottom: 30px; }
.p02-cont01 .copy01 .big { font-size: 34px; line-height: 1.6; }
.p02-cont01 .copy01 > p:first-child { margin-bottom: 10px; padding-right: 80px; }

.p02-cont01-2 { position: relative; margin-bottom: 60px; }
.p02-cont01-2 > .img { margin-top: 30px; position: relative; z-index: 2; }
.p02-cont01-2 > .inner01 { margin-bottom: 30px; position: relative; z-index: 2; }
.p02-cont01-2 .blue-listBox { position: relative; z-index: 2; }

.p02-cont01-2:before { content: ""; background: url("../img/p02/sp-bowa.png") no-repeat; width: 106.13vw; height: 106.13vw; background-size: contain; position: absolute; left: 32.53vw; bottom: 17.86vw; }

.blue-listBox { background: #fff; border: solid 2px #494AE9; box-sizing: border-box; width: 100%; border-radius: 10px; }
.blue-listBox > .tit { color: #fff; box-sizing: border-box; border-radius: 6px 6px 0 0; font-size: 18px; font-weight: 700; background: #494AE9; padding: 16px; text-align: center; }
.blue-listBox .inner { box-sizing: border-box; padding: 30px 40px; display: flex; flex-wrap: wrap; justify-content: center; }

ul.dot-list02.flex { display: block; width: auto; }
ul.dot-list02.flex > li { padding-left: 14px; background: url("../img/p02/list-ico.svg") no-repeat left top 9px; margin-bottom: 10px; }
ul.dot-list02.flex > li:last-child { margin-bottom: 0; }

.point-list > section { margin-bottom: 20px; box-sizing: border-box; background: #F0F1F6; padding: 30px 20px 40px; border-radius: 10px; width: 100%; }
.point-list > section .num { display: flex; flex-wrap: wrap; align-items: center; border-bottom: solid 1px #CCCCCC; box-sizing: border-box; font-weight: 700; color: #1E008B; padding-bottom: 20px; line-height: 1; margin-bottom: 20px; }
.point-list > section .cont { box-sizing: border-box; }
.point-list > section .cont > .tit { font-size: 24px; font-weight: 700; color: #1E008B; margin-bottom: 10px; }
.point-list > section:last-child { margin-bottom: 0; }

.page-ceramic section#pro-sec { padding: 80px 5.33vw; background: #EBF6FF; }
.page-ceramic ul.pro-list02.flex > li { background: #fff; }

div#p02Box03 { padding: 80px 5.33vw; }

section.p02-set { margin-bottom: 80px; position: relative; }
section.p02-set > h2, section.p02-set > h3, section.p02-set > div { position: relative; z-index: 3; }
section.p02-set .twin-list.flex { margin-top: 30px; }
section.p02-set ul.dpt-list01.flex { box-sizing: border-box; padding-right: 20px; }

section.p02-set.set01:before { content: ""; background: url("../img/p02/sp-bowa.png") no-repeat; width: 106.13vw; height: 106.13vw; background-size: contain; position: absolute; left: 18.93vw; bottom: -57.33vw; }

section.p02-set.set02 { z-index: 5; }

.twin-list.flex { display: block; }
.twin-list.flex > div { margin-bottom: 13px; }
.twin-list.flex > div .text { margin-top: 10px; }
.twin-list.flex > div:last-child { margin-bottom: 0; }

.grayBox { box-sizing: border-box; padding: 30px 20px 30px 30px; border-radius: 10px; background: #F0F1F6; }

section.p02-set:last-child { margin-bottom: 0; }

.sub01 { font-weight: 700; font-size: 30px; margin-bottom: 20px; }

ul.dpt-list01.flex { width: 100%; display: block; }
ul.dpt-list01.flex > li { padding-left: 16px; position: relative; margin-bottom: 10px; }
ul.dpt-list01.flex > li:before { content: "・"; position: absolute; left: 0; top: 0; }
ul.dpt-list01.flex > li:last-child { margin-bottom: 0; }

section#blog-sec.column-sec01 { padding: 80px 5.33vw; background: #EBF6FF; min-height: 0; }

/*03 取扱セラミック素材
----------------------------------*/
div#contents.bg01 { background: url("../img/p02/bowa02.png") no-repeat top 1261px right calc(50% + 796px), url("../img/p02/bowa01.png") no-repeat top -23px left calc(50% + 715px); }

section#p03Box01 { padding: 70px 5.33vw 80px; }
section#p03Box01 .mate-list.flex .mate-btn a .arrow { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; border: solid 1px #1E008B; width: 52px; height: 32px; border-radius: 20px; background: #1E008B; box-sizing: border-box; position: absolute; right: 8px; bottom: -2px; z-index: 2; }
section#p03Box01 .mate-list.flex .mate-btn a .arrow img { filter: brightness(0) saturate(100%) invert(100%) sepia(100%) saturate(0%) hue-rotate(288deg) brightness(102%) contrast(102%); }
section#p03Box01 .mate-list.flex .mate-btn:nth-child(3n) { margin-right: 0; }

.p03-cont01.flex { display: block; margin-bottom: 30px; position: relative; }
.p03-cont01.flex > .cont h3.sub01.blue { font-size: 24px; }
.p03-cont01.flex > .cont h3.sub01.blue .inb { font-size: 20px; }
.p03-cont01.flex > .img { margin-top: 30px; position: relative; z-index: 2; }

.mate-set { margin-top: 60px; }
.mate-set .mate-list.flex { padding: 0; background: none; }
.mate-set .mate-list.flex .mate-btn { margin-bottom: 8vw; }
.mate-set .mate-list.flex .mate-btn:last-child { margin-bottom: 0; }

div.details.flex { display: block; position: relative; z-index: 3; }
div.details.flex > div.box { border-radius: 10px; border: solid 2px #494AE9; background: #fff; margin-bottom: 20px; box-sizing: border-box; }
div.details.flex > div.box .tit { color: #fff; text-align: center; background: #494AE9; font-weight: 700; font-size: 18px; border-radius: 8px 8px 0 0; padding: 14px 15px 16px; }
div.details.flex > div.box .inner { padding: 30px 18px 28px; }
div.details.flex > div.box:last-child { margin-bottom: 0; }

ul.dot-list03 > li { padding-left: 16px; position: relative; margin-bottom: 10px; }
ul.dot-list03 > li:last-child { margin-bottom: 0; }
ul.dot-list03 > li:before { content: "・"; position: absolute; left: 0; top: 0; }

.typeBox { padding-bottom: 80px; margin-bottom: 80px; border-bottom: solid 1px #E5E5E5; }

.typeBox:first-child { position: relative; z-index: 3; }
.typeBox:first-child .p03-cont01.flex:before { content: ""; background: url("../img/p02/sp-bowa.png") no-repeat; width: 106.13vw; height: 106.13vw; background-size: contain; position: absolute; left: 27.73vw; bottom: -68vw; }

.typeBox:last-child { padding-bottom: 0; margin-bottom: 0; border-bottom: none; position: relative; }
.typeBox:last-child .p03-cont01.flex { z-index: 3; }

.typeBox:last-child:before { content: ""; background: url("../img/p02/sp-bowa.png") no-repeat; width: 106.13vw; height: 106.13vw; background-size: contain; position: absolute; right: 25.6vw; top: -103.46vw; }

.grayBox.mate-list02 .bikou01 { margin-top: 10px; }

/*04 取扱セラミック素材　詳細
----------------------------------*/
section#p03sBox01 { padding: 70px 5.33vw 80px; }
section#p03sBox01 .wrap h2.copy01 { line-height: 1.6; }
section#p03sBox01 .wrap h2.copy01 .blue { line-height: 1.5; }
section#p03sBox01 .wrap > div, section#p03sBox01 .wrap > h2 { position: relative; z-index: 2; }
section#p03sBox01 .wrap .img { margin-top: 30px; position: relative; }
section#p03sBox01 .wrap .img img { display: block; position: relative; z-index: 3; border-radius: 2.66vw; }
section#p03sBox01 .wrap .img:before { content: ""; background: url("../img/p02/sp-bowa.png") no-repeat; width: 106.13vw; height: 106.13vw; background-size: contain; position: absolute; left: 19.73vw; bottom: -34.66vw; }

.mate-details { margin-top: 60px; position: relative; z-index: 3; }
.mate-details .bikou01 { margin-top: 10px; }

.twin-cont01.flex { display: block; }

.TBL01 table { border-collapse: separate; border-spacing: 0; }
.TBL01 th, .TBL01 td { box-sizing: border-box; padding: 10px 10px; }
.TBL01 th { width: 100px; background: #EFEBFF; color: #1E008B; font-weight: 700; border-bottom: solid 1px #D6CCFF; }
.TBL01 td { border-bottom: solid 1px #EFEBFF; border-right: solid 1px #EFEBFF; }

.TBL01:first-child tr:first-child th { border-radius: 10px 0 0 0; }
.TBL01:first-child tr:first-child td { border-radius: 0 10px 0 0; border-top: solid 1px #EFEBFF; }

.TBL01:last-child tr:last-child th { border-radius: 0 0 0 10px; border-bottom: none; }
.TBL01:last-child tr:last-child td { border-radius: 0 0 10px 0; }

section#p03sBox02 { padding: 80px 5.33vw; background: #EBF6FF; }
section#p03sBox02 .point-list > section { background: #fff; }

section#p03sBox03 { padding: 80px 5.33vw; background: url("../img/p02/sp-bowa.png") no-repeat top 311px right 28.53vw; background-size: 106.13vw; }
section#p03sBox03 .wrap:before { content: ""; background: url("../img/p04/p04-ilu02.svg") no-repeat; width: 82px; height: 91px; position: absolute; top: -16px; right: 20px; background-size: contain; }
section#p03sBox03 .titles01 { position: relative; z-index: 2; }

.solu-list { margin-top: 60px; }

article.kadai-art { margin-bottom: 40px; border-radius: 20px; background: #F0F1F6; padding: 50px 20px; }
article.kadai-art > .img { margin-top: 30px; }

article.kadai-art:last-child { margin-bottom: 0; }

.kadai-tit { margin-bottom: 30px; display: flex; flex-wrap: wrap; align-items: flex-start; }
.kadai-tit span.kadai-num { width: 57px; height: 30px; display: flex; flex-wrap: wrap; align-items: center; justify-content: center; color: #fff; font-weight: 700; background: #1E008B; border-radius: 8px 8px 0 8px; font-size: 14px; }
.kadai-tit span.kadai-text { width: 100%; font-weight: 700; font-size: 24px; margin-top: 10px; }

.textBox02.whiteBox { margin-top: 20px; }

.textBox03.whiteBox { margin-top: 40px; box-sizing: border-box; position: relative; border: solid 2px #707070; padding-top: 60px; padding-left: 20px; padding-right: 20px; }

.textBox04.whiteBox { margin-top: 40px; box-sizing: border-box; position: relative; border: solid 2px #494AE9; padding-top: 60px; padding-left: 20px; padding-right: 20px; }
.textBox04.whiteBox .ang-tit { background: #494AE9; }
.textBox04.whiteBox .ang-tit > span { display: inline-block; padding-left: 32px; background: url("../img/p04/ico-pikon.svg") no-repeat center left; }

.textBox03.whiteBox + .textBox04.whiteBox:before { content: ""; width: 0; height: 0; border-top: solid 10px #494AE9; border-left: solid 10px transparent; border-right: solid 10px transparent; position: absolute; left: 0; right: 0; margin: 0 auto; bottom: calc(100% + 18px); }

.ang-tit { position: absolute; left: -2px; top: -2px; z-index: 2; color: #fff; font-weight: 700; font-size: 18px; border-radius: 10px 0 10px 0; padding: 6px 16px; background: #707070; }

section#p03sBox04 { padding: 100px 5.33vw; background: #EBF6FF; }

.big-btn.big-btn02 { width: 100%; margin-bottom: 5.33vw; }
.big-btn.big-btn02 a { height: 31.46vw; background: url("../img/p04/btn-bg-sp.svg") no-repeat center top; background-size: contain; padding: 10.66vw; font-weight: 700; text-align: center; font-size: 4.26vw; }
.big-btn.big-btn02 a .arrow { width: 14.4vw; }

.big-btn.big-btn02:last-child { margin-bottom: 0; }

/*05 成形 
----------------------------------*/
section#p05sBox01 { padding: 70px 5.33vw 80px; }
section#p05sBox01 .blue-listBox { margin-top: 30px; }
section#p05sBox01 ul.dot-list02.flex { display: block; }
section#p05sBox01 ul.dot-list02.flex > li { margin-bottom: 10px; }
section#p05sBox01 ul.dot-list02.flex > li:last-child { margin-bottom: 0; }
section#p05sBox01 .copy01 { line-height: 1.6; }
section#p05sBox01 .copy01 .big { line-height: 1.4; }
section#p05sBox01 .blue-listBox .inner { padding-left: 20px; padding-right: 20px; }
section#p05sBox01 .twin-cont02.flex .img img { border-radius: 2.66vw; }

.twin-cont02.flex { display: block; position: relative; }
.twin-cont02.flex .cont { position: relative; z-index: 3; }
.twin-cont02.flex .img { margin-top: 30px; position: relative; z-index: 3; }

.twin-cont02.flex:before { content: ""; background: url("../img/p02/sp-bowa.png") no-repeat; width: 106.13vw; height: 106.13vw; background-size: contain; position: absolute; left: 24vw; bottom: -55.46vw; }

.p05-cont01.flex { margin-top: 60px; display: block; position: relative; z-index: 3; }

section#p05sBox03 { padding: 80px 5.33vw; }
section#p05sBox03 .wrap:before { content: ""; background: url("../img/p05/ilu01.svg") no-repeat; width: 87px; height: 62px; position: absolute; top: 16px; left: 157px; background-size: contain; }
section#p05sBox03 .titles01 { margin-bottom: 40px; }

div.flow-list10.flex:before { content: ""; background: url("../img/p02/sp-bowa.png") no-repeat; width: 106.13vw; height: 106.13vw; background-size: contain; position: absolute; right: 28.53vw; bottom: -56vw; }

div.flow-list10.flex { box-sizing: border-box; padding-left: 10px; display: block; position: relative; }

article.flow-art { width: 100%; position: relative; background: #EFEBFF; border-radius: 10px; box-sizing: border-box; padding: 40px 22px; margin-bottom: 64px; z-index: 3; }
article.flow-art .flow-num { width: 60px; height: 30px; position: absolute; z-index: 2; left: -10px; top: -10px; color: #fff; font-weight: 700; padding: 8px 5px; text-align: center; box-sizing: border-box; font-size: 14px; background: #494AE9; border-radius: 5px 5px 0 5px; line-height: 1; box-shadow: 0 0 15px rgba(26, 115, 240, 0.15); }
article.flow-art > h3.tit { margin-bottom: 10px; font-size: 20px; font-weight: 700; }

article.flow-art:last-child { margin-bottom: 0; }

article.flow-art:after { content: ""; background: url(../img/top/flow-arrow-sp.svg) no-repeat; width: 16px; height: 22px; background-size: contain; position: absolute; top: calc(100% + 16px); left: 50%; transform: translateX(-50%); z-index: 3; }

article.flow-art:last-child:after { content: none; }

.sizeBox.range-cont { margin-top: 80px; position: relative; z-index: 3; }
.sizeBox.range-cont h3.titles01.type02 { margin-bottom: 40px; }

.size-conts.flex { display: block; }
.size-conts.flex > .rangeBox { box-sizing: border-box; margin-bottom: 20px; }
.size-conts.flex > .rangeBox:last-child { margin-bottom: 0; }

/*06 精密機械
----------------------------------*/
section#p06Box01 { padding: 70px 5.33vw 80px; background: url("../img/p02/sp-bowa.png") no-repeat bottom -21.33vw left 32vw; background-size: 106.13vw; }
section#p06Box01 .wrap .img { margin-top: 30px; }
section#p06Box01 .wrap .copy01 { line-height: 1.4; }
section#p06Box01 .wrap .copy01 .big { line-height: 1.6; }

section#p06Box02 { padding: 80px 5.33vw; background: #EBF6FF; }
section#p06Box02 .tit-head { margin-bottom: 40px; }

section.tec-sec.flex { box-sizing: border-box; background: #fff; border-radius: 10px; padding: 50px 20px; margin-bottom: 40px; justify-content: space-between; display: block; }
section.tec-sec.flex > .img { margin-top: 30px; }
section.tec-sec.flex span.kadai-num { font-size: 14px; width: 37px; }
section.tec-sec.flex .blue-listBox { margin-top: 20px; }
section.tec-sec.flex .blue-listBox .inner { padding: 30px 20px; display: block; }
section.tec-sec.flex .bikou01 { margin-top: 10px; }

section.tec-sec.flex:last-child { margin-bottom: 0; }

section#p06Box03 { padding: 80px 5.33vw; background: url("../img/p02/sp-bowa.png") no-repeat bottom -21.33vw left 32vw; background-size: 106.13vw; }
section#p06Box03 .tit-head { margin-bottom: 40px; }
section#p06Box03 section.tec-sec.flex { background: #F0F1F6; }

/*07 試作開発支援
----------------------------------*/
section#p07Box01 { padding: 70px 5.33vw 80px; }

.p07-conBox { display: block; }
.p07-conBox h2.con-copy01 { margin-bottom: 30px; font-size: 24px; }
.p07-conBox h2.con-copy01 .blue { font-size: 30px; }
.p07-conBox h2.con-copy01 span.gra01 { padding-bottom: 12px; }
.p07-conBox > .img { margin-top: 40px; }

.p07-trou-box.trou-box.flex { height: auto; padding: 40px 20px; box-shadow: 0 0 15px rgba(26, 115, 240, 0.08); background: #fff; margin-top: 80px; margin-bottom: 100px; }

section#p07Box02 { padding: 80px 5.33vw; background: #EBF6FF; }

section.dev-sec.flex { margin-bottom: 40px; box-sizing: border-box; padding: 40px 20px; border-radius: 10px; background: #fff; position: relative; justify-content: space-between; align-items: flex-start; display: block; }
section.dev-sec.flex .cont .inner p { line-height: 2; }
section.dev-sec.flex .img { margin-top: 30px; }

section.dev-sec.flex:last-child { margin-bottom: 0; }

section.dev-sec.flex:before { content: ""; width: 6px; height: 100%; background: #1E008B; border-radius: 10px 0 0 10px; position: absolute; left: 0; top: 0; }

.dev-tit { font-size: 24px; font-weight: 700; margin-bottom: 30px; }

ul.piko-list { margin: 14px 0; }
ul.piko-list > li { position: relative; margin-bottom: 10px; font-size: 14px; padding-left: 17px; }
ul.piko-list > li > span { display: inline-block; padding: 10px 10px 10px 24px; border-radius: 4px; background: #EFEBFF; }
ul.piko-list > li .blue02 { font-weight: 700; }
ul.piko-list > li:before { content: ""; background: url("../img/p07/pikon.svg") no-repeat center; width: 34px; height: 34px; position: absolute; left: 0; top: 0; bottom: 0; margin: auto 0; }
ul.piko-list > li:last-child { margin-bottom: 0; }

span.blue02-bg { background: #EFEBFF; }

section#p07Box03 { padding: 80px 5.33vw; }
section#p07Box03 .whiteBox.conBox02 { margin-top: 60px; background: #F7F5FF; }

h3.supp-tit { font-size: 26px; font-weight: 700; margin-bottom: 20px; padding-left: 48px; background: url("../img/p07/ico01.svg") no-repeat left top; background-size: 38px; }

section.supp-sec.flex.supp02 h3.supp-tit { background-image: url("../img/p07/ico02.svg"); }

section.supp-sec.flex.supp03 h3.supp-tit { background-image: url("../img/p07/ico03.svg"); }

section.supp-sec.flex.supp04 ul.check-list01.flex > li { width: 235px; }
section.supp-sec.flex.supp04 ul.check-list01.flex > li:nth-child(4) { width: auto; }
section.supp-sec.flex.supp04 h3.supp-tit { background-image: url("../img/p07/ico04.svg"); }

section.supp-sec.flex.supp05 h3.supp-tit { background-image: url("../img/p07/ico05.svg"); }

section.supp-sec.flex.supp06 h3.supp-tit { background-image: url("../img/p07/ico06.svg"); }

section.supp-sec.flex { margin-bottom: 40px; box-sizing: border-box; padding: 50px 20px; border-radius: 10px; background: #F0F1F6; position: relative; display: block; }
section.supp-sec.flex ul.check-list01.flex > li { box-sizing: border-box; font-weight: 500; margin-bottom: 6px; }
section.supp-sec.flex ul.check-list01.flex > li .blue { font-weight: 700; font-size: 16px; }
section.supp-sec.flex ul.check-list01.flex > li:last-child { margin-bottom: 0; }
section.supp-sec.flex .img { margin-top: 30px; }
section.supp-sec.flex div.details.flex { margin-top: 20px; }
section.supp-sec.flex div.details.flex > div.box { width: 100%; margin: 0 0 20px; }
section.supp-sec.flex div.details.flex > div.box .tit { padding-top: 3px; padding-bottom: 3px; }
section.supp-sec.flex div.details.flex > div.box .inner { padding-top: 20px; padding-bottom: 18px; }
section.supp-sec.flex div.details.flex > div.box .inner ul.piko-list { margin: 0; }
section.supp-sec.flex div.details.flex > div.box:last-child { margin-bottom: 0; }

section.supp-sec.flex:last-child { margin-bottom: 0; }

/*08  設備紹介
----------------------------------*/
section#p08Box01 { padding: 70px 5.33vw 80px; background: url("../img/p02/sp-bowa.png") no-repeat top 240px left 32vw; background-size: 106.13vw; }

.p08-cont01 { margin-bottom: 60px; position: relative; }
.p08-cont01 .copy01 { white-space: nowrap; }
.p08-cont01 .copy01 .blue { line-height: 1.4; }

.p08-cont01:before { content: ""; background: url("../img/p08/ilu01.svg") no-repeat; width: 71px; height: 77px; position: absolute; right: 4px; top: 6px; background-size: contain; }

section#p08Box02 { padding: 80px 5.33vw; background: #EBF6FF; }
section#p08Box02 .TBL03 { width: 798px; padding-right: 5.33vw; }
section#p08Box02 .TBL03 .col01 { width: 190px; }
section#p08Box02 .TBL03 .col02 { width: 168px; }
section#p08Box02 .TBL03 .col03 { width: 190px; }
section#p08Box02 .TBL03 .col04 { width: 168px; }
section#p08Box02 .TBL03 .col05 { width: 82px; }
section#p08Box02 .TBL03 .col01, section#p08Box02 .TBL03 .col02, section#p08Box02 .TBL03 .col03, section#p08Box02 .TBL03 .col04, section#p08Box02 .TBL03 .col05 { display: flex; flex-wrap: wrap; align-items: center; box-sizing: border-box; }
section#p08Box02 .col02-05-wrap { width: calc(100% - 190px); }
section#p08Box02 .col03-05-wrap { width: calc(100% - 168px); }
section#p08Box02 .TB-head.flex > div { background: #494AE9; color: #fff; font-weight: 700; padding: 10px 20px; border-right: solid 1px #E7E0FF; }
section#p08Box02 .TB-head.flex .col01 { border-radius: 10px 0 0 0; }
section#p08Box02 .TB-head.flex .col05 { border-radius: 0 10px 0 0; border-right: none; }
section#p08Box02 .TB-body.flex { background: #FBFAFF; border: solid 1px #E7E0FF; border-top: none; box-sizing: border-box; }
section#p08Box02 .TB-body.flex .col01 { width: 189px; color: #1E008B; justify-content: center; padding: 10px; border-right: solid 1px #E7E0FF; font-weight: 700; }
section#p08Box02 .TB-body.flex .col02 { justify-content: center; padding: 10px; }
section#p08Box02 .TB-body.flex .col03 { padding: 10px 20px; }
section#p08Box02 .TB-body.flex .col04 { padding: 10px 20px; }
section#p08Box02 .TB-body.flex .col05 { width: 80px; justify-content: center; padding: 10px; }
section#p08Box02 .TB-body.flex:nth-child(2n) { background: #fff; }
section#p08Box02 .TB-body.flex:last-child { border-radius: 0 0 10px 10px; }
section#p08Box02 .col02-05.flex { border-bottom: solid 1px #E7E0FF; }
section#p08Box02 .col02-05.flex .col02 { border-right: solid 1px #E7E0FF; }
section#p08Box02 .col02-05.flex:last-child { border-bottom: none; }
section#p08Box02 .col03-05.flex { border-bottom: solid 1px #E7E0FF; }
section#p08Box02 .col03-05.flex .col03 { border-right: solid 1px #E7E0FF; }
section#p08Box02 .col03-05.flex .col04 { border-right: solid 1px #E7E0FF; }
section#p08Box02 .col03-05.flex:last-child { border-bottom: none; }

.eq-list.flex { justify-content: space-between; display: block; }

article.eq-art { margin-bottom: 40px; box-sizing: border-box; background: #fff; padding: 20px 20px 30px; border-radius: 10px; box-shadow: 0 0 15px rgba(26, 115, 240, 0.08); }
article.eq-art .img { margin-bottom: 20px; }
article.eq-art .img .in-img { padding-top: 68.08%; }
article.eq-art h3.tit { font-weight: 500; font-size: 20px; padding-bottom: 20px; border-bottom: solid 1px #E3E5EC; margin-bottom: 20px; }

.TBL02 th, .TBL02 td { box-sizing: border-box; padding-bottom: 10px; }
.TBL02 th { width: 85px; font-weight: 500; color: #1E008B; }
.TBL02 tr:last-child th, .TBL02 tr:last-child td { padding-bottom: 0; }

.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: calc(5% - 25px) !important; }

.scr-wrap { width: calc(100% + 5.33vw); overflow: auto; }

/*09 実績紹介 
----------------------------------*/
div#contents.bg03 { background: url("../img/p02/sp-bowa.png") no-repeat top 28px left 30.4vw; background-size: 106.13vw; }

.case-list-all { display: flex; flex-wrap: wrap; justify-content: space-between; }
.case-list-all article.works-art, .case-list-all article.blog-art01 { margin-bottom: 30px; width: 100%; }
.case-list-all article.works-art:last-child, .case-list-all article.blog-art01:last-child { margin-bottom: 0; }

/*詳細*/
.single div#contents.bg03, .single div#two-main { background: none; }

div#two-main { padding: 0 5.33vw 0; background: url("../img/p02/sp-bowa.png") no-repeat bottom right 25.6vw; background-size: 106.13vw; }

div#two-side { margin-top: 100px; padding: 0 5.33vw 0; }

div#p09sBox01 { padding: 70px 0 80px; }

article.singleBox01 .infos.flex { margin-bottom: 20px; align-items: center; }
article.singleBox01 .infos.flex .n-date { margin-left: auto; font-size: 16px; color: #9A9A9A; }
article.singleBox01 .w-data { margin-top: 40px; margin-bottom: 60px; }

h1.sw-tit01 { font-weight: 500; line-height: 1.6; font-size: 20px; margin-bottom: 30px; }

.w-tit02 { padding-left: 14px; font-weight: 700; font-size: 16px; background: url("../img/p02/list-ico.svg") no-repeat left center; margin-bottom: 15px; }

.works-cont01.flex { justify-content: space-between; align-items: flex-start; }
.works-cont01.flex .gallery-main { width: 100%; }
.works-cont01.flex .gallery-main button.slick-arrow { opacity: 1; z-index: 2; transition: 0s; width: 6.4vw; height: 6.4vw; box-sizing: border-box; transition: 0s; top: 30.1vw; border-radius: 100%; border: solid 1px #1E008B; }
.works-cont01.flex .gallery-main button.slick-prev.slick-arrow { background: url("../img/p09/gallery-arrow01.svg") no-repeat center #fff; left: -3.2vw; right: auto; background-size: 1.6vw; }
.works-cont01.flex .gallery-main button.slick-next.slick-arrow { background: url("../img/p09/gallery-arrow02.svg") no-repeat center #fff; right: -3.2vw; background-size: 1.6vw; }
.works-cont01.flex .gallery-main button.slick-arrow:before { content: none; }
.works-cont01.flex .gallery-main button.slick-prev.slick-arrow.slick-disabled { background-image: url("../img/p09/gallery-arrow01h.svg"); background-color: #1E008B; }
.works-cont01.flex .gallery-main button.slick-next.slick-arrow.slick-disabled { background-image: url("../img/p09/gallery-arrow02h.svg"); background-color: #1E008B; }
.works-cont01.flex .gallery-thumb.flex { width: 100%; margin-top: 20px; 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 .cap { line-height: 1.6; margin-top: 2.66vw; font-size: 4.26vw; }

.g-main-img a { position: relative; text-decoration: none; display: block; }
.g-main-img a .in-img { border-radius: 5px; padding-top: 67.37%; }

.g-thumb { width: 20.8vw; border-radius: 1.6vw; position: relative; margin-top: 2.66vw; margin-right: 2.03vw; cursor: pointer; transition: 0.3s; }
.g-thumb .in-img { border-radius: 1.6vw; padding-top: 67.92%; }

.g-thumb:before { content: ""; border-radius: 1.6vw; width: 100%; height: 100%; background: #000; position: absolute; left: 0; top: 0; z-index: 2; opacity: 0; }

.g-thumb.slick-current:before { opacity: 0.5; }

.g-thumb:nth-child(4n) { 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: 30px; font-size: 24px; color: #1E008B; }

.wt-text01 { margin-bottom: 40px; }

.bfafBox.flex { margin-bottom: 20px; }

.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: 52px; position: relative; box-sizing: border-box; border: solid 2px #707070; border-radius: 10px; }
.bfafBox.flex > div.img .in-img { border-radius: 8px; padding-top: 68.26%; }
.bfafBox.flex > div.img.af { border-color: #494AE9; }
.bfafBox.flex > div.img:last-child { margin-bottom: 0; }

.bfafBox.flex.bfaf .ang-tit { display: block; line-height: 1.6; font-size: 3.73vw; font-weight: 500; padding: 0.53vw 3.73vw; color: #fff; background: #707070; }
.bfafBox.flex.bfaf .af .ang-tit { background: #494AE9; }
.bfafBox.flex.bfaf > div.img.bf:before { content: ""; background: url("../img/top/flow-arrow-sp.svg") no-repeat; width: 16px; height: 22px; position: absolute; top: calc(100% + 16px); left: 50%; transform: translateX(-50%); }

.sideBox { margin-bottom: 40px; position: relative; }
.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.titles02 { color: #1E008B; font-size: 18px; margin-bottom: 24px; }
.side-tit.titles02 > span { padding-left: 29px; }

ul.side-list { border-top: solid 1px #D1D2F9; }
ul.side-list > li.r_current a { background-color: #EFEBFF; }
ul.side-list > li { border-bottom: solid 1px #D1D2F9; }
ul.side-list > li a { display: block; padding: 24px 40px 24px 15px; background: url("../img/p09/side-arrow.svg") no-repeat center right 15px; font-weight: 500; }

.side-inner select { display: block; width: 100%; border-radius: 0; padding: 5px 47px 5px 20px; box-sizing: border-box; height: 46px; background: url("../img/p09/select-arrow.svg") no-repeat center right 16px #fff; font-size: 16px; font-weight: 400; cursor: pointer; border: none; -webkit-appearance: none; appearance: none; border-radius: 4px; border: solid 1px #494AE9; }

div.witerBox { position: relative; background: #F0F1F6; border-radius: 10px; padding: 40px 20px; margin-top: 80px; }
div.witerBox .titles05 { font-size: 18px; margin-left: 10px; }
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: #1E008B; }
div.witerBox .inner .team-name.team-name01 { font-weight: 400; }
div.witerBox .inner .wr-detail { line-height: 1.6; margin-top: 7px; margin-bottom: 20px; }
div.witerBox .inner .img { width: 100px; margin: 0 auto 40px; }
div.witerBox .inner .img .in-img { border-radius: 100%; padding-top: 100%; }

/*ページャー*/
div#pager00 { text-align: center; }

div#pager00 .wp-pagenavi { margin-top: 80px; }

.wp-pagenavi > span, .wp-pagenavi > a { display: inline-block; margin: 2px; text-decoration: none; width: 48px; height: 48px; text-align: center; line-height: 44px; font-size: 14px; font-weight: 700; color: #1E008B; background: #fff; box-sizing: border-box; border-radius: 100%; border: solid 2px #1E008B; }

.wp-pagenavi a.page { position: relative; }

.wp-pagenavi span.extend { background: none; color: #1E008B; box-shadow: none; border: none; }

.wp-pagenavi a.previouspostslink { color: transparent; background: url("../img/p09/arrow02.svg") no-repeat center #fff; margin-left: 0; }

.wp-pagenavi a.nextpostslink { color: transparent; background: url("../img/p09/arrow03.svg") no-repeat center #fff; margin-right: 0; }

.wp-pagenavi span.current { color: #fff; background: #1E008B; }

.wp-pagenavi a.first { background: url("../img/p09/arrow01.svg") no-repeat center #fff; color: transparent; }

.wp-pagenavi a.last { background: url("../img/p09/arrow04.svg") no-repeat center #fff; color: transparent; }

.wp-pagenavi span.pages { display: none; }

.post-navigation ul { margin-top: 80px; display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; }
.post-navigation ul > li .arrow { width: 50px; height: 50px; display: inline-block; border-radius: 100%; border: solid 1px #1E008B; box-sizing: border-box; background-color: #1E008B; background-position: center; background-repeat: no-repeat; }
.post-navigation ul > li:last-child { margin-right: 0; }
.post-navigation ul li.prev a, .post-navigation ul li.next a { color: #1E008B; text-decoration: none; display: flex; flex-wrap: wrap; align-items: center; font-weight: 700; }
.post-navigation ul li.prev a .text, .post-navigation ul li.next a .text { display: none; }
.post-navigation ul li.kara { opacity: 0; pointer-events: none; display: flex; flex-wrap: wrap; }
.post-navigation ul li.kara .text { display: none; }
.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.prev .arrow { background-image: url("../img/p09/arrow-prev.svg"); }
.post-navigation ul li.next .arrow { background-image: url("../img/p09/arrow-next.svg"); }
.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 #1E008B; background: #fff; color: #1E008B; border-radius: 40px; font-weight: 700; }

.blog-text p:first-child { margin-top: 0; }
.blog-text p:first-child img { margin-top: 0; }
.blog-text img:first-child { margin-top: 0; }
.blog-text img[class*="wp-image-"] { margin: 20px 0; }
.blog-text iframe { max-width: 100%; }
.blog-text div { max-width: 100%; }
.blog-text a { max-width: 100%; text-decoration: underline; }

/*10 選ばれる理由
----------------------------------*/
section#p10Box01 { padding: 70px 5.33vw 80px; background: url("../img/p02/sp-bowa.png") no-repeat bottom -29.33vw right 41.86vw; background-size: 106.13vw; }
section#p10Box01 .con-copy01 { font-size: 24px; margin-bottom: 20px; }
section#p10Box01 .con-copy01 .big { font-size: 37px; }
section#p10Box01 .case-area { margin-top: 100px; }

div.p10-conBox { margin-bottom: 40px; position: relative; z-index: 2; }
div.p10-conBox > .cont { position: relative; }
div.p10-conBox > .cont .text p { display: inline; }
div.p10-conBox > .cont:before { content: ""; background: url("../img/p10/ilu01.svg") no-repeat; width: 84px; height: 116px; position: absolute; right: 0; top: -31px; background-size: contain; }
div.p10-conBox .text02 { margin-top: 10px; }
div.p10-conBox .text02 .blue { font-weight: 700; }

.reason-list10.flex:before { content: ""; background: url("../img/p02/sp-bowa.png") no-repeat; width: 106.13vw; height: 106.13vw; background-size: contain; position: absolute; left: 12vw; top: -98px; }

.reason-list10.flex { position: relative; }
.reason-list10.flex > .box { background: #fff; width: 100%; box-sizing: border-box; padding: 30px 20px; box-shadow: 0 0 15px rgba(26, 115, 240, 0.08); margin-bottom: 20px; position: relative; z-index: 2; border-radius: 5px; }
.reason-list10.flex > .box h3.re-tit10 { margin-bottom: 14px; font-weight: 700; padding-left: 58px; color: #1E008B; background: url("../img/p10/ico01.svg") no-repeat left top; font-size: 18px; line-height: 48px; }
.reason-list10.flex > .box:last-child { margin-bottom: 0; }
.reason-list10.flex > .box.box02 h3.re-tit10 { background-image: url("../img/p10/ico02.svg"); }
.reason-list10.flex > .box.box03 h3.re-tit10 { background-image: url("../img/p10/ico03.svg"); }
.reason-list10.flex > .box.box04 h3.re-tit10 { background-image: url("../img/p10/ico04.svg"); }

.p10-cont01.flex { margin-top: 100px; display: block; }
.p10-cont01.flex .img { margin-top: 30px; }

/*11 会社案内 
----------------------------------*/
section#p11Box01 { padding: 70px 5.33vw 80px; }
section#p11Box01 .titles01 { margin-bottom: 30px; }

section#p11Box02 { padding: 80px 5.33vw; background: #EBF6FF; }
section#p11Box02 .titles01 { margin-bottom: 30px; }

section#p11Box03 { padding: 80px 5.33vw; }
section#p11Box03 .titles01 { margin-bottom: 50px; }

.p11-cont01.flex { display: block; }

.TBL03 { width: 100%; }
.TBL03 tr:first-child th { padding-top: 0; }
.TBL03 th, .TBL03 td { box-sizing: border-box; padding: 30px 0; vertical-align: top; display: block; }
.TBL03 th { width: auto; font-weight: 700; color: #1E008B; padding-bottom: 15px; }
.TBL03 td { border-bottom: solid 1px #DADADA; padding-top: 0; }
.TBL03 a[target="_blank"] { display: inline-block; padding-right: 22px; background: url("../img/p11/ico-blank.svg") no-repeat right center; background-size: 18px; }

.greeting.whiteBox { padding: 60px 20px; }
.greeting.whiteBox > .inner.flex { display: block; }
.greeting.whiteBox > .inner.flex > .right { text-align: center; }
.greeting.whiteBox > .inner.flex > .right .daihyo { margin-bottom: 10px; width: 49.06vw; margin: 40px auto 0; }
.greeting.whiteBox .con-copy01 { line-height: 1.6; margin-bottom: 30px; font-size: 24px; }
.greeting.whiteBox .textBox { margin-bottom: 20px; }
.greeting.whiteBox .textBox > div { margin-bottom: 20px; }
.greeting.whiteBox .textBox > div:last-child { margin-bottom: 0; }

.p11-names { line-height: 1.8; font-weight: 700; }
.p11-names .line02 { font-size: 20px; margin-left: 14px; }

.p11-cont03-1.flex { display: block; margin-bottom: 60px; }
.p11-cont03-1.flex .img { margin-top: 40px; }
.p11-cont03-1.flex .cont .textBox > div { margin-bottom: 20px; }
.p11-cont03-1.flex .cont .textBox > div:last-child { margin-bottom: 0; }

.p11-logo { margin-bottom: 40px; max-width: 321px; width: 100%; }

.com-name { font-size: 20px; font-weight: 700; margin-bottom: 20px; }

.p11-cont03-2.flex { display: block; }
.p11-cont03-2.flex .img { width: 122px; margin: 40px auto 0; }
.p11-cont03-2.flex .cont .w-tit02 { font-size: 24px; margin-bottom: 30px; }

/*12 ブログ
----------------------------------*/
.blog-tit01 { font-weight: 700; font-size: 20px; margin-bottom: 15px; line-height: 1.6; color: #1E008B; }

.blog-tit02 { font-weight: 700; font-size: 18px; padding-left: 14px; background: url(../img/p02/list-ico.svg) no-repeat left center; margin-bottom: 10px; }

article.singleBox01.singleBox01-blog div#toc_container { box-sizing: border-box; width: 100%; background: #EFEBFF; border: none; border-radius: 10px; padding: 30px; margin-bottom: 40px; }
article.singleBox01.singleBox01-blog div#toc_container p.toc_title { text-align: left; line-height: 1.6; font-size: 20px; font-weight: 700; margin-bottom: 10px; }
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; }
article.singleBox01.singleBox01-blog div#toc_container ul.toc_list > li span.toc_number { display: inline-block; font-size: 20px; font-family: "robo"; color: #1E008B; vertical-align: -2px; margin-right: 10px; }
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: #1E008B; font-weight: 700; line-height: 1.2; margin-bottom: 14px; font-size: 18px; }

ul.word_list.flex { margin-top: -10px; margin-left: -10px; width: calc(100% + 10px); }
ul.word_list.flex > li { margin: 10px 0 0 10px; }

/* 13 お問い合わせ
----------------------------------*/
section#p10Box01.p13Box01 { background: none; }
section#p10Box01.p13Box01 div.p10-conBox > .cont:before { content: none; }
section#p10Box01.p13Box01 div.p10-conBox { margin-bottom: 112px; }
section#p10Box01.p13Box01 .case-area { margin-top: 113px; }

.reason-list10.reason-list13.flex { position: relative; }
.reason-list10.reason-list13.flex .box.box01 h3.re-tit10 { line-height: 29px; height: 58px; background-image: url("../img/p13/ico01.svg"); }
.reason-list10.reason-list13.flex .box.box02 h3.re-tit10 { background-image: url("../img/p13/ico02.svg"); }
.reason-list10.reason-list13.flex .box.box03 h3.re-tit10 { line-height: 29px; height: 58px; background-image: url("../img/p13/ico03.svg"); }
.reason-list10.reason-list13.flex .box.box04 h3.re-tit10 { background-image: url("../img/p13/ico04.svg"); }

.reason-list10.reason-list13.flex:before { content: ""; background: url("../img/p13/ilu02.svg") no-repeat; width: 276px; height: 64px; position: absolute; left: 20px; bottom: 100%; top: auto; }

section#p13Box02 { padding: 80px 5.33vw; background: #EBF6FF; }
section#p13Box02 .titles01 { margin-bottom: 40px; }
section#p13Box02 .contact-types.flex > .box { padding-top: 40px; padding-bottom: 50px; margin-bottom: 20px; }
section#p13Box02 .contact-types.flex .box:nth-child(3) { width: 100%; margin-bottom: 0; padding: 40px 20px 60px; text-align: left; }
section#p13Box02 .contact-types.flex .box:nth-child(3) > .ico { text-align: center; }
section#p13Box02 .contact-types.flex .box:nth-child(3) > h3.tit { text-align: center; margin-bottom: 40px; }

/*フォーム*/
.file-bikou { font-size: 14px; }

ul.contact-state { display: flex; flex-wrap: wrap; justify-content: center; margin: 40px 0 10px; }

ul.contact-state > li { display: table; width: 76px; height: 60px; position: relative; margin-right: 14px; }

ul.contact-state > li > span { display: table-cell; text-align: center; vertical-align: middle; background: #fff; color: #1E008B; font-size: 14px; font-weight: 700; border: solid 1px #1E008B; border-radius: 4px; }

ul.contact-state > li.state01 { margin-left: 0; }

ul.contact-state > li.state01 > span { background: #1E008B; color: #fff; }

ul.contact-state > li > span span.num { display: block; }

ul.contact-state > li:after { content: ""; width: 14px; height: 1px; position: absolute; top: 0; bottom: 0; left: 100%; margin: auto 0; top: 0; bottom: 0; background: #1E008B; }

ul.contact-state > li:last-child:after { content: none; }

ul.contact-state.contact-state02 { display: flex; flex-wrap: wrap; justify-content: space-between; }

ul.contact-state.contact-state02 > li.state02 > span { background: #1E008B; color: #fff; }

span.num-circle { margin-right: 7px; }

a.green { text-decoration: underline; }

.contactTBL th, .contactTBL td { display: block; box-sizing: border-box; font-size: 16px; padding: 30px 0; color: #000000; line-height: 1.66; }
.contactTBL th { padding-bottom: 15px; }
.contactTBL th span.form-bikou { font-weight: 500; font-size: 14px; }
.contactTBL td { padding-top: 0; }
.contactTBL .wpcf7-list-item { margin-left: 0; display: block; margin-bottom: 10px; }
.contactTBL .wpcf7-list-item.last { margin-bottom: 0; }
.contactTBL input[type="checkbox"], .contactTBL input[type="radio"] { transform-origin: left center; transform: scale(1.5); margin-right: 8px; }

span.hissu { display: inline-block; color: #fff; padding: 0px 7px; background: #1E008B; margin-right: 8px; box-sizing: border-box; font-size: 14px; font-weight: 700; border-radius: 2px; }

span.nini { display: inline-block; padding: 0px 6px; margin-right: 8px; font-size: 14px; font-weight: 700; border-radius: 5px; color: #1E008B; border: solid 1px; border-radius: 2px; box-sizing: border-box; }

input.wpcf7-number, input.wpcf7-date, input.wpcf7-text { box-sizing: border-box; height: 40px; border: solid 1px #B3B3B3; padding: 5px 20px; font-size: 16px; background: #fff; width: 100%; border-radius: 2px; }

input.wpcf7-date { padding: 5px 10px; }

select.wpcf7-select { box-sizing: border-box; height: 40px; border: solid 1px #B3B3B3; padding: 5px 20px; font-size: 16px; background: #fff; width: auto; border-radius: 2px; }

select { background: #fff; border-radius: 2px; }

textarea.wpcf7-textarea { box-sizing: border-box; height: 160px; border: solid 1px #B3B3B3; padding: 5px 20px; font-size: 16px; background: #fff; width: 100%; border-radius: 2px; }

input#com-name, input#busho { width: 100%; }

.okomari-list span.wpcf7-list-item { display: block; }

.radio-list span.wpcf7-list-item { display: block; }

.contactTBL .select-con .wpcf7-list-item { display: inline-block; margin-right: 10px !important; }

.select-con { margin-bottom: 15px; }

input#your-name, input#your-kana { width: 100%; }

.cours-area { margin-top: 5px; }

input.wpcf7-text.tel01, input#zip01 { width: 180px; }

select#pref3 { width: auto; }

span.form-bikou { display: block; }

ul.address-list > li { margin-bottom: 30px; }
ul.address-list > li:last-child { margin-bottom: 0; }
ul.address-list .th { font-size: 14px; margin-bottom: 5px; }

.contactArea .codedropz-upload-container { padding: 0; }

.contactArea .codedropz-upload-handler { border: solid 1px #D4D4D4; border-radius: 0; background: url("../img/p13/ico-file.svg") no-repeat center top 42px #fff; padding: 74px 3px 40px; }

.contactArea .codedropz-upload-inner { color: #1C1C1C; line-height: 1.5; font-size: 16px; font-weight: 500; }

.contactArea .codedropz-upload-inner h3, .contactArea .codedropz-upload-inner > span { font-size: 16px; font-weight: 500; margin: 0; color: #B3B3B3; }

a.cd-upload-btn { width: 140px; height: 40px; display: inline-block; line-height: 35px; background: #E3E3E3; border: none; border-radius: 0; padding-top: 3px; font-size: 16px; margin-top: 8px; color: #000000; }

.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 2px #1E008B; color: #fff; width: 100%; height: 70px; font-size: 16px; font-weight: 700; position: relative; z-index: 3; background: url("../img/p13/form-arrow01.svg") no-repeat center right 30px #1E008B; border-radius: 38px; text-align: center; }

.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: #1E008B; background-image: url("../img/p13/form-arrow02.svg"); background-position: left 30px 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: #B2B2B2; line-height: 1.5; }

/*確認画面*/
.contactArea.che { background: #eee; padding: 30px 10px; }
.contactArea.che .pop-btn.opcl-btn.on { pointer-events: none; }
.contactArea.che .opcl-wrap { display: block !important; }
.contactArea.che div.opcl-inBox { padding-top: 20px; }

.contactArea.che .contactTBL tr { border-bottom: solid 1px #000; }

.contactArea.che .contactTBL th, .contactArea.che .contactTBL td { padding-top: 5px; padding-bottom: 5px; vertical-align: middle; }

.contactArea.che .dnd-upload-status .dnd-upload-details .remove-file, .contactArea.che .codedropz-upload-handler, .contactArea.che .bikou-text01, .contactArea.che span.dnd-progress-bar, .contactArea.che input[type=checkbox] { display: none; }

.contactArea.che input[type=checkbox]:checked { display: inline-block; }

.contactArea.che input[type=checkbox] ~ span.wpcf7-list-item-label { display: none; }

.contactArea.che input[type=checkbox]:checked ~ span.wpcf7-list-item-label { display: inline-block; font-weight: 700; }

.contactArea.che input[type=radio] { display: none; }

.contactArea.che input[type=radio]:checked { display: inline-block; }

.contactArea.che input[type=radio] ~ span.wpcf7-list-item-label { display: none; }

.contactArea.che input[type=radio]:checked ~ span.wpcf7-list-item-label { display: inline-block; font-weight: 700; }

.contactArea.che textarea.wpcf7-textarea, .contactArea.che input.wpcf7-number, .contactArea.che input.wpcf7-date, .contactArea.che input.wpcf7-text, .contactArea.che select { font-weight: 700; }

span.sp-flex { display: flex; flex-wrap: wrap; align-items: flex-start; }

span.sp-flex-in { width: calc(100% - 55px); }

/*100 thanksページ等
----------------------------------*/
div#p100Box01, div#p101Box01 { padding: 70px 5.33vw 80px; }
div#p100Box01 .btn01, div#p101Box01 .btn01 { margin: 40px auto 0; }

.pp-title01 { font-size: 22px; border-bottom: solid 2px; margin-bottom: 25px; padding-bottom: 10px; }

.pp-title02:first-child { margin-top: 0; }

.pp-title02 { font-size: 18px; padding-left: 15px; position: relative; color: #1E008B; margin-top: 50px; }

.pp-title02:before { content: ""; width: 5px; height: 65%; background: #1E008B; position: absolute; left: 0; top: 0; bottom: 0; margin: auto 0; }

/*デバイス幅ごとの調整（必要な幅があれば追加して調整）*/
