@charset "UTF-8";
/* Scss Document */
html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video { margin: 0; padding: 0; border: 0; outline: 0; font-size: 100%; vertical-align: baseline; background: transparent; }

html { font-size: 62.5%; }

body { line-height: 1; }

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section { display: block; }

ul { list-style: none; }

blockquote, q { quotes: none; }

blockquote:before, blockquote:after, q:before, q:after { content: ''; content: none; }

a { margin: 0; padding: 0; font-size: 100%; vertical-align: baseline; background: transparent; }

/* change colours to suit your needs */
ins { background-color: #ff9; color: #000; text-decoration: none; }

/* change colours to suit your needs */
mark { background-color: #ff9; color: #000; font-style: italic; font-weight: bold; }

del { text-decoration: line-through; }

abbr[title], dfn[title] { border-bottom: 1px dotted; cursor: help; }

table { border-collapse: collapse; border-spacing: 0; }

/* change border colour to suit your needs */
hr { display: block; height: 1px; border: 0; border-top: 1px solid #cccccc; margin: 1em 0; padding: 0; }

input, select { vertical-align: middle; }

/* Scss Document */
/* Scss Document */
/* アニメーション記述用 */
@keyframes headerFixed { 0% { transform: translateY(-80px); }
  100% { transform: translateY(0px); } }
@keyframes loop { 0% { transform: translateX(100%); }
  to { transform: translateX(-100%); } }
@keyframes loop2 { 0% { transform: translateX(0); }
  to { transform: translateX(-200%); } }
/* Scss Document */
body { box-sizing: border-box; line-height: 1.7333333333; text-align: justify; font-size: 1.3rem; color: #2E2E2E; font-family: "Yu Gothic Pr6N B", "游ゴシック体 Pr6N B", "YuGothic", "ヒラギノ角ゴ Pro W3", "Meiryo", sans-serif; word-wrap: break-word; font-weight: bold; }
@media (min-width: 769px) { body { font-size: calc( 1.3rem + ( 1vw - 7.69px ) * 0.3913894325 ); } }
@media (min-width: 1280px) { body { font-size: 1.5rem; } }

.t_center { text-align: center; }

.t_left { text-align: left; }

.t_right { text-align: right; }

.sp { display: inherit; }
@media screen and (min-width: 769px) { .sp { display: none; } }
@media screen and (min-width: 1181px) { .sp { display: none; } }

.tab { display: none; }
@media screen and (min-width: 769px) { .tab { display: inherit; } }
@media screen and (min-width: 1181px) { .tab { display: none; } }

.sp_tab { display: inherit; }
@media screen and (min-width: 769px) { .sp_tab { display: inherit; } }
@media screen and (min-width: 1181px) { .sp_tab { display: none; } }

.pc_tab { display: none; }
@media screen and (min-width: 769px) { .pc_tab { display: inherit; } }
@media screen and (min-width: 1181px) { .pc_tab { display: inherit; } }

.pc { display: none; }
@media screen and (min-width: 769px) { .pc { display: none; } }
@media screen and (min-width: 1181px) { .pc { display: inherit; } }

a, button { text-decoration: none; color: inherit; transition: .4s; }

button { background-color: transparent; border: none; cursor: pointer; outline: none; padding: 0; appearance: none; }

img { width: 100%; vertical-align: bottom; }

.s-inner { box-sizing: border-box; width: 100%; max-width: 800px; margin: auto; padding: 0 4%; }
@media screen and (min-width: 961px) { .s-inner { padding: 0 2%; } }
@media screen and (min-width: 1181px) { .s-inner { padding: 0; } }

.m-inner { box-sizing: border-box; width: 100%; max-width: 1000px; margin: auto; padding: 0 4%; padding: 0 8%; }
@media screen and (min-width: 961px) { .m-inner { padding: 0 2%; } }
@media screen and (min-width: 1181px) { .m-inner { padding: 0; } }

.l-inner { box-sizing: border-box; width: 100%; max-width: 1160px; margin: auto; padding: 0 4%; }
@media screen and (min-width: 961px) { .l-inner { padding: 0 2%; } }
@media screen and (min-width: 1181px) { .l-inner { padding: 0; } }

@media screen and (min-width: 1181px) { .s-inner { padding: 0; }
  .m-inner { padding: 0; } }
h2 { font-size: 2rem; letter-spacing: 0.02em; text-align: center; }
@media (min-width: 769px) { h2 { font-size: calc( 2rem + ( 1vw - 7.69px ) * 4.3052837573 ); } }
@media (min-width: 1280px) { h2 { font-size: 4.2rem; } }

h3 { font-size: 2rem; letter-spacing: 0.02em; text-align: center; }
@media (min-width: 769px) { h3 { font-size: calc( 2rem + ( 1vw - 7.69px ) * 1.9569471624 ); } }
@media (min-width: 1280px) { h3 { font-size: 3rem; } }

p { font-size: 100%; }

::selection { background: #b0d0ec; color: #fff; }

.en { font-family: "Raleway", sans-serif; letter-spacing: normal; }

a:hover { opacity: 0.8; }

.icon { margin-right: 5px; }

.flex_wrap { display: -webkit-box; display: -webkit-flex; display: -ms-flexbox; display: flex; -webkit-box-orient: horizontal; -webkit-box-direction: normal; -webkit-flex-flow: row wrap; -ms-flex-flow: row wrap; flex-flow: row wrap; -webkit-align-content: flex-start; -ms-flex-line-pack: start; align-content: flex-start; -webkit-box-pack: justify; -webkit-justify-content: space-between; -ms-flex-pack: justify; justify-content: space-between; }
.flex_wrap > * { flex: 0 1 48%; width: 48%; max-width: 48%; }

.box { margin-bottom: 11.6666666667%; }
@media screen and (max-width: 769px) { .box { margin-bottom: 70px; } }
@media screen and (min-width: 1200px) { .box { margin-bottom: 140px; } }

.cap { position: absolute; left: 5px; bottom: 5px; z-index: 1; font-size: 1rem; letter-spacing: normal; line-height: 1; }

.attent { color: #ccc; font-size: 1rem; letter-spacing: normal; }

.title { margin-bottom: 25px; text-align: center; }
.title .title__en { font-size: 2rem; font-family: "Raleway", sans-serif; letter-spacing: 2px; }
.title .maintitle__yomi { font-size: 1.3rem; color: #737373; }

.btn a { position: relative; display: block; margin: auto; padding: 15px 0; width: 100%; max-width: 330px; text-align: center; letter-spacing: 0.1em; font-size: 1.4rem; color: #fff; background: #2E2E2E; border: solid 1px #2E2E2E; }
.btn a::before { position: absolute; content: ""; top: 45%; right: 20px; width: 6px; height: 6px; border-top: solid 1px; border-right: solid 1px; border-color: #fff; transform: rotate(45deg) translate(0, -50%); }

/*------------------------------
		769px以上
------------------------------*/
@media screen and (min-width: 769px) { .btn a::before { right: 25px; }
  .btn a:hover { color: #2E2E2E; background: #fff; opacity: 1; }
  .btn a:hover::before { border-color: #2E2E2E; }
  .title { margin-bottom: 40px; } }
/* Scss Document */
.header { position: fixed; z-index: 1000; left: 0; top: 0; width: 100%; }
.header__wrap { position: relative; height: 90px; }
.header__logo { display: -webkit-box; display: -webkit-flex; display: -ms-flexbox; display: flex; -webkit-box-orient: horizontal; -webkit-box-direction: normal; -webkit-flex-flow: row wrap; -ms-flex-flow: row wrap; flex-flow: row wrap; -webkit-align-content: flex-start; -ms-flex-line-pack: start; align-content: flex-start; -webkit-box-pack: justify; -webkit-justify-content: space-between; -ms-flex-pack: justify; justify-content: space-between; -webkit-box-align: center; -webkit-align-items: center; -ms-flex-align: center; align-items: center; position: absolute; width: 100%; top: 50%; transform: translateY(-50%); top: 55%; left: 5%; width: 60%; max-width: 260px; }
.header__logo-img { flex: 0 1 23%; width: 23%; max-width: 23%; }
.header__logo-img-on { display: none; }
.header__title { flex: 0 1 72%; width: 72%; max-width: 72%; color: #fff; }
.header__title-jn { font-size: 1.2rem; }
@media (min-width: 769px) { .header__title-jn { font-size: calc( 1.2rem + ( 1vw - 7.69px ) * 0.5115089514 ); } }
@media (min-width: 1160px) { .header__title-jn { font-size: 1.4rem; } }
.header__title-en { font-size: 1.1rem; }
@media (min-width: 769px) { .header__title-en { font-size: calc( 1.1rem + ( 1vw - 7.69px ) * 0.5115089514 ); } }
@media (min-width: 1160px) { .header__title-en { font-size: 1.3rem; } }
.header__menu-btn { position: absolute; width: 100%; top: 50%; transform: translateY(-50%); right: 6%; width: 40px; height: 30px; z-index: 999; }
.header__menu-btn span { display: block; position: absolute; width: 100%; height: 2px; border-radius: 4px; background: #fff; transition: .3s; }
.header__menu-btn span:first-child { top: 0; }
.header__menu-btn span:nth-child(2) { top: 15px; left: 9px; }
.header__menu-btn span:last-child { bottom: 0; }
.header__menu-nav { display: none; position: relative; width: 100%; height: calc(100vh - 0px); background: rgba(255, 255, 255, 0.9); }
.header__menu-nav-wrap { box-sizing: border-box; position: absolute; width: 100%; top: 50%; transform: translateY(-50%); top: 45%; padding: 0 15%; }
.header__menu-nav ul li { margin-bottom: 30px; }
.header__menu-nav a { display: block; }
.header__menu-nav a span { display: block; text-align: right; line-height: 1.5; letter-spacing: 1.5px; }
.header__menu-nav a .jp { font-size: 1.2rem; font-weight: bold; font-family: "Raleway", sans-serif; }
.header__menu-nav a .en { font-size: 1.8rem; font-weight: bold; font-family: "Raleway", sans-serif; }
@media (min-width: 769px) { .header__menu-nav a .en { font-size: calc( 1.8rem + ( 1vw - 7.69px ) * -0.2557544757 ); } }
@media (min-width: 1160px) { .header__menu-nav a .en { font-size: 1.7rem; } }
.header__menu-nav .active { color: #fff; }
.header__contact { position: absolute; right: 0; max-width: 360px; width: 100%; padding: 20px; box-sizing: border-box; background: #2E2E2E; color: #fff; font-weight: bold; text-align: center; }
.header__contact-wrap { max-width: 280px; }
.header__contact .header__tel { font-family: "Roboto", sans-serif; line-height: 1.3; }
.header__contact .header__tel span { font-size: 3rem; display: inline-block; background: rgba(255, 255, 255, 0); }
@media (min-width: 769px) { .header__contact .header__tel span { font-size: calc( 3rem + ( 1vw - 7.69px ) * -1.1741682975 ); } }
@media (min-width: 1280px) { .header__contact .header__tel span { font-size: 2.4rem; } }
.header__contact .header__tel i { margin-right: 5%; font-size: 2.5rem; transform: scale(-1, 1); }
@media (min-width: 769px) { .header__contact .header__tel i { font-size: calc( 2.5rem + ( 1vw - 7.69px ) * -0.9784735812 ); } }
@media (min-width: 1280px) { .header__contact .header__tel i { font-size: 2rem; } }
.header__contact .header__contact-txt { margin-bottom: 5px; font-size: 1.4rem; letter-spacing: -0.1px; }
@media (min-width: 769px) { .header__contact .header__contact-txt { font-size: calc( 1.4rem + ( 1vw - 7.69px ) * -0.5870841487 ); } }
@media (min-width: 1280px) { .header__contact .header__contact-txt { font-size: 1.1rem; } }
.header__contact .mail-box a { width: 100%; padding: 10px; box-sizing: border-box; background: #fff; color: #2E2E2E; border: solid 1px #2E2E2E; font-size: 1.4rem; }
@media (min-width: 769px) { .header__contact .mail-box a { font-size: calc( 1.4rem + ( 1vw - 7.69px ) * -0.1956947162 ); } }
@media (min-width: 1280px) { .header__contact .mail-box a { font-size: 1.3rem; } }
.header__contact .mail-box a i { margin-right: 3%; font-size: 2rem; vertical-align: middle; }
.header__contact .mail-box a:hover { opacity: 1; color: #fff; background: #2E2E2E; border: solid 1px #fff; }

.on { background: rgba(255, 255, 255, 0.9) !important; }
.on .header__logo { top: 48%; }
.on .header__logo .header__logo-img { display: none; }
.on .header__logo .header__logo-img-on { display: block; flex: 0 1 25%; width: 25%; max-width: 25%; }
.on .header__title { color: #737373; }
.on .header__menu-btn span { background: #2E2E2E; }
.on .header__menu-nav { overflow: scroll; }
.on .header__menu-nav .active { color: #737373; }

.open .header__menu-btn { background: #2E2E2E; height: 65px; width: 65px; }
.open .header__menu-btn span { width: 60%; left: 20%; background: #fff; }
.open .header__menu-btn span:first-child { top: 32px; transform: rotate(-145deg); }
.open .header__menu-btn span:nth-child(2) { opacity: 0; }
.open .header__menu-btn span:last-child { bottom: 31px; transform: rotate(145deg); }
.open .header__menu-nav .active { color: #2E2E2E; }

/*------------------------------
		769px以上
------------------------------*/
/*------------------------------
		1181px以上
------------------------------*/
@media screen and (min-width: 1181px) { .header__wrap { height: 130px; }
  .header__logo { left: 3%; }
  .header__logo-img { flex: 0 1 29%; width: 29%; max-width: 29%; }
  .header__title { flex: 0 1 67%; width: 67%; max-width: 67%; }
  .header__menu-btn { display: none; }
  .header__menu-nav { display: block !important; position: static; height: auto; padding: 0; background: none; }
  .header__menu-nav-wrap { position: static; transform: none; }
  .header__menu-nav ul { position: absolute; width: 100%; top: 50%; left: 50%; transform: translate(-50%, -50%); left: 52%; width: 50%; max-width: 600px; display: -webkit-box; display: -webkit-flex; display: -ms-flexbox; display: flex; -webkit-box-orient: horizontal; -webkit-box-direction: normal; -webkit-flex-flow: row wrap; -ms-flex-flow: row wrap; flex-flow: row wrap; -webkit-align-content: flex-start; -ms-flex-line-pack: start; align-content: flex-start; -webkit-box-pack: justify; -webkit-justify-content: space-between; -ms-flex-pack: justify; justify-content: space-between; margin: 0; }
  .header__menu-nav ul li { flex: 0 1 auto; width: auto; max-width: auto; margin-bottom: 0px; }
  .header__menu-nav ul li a { padding: 0; }
  .header__menu-nav ul li a span { text-align: center; }
  .header__contact { max-width: 260px; padding: 17px 20px; }
  .on { animation: headerFixed .8s ease 0s 1 alternate; }
  .on .header__wrap { height: 100px; }
  .on .header__logo-img .cls-1 { fill: #000; } }
/*------------------------------
		961px以上
------------------------------*/
/*------------------------------
		1400px以上
------------------------------*/
@media screen and (min-width: 1350px) { .header__contact { right: 5%; }
  .on .header__contact { right: 0; } }
/*------------------------------
		1600px以上
------------------------------*/
/* Scss Document */
.footer { padding: 0 8%; background: #fff; font-size: 1.4rem; font-weight: bold; box-sizing: border-box; }
.footer #gotop { position: fixed; z-index: 1000; right: 10px; bottom: 10px; width: 50px; height: 50px; background: #2E2E2E; color: #fff; }
.footer #gotop span { position: absolute; width: 100%; top: 50%; left: 50%; transform: translate(-50%, -50%); top: 70%; font-size: 1.2rem; font-family: "Raleway", sans-serif; letter-spacing: 1.2px; }
.footer #gotop:after { display: block; content: ''; position: absolute; left: 50%; top: 40%; transform: translate(-50%, -50%) rotate(45deg); width: 10px; height: 10px; border-top: 2px solid; border-left: 2px solid; color: #fff; }
.footer__wrap { max-width: 1300px; width: 100%; margin: auto; box-sizing: border-box; }
.footer__wrap .footer__txt { margin-bottom: 15px; }
.footer__wrap .footer__txt .footer__txt-main { font-size: 1.5rem; }
@media (min-width: 769px) { .footer__wrap .footer__txt .footer__txt-main { font-size: calc( 1.5rem + ( 1vw - 7.69px ) * 0.5870841487 ); } }
@media (min-width: 1280px) { .footer__wrap .footer__txt .footer__txt-main { font-size: 1.8rem; } }
.footer__wrap .footer__txt .footer__txt-sub { font-size: 1.3rem; }
@media (min-width: 769px) { .footer__wrap .footer__txt .footer__txt-sub { font-size: calc( 1.3rem + ( 1vw - 7.69px ) * 0.3913894325 ); } }
@media (min-width: 1280px) { .footer__wrap .footer__txt .footer__txt-sub { font-size: 1.5rem; } }
.footer__wrap .footer__txt .footer__info { margin-bottom: 5px; line-height: 1.5; }
.footer__logo { max-width: 180px !important; width: 40%; margin: auto; padding: 25px 0; }
.footer__nav { display: -webkit-box; display: -webkit-flex; display: -ms-flexbox; display: flex; -webkit-box-orient: horizontal; -webkit-box-direction: normal; -webkit-flex-flow: row wrap; -ms-flex-flow: row wrap; flex-flow: row wrap; -webkit-align-content: flex-start; -ms-flex-line-pack: start; align-content: flex-start; -webkit-box-pack: justify; -webkit-justify-content: space-between; -ms-flex-pack: justify; justify-content: space-between; -webkit-box-pack: start; -webkit-justify-content: flex-start; -ms-flex-pack: start; justify-content: flex-start; padding: 20px 0; border-top: 1px solid #DBDBDB; border-bottom: 1px solid #DBDBDB; }
.footer__nav li { display: inline-block; position: relative; flex: 0 1 50%; width: 50%; max-width: 50%; margin-bottom: 20px; }
.footer__nav li a { display: block; }
.footer__nav li:after { content: ""; width: 5px; height: 5px; border-top: 1px solid #2E2E2E; border-right: 1px solid #2E2E2E; position: absolute; top: 0; bottom: 0; margin: auto; right: 15%; transform: rotate(45deg); }
.footer__nav li:last-child { margin-bottom: 0; }
.footer__sub-nav { margin-bottom: 30px; }
.footer__sub-nav li a { display: block; padding: 15px; border-bottom: 1px solid; font-size: 1.3rem; text-align: center; position: relative; }
.footer__sub-nav li a:after { content: ''; position: absolute; width: 4px; height: 4px; border-top: 1px solid; border-right: 1px solid; top: 50%; transform: rotate(45deg) translate(0%, -50%); margin-left: 10px; }
.footer .copyright { padding: 20px 0; color: #737373; font-size: 1.2rem; text-align: center; }

/*------------------------------
		769px以上
------------------------------*/
@media screen and (min-width: 769px) { .footer { padding: 4% 0; }
  .footer__wrap { display: -webkit-box; display: -webkit-flex; display: -ms-flexbox; display: flex; -webkit-box-orient: horizontal; -webkit-box-direction: normal; -webkit-flex-flow: row wrap; -ms-flex-flow: row wrap; flex-flow: row wrap; -webkit-align-content: flex-start; -ms-flex-line-pack: start; align-content: flex-start; -webkit-box-pack: justify; -webkit-justify-content: space-between; -ms-flex-pack: justify; justify-content: space-between; -webkit-box-align: center; -webkit-align-items: center; -ms-flex-align: center; align-items: center; padding: 0 4%; }
  .footer__logo { flex: 0 1 20%; width: 20%; max-width: 20%; margin: auto; }
  .footer__box { flex: 0 1 50%; width: 50%; max-width: 50%; }
  .footer nav { flex: 0 1 100%; width: 100%; max-width: 100%; padding: 20px 0 0; }
  .footer__nav { max-width: 800px; margin: auto; padding: 0; border: none; }
  .footer__nav li { flex: 0 1 33%; width: 33%; max-width: 33%; text-align: center; }
  .footer__nav li a { display: inline-block; position: relative; }
  .footer__nav li a:after { content: ""; width: 5px; height: 5px; border-top: 1px solid #2E2E2E; border-right: 1px solid #2E2E2E; position: absolute; top: 0; bottom: 0; margin: auto; right: -20px; transform: rotate(45deg); }
  .footer__nav li:after { content: none; }
  .footer__nav li:last-child { margin-bottom: 20px; }
  .footer__sub-nav { display: -webkit-box; display: -webkit-flex; display: -ms-flexbox; display: flex; -webkit-box-orient: horizontal; -webkit-box-direction: normal; -webkit-flex-flow: row wrap; -ms-flex-flow: row wrap; flex-flow: row wrap; -webkit-align-content: flex-start; -ms-flex-line-pack: start; align-content: flex-start; -webkit-box-pack: justify; -webkit-justify-content: space-between; -ms-flex-pack: justify; justify-content: space-between; }
  .footer__sub-nav li a { border-bottom: none; }
  .footer .copyright { padding: 0; text-align: center; } }
/*------------------------------
		961px以上
------------------------------*/
@media screen and (min-width: 961px) { .footer { padding: 6% 0; }
  .footer__wrap { -webkit-box-align: end; -webkit-align-items: flex-end; -ms-flex-align: end; align-items: flex-end; }
  .footer__wrap .footer__txt { margin-bottom: 30px; }
  .footer__wrap .footer__txt:last-child { margin-bottom: 0; }
  .footer__sub-nav { margin-bottom: 0; }
  .footer__logo { flex: 0 1 12%; width: 12%; max-width: 12%; margin: 0; padding: 0; }
  .footer__box { flex: 0 1 30%; width: 30%; max-width: 30%; }
  .footer nav { flex: 0 1 45%; width: 45%; max-width: 45%; }
  .footer__nav li { text-align: left; }
  .footer__name { flex: 0 1 30%; width: 30%; max-width: 30%; text-align: left; }
  .footer__name p { text-align: left; }
  .footer__name img { margin: 0 0 10px 0; }
  .footer .copyright { text-align: left; } }
/*------------------------------
		1181px以上
------------------------------*/
/*------------------------------
		1600px以上
------------------------------*/
.contact { background: url(/img/common/bg_contact_sp.png) center bottom/cover no-repeat; padding: 10% 0%; }
.contact .contact__title { margin-bottom: 30px; color: #fff; text-align: center; }
.contact .contact__title .contact__title-sub { font-size: 3rem; letter-spacing: 3px; }
@media (min-width: 769px) { .contact .contact__title .contact__title-sub { font-size: calc( 3rem + ( 1vw - 7.69px ) * 1.9569471624 ); } }
@media (min-width: 1280px) { .contact .contact__title .contact__title-sub { font-size: 4rem; } }
.contact .contact__title .contact__title-main { font-size: 1.5rem; }
.contact .contact__wrap .contact__box { background: #fff; margin-bottom: 10px; padding: 20px 7%; box-sizing: border-box; text-align: center; }
.contact .contact__wrap .contact__box-title { position: relative; margin-bottom: 2%; padding: 0 0 5px; font-size: 1.5rem; }
.contact .contact__wrap .contact__box-title:after { content: ""; display: block; position: absolute; width: 100%; left: 50%; transform: translateX(-50%); top: 100%; height: 1px; background: #DBDBDB; }
.contact .contact__wrap .contact__telnum a { font-size: 3.5rem; font-family: "Roboto", sans-serif; }
.contact .contact__wrap .contact__mail { font-size: 2.4rem; font-family: "Roboto", sans-serif; }
.contact .contact__wrap i { font-size: 2.5rem; margin-right: 3%; transform: scale(-1, 1); }
.contact .contact__wrap .contact__txt { font-size: 1.3rem; font-family: "Yu Gothic Pr6N B", "游ゴシック体 Pr6N B", "YuGothic", "ヒラギノ角ゴ Pro W3", "Meiryo", sans-serif; font-weight: bold; }

.titleimg { position: relative; margin-bottom: 30px; height: 20vh; max-height: 200px; }
.titleimg .titleimg__wrap { position: absolute; top: 50%; left: 50%; width: 100%; text-align: center; font-weight: bold; color: #fff; transform: translate(-50%, -50%); z-index: 2; }
.titleimg .titleimg__wrap .titleimg__en-ttl { font-size: 2.4rem; letter-spacing: 0.1em; }
@media (min-width: 769px) { .titleimg .titleimg__wrap .titleimg__en-ttl { font-size: calc( 2.4rem + ( 1vw - 7.69px ) * 2.5974025974 ); } }
@media (min-width: 1000px) { .titleimg .titleimg__wrap .titleimg__en-ttl { font-size: 3rem; } }
.titleimg .titleimg__wrap .titleimg__ttl { font-size: 1.4rem; }
@media (min-width: 769px) { .titleimg .titleimg__wrap .titleimg__ttl { font-size: calc( 1.4rem + ( 1vw - 7.69px ) * 0.8658008658 ); } }
@media (min-width: 1000px) { .titleimg .titleimg__wrap .titleimg__ttl { font-size: 1.6rem; } }
.titleimg::before { position: absolute; content: ""; display: block; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0, 0, 0, 0.25); z-index: 1; }

/*------------------------------
		769px以上
------------------------------*/
@media screen and (min-width: 769px) { .contact { padding: 5% 0%; background: url(/img/common/bg_contact_pc.png) center bottom/cover no-repeat; }
  .contact .contact__wrap { display: -webkit-box; display: -webkit-flex; display: -ms-flexbox; display: flex; -webkit-box-orient: horizontal; -webkit-box-direction: normal; -webkit-flex-flow: row wrap; -ms-flex-flow: row wrap; flex-flow: row wrap; -webkit-align-content: flex-start; -ms-flex-line-pack: start; align-content: flex-start; -webkit-box-pack: justify; -webkit-justify-content: space-between; -ms-flex-pack: justify; justify-content: space-between; }
  .contact .contact__wrap .contact__box { flex: 0 1 48.5%; width: 48.5%; max-width: 48.5%; padding: 3.3%; }
  .contact .contact__wrap .contact__box-title:after { width: 70%; }
  .titleimg { margin-bottom: 50px; height: 30vh; max-height: 220px; } }
/*------------------------------
		961px以上
------------------------------*/
/*------------------------------
		1181px以上
------------------------------*/
/*------------------------------
		1600px以上
------------------------------*/
/* Scss Document */
.form-group { display: -webkit-box; display: -webkit-flex; display: -ms-flexbox; display: flex; -webkit-box-orient: horizontal; -webkit-box-direction: normal; -webkit-flex-flow: row wrap; -ms-flex-flow: row wrap; flex-flow: row wrap; -webkit-align-content: flex-start; -ms-flex-line-pack: start; align-content: flex-start; -webkit-box-pack: justify; -webkit-justify-content: space-between; -ms-flex-pack: justify; justify-content: space-between; margin-bottom: 50px; }
.form-group.error { background: #ffe7df; }
.form-group .form-title { flex: 0 1 20%; width: 20%; max-width: 20%; font-size: 1.4rem; font-weight: bold; }
@media (min-width: 768px) { .form-group .form-title { font-size: calc( 1.4rem + ( 1vw - 7.68px ) * 0.462962963 ); } }
@media (min-width: 1200px) { .form-group .form-title { font-size: 1.6rem; } }
.form-group .txt { flex: 0 1 70%; width: 70%; max-width: 70%; }
.form-group .txt .form-control { box-sizing: border-box; padding: 10px; width: 100%; }
.form-group .txt .form-control.datepicker { max-width: 160px; }
.form-group .txt span { display: block; }
.form-group .txt .datepicer_box { position: relative; }

select { padding: 6px 12px 6px 6px; font-size: 1.3rem; border: 1px solid #aaa; border-radius: 2px; background: transparent; }

textarea { resize: vertical; min-height: 80px; }

.form_label { vertical-align: middle; margin: 5px 12px 5px 0; cursor: pointer; }
.form_label input[type=radio] { display: none; }
.form_label input[type=radio] + .radio-parts { position: relative; padding-left: 26px; }
.form_label input[type=radio] + .radio-parts:before { content: ''; display: block; box-sizing: border-box; position: absolute; top: 2px; left: 2px; width: 16px; height: 16px; border: 1px solid #aaa; border-radius: 50%; }
.form_label input[type=radio] + .radio-parts:after { content: ''; display: none; box-sizing: border-box; position: absolute; top: 6px; left: 6px; width: 8px; height: 8px; background: #2E2E2E; border-radius: 50%; }
.form_label input[type=radio]:checked + .radio-parts { color: #2E2E2E; }
.form_label input[type=radio]:checked + .radio-parts:before { border-color: #2E2E2E; }
.form_label input[type=radio]:checked + .radio-parts:after { display: block; }
.form_label input[type=checkbox] { display: none; }
.form_label input[type=checkbox] + .checkbox-parts { position: relative; padding-left: 26px; }
.form_label input[type=checkbox] + .checkbox-parts:before { content: ''; display: block; box-sizing: border-box; position: absolute; top: 3px; left: 3px; width: 14px; height: 14px; border: 1px solid #aaa; border-radius: 3px; }
.form_label input[type=checkbox] + .checkbox-parts:after { content: ''; display: none; box-sizing: border-box; position: absolute; top: 0; left: 1px; width: 18px; height: 10px; border-left: 2px solid #2E2E2E; border-bottom: 2px solid #2E2E2E; transform: rotate(-50deg); }
.form_label input[type=checkbox]:checked + .checkbox-parts { color: #2E2E2E; }
.form_label input[type=checkbox]:checked + .checkbox-parts:after { display: block; }

.required { display: inline-block; vertical-align: middle; margin: 0 6px; padding: 3px; line-height: 1; font-weight: normal; font-size: 1.0rem; color: #fff; background: #2E2E2E; border-radius: 2px; }

.attention { margin: 3px 0; font-size: 1.2rem; letter-spacing: normal; color: #666; }
.attention:before { content: '※'; }
.attention.option-color_red { color: #FF5722; }

.ui-datepicker-trigger { display: none; }

#ui-datepicker-div { z-index: 991 !important; width: auto; font-family: inherit; border-radius: 0; top: 100% !important; left: 0 !important; }
#ui-datepicker-div .ui-datepicker-header { height: 40px; border: none; background: transparent; }
#ui-datepicker-div .ui-datepicker-header .ui-datepicker-title { height: 40px; line-height: 40px; margin: 0 40px; }
#ui-datepicker-div .ui-datepicker-header .ui-datepicker-next, #ui-datepicker-div .ui-datepicker-header .ui-datepicker-prev { width: 40px; height: 40px; }
#ui-datepicker-div .ui-datepicker-header .ui-datepicker-next.ui-state-hover, #ui-datepicker-div .ui-datepicker-header .ui-datepicker-prev.ui-state-hover { border: none; background: transparent; }
#ui-datepicker-div .ui-datepicker-header .ui-datepicker-next span, #ui-datepicker-div .ui-datepicker-header .ui-datepicker-prev span { position: absolute; top: 50%; display: block; width: 10px; height: 10px; margin: 0; border-top: 1px solid #333; border-left: 1px solid #333; background: transparent; }
#ui-datepicker-div .ui-datepicker-header .ui-datepicker-next span { right: 50%; transform: rotate(135deg) translateY(50%); }
#ui-datepicker-div .ui-datepicker-header .ui-datepicker-prev span { left: 50%; transform: rotate(-45deg) translateY(-50%); }
#ui-datepicker-div .ui-datepicker-header .ui-datepicker-next-hover { top: 2px; right: 2px; }
#ui-datepicker-div .ui-datepicker-header .ui-datepicker-prev-hover { top: 2px; left: 2px; }
#ui-datepicker-div .ui-datepicker-header .ui-datepicker-year { width: auto; margin-right: 3px; font-family: inherit; font-size: 1.3rem; }
#ui-datepicker-div .ui-datepicker-header .ui-datepicker-month { width: auto; margin-left: 6px; font-family: inherit; font-size: 1.3rem; }
#ui-datepicker-div .ui-datepicker-calendar { font-size: 1.1rem; }
#ui-datepicker-div .ui-datepicker-calendar th { width: 40px; height: 40px; padding: 0; font-size: 1.1rem; line-height: 40px; font-weight: 200; }
#ui-datepicker-div .ui-datepicker-calendar td { width: 40px; height: 40px; padding: 0; line-height: 40px; }
#ui-datepicker-div .ui-datepicker-calendar td.ui-state-disabled { background: #ddd; }
#ui-datepicker-div .ui-datepicker-calendar td.ui-datepicker-other-month { background: transparent; }
#ui-datepicker-div .ui-datepicker-calendar td.ui-datepicker-current-day, #ui-datepicker-div .ui-datepicker-calendar td:hover { background: #2E2E2E; }
#ui-datepicker-div .ui-datepicker-calendar td.ui-datepicker-current-day a, #ui-datepicker-div .ui-datepicker-calendar td:hover a { color: #fff; }
#ui-datepicker-div .ui-datepicker-calendar td a { color: #2E2E2E; }
#ui-datepicker-div .ui-datepicker-calendar td a, #ui-datepicker-div .ui-datepicker-calendar td span { padding: 0; text-align: center; border: none; background: transparent; }

.state_message { margin-bottom: 60px; text-align: center; }
.state_message p { height: 40px; line-height: 40px; text-align: center; font-size: 1.6rem; color: #fff; background: #5bb75b; }
.state_message p.class-ng { background: #2E2E2E; }

/*------------------------------
		980px以上
------------------------------*/
/*------------------------------
		1280px以上
------------------------------*/

/*# sourceMappingURL=common.css.map */
