@charset "UTF-8";
html { background-color: #FFF; font-size: 62.5%; }

a:link { color: #5F4B8B; text-decoration: underline; }

a:visited { color: #1F1F1F; }

a:hover { color: #6F34F1; text-decoration: none; }

a:active { color: #1F1F1F; }

/* clearfixハック */
.clearfix:after { content: "."; display: block; clear: both; height: 0; visibility: hidden; }

.clearfix { min-height: 1px; }

.sp { display: block; }
@media (min-width: 992px) { .sp { display: none; } }

.pc { display: none; }
@media (min-width: 992px) { .pc { display: block; } }

body { margin: 0; padding: 0; text-align: center; font-family: "Arial", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "MS PGothic", "ＭＳ Ｐゴシック", sans-serif; }
@media (min-width: 992px) { body #page-wrapper { padding-top: 17.8rem; }
  body #page-wrapper.under-pages { padding-top: 70px; } }
body .wrapper { width: 85%; margin: 0 auto; }
@media (min-width: 768px) { body .wrapper { width: 750px; font-size: 1.6rem; } }
@media (min-width: 992px) { body .wrapper { width: 970px; } }
@media (min-width: 1200px) { body .wrapper { width: 1040px; } }

/* button */
.link1 li a { width: 100%; font-size: 1.6rem; text-decoration: none; display: block; text-align: center; padding: 15px 0 15px 0; color: #fff; background-color: #5F4B8B; -webkit-border-radius: 3px; -moz-border-radius: 3px; border-radius: 3px; transition-property: all; transition: 0.3s linear; }
@media (min-width: 768px) { .link1 li a { width: 320px; } }

.link1 li a:hover { background-color: #6F34F1; text-decoration: none; }

.arrow { position: relative; display: inline-block; padding-left: 20px; }

.arrow2 { position: relative; display: inline-block; padding-right: 20px; }

.arrow::before { content: ''; width: 6px; height: 6px; border: 0px; border-top: solid 2px #FFF; border-right: solid 2px #FFF; -ms-transform: rotate(45deg); -webkit-transform: rotate(45deg); transform: rotate(45deg); position: absolute; top: 50%; right: 15px; margin-top: -4px; transition-property: all; transition: 0.3s linear; }

.arrow2::before { content: ''; width: 6px; height: 6px; border: 0px; border-top: solid 2px #FFF; border-left: solid 2px #FFF; -ms-transform: rotate(-45deg); -webkit-transform: rotate(-45deg); transform: rotate(-45deg); position: absolute; top: 50%; left: 15px; margin-top: -4px; transition-property: all; transition: 0.3s linear; }

.arrow:hover::before { right: 10px; }

.arrow2:hover::before { left: 10px; }

/* overlay */
.overlay { background: rgba(0, 0, 0, 0.3); }

/* loading bar */
.loadingBar { width: 0px; height: 2px; background: #5F4B8B; position: fixed; top: 0; left: 0; transition: all 0.2s linear 0s; z-index: 1000; }

/* header */
header { width: 100%; padding: 15px 0; background-color: rgba(255, 255, 255, 0.99); border-bottom: #D2D2D2 solid 1px; }
header h1 { width: 225px; }
header h1 a { display: block; width: 225px; height: 40px; text-indent: -99999px; background: url(../images/logo_mobile@2x.png) no-repeat; background-size: contain; transition-property: all; transition: 0.1s linear; }
header .navDesktop { display: none; }
@media (min-width: 992px) { header h1 { width: 110px; }
  header h1 a { display: block; width: 110px; height: 112px; text-indent: -99999px; background: url(../images/logo_desktop.png) no-repeat; background: contain; } }

@media (min-width: 992px) { header { overflow: hidden; position: fixed; z-index: 999; top: 0; left: 0; padding: 45px 0 20px 0; -moz-transition: all 0.3s; -o-transition: all 0.3s; -webkit-transition: all 0.3s; transition: all 0.3s; }
  header .wrapper { display: flex; justify-content: space-between; align-items: flex-start; }
  header .navDesktop { flex-grow: 1; display: flex; justify-content: flex-end; }
  header .navDesktop ul { text-align: left; border-left: #D1D1D1 solid 1px; margin: 0px 45px 0 0; height: auto; }
  header .navDesktop ul:last-child { margin-right: 0px; }
  header .navDesktop li { font-size: 1.4rem; font-weight: bold; padding: 0 0 25px 20px; }
  header .navDesktop li a { color: #1F1F1F; text-decoration: none; }
  header .navDesktop li a:hover { color: #6F34F1; }
  header .navDesktop li:last-child { padding: 0 0 0px 20px; }
  header.smaller { padding: 30px 0 15px 0; }
  header.smaller h1 { width: 225px; }
  header.smaller h1 a { display: block; width: 225px; height: 40px; text-indent: -99999px; background: url(../images/logo_mobile@2x.png) no-repeat; background-size: contain; } }
@media (min-width: 992px) and (min-width: 992px) { header.smaller ul { border-left: none; margin: 15px 0px 0 0; }
  header.smaller li { font-size: 1.2rem; display: inline; padding: 0 0 0 20px; } }

/* global navi */
/*　nabi開閉部分　*/
.nav-wrap { box-sizing: border-box; position: absolute; width: 100%; z-index: 99999; }

.gnav { margin-top: 63px; background: rgba(255, 255, 255, 0.9); border-top: #CCC solid 1px; list-style-type: none; }

.gnav li { border-bottom: #CCC solid 1px; text-align: left; padding-left: 20px; }

.gnav li a { font-size: 1.6rem; display: block; text-decoration: none; padding: 10px 0; font-family: 'Libre Baskerville', serif; font-weight: normal; font-style: italic; color: #999; }

.gnav li a span { font-size: 77%; font-family: "Arial", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "MS PGothic", "ＭＳ Ｐゴシック", sans-serif; margin-left: 2em; font-style: normal; color: #333; }

.gnav li a:hover { color: #008680; }

.gnav li a.uc, .gnav li a.uc span, .gnav li a.uc:hover, .gnav li a.uc:hover span { color: #CCC; cursor: default; }

/*ハンバーガーボタン*/
.pushy { display: none; }

.gnav-btn { position: absolute; top: -35px; right: 20px; }

@media (min-width: 992px) { .gnav-btn { display: none; } }
.menu-trigger, .menu-trigger span { display: inline-block; box-sizing: border-box; transition: all .4s; }

.menu-trigger { position: relative; width: 25px; height: 38px; }

.menu-trigger span { position: absolute; left: 0; width: 100%; }

.menu-trigger span:nth-of-type(1) { top: 0; height: 2px; background-color: #000; }

.menu-trigger span:nth-of-type(2) { top: 6px; height: 2px; background-color: #000; }

.menu-trigger span:nth-of-type(3) { top: 12px; height: 2px; background-color: #000; }

/* 開閉アニメーション */
.menu-trigger.active span:nth-of-type(1) { -webkit-transform: translateY(2px) rotate(-45deg); transform: translateY(2px) rotate(-45deg); background-color: #FFF; }

.menu-trigger.active span:nth-of-type(2) { opacity: 0; background-color: #FFF; }

.menu-trigger.active span:nth-of-type(3) { -webkit-transform: translateY(-10px) rotate(45deg); transform: translateY(-10px) rotate(45deg); background-color: #FFF; }

@-webkit-keyframes active-menu-bar02 { 100% { height: 0; } }
@keyframes active-menu-bar02 { 100% { height: 0; } }
footer { padding: 130px 0 0 0; background: #5F4B8B url(../images/footer_bg.png) repeat-x top; }
footer .wrapper { padding-top: 20px; }
@media (min-width: 992px) { footer .wrapper { display: flex; justify-content: space-between; }
  footer .wrapper address { display: block; } }
footer a { color: #FFF !important; text-decoration: none !important; }
footer a:hover { color: #EEE4F4 !important; }
footer h3 { text-align: left; font-size: 1.4rem; line-height: 200%; letter-spacing: 1px; font-family: "Arial", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "MS PGothic", "ＭＳ Ｐゴシック", sans-serif; color: #FFF; }
footer h3 strong { font-weight: bold; }
footer p { color: #FFF; text-align: left; font-size: 1.4rem; line-height: 200%; letter-spacing: 1px; margin-bottom: 1em; }
footer nav { text-align: left; font-size: 1.4rem; letter-spacing: 1px; font-family: "Arial", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "MS PGothic", "ＭＳ Ｐゴシック", sans-serif; padding: 40px 0; }
@media (min-width: 768px) { footer nav { display: block; display: flex; } }
@media (min-width: 992px) { footer nav { padding: 0 0 40px 0; } }
@media (min-width: 768px) { footer nav ul { width: 230px; margin: 0 55px 0 0; } }
@media (min-width: 992px) { footer nav ul { margin: 0 0 0 55px; } }
footer nav li { padding: 10px 0; border-bottom: #8778a8 solid 1px; margin-bottom: 15px; }
footer .copyright { background: #40325D; }
footer .copyright .wrapper { display: block; text-align: center !important; font-size: 1.2rem; font-family: "Arial", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "MS PGothic", "ＭＳ Ｐゴシック", sans-serif; color: #FFF; padding: 15px 0; }

#page-top { display: block; position: fixed; right: 20px; bottom: 20px; z-index: 999; }
#page-top img { height: 60px; width: 60px; }
@media (min-width: 768px) { #page-top img { height: 76px; width: 76px; } }

/* top page */
#topMain { width: 100%; height: calc(100vh - 70px); background: url(../images/main_sp.jpg) no-repeat; background-size: cover; color: #FFF; }
@media (min-width: 768px) { #topMain { background: url(../images/main.jpg) no-repeat; background-size: cover; } }
@media (min-width: 992px) { #topMain { height: calc(100vh - 177px); } }
#topMain .wrapper { height: 100%; display: flex; justify-content: center; align-items: center; }
#topMain .scroll-wrapper { position: absolute; bottom: 20px; left: 50%; margin-left: -20px; }
#topMain .scroll-wrapper .scroll { font-family: 'Playfair Display',serif; font-weight: 400; font-style: italic; font-size: 1.8rem; letter-spacing: 1px; margin-bottom: 0.5em; }
#topMain .scroll-wrapper .scroll-container { display: block; z-index: 99; left: 50%; margin-left: -10px; bottom: 0px; border: 1px #FFF solid; -webkit-border-radius: 15px; -moz-border-radius: 15px; border-radius: 15px; width: 18px; height: 34px; opacity: 1; transition: 0.5s; position: relative; }
#topMain .scroll-wrapper .scroll-container:before { content: ""; position: absolute; background-color: #FFF; width: 2px; height: 7px; left: 8px; /*top: 5px;*/ animation: shakeScroll 1.25s linear infinite; }
@keyframes shakeScroll { 0% { top: 5px; }
  50% { top: 10px; }
  100% { top: 5px; } }
#topMain .scroll-wrapper .scroll-arrow { font-size: 1.2rem; }
#topMain .box { padding-bottom: 100px; }
#topMain h2 { font-family: 'Playfair Display',serif; font-weight: 400; font-size: 8rem; line-height: 100%; margin-bottom: 0.3em; text-shadow: rgba(0, 0, 0, 0.2) 0px 0px 10px; }
@media (min-width: 768px) { #topMain h2 { font-size: 11rem; margin-bottom: 0.2em; } }
#topMain h3 { font-size: 1.6rem; line-height: 100%; font-weight: bold; }
@media (min-width: 992px) { #topMain h3 { font-size: 1.9rem; } }

#philosophy { background: url(../images/philosophy-img.jpg) no-repeat; background-size: cover; color: #FFF; }
@media (min-width: 768px) { #philosophy { background-attachment: fixed; } }
#philosophy .wrapper { box-sizing: border-box; text-align: center; padding: 90px 0px 60px 0px; }
@media (min-width: 768px) { #philosophy .wrapper { text-align: left; padding: 170px 215px 100px 0px; } }
@media (min-width: 992px) { #philosophy .wrapper { padding: 170px 435px 100px 0px; } }
@media (min-width: 1200px) { #philosophy .wrapper { padding: 170px 505px 100px 0px; } }
#philosophy .wrapper h3 { font-size: 2.1rem; font-weight: bold; position: relative; margin-bottom: 40px; }
#philosophy .wrapper h3:before { display: block; position: absolute; background: #FFF; content: ''; width: 85px; height: 1px; left: 50%; bottom: -15px; margin-left: -42.5px; }
@media (min-width: 768px) { #philosophy .wrapper h3:before { left: 0; margin-left: 0; } }
#philosophy .wrapper p { text-align: left; font-size: 1.4rem; line-height: 200%; letter-spacing: 1px; margin-bottom: 2em; }
@media (min-width: 768px) { #philosophy .wrapper p { font-size: 1.6rem; } }

#information-box .wrapper { box-sizing: border-box; text-align: center; padding: 40px 0px 0px 0px; }
@media (min-width: 768px) { #information-box .wrapper { text-align: left; padding: 50px 0px 0px 0px; display: flex; justify-content: space-between; } }
@media (min-width: 768px) { #information-box .wrapper #information-list { width: 340px; } }
@media (min-width: 992px) { #information-box .wrapper #information-list { width: 480px; } }
@media (min-width: 1200px) { #information-box .wrapper #information-list { width: 550px; } }
#information-box .wrapper #information-list h3 { font-size: 2.1rem; font-weight: bold; margin-bottom: 40px; position: relative; }
@media (min-width: 768px) { #information-box .wrapper #information-list h3 { border-bottom: #5F4B8B solid 3px; padding-bottom: 10px; margin-bottom: 20px; } }
#information-box .wrapper #information-list h3:before { display: block; position: absolute; background: #5F4B8B; content: ''; width: 85px; height: 1px; left: 50%; bottom: -15px; margin-left: -42.5px; }
@media (min-width: 768px) { #information-box .wrapper #information-list h3:before { display: none; } }
#information-box .wrapper #information-list dl { text-align: left; font-size: 1.4rem; line-height: 160%; margin-bottom: 1em; border-bottom: #D8D8D8 solid 1px; }
@media (min-width: 768px) { #information-box .wrapper #information-list dl { font-size: 1.6rem; } }
#information-box .wrapper #information-list dl dt { line-height: 100%; margin-bottom: 0.3em; }
#information-box .wrapper #information-list dl dt span { background: #AA97DE; color: #FFF; text-align: center; font-size: 1rem; padding: 2px 15px; margin: -3px 0 0 1em; }
#information-box .wrapper #information-list dl dd { padding-bottom: 1em; }
#information-box .wrapper #facebook-box { width: 100%; height: 453px; margin-top: 40px; }
@media (min-width: 768px) { #information-box .wrapper #facebook-box { margin-top: 0; width: 390px; height: 453px; } }

/* pages */
#page-title { background: url(../images/pges-title-bg-sp.jpg) no-repeat; background-size: cover; padding: 18px 0; }
@media (min-width: 768px) { #page-title { background: none; padding: 0; } }
#page-title .bg-layer { background: none; }
#page-title .bg-layer .wrapper .title-en { color: #FFF; font-family: 'Playfair Display',serif; font-weight: 400; font-size: 2.4rem; letter-spacing: 1px; }
@media (min-width: 768px) { #page-title .bg-layer { height: 200px; background: url(../images/pges-title-bg.jpg) no-repeat; background-size: cover; }
  #page-title .bg-layer .wrapper { position: relative; height: 183px; }
  #page-title .bg-layer .wrapper .title-en { position: absolute; font-size: 8rem; right: 0px; bottom: 0px; } }
#page-title h2 { font-size: 1rem; font-weight: bold; margin: 13px 0 0 0; color: #FFF; }
@media (min-width: 768px) { #page-title h2 { font-size: 2.1rem; float: right; position: relative; margin: 20px 0 100px 0; color: #000; } }
@media (min-width: 768px) { #page-title h2:before { position: absolute; display: block; content: ''; background: #000; width: 35px; height: 5px; bottom: -20px; left: 0; } }

#page-contents { padding: 50px 0 0 0; }
@media (min-width: 768px) { #page-contents { padding: 0 0 0 0; } }
#page-contents .main { text-align: left; }
@media (min-width: 768px) { #page-contents .main { width: 550px; float: left; } }
@media (min-width: 992px) { #page-contents .main { width: 670px; float: left; } }
@media (min-width: 1200px) { #page-contents .main { width: 740px; float: left; } }
#page-contents .main h3 { text-align: center; font-size: 2.1rem; font-weight: bold; margin-bottom: 60px; position: relative; }
@media (min-width: 768px) { #page-contents .main h3 { text-align: left; border-bottom: #5F4B8B solid 3px; padding-bottom: 10px; margin-bottom: 90px; } }
#page-contents .main h3:before { display: block; position: absolute; background: #5F4B8B; content: ''; width: 85px; height: 1px; left: 50%; bottom: -15px; margin-left: -42.5px; }
@media (min-width: 768px) { #page-contents .main h3:before { display: none; } }
#page-contents .main dl { text-align: left; font-size: 1.4rem; line-height: 160%; margin-bottom: 1em; border-bottom: #D8D8D8 solid 1px; }
@media (min-width: 768px) { #page-contents .main dl { font-size: 1.8rem; } }
#page-contents .main dl dt { line-height: 100%; margin-bottom: 0.3em; }
#page-contents .main dl dt span { background: #AA97DE; color: #FFF; text-align: center; font-size: 1rem; padding: 2px 15px; margin: 0 0 0 1em; }
#page-contents .main dl dd { padding-bottom: 1em; }
#page-contents .main p { font-size: 1.4rem; line-height: 160%; margin-bottom: 1em; }
@media (min-width: 768px) { #page-contents .main p { font-size: 1.8rem; } }
#page-contents .main .link1 { margin-bottom: 60px; }
@media (min-width: 768px) { #page-contents .main .link1 { margin-bottom: 40px; } }
#page-contents .main .link1 li a { width: 70%; margin: 0 auto; }
@media (min-width: 768px) { #page-contents .main .link1 li a { float: right; width: 225px; } }
#page-contents .pages { text-align: left; }
@media (min-width: 768px) { #page-contents .pages { width: 550px; float: left; } }
@media (min-width: 992px) { #page-contents .pages { width: 670px; float: left; } }
@media (min-width: 1200px) { #page-contents .pages { width: 740px; float: left; } }
#page-contents .pages img { max-width: 100%; height: auto; }
#page-contents .pages p { font-size: 1.4rem; line-height: 200%; margin-bottom: 1em; }
@media (min-width: 768px) { #page-contents .pages p { font-size: 1.6rem; } }
#page-contents .pages .date { text-align: left; font-size: 1.4rem; line-height: 160%; }
@media (min-width: 768px) { #page-contents .pages .date { font-size: 1.8rem; } }
#page-contents .pages .date span { background: #AA97DE; color: #FFF; text-align: center; font-size: 1rem; padding: 2px 15px; margin: 0 0 0 1em; }
#page-contents .pages h3 { font-size: 1.4rem; line-height: 160%; font-weight: bold; padding-bottom: 1em; margin-bottom: 1.5em; border-bottom: #D8D8D8 solid 1px; }
@media (min-width: 768px) { #page-contents .pages h3 { font-size: 1.8rem; } }
#page-contents .pages .link1 { margin: 60px 0 60px 0; }
@media (min-width: 768px) { #page-contents .pages .link1 { margin: 40px 0 40px 0; } }
#page-contents .pages .link1 li a { width: 70%; margin: 0 auto; }
@media (min-width: 768px) { #page-contents .pages .link1 li a { float: left; width: 225px; } }
#page-contents aside { display: none; }
@media (min-width: 768px) { #page-contents aside { display: block; width: 160px; float: right; }
  #page-contents aside h4 { font-family: 'Playfair Display',serif; font-weight: 400; font-size: 2.4rem; letter-spacing: 1px; border-bottom: #D1D1D1 solid 1px; padding-bottom: 10px; margin-bottom: 30px; }
  #page-contents aside ul { font-size: 1.6rem; line-height: 200%; letter-spacing: 1px; margin-bottom: 2em; }
  #page-contents aside ul li { padding: 5px 0; } }
@media (min-width: 992px) { #page-contents aside { width: 245px; float: right; } }

/* service */
#service-contents h3 { text-align: center; font-size: 2.1rem; font-weight: bold; margin-bottom: 60px; position: relative; }
@media (min-width: 768px) { #service-contents h3 { text-align: left; font-family: "Times New Roman", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "MS PMincho", "ＭＳ Ｐ明朝", "serif"; font-size: 3.2rem; margin-bottom: 90px; } }
#service-contents h3:before { display: block; position: absolute; background: #5F4B8B; content: ''; width: 85px; height: 1px; left: 50%; bottom: -15px; margin-left: -42.5px; }
@media (min-width: 768px) { #service-contents h3:before { background: #1F1F1F; width: 650px; left: 0px; bottom: -15px; margin-left: 0px; } }
#service-contents .service-box { margin-bottom: 40px; }
@media (min-width: 768px) { #service-contents .service-box { margin-bottom: 70px; display: flex; justify-content: space-between; } }
#service-contents .service-box h4 { width: 100%; padding: 15px 0; text-align: center; border: #1F1F1F solid 1px; font-size: 1.6rem; line-height: 100%; font-weight: bold; -webkit-border-radius: 3px; -moz-border-radius: 3px; border-radius: 3px; margin-bottom: 15px; transition: all 0.3s; }
@media (min-width: 768px) { #service-contents .service-box h4 { border: none; background: #1F1F1F; color: #FFF; font-size: 2.1rem; margin-bottom: 25px; } }
@media (min-width: 992px) { #service-contents .service-box h4 { font-size: 2.4rem; } }
#service-contents .service-box h5 { text-align: center; font-size: 1.6rem; font-weight: bold; line-height: 180%; margin-bottom: 15px; }
#service-contents .service-box h5 span { font-size: 1.4rem; }
@media (min-width: 992px) { #service-contents .service-box h5 span { font-size: 1.6rem; } }
@media (min-width: 768px) { #service-contents .service-box h5 { margin-bottom: 20px; } }
@media (min-width: 992px) { #service-contents .service-box h5 { font-size: 1.8rem; } }
#service-contents .service-box p { font-size: 1.4rem; line-height: 200%; margin-bottom: 15px; }
@media (min-width: 992px) { #service-contents .service-box p { font-size: 1.6rem; margin-bottom: 20px; } }
#service-contents .service-box ol { margin-left: 1.5em; }
#service-contents .service-box ol li { list-style: disc; font-size: 1.4rem; line-height: 160%; font-weight: bold; margin-bottom: 10px; }
@media (min-width: 992px) { #service-contents .service-box ol li { font-size: 1.6rem; } }
#service-contents .service-box img { width: 100%; height: auto; margin-bottom: 15px; }
#service-contents .service-box .deta { text-align: left; }
@media (min-width: 768px) { #service-contents .service-box .deta { width: 340px; } }
@media (min-width: 992px) { #service-contents .service-box .deta { width: 450px; } }
@media (min-width: 1200px) { #service-contents .service-box .deta { width: 510px; } }
#service-contents .service-box .img { width: 100%; transition: all 0.3s; }
@media (min-width: 768px) { #service-contents .service-box .img { width: 380px; } }
@media (min-width: 992px) { #service-contents .service-box .img { width: 480px; } }
#service-contents .service-box .img img { width: 100%; height: auto; }

/* company */
#company-contents h3 { text-align: center; font-size: 2.1rem; font-weight: bold; margin-bottom: 40px; position: relative; }
@media (min-width: 768px) { #company-contents h3 { text-align: left; font-family: "Times New Roman", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "MS PMincho", "ＭＳ Ｐ明朝", "serif"; font-size: 3.2rem; margin-bottom: 60px; } }
#company-contents h3:before { display: block; position: absolute; background: #5F4B8B; content: ''; width: 85px; height: 1px; left: 50%; bottom: -15px; margin-left: -42.5px; }
@media (min-width: 768px) { #company-contents h3:before { background: #1F1F1F; width: 650px; left: 0px; bottom: -15px; margin-left: 0px; } }
#company-contents table { width: 100%; border-collapse: collapse; }
#company-contents table tr.odd { background: none; }
@media (min-width: 768px) { #company-contents table tr.odd { background: #F0F4F6; } }
#company-contents table th { text-align: left; display: block; font-size: 1.4rem; line-height: 200%; background: #EEE4F4; padding: 0.5em 2em; }
@media (min-width: 768px) { #company-contents table th { background: none; display: table-cell; font-size: 1.8rem; font-weight: bold; padding: 15px 0 15px 8em; } }
#company-contents table td { text-align: left; display: block; font-size: 1.4rem; line-height: 200%; padding: 0.5em 2em; }
@media (min-width: 768px) { #company-contents table td { display: table-cell; font-size: 1.8rem; padding: 15px 0; } }
#company-contents h4 { text-align: left; font-size: 1.4rem; line-height: 200%; }
@media (min-width: 768px) { #company-contents h4 { font-size: 1.8rem; font-weight: bold; background: #F0F4F6; padding: 15px 0 15px 8em; margin-bottom: 1em; } }
#company-contents #map { border: #1F1F1F solid 1px; margin-bottom: 1em; }
#company-contents #map #map_basic { width: 100%; height: 320px !important; }
@media (min-width: 768px) { #company-contents #map #map_basic { height: 440px !important; } }

/* message */
@media (min-width: 768px) { #message { margin-top: -86px; padding-top: 86px; } }
#message .wrapper { margin: 90px auto 40px auto; }
@media (min-width: 768px) { #message .wrapper { margin: 120px auto 70px auto; } }
#message h3 { text-align: center; font-size: 2.1rem; font-weight: bold; margin-bottom: 40px; position: relative; }
@media (min-width: 768px) { #message h3 { text-align: left; font-family: "Times New Roman", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "MS PMincho", "ＭＳ Ｐ明朝", "serif"; font-size: 3.2rem; margin-bottom: 60px; } }
#message h3:before { display: block; position: absolute; background: #5F4B8B; content: ''; width: 85px; height: 1px; left: 50%; bottom: -15px; margin-left: -42.5px; }
@media (min-width: 768px) { #message h3:before { background: #1F1F1F; width: 650px; left: 0px; bottom: -15px; margin-left: 0px; } }
#message .message-box { text-align: left; }
@media (min-width: 768px) { #message .message-box { display: flex; justify-content: space-between; } }
#message .message-box .txt { width: 100%; margin-bottom: 20px; }
@media (min-width: 768px) { #message .message-box .txt { width: 350px; } }
@media (min-width: 992px) { #message .message-box .txt { width: 450px; } }
@media (min-width: 1200px) { #message .message-box .txt { width: 520px; } }
#message .message-box .txt p { font-size: 1.4rem; line-height: 200%; margin-bottom: 15px; }
@media (min-width: 992px) { #message .message-box .txt p { font-size: 1.6rem; margin-bottom: 20px; } }
#message .message-box .img { width: 100%; }
@media (min-width: 768px) { #message .message-box .img { width: 380px; } }
@media (min-width: 992px) { #message .message-box .img { width: 475px; } }
#message .message-box .img img { width: 100%; height: auto; }
#message .message-box .img p { text-align: left; font-size: 1.2rem; line-height: 180%; }
@media (min-width: 992px) { #message .message-box .img p { text-align: right; font-size: 1.4rem; } }

/* flow */
#flow-header { position: relative; padding-bottom: 40px; }
@media (min-width: 768px) { #flow-header { padding-bottom: 50px; } }
#flow-header:after { content: ""; position: absolute; right: 0; bottom: -25px; left: 0; width: 0px; height: 0px; margin: auto; border-style: solid; border-color: #FFF transparent transparent transparent; border-width: 25px 70px 0 70px; }
#flow-header h3 { text-align: left; font-size: 1.4rem; line-height: 200%; }
@media (min-width: 768px) { #flow-header h3 { display: inline-block; font-size: 1.8rem; line-height: 180%; font-weight: bold; } }

#flow-contents { background: #F1F1F1; }
#flow-contents ol { padding: 40px 0 15px 0; }
@media (min-width: 768px) { #flow-contents ol { padding: 50px 0 20px 0; } }
#flow-contents ol li { display: block; position: relative; box-sizing: border-box; text-align: left; width: 90%; margin: 0 auto 25px auto; padding: 25px 20px 50px 20px; background: #FFF; border: #AA97DE solid 1px; box-shadow: 0px 0px 9px 3px rgba(0, 0, 0, 0.16); -webkit-border-radius: 3px; -moz-border-radius: 3px; border-radius: 3px; }
@media (min-width: 768px) { #flow-contents ol li { width: 640px; margin: 0 auto 35px auto; padding: 30px 280px 65px 35px; min-height: 270px; }
  #flow-contents ol li.flow01 { background: #FFF url(../images/flow-img01.jpg) no-repeat top right; }
  #flow-contents ol li.flow02 { background: #FFF url(../images/flow-img02.jpg) no-repeat top right; }
  #flow-contents ol li.flow03 { background: #FFF url(../images/flow-img03.jpg) no-repeat top right; }
  #flow-contents ol li.flow04 { background: #FFF url(../images/flow-img04.jpg) no-repeat top right; }
  #flow-contents ol li.flow05 { background: #FFF url(../images/flow-img05.jpg) no-repeat top right; }
  #flow-contents ol li.flow06 { background: #FFF url(../images/flow-img06.jpg) no-repeat top right; } }
@media (min-width: 768px) and (min-width: 768px) { #flow-contents ol li.flow06 { min-height: 241px; } }

#flow-contents ol li:after { content: ""; position: absolute; right: 0; bottom: 10px; left: 0; width: 0px; height: 0px; margin: auto; border-style: solid; border-color: #93938E transparent transparent transparent; border-width: 12px 12px 0 12px; }
#flow-contents ol li.flow06:after { content: none; }
#flow-contents ol li h4 { font-size: 1.6rem; font-weight: bold; margin-bottom: 0.5em; }
@media (min-width: 768px) { #flow-contents ol li h4 { font-size: 2.1rem; margin-bottom: 20px; } }
#flow-contents ol li p { font-size: 1.4rem; line-height: 180%; margin-bottom: 15px; }
@media (min-width: 768px) { #flow-contents ol li p { font-size: 1.6rem; margin-bottom: 20px; line-height: 200%; } }
#flow-contents ol li ul li { display: inline; background: none; border: none; box-shadow: none; -webkit-border-radius: 0; -moz-border-radius: 0; border-radius: 0; }
@media (min-width: 768px) { #flow-contents ol li ul li { min-height: inherit; margin: 0 auto !important; } }
#flow-contents ol li ul li:after { content: none; }

/* works */
#works-contents { display: flex; justify-content: space-between; flex-wrap: wrap; }
#works-contents .works-list { width: calc((100% - 20px) / 2); }
@media (min-width: 992px) { #works-contents .works-list { width: calc((100% - 60px) / 3); } }
#works-contents .works-list a { text-decoration: none; }
#works-contents .works-list a img { transition: 0.3s; }
#works-contents .works-list a:hover img { opacity: 0.75; }
#works-contents .works-list .img { width: 100%; margin-bottom: 0.5em; }
#works-contents .works-list .img img { width: 100%; height: auto; }
#works-contents .works-list .title { font-size: 1.2rem; margin-bottom: 0.5em; }
@media (min-width: 992px) { #works-contents .works-list .title { font-size: 1.4rem; } }
#works-contents .works-list .icon { width: 100%; padding: 0.2em 0; margin: 0 0 40px 0; font-size: 1.0rem; background: #AA97DE; color: #FFF; }
@media (min-width: 992px) { #works-contents .works-list .icon { width: 50%; margin: 0 auto 60px auto; font-size: 1.2rem; } }

#works-contents::after { content: ""; display: block; width: calc((100% - 60px) / 3); }

@media (min-width: 992px) { #works-contents-data.wrapper { width: 780px; } }
@media (min-width: 1200px) { #works-contents-data.wrapper { width: 780px; } }
#works-contents-data .head { display: flex; justify-content: space-between; margin-bottom: 2em; }
#works-contents-data .head .title { font-size: 1.4rem; font-weight: bold; }
@media (min-width: 768px) { #works-contents-data .head .title { font-size: 2.1rem; } }
#works-contents-data .head .icon { width: 70px; padding: 0.2em 0; font-size: 1.0rem; background: #AA97DE; color: #FFF; }
@media (min-width: 992px) { #works-contents-data .head .icon { width: 165px; font-size: 1.2rem; } }
#works-contents-data .img { width: 100%; margin-bottom: 1.5em; }
#works-contents-data .img img { width: 100%; height: auto; }
#works-contents-data table { width: 100%; border-collapse: collapse; border-bottom: #1F1F1F solid 1px; border-top: #1F1F1F solid 1px; }
#works-contents-data table th { display: block; background: #F8F8F8; text-align: left; vertical-align: top; font-size: 1.4rem; line-height: 180%; font-weight: bold; white-space: nowrap; border-bottom: #8E8E8E dotted 1px; border-top: #8E8E8E dotted 1px; padding: 0.5em 1em; }
@media (min-width: 768px) { #works-contents-data table th { display: table-cell; font-size: 1.8rem; line-height: 200%; padding: 1em 2em; } }
#works-contents-data table td { display: block; text-align: left; font-size: 1.4rem; line-height: 180%; border-bottom: #8E8E8E dotted 1px; border-top: #8E8E8E dotted 1px; padding: 0.5em 1em; }
@media (min-width: 768px) { #works-contents-data table td { display: table-cell; font-size: 1.8rem; line-height: 200%; padding: 1em 2em; } }
#works-contents-data .link1 { margin: 60px 0 60px 0; }
@media (min-width: 768px) { #works-contents-data .link1 { margin: 40px 0 40px 0; } }
#works-contents-data .link1 li a { width: 70%; margin: 0 auto; }
@media (min-width: 768px) { #works-contents-data .link1 li a { width: 225px; } }

/* contact */
#contact-contents { padding-bottom: 60px; }
@media (min-width: 768px) { #contact-contents { padding-bottom: 90px; } }
@media (min-width: 992px) { #contact-contents.wrapper { width: 780px; } }
@media (min-width: 1200px) { #contact-contents.wrapper { width: 780px; } }
#contact-contents .txt-red { color: red; }
#contact-contents p { text-align: left; font-size: 1.4rem; line-height: 200%; margin-bottom: 20px; }
@media (min-width: 992px) { #contact-contents p { display: inline-block; font-size: 1.6rem; margin-bottom: 40px; } }
#contact-contents table { width: 100%; border-collapse: collapse; }
#contact-contents table th { text-align: left; display: block; font-size: 1.4rem; line-height: 120%; font-weight: bold; padding: 0.5em 0 0 0; }
@media (min-width: 768px) { #contact-contents table th { background: none; display: table-cell; font-size: 1.8rem; padding: 15px 0 15px 0; } }
#contact-contents table td { text-align: left; display: block; font-size: 1.4rem; line-height: 200%; padding: 0.5em 0 1.5em 0; }
@media (min-width: 768px) { #contact-contents table td { display: table-cell; font-size: 1.8rem; padding: 15px 0; } }
#contact-contents table td input, #contact-contents table td textarea { width: 100%; border: #C3C3C3 solid 1px; -webkit-border-radius: 3px; -moz-border-radius: 3px; border-radius: 3px; background: #FCFCFC; font-size: 1.4rem; line-height: 160%; }
@media (min-width: 768px) { #contact-contents table td input, #contact-contents table td textarea { font-size: 1.6rem; line-height: 200%; } }
#contact-contents table td input:focus, #contact-contents table td textarea:focus { background: #F8E3FC; }
#contact-contents table td input { height: 50px; }
#contact-contents table td textarea { height: 155px; }
#contact-contents #box-info-bt { margin-top: calc(20px - 1em); }
@media (min-width: 768px) { #contact-contents #box-info-bt { margin-top: 40px; } }
#contact-contents #box-info-bt input { width: 100%; font-size: 1.6rem; text-decoration: none; text-align: center; padding: 15px 0 15px 0; margin: 1em 0; color: #fff; background-color: #5F4B8B; border: none; -webkit-border-radius: 3px; -moz-border-radius: 3px; border-radius: 3px; transition-property: all; transition: 0.3s linear; }
@media (min-width: 768px) { #contact-contents #box-info-bt input { width: 320px; margin: 0 1em; cursor: pointer; } }
#contact-contents #box-info-bt input:hover { background-color: #6F34F1; text-decoration: none; }
