@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 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: #000; font-family: Futo Go B101, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif"; word-wrap: break-word; font-weight: bold; letter-spacing: 3px; }
@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: 1280px) { .sp { display: none; } }

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

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

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

.pc { display: none; }
@media screen and (min-width: 769px) { .pc { display: none; } }
@media screen and (min-width: 1280px) { .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: 1000px; margin: auto; padding: 0 4%; }
@media screen and (min-width: 961px) { .s-inner { padding: 0 2%; } }
@media screen and (min-width: 1280px) { .s-inner { padding: 0; } }

.m-inner { box-sizing: border-box; width: 100%; max-width: 1280px; margin: auto; padding: 0 4%; }
@media screen and (min-width: 961px) { .m-inner { padding: 0 2%; } }
@media screen and (min-width: 1280px) { .m-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: "Atkinson Hyperlegible", 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: 30px; text-align: center; }
.title .title__jp { margin-bottom: 5px; font-size: 1.4rem; }
@media (min-width: 769px) { .title .title__jp { font-size: calc( 1.4rem + ( 1vw - 7.69px ) * 2.9354207436 ); } }
@media (min-width: 1280px) { .title .title__jp { font-size: 2.9rem; } }
.title .title__en { margin-bottom: 10px; font-size: 3rem; font-weight: normal; letter-spacing: 8px; line-height: 1; }
@media (min-width: 769px) { .title .title__en { font-size: calc( 3rem + ( 1vw - 7.69px ) * 5.8708414873 ); } }
@media (min-width: 1280px) { .title .title__en { font-size: 6rem; } }

.btn a { position: relative; display: block; margin: auto; padding: 10px 0; width: 100%; max-width: 250px; border-radius: 30px; text-align: center; letter-spacing: 0.1em; font-size: 1.4rem; color: #7a909c; background: #fff; }

/*------------------------------
		769px以上
------------------------------*/
@media screen and (min-width: 769px) { .btn a:hover { color: #fff; background: #7a909c; 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__logo-img { display: none; }
.header__wrap { position: relative; height: 80px; }
.header__login { position: fixed; left: 50%; transform: translate(-50%, -50%); bottom: -20px; 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; max-width: 800px; width: 100%; margin-bottom: 10px !important; padding: 0 4%; box-sizing: border-box; }
.header__login .btn { flex: 0 1 49%; width: 49%; max-width: 49%; }
.header__login .btn a { display: inline-block; background: #ff9d00; border-bottom: none; color: #fff; font-size: 1.4rem; }
@media (min-width: 769px) { .header__login .btn a { font-size: calc( 1.4rem + ( 1vw - 7.69px ) * -0.1956947162 ); } }
@media (min-width: 1280px) { .header__login .btn a { font-size: 1.3rem; } }
.header__menu-txt { position: absolute; font-size: 1.1rem; color: #fff; letter-spacing: 1px; }
.header__menu-btn { position: absolute; width: 100%; top: 50%; transform: translateY(-50%); right: 5%; width: 40px; height: 45px; z-index: 999; }
.header__menu-btn-wrap { position: absolute; height: 23px; width: 40px; }
.header__menu-btn-wrap span { display: block; position: absolute; width: 100%; height: 2px; border-radius: 4px; background: #fff; transition: .3s; }
.header__menu-btn-wrap span:first-child { top: 0; }
.header__menu-btn-wrap span:nth-child(2) { top: 0; bottom: 0; margin: auto; }
.header__menu-btn-wrap span:last-child { width: 80%; right: 0; bottom: 0; }
.header__menu-btn p { position: absolute; top: 35px; left: 50%; transform: translateY(-50%) translateX(-50%); color: #fff; font-size: 1.2rem; letter-spacing: 1px; line-height: 1; }
.header__menu-nav { display: none; position: relative; width: 100%; height: calc(100vh - 0px); background: #fff; }
.header__menu-nav-wrap { box-sizing: border-box; position: absolute; width: 100%; top: 50%; transform: translateY(-50%); top: 50%; padding: 0 15%; }
.header__menu-nav ul li { margin-bottom: 20px; }
.header__menu-nav ul li:nth-child(5n) { margin-bottom: 35px; }
.header__menu-nav ul .header__menu-logo { display: inline-block; width: 30px; margin-right: 3px; }
.header__menu-nav a { display: inline-block; border-bottom: 2px solid #000; }
.header__menu-nav a span { display: block; line-height: 1.5; letter-spacing: 1.5px; }
.header__menu-nav a .jp { font-size: 1.4rem; }
.header__menu-nav a .en { margin-bottom: 5px; font-size: 2rem; font-family: "Atkinson Hyperlegible", sans-serif; letter-spacing: 5px; }
@media (min-width: 769px) { .header__menu-nav a .en { font-size: calc( 2rem + ( 1vw - 7.69px ) * 0.1956947162 ); } }
@media (min-width: 1280px) { .header__menu-nav a .en { font-size: 2.1rem; } }
.header__btn .btn { margin-bottom: 10px; }
.header__btn .btn a { background: #7a909c; color: #fff; border-bottom: none; }

.on { background: #fff; }
.on .header__menu-btn span { background: #000; }
.on .header__menu-btn p { color: #000; }
.on .header__logo-img { display: block; position: absolute; width: 100%; top: 50%; transform: translateY(-50%); left: 5%; max-width: 150px; width: 100%; }
.on .header__title { color: #737373; }

.open .header__login { display: none; }
.open .header__menu-btn { height: 30px; }
.open .header__menu-btn-wrap { height: 25px; }
.open .header__menu-btn span { background: #000; }
.open .header__menu-btn span:first-child { top: 14px; transform: rotate(-135deg); }
.open .header__menu-btn span:nth-child(2) { opacity: 0; }
.open .header__menu-btn span:last-child { width: 100%; bottom: 9px; transform: rotate(135deg); }
.open .header__menu-btn p { display: none; }
.open .header__menu-nav .active { color: #000; }

/*------------------------------
		769px以上
------------------------------*/
@media screen and (min-width: 769px) { .header__login .btn a { max-width: 400px; }
  .header__menu-btn { right: 3%; } }
/*------------------------------
		1181px以上
------------------------------*/
@media screen and (min-width: 1280px) { .header__wrap { height: 130px; }
  .header__login { position: static; transform: none; margin-bottom: 0 !important; }
  .header__login .btn { flex: 0 1 100%; width: 100%; max-width: 100%; margin-bottom: 5px; }
  .header__login .btn:last-child { margin-bottom: 0; }
  .header__login .btn a { padding: 5px 0; border: 1px solid #ff9d00; }
  .header__login .btn a:before { content: none; }
  .header__login .btn a:hover { background: #fff; color: #ff9d00; border: 1px solid #ff9d00; }
  .header__menu-btn { display: none; }
  .header__menu-nav { display: block; 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%); top: 100%; width: 80%; max-width: 1200px; 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; margin: 0; background: rgba(255, 255, 255, 0.9); border-radius: 10px; box-sizing: border-box; padding: 30px 40px; }
  .header__menu-nav ul li { flex: 0 1 auto; width: auto; max-width: auto; margin-bottom: 0px; padding: 0; }
  .header__menu-nav ul li:nth-child(5n) { margin-bottom: 0; }
  .header__menu-nav ul li a { position: relative; cursor: pointer; padding: 0; border-bottom: none; }
  .header__menu-nav ul li a:before { content: ""; position: absolute; left: 0; right: 0; bottom: 0; width: 100%; height: 2px; background: #000; transform: scale(0, 1); transform-origin: center; transition: transform .2s; }
  .header__menu-nav ul li a:hover:before { transform: scale(1); }
  .header__menu-nav ul li a span { text-align: center; }
  .header__menu-nav ul .header__login { max-width: 100%; height: auto; min-width: 150px; }
  .on .header__logo-img { left: 2%; max-width: 160px; }
  .on .header__wrap { height: 100px; }
  .on .header__menu-nav ul { padding: 0; background: none; top: 50%; left: 57%; } }
/*------------------------------
		961px以上
------------------------------*/
/*------------------------------
		1600px以上
------------------------------*/
/* Scss Document */
.footer { padding: 50px 6%; background: #b9c5ca; box-sizing: border-box; }
.footer #gotop { position: fixed; z-index: 999; right: 10px; bottom: 80px; width: 50px; height: 50px; background: #000; 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: "Atkinson Hyperlegible", 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 .footer__img { margin-bottom: 20px; }
.footer__wrap .footer__title { margin-bottom: 10px; font-size: 2rem; text-align: left; }
@media (min-width: 769px) { .footer__wrap .footer__title { font-size: calc( 2rem + ( 1vw - 7.69px ) * 1.9569471624 ); } }
@media (min-width: 1280px) { .footer__wrap .footer__title { font-size: 3rem; } }
.footer__wrap .footer__list { margin-bottom: 20px; }
.footer__wrap .footer__list-box { 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__wrap .footer__list-main { flex: 0 1 auto; width: auto; max-width: auto; }
.footer__wrap .footer__list-sub { flex: 0 1 80%; width: 80%; max-width: 80%; }
.footer__btn .btn { margin-bottom: 10px; }
.footer .copyright { padding: 20px 0; font-size: 1.2rem; text-align: center; }

/*------------------------------
		769px以上
------------------------------*/
@media screen and (min-width: 769px) { .footer { padding: 4% 0 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; }
  .footer__wrap .footer__img { flex: 0 1 40%; width: 40%; max-width: 40%; }
  .footer__wrap .footer__box { flex: 0 1 55%; width: 55%; max-width: 55%; }
  .footer__btn { 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__btn .btn { flex: 0 1 48%; width: 48%; max-width: 48%; }
  .footer__btn .btn a { max-width: 300px; } }
/*------------------------------
		961px以上
------------------------------*/
@media screen and (min-width: 961px) { .footer__wrap .footer__list-sub { flex: 0 1 90%; width: 90%; max-width: 90%; }
  .footer__wrap .footer__box { flex: 0 1 50%; width: 50%; max-width: 50%; } }
/*------------------------------
		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: #000; }
.contact .contact__wrap .contact__mail { font-size: 2.4rem; font-family: #000; }
.contact .contact__wrap i { font-size: 2.5rem; margin-right: 5%; transform: scale(-1, 1); }
.contact .contact__wrap .contact__txt { font-size: 1.3rem; font-weight: bold; }

.titleimg { position: relative; margin-bottom: 30px; height: 14vh; max-height: 140px; }
.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: 80px; 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: #000; border-radius: 50%; }
.form_label input[type=radio]:checked + .radio-parts { color: #000; }
.form_label input[type=radio]:checked + .radio-parts:before { border-color: #000; }
.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 #000; border-bottom: 2px solid #000; transform: rotate(-50deg); }
.form_label input[type=checkbox]:checked + .checkbox-parts { color: #000; }
.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: #000; 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: #000; }
#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: #000; }
#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: #000; }

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

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