﻿body,
* {
    outline: none !important
}

* {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    -ms-box-sizing: border-box;
    -o-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-tap-highlight-color: transparent;
    -moz-tap-highlight-color: transparent
}

html {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    -ms-box-sizing: border-box;
    -o-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-touch-callout: none;
    font-size: 100%;
    overflow-x: hidden
}

body {
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -ms-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
    background-color: #fff;
    background-attachment: fixed;
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    color: #000;
    margin: 0;
    position: relative;
    width: 100%
}

button {
    border: none;
    cursor: pointer
}

ul {
    margin: 0;
    padding: 0
}

a {
    color: inherit;
    text-decoration: none
}

a:active,
a:focus {
    color: inherit;
    cursor: pointer;
    font-family: inherit;
    text-decoration: none !important
}

.hoverable a:hover {
    color: inherit;
    cursor: pointer;
    font-family: inherit;
    text-decoration: none !important;
    cursor: pointer
}

legend {
    color: #000
}

ol,
ul {
    list-style: none
}

* {
    text-decoration: none
}

caption,
th {
    text-align: left
}

sup {
    vertical-align: text-top
}

img {
    display: block;
    border: none !important
}

sub {
    vertical-align: text-bottom
}

input,
textarea,
select {
    *font-size: 100%
}

a {
    color: inherit;
    text-decoration: none
}

textarea {
    outline: none;
    resize: none
}

abbr,
acronym {
    border: 0;
    font-variant: normal
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-size: 100%;
    font-weight: normal
}

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

fieldset,
img {
    border: 0
}

input,
textarea,
select {
    font-family: inherit;
    font-size: inherit;
    font-weight: inherit
}

address,
caption,
cite,
code,
dfn,
th,
var {
    font-style: normal;
    font-weight: normal
}

q:before,
q:after {
    content: ''
}

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

html,
body,
div,
dl,
dt,
dd,
ul,
ol,
li,
h1,
h2,
h3,
h4,
h5,
h6,
pre,
code,
form,
fieldset,
legend,
input,
textarea,
p,
a,
blockquote,
figure {
    margin: 0;
    padding: 0
}

/*! normalize.css v8.0.0 | MIT License | github.com/necolas/normalize.css */
html {
    line-height: 1.15;
    -webkit-text-size-adjust: 100%
}

body {
    margin: 0
}

h1 {
    font-size: 2em;
    margin: 0.67em 0
}

hr {
    box-sizing: content-box;
    height: 0;
    overflow: visible
}

pre {
    font-family: monospace, monospace;
    font-size: 1em
}

a {
    background-color: transparent
}

abbr[title] {
    border-bottom: none;
    text-decoration: underline;
    text-decoration: underline dotted
}

b,
strong {
    font-weight: bolder
}

code,
kbd,
samp {
    font-family: monospace, monospace;
    font-size: 1em
}

small {
    font-size: 80%
}

sub,
sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline
}

sub {
    bottom: -0.25em
}

sup {
    top: -0.5em
}

img {
    border-style: none
}

button,
input,
optgroup,
select,
textarea {
    font-family: inherit;
    font-size: 100%;
    line-height: 1.15;
    margin: 0
}

button,
input {
    overflow: visible
}

button,
select {
    text-transform: none
}

button,
[type="button"],
[type="reset"],
[type="submit"] {
    -webkit-appearance: button
}

button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
    border-style: none;
    padding: 0
}

button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
    outline: 1px dotted ButtonText
}

fieldset {
    padding: 0.35em 0.75em 0.625em
}

legend {
    box-sizing: border-box;
    color: inherit;
    display: table;
    max-width: 100%;
    padding: 0;
    white-space: normal
}

progress {
    vertical-align: baseline
}

textarea {
    overflow: auto
}

[type="checkbox"],
[type="radio"] {
    box-sizing: border-box;
    padding: 0
}

[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
    height: auto
}

[type="search"] {
    -webkit-appearance: textfield;
    outline-offset: -2px
}

[type="search"]::-webkit-search-decoration {
    -webkit-appearance: none
}

::-webkit-file-upload-button {
    -webkit-appearance: button;
    font: inherit
}

details {
    display: block
}

summary {
    display: list-item
}

template {
    display: none
}

[hidden] {
    display: none
}

@keyframes slideDown {
    0% {
        opacity: 0;
        transform: translateY(-30px)
    }
}

body {
    font-family: "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
    overflow: hidden
}

@media only screen and (max-width: 64em) {
    body {
        top: 0px
    }
}

@media only screen and (max-width: 61.25em) {
    body {
        top: 0px
    }
}

@media only screen and (max-width: 47.9375em) {
    body {
        top: 0
    }
}

.wrapper {
    display: block;
    margin: 0 auto;
    padding: 0;
    position: relative;
    width: 1040px
}

@media only screen and (max-width: 64em) {
    .wrapper {
        width: 100%;
        overflow: hidden
    }
}

@media only screen and (max-width: 47.9375em) {
    .wrapper {
        width: 100%;
        overflow: hidden
    }
}

@font-face {
    font-family: 'Spainter';
    src: url(../fonts/signpainter_housescript_regular-webfont.woff2) format("woff2"), url(../fonts/signpainter_housescript_regular-webfont.woff) format("woff"), url(../fonts/signpainter_housescript_regular-webfont.ttf) format("truetype")
}

.btn {
    transition: .3s
}

.btn-primary {
    background-color: #cc5a5a;
    border-bottom: 4px solid #9f4646;
    color: #fff
}

.btn-primary:hover {
    opacity: .8
}

.btn-secondary {
    background-color: #41aea2;
    border-bottom: 4px solid #2a7169;
    color: #fff
}

.btn-secondary:hover {
    opacity: .8
}

.btn-tertiary {
    background-color: #f6b656;
    border-bottom: 4px solid #da953e;
    color: #fff
}

.btn-tertiary:hover {
    opacity: .8
}

.btn-inverted {
    border: 1px solid #a7a8aa;
    border-radius: 4px
}

.btn-inverted:hover {
    opacity: .8
}

#header {
    background-color: #fbfcff;
    display: block;
    height: 250px;
    padding: 0;
    position: relative;
    z-index: 99999;
    width: 100%
}

@media only screen and (max-width: 64em) {
    #header {
        position: relative;
        height: 150px;
        padding: 0px 0
    }
}

@media only screen and (max-width: 61.25em) {
    #header {
        position: relative;
        height: 150px;
        padding: 0px 0
    }
}

@media only screen and (max-width: 47.9375em) {
    #header {
        position: relative;
        height: 60px;
        padding: 0px 0
    }
}

#header .wrapper {
    width: 1150px
}

@media only screen and (max-width: 64em) {
    #header .wrapper {
        width: 100%
    }
}

@media only screen and (max-width: 61.25em) {
    #header .wrapper {
        width: 100%
    }
}

@media only screen and (max-width: 47.9375em) {
    #header .wrapper {
        width: 100%
    }
}

#header .header-contents {
    display: block;
    margin: 0 0;
    overflow: hidden;
    padding: 0;
    position: relative;
    width: 1150px
}

@media only screen and (max-width: 64em) {
    #header .header-contents {
        margin: 0 auto;
        width: 100%;
        padding: 0 10px
    }
}

@media only screen and (max-width: 61.25em) {
    #header .header-contents {
        margin: 0 auto;
        width: 100%;
        padding: 0 15px
    }
}

@media only screen and (max-width: 47.9375em) {
    #header .header-contents {
        margin: 0 auto;
        width: 100%;
        padding: 0 15px
    }
}

#header .header-contents .header-left {
    display: inline-block;
    float: left;
    margin: 65px 0 0;
    width: 250px
}

@media only screen and (max-width: 64em) {
    #header .header-contents .header-left {
        float: left;
        margin: 15px 0 0;
        padding: 15px 0 0 5px;
        width: max-content
    }
}

@media only screen and (max-width: 61.25em) {
    #header .header-contents .header-left {
        float: left;
        margin: 15px 0 0;
        padding: 15px 0 0 5px;
        width: max-content
    }
}

@media only screen and (max-width: 47.9375em) {
    #header .header-contents .header-left {
        float: left;
        margin: 0 0 0;
        padding: 15px 0 0 5px;
        width: max-content
    }
}

#header .header-contents .header-left .h-logo {
    display: block;
    float: left;
    overflow: hidden;
    padding: 0px 0 0 0px;
    transition: .3s;
    width: max-content
}

@media only screen and (max-width: 64em) {
    #header .header-contents .header-left .h-logo {
        float: left;
        margin: 5px 0 0 0px;
        padding: 5px 0 0 0px;
        width: max-content
    }
}

@media only screen and (max-width: 61.25em) {
    #header .header-contents .header-left .h-logo {
        float: left;
        margin: 5px 0 0 0px;
        padding: 5px 0 0 0px;
        width: max-content
    }
}

@media only screen and (max-width: 47.9375em) {
    #header .header-contents .header-left .h-logo {
        float: left;
        margin: 5px 0 0 0px;
        padding: 5px 0 0 0px;
        width: max-content
    }
}

#header .header-contents .header-left .h-logo:hover {
    opacity: .8
}

#header .header-contents .header-left .h-logo h1 {
    display: block;
    font-size: 0;
    margin: 0 auto
}

#header .header-contents .header-left .h-logo a {
    display: block;
    font-size: 0;
    margin: 0 auto
}

#header .header-contents .header-left .h-logo a img {
    display: block;
    float: left;
    width: 190px
}

@media only screen and (max-width: 64em) {
    #header .header-contents .header-left .h-logo a img {
        height: auto;
        width: 115px
    }
}

@media only screen and (max-width: 61.25em) {
    #header .header-contents .header-left .h-logo a img {
        height: auto;
        width: 115px
    }
}

@media only screen and (max-width: 47.9375em) {
    #header .header-contents .header-left .h-logo a img {
        height: auto;
        width: 115px
    }
}

#header .header-contents .header-right {
    display: inline-block;
    float: right;
    margin: 40px 0 0;
    width: max-content
}

@media only screen and (max-width: 64em) {
    #header .header-contents .header-right {
        margin: 15px 0 0
    }
}

@media only screen and (max-width: 47.9375em) {
    #header .header-contents .header-right {
        margin: 0 0 0
    }
}

#header .header-contents .header-right .telnum {
    display: inline-block;
    float: left;
    margin: 0px 0 0
}

@media only screen and (max-width: 64em) {
    #header .header-contents .header-right .telnum {
        display: block;
        margin: 0 20px 0 0
    }
}

@media only screen and (max-width: 61.25em) {
    #header .header-contents .header-right .telnum {
        display: block;
        margin: 0 20px 0 0
    }
}

@media only screen and (max-width: 47.9375em) {
    #header .header-contents .header-right .telnum {
        display: none
    }
}

#header .header-contents .header-right .telnum .telnum-item {
    display: block;
    font-size: 23px;
    font-weight: bold;
    line-height: 100%;
    padding: 0 0 0 23px;
    position: relative;
    text-align: center;
    transition: .5s
}

#header .header-contents .header-right .telnum .telnum-item:hover {
    opacity: .6
}

#header .header-contents .header-right .telnum .telnum-item::before {
    background: url("../images/common/telnum_icon.png");
    background-size: 100%;
    background-repeat: no-repeat;
    content: "";
    display: block;
    height: 19px;
    left: 0px;
    position: absolute;
    top: 23px;
    width: 17px
}

#header .header-contents .header-right .telnum .telnum-item b {
    display: block;
    font-size: 12px;
    margin: 0 0 0px
}

#header .header-contents .header-right .telnum .telnum-item span {
    display: block;
    font-size: 12px;
    font-weight: normal
}

#header .header-contents .header-right .telnum-sp {
    display: none;
    float: right;
    margin: 20px 6px 0 0;
    width: 20px
}

@media only screen and (max-width: 64em) {
    #header .header-contents .header-right .telnum-sp {
        display: none;
        width: 18px
    }
}

@media only screen and (max-width: 61.25em) {
    #header .header-contents .header-right .telnum-sp {
        display: none;
        width: 18px
    }
}

@media only screen and (max-width: 47.9375em) {
    #header .header-contents .header-right .telnum-sp {
        display: block;
        width: 18px
    }
}

#header .header-contents .header-right .telnum-sp img {
    width: 100%
}

#header .header-contents .header-right .mail {
    background: url("../images/mail_bg.png");
    background-size: 100%;
    background-repeat: no-repeat;
    border-radius: 15px;
    display: table;
    float: left;
    height: 40px;
    margin: 10px 0 0 30px;
    transition: .5s;
    width: 180px
}

@media only screen and (max-width: 64em) {
    #header .header-contents .header-right .mail {
        height: 30px;
        float: right;
        margin: 15px 0 0 0;
        width: 150px
    }
}

@media only screen and (max-width: 61.25em) {
    #header .header-contents .header-right .mail {
        height: 30px;
        float: right;
        margin: 15px 0 0 0;
        width: 150px
    }
}

@media only screen and (max-width: 47.9375em) {
    #header .header-contents .header-right .mail {
        height: 30px;
        float: right;
        margin: 15px 0 0 0;
        width: 150px
    }
}

#header .header-contents .header-right .mail:hover {
    opacity: .8
}

#header .header-contents .header-right .mail .mail-item {
    color: #fff;
    display: table-cell;
    font-size: 12px;
    font-weight: bold;
    line-height: 120%;
    padding: 0 0 0 30px;
    position: relative;
    text-align: center;
    vertical-align: middle
}

@media only screen and (max-width: 64em) {
    #header .header-contents .header-right .mail .mail-item {
        font-size: 9px;
        padding: 0 0 0 20px
    }
}

@media only screen and (max-width: 61.25em) {
    #header .header-contents .header-right .mail .mail-item {
        font-size: 9px;
        padding: 0 0 0 20px
    }
}

@media only screen and (max-width: 47.9375em) {
    #header .header-contents .header-right .mail .mail-item {
        font-size: 9px;
        padding: 0 0 0 20px
    }
}

#header .header-contents .header-right .mail .mail-item::before {
    background: url("../images/common/mail_icon.png");
    background-size: 100%;
    background-repeat: no-repeat;
    content: "";
    display: block;
    height: 14px;
    left: 15px;
    position: absolute;
    top: 13px;
    width: 20px
}

@media only screen and (max-width: 64em) {
    #header .header-contents .header-right .mail .mail-item::before {
        left: 13px;
        top: 9px;
        width: 16px
    }
}

@media only screen and (max-width: 61.25em) {
    #header .header-contents .header-right .mail .mail-item::before {
        left: 13px;
        top: 9px;
        width: 16px
    }
}

@media only screen and (max-width: 47.9375em) {
    #header .header-contents .header-right .mail .mail-item::before {
        left: 13px;
        top: 9px;
        width: 16px
    }
}

#header .header-contents .hamburger {
    display: none;
    float: right
}

@media only screen and (max-width: 47.9375em) {
    #header .header-contents .hamburger {
        display: block
    }
}

#header-bottom {
    background-color: #fbfcff;
    display: block;
    height: 105px;
    padding: 0;
    position: relative;
    z-index: 99999;
    width: 100%
}

@media only screen and (max-width: 64em) {
    #header-bottom {
        position: fixed;
        height: 100px;
        padding: 0px 0
    }
}

@media only screen and (max-width: 61.25em) {
    #header-bottom {
        position: relative;
        height: 100px;
        padding: 0px 0
    }
}

@media only screen and (max-width: 47.9375em) {
    #header-bottom {
        position: relative;
        height: 60px;
        padding: 0px 0
    }
}

#header-bottom .wrapper {
    width: 1150px
}

@media only screen and (max-width: 64em) {
    #header-bottom .wrapper {
        width: 100%
    }
}

@media only screen and (max-width: 61.25em) {
    #header-bottom .wrapper {
        width: 100%
    }
}

@media only screen and (max-width: 47.9375em) {
    #header-bottom .wrapper {
        width: 100%
    }
}

#header-bottom .header-contents {
    display: block;
    margin: 0 0;
    overflow: hidden;
    padding: 0;
    position: relative;
    width: 1150px
}

@media only screen and (max-width: 64em) {
    #header-bottom .header-contents {
        margin: 0 auto;
        width: 100%;
        padding: 0 10px
    }
}

@media only screen and (max-width: 61.25em) {
    #header-bottom .header-contents {
        margin: 0 auto;
        width: 100%;
        padding: 0 15px
    }
}

@media only screen and (max-width: 47.9375em) {
    #header-bottom .header-contents {
        margin: 0 auto;
        width: 100%;
        padding: 0 15px
    }
}

#header-bottom .header-contents .header-left {
    display: inline-block;
    float: left;
    margin: 40px 0 0;
    width: 250px
}

@media only screen and (max-width: 64em) {
    #header-bottom .header-contents .header-left {
        float: left;
        padding: 0 0 0 5px;
        width: max-content
    }
}

@media only screen and (max-width: 61.25em) {
    #header-bottom .header-contents .header-left {
        float: left;
        margin: 30px 0 0;
        padding: 0 0 0 5px;
        width: max-content
    }
}

@media only screen and (max-width: 47.9375em) {
    #header-bottom .header-contents .header-left {
        float: left;
        margin: 0 0 0;
        padding: 15px 0 0 5px;
        width: max-content
    }
}

#header-bottom .header-contents .header-left .h-logo {
    display: block;
    float: left;
    overflow: hidden;
    padding: 0px 0 0 0px;
    transition: .3s;
    width: max-content
}

@media only screen and (max-width: 64em) {
    #header-bottom .header-contents .header-left .h-logo {
        float: left;
        margin: 5px 0 0 0px;
        padding: 5px 0 0 0px;
        width: max-content
    }
}

@media only screen and (max-width: 61.25em) {
    #header-bottom .header-contents .header-left .h-logo {
        float: left;
        margin: 5px 0 0 0px;
        padding: 5px 0 0 0px;
        width: max-content
    }
}

@media only screen and (max-width: 47.9375em) {
    #header-bottom .header-contents .header-left .h-logo {
        float: left;
        margin: 5px 0 0 0px;
        padding: 5px 0 0 0px;
        width: max-content
    }
}

#header-bottom .header-contents .header-left .h-logo:hover {
    opacity: .8
}

#header-bottom .header-contents .header-left .h-logo h1 {
    display: block;
    font-size: 0;
    margin: 0 auto
}

#header-bottom .header-contents .header-left .h-logo a {
    display: block;
    font-size: 0;
    margin: 0 auto
}

#header-bottom .header-contents .header-left .h-logo a img {
    display: block;
    float: left;
    width: 190px
}

@media only screen and (max-width: 64em) {
    #header-bottom .header-contents .header-left .h-logo a img {
        height: auto;
        width: 115px
    }
}

@media only screen and (max-width: 61.25em) {
    #header-bottom .header-contents .header-left .h-logo a img {
        height: auto;
        width: 115px
    }
}

@media only screen and (max-width: 47.9375em) {
    #header-bottom .header-contents .header-left .h-logo a img {
        height: auto;
        width: 115px
    }
}

#header-bottom .header-contents .header-right {
    display: inline-block;
    float: right;
    margin: 20px 0 0;
    width: max-content
}

@media only screen and (max-width: 47.9375em) {
    #header-bottom .header-contents .header-right {
        margin: 0 0 0
    }
}

#header-bottom .header-contents .header-right .telnum {
    display: inline-block;
    float: left;
    margin: 0px 0 0
}

@media only screen and (max-width: 64em) {
    #header-bottom .header-contents .header-right .telnum {
        display: block;
        margin: 0 20px 0 0
    }
}

@media only screen and (max-width: 61.25em) {
    #header-bottom .header-contents .header-right .telnum {
        display: block;
        margin: 0 20px 0 0
    }
}

@media only screen and (max-width: 47.9375em) {
    #header-bottom .header-contents .header-right .telnum {
        display: none
    }
}

#header-bottom .header-contents .header-right .telnum .telnum-item {
    display: block;
    font-size: 23px;
    font-weight: bold;
    line-height: 100%;
    padding: 0 0 0 23px;
    position: relative;
    text-align: center;
    transition: .5s
}

#header-bottom .header-contents .header-right .telnum .telnum-item:hover {
    opacity: .6
}

#header-bottom .header-contents .header-right .telnum .telnum-item::before {
    background: url("../images/common/telnum_icon.png");
    background-size: 100%;
    background-repeat: no-repeat;
    content: "";
    display: block;
    height: 19px;
    left: 0px;
    position: absolute;
    top: 23px;
    width: 17px
}

#header-bottom .header-contents .header-right .telnum .telnum-item b {
    display: block;
    font-size: 12px;
    margin: 0 0 0px
}

#header-bottom .header-contents .header-right .telnum .telnum-item span {
    display: block;
    font-size: 12px;
    font-weight: normal
}

#header-bottom .header-contents .header-right .telnum-sp {
    display: none;
    float: right;
    margin: 20px 6px 0 0;
    width: 20px
}

@media only screen and (max-width: 64em) {
    #header-bottom .header-contents .header-right .telnum-sp {
        display: none;
        width: 18px
    }
}

@media only screen and (max-width: 61.25em) {
    #header-bottom .header-contents .header-right .telnum-sp {
        display: none;
        width: 18px
    }
}

@media only screen and (max-width: 47.9375em) {
    #header-bottom .header-contents .header-right .telnum-sp {
        display: block;
        width: 18px
    }
}

#header-bottom .header-contents .header-right .telnum-sp img {
    width: 100%
}

#header-bottom .header-contents .header-right .mail {
    background: url("../images/mail_bg.png");
    background-size: 100%;
    background-repeat: no-repeat;
    border-radius: 15px;
    display: table;
    float: left;
    height: 40px;
    margin: 10px 0 0 30px;
    transition: .5s;
    width: 180px
}

@media only screen and (max-width: 64em) {
    #header-bottom .header-contents .header-right .mail {
        height: 30px;
        float: right;
        margin: 15px 0 0 0;
        width: 150px
    }
}

@media only screen and (max-width: 61.25em) {
    #header-bottom .header-contents .header-right .mail {
        height: 30px;
        float: right;
        margin: 15px 0 0 0;
        width: 150px
    }
}

@media only screen and (max-width: 47.9375em) {
    #header-bottom .header-contents .header-right .mail {
        height: 30px;
        float: right;
        margin: 15px 0 0 0;
        width: 150px
    }
}

#header-bottom .header-contents .header-right .mail:hover {
    opacity: .8
}

#header-bottom .header-contents .header-right .mail .mail-item {
    color: #fff;
    display: table-cell;
    font-size: 12px;
    font-weight: bold;
    line-height: 120%;
    padding: 0 0 0 30px;
    position: relative;
    text-align: center;
    vertical-align: middle
}

@media only screen and (max-width: 64em) {
    #header-bottom .header-contents .header-right .mail .mail-item {
        font-size: 9px;
        padding: 0 0 0 20px
    }
}

@media only screen and (max-width: 61.25em) {
    #header-bottom .header-contents .header-right .mail .mail-item {
        font-size: 9px;
        padding: 0 0 0 20px
    }
}

@media only screen and (max-width: 47.9375em) {
    #header-bottom .header-contents .header-right .mail .mail-item {
        font-size: 9px;
        padding: 0 0 0 20px
    }
}

#header-bottom .header-contents .header-right .mail .mail-item::before {
    background: url("../images/common/mail_icon.png");
    background-size: 100%;
    background-repeat: no-repeat;
    content: "";
    display: block;
    height: 14px;
    left: 15px;
    position: absolute;
    top: 13px;
    width: 20px
}

@media only screen and (max-width: 64em) {
    #header-bottom .header-contents .header-right .mail .mail-item::before {
        left: 13px;
        top: 9px;
        width: 16px
    }
}

@media only screen and (max-width: 61.25em) {
    #header-bottom .header-contents .header-right .mail .mail-item::before {
        left: 13px;
        top: 9px;
        width: 16px
    }
}

@media only screen and (max-width: 47.9375em) {
    #header-bottom .header-contents .header-right .mail .mail-item::before {
        left: 13px;
        top: 9px;
        width: 16px
    }
}

#header-bottom .header-contents .hamburger {
    display: none;
    float: right
}

@media only screen and (max-width: 47.9375em) {
    #header-bottom .header-contents .hamburger {
        display: block
    }
}

#banner .slider-top .slider-cover {
    display: block;
    margin: 0px 0 0;
    overflow: hidden;
    padding: 0;
    position: relative;
    width: 100%
}

@media only screen and (max-width: 64em) {
    #banner .slider-top .slider-cover {
        height: auto;
        margin: 0px 0 0
    }
}

@media only screen and (max-width: 56.25em) {
    #banner .slider-top .slider-cover {
        height: auto;
        margin: 0px 0 0
    }
}

@media only screen and (max-width: 47.9375em) {
    #banner .slider-top .slider-cover {
        height: auto;
        margin: 0px 0 0
    }
}

#banner .slider-top .slider-cover img {
    display: block;
    width: 100%
}

#banner .slider-top .slider-cover img.banner-pc {
    display: block;
    height: auto;
    object-fit: cover;
    width: 100%
}

@media only screen and (max-width: 64em) {
    #banner .slider-top .slider-cover img.banner-pc {
        display: block;
        height: auto
    }
}

@media only screen and (max-width: 47.9375em) {
    #banner .slider-top .slider-cover img.banner-pc {
        display: none
    }
}

#banner .slider-top .slider-cover img.banner-sp {
    display: none
}

@media only screen and (max-width: 64em) {
    #banner .slider-top .slider-cover img.banner-sp {
        display: none
    }
}

@media only screen and (max-width: 47.9375em) {
    #banner .slider-top .slider-cover img.banner-sp {
        display: block
    }
}

#banner .slider-top .slider-cover img.banner-sp img {
    width: 100%
}

#banner .slider-top .slider-cover .banner-content-wrapper {
    display: block;
    margin: 0 auto;
    left: -50px;
    padding: 0 0 0 0px;
    position: absolute;
    right: -70px;
    top: 25px;
    width: 1050px
}

@media only screen and (max-width: 64em) {
    #banner .slider-top .slider-cover .banner-content-wrapper {
        display: block;
        padding: 0;
        top: 10px;
        width: 65%
    }
}

@media only screen and (max-width: 47.9375em) {
    #banner .slider-top .slider-cover .banner-content-wrapper {
        display: none;
        width: 85%
    }
}

#banner .slider-top .slider-cover .banner-content-wrapper .banner-content {
    display: block;
    position: relative;
    width: 1050px
}

@media only screen and (max-width: 64em) {
    #banner .slider-top .slider-cover .banner-content-wrapper .banner-content {
        width: 100%
    }
}

#banner .slider-top .slider-cover .banner-content-wrapper .banner-content img {
    height: 100%;
    object-fit: cover;
    width: 100%
}

#banner .slider-top .slick-dots {
    bottom: 12px
}

#banner .slider-top .slick-dots li button:before {
    color: #fff;
    font-size: 11px;
    opacity: 1
}

#banner .slider-top .slick-dots li.slick-active button:before {
    color: #41aea2
}

#banner .btn {
    color: #fff;
    border-radius: 10px;
    display: block;
    font-size: 30px;
    font-weight: bold;
    float: none !important;
    height: 91px;
    line-height: 200%;
    margin: 30px auto;
    padding-top: 15px;
    text-align: center;
    width: 544px
}

@media only screen and (max-width: 47.9375em) {
    #banner .btn {
        display: none
    }
}

#banner .btn span {
    display: block;
    font-size: 15px;
    font-weight: normal;
    line-height: 100%
}

#banner .btn span:before {
    content: '\005c';
    display: inline-block;
    margin-right: 20px
}

#banner .btn span:after {
    content: '\002F';
    display: inline-block;
    margin-left: 20px
}

#banner .cover {
    display: block;
    height: 380px;
    margin: 0;
    overflow: hidden;
    position: relative;
    width: 100%
}

@media only screen and (max-width: 47.9375em) {
    #banner .cover {
        height: 150px
    }
}

#banner .cover img {
    display: block;
    height: 100%;
    object-fit: cover;
    width: 100%
}

#banner .cover .title-wrapper {
    background-color: rgba(65, 174, 162, 0.8);
    bottom: 40px;
    display: block;
    padding: 26px 62px 26px 140px;
    position: absolute
}

@media only screen and (max-width: 47.9375em) {
    #banner .cover .title-wrapper {
        bottom: 15px;
        display: inline-block;
        padding: 4px 4px 4px 2.5%;
        white-space: nowrap
    }
}

#banner .cover .title-wrapper .title {
    color: #fff;
    display: inline-block;
    font-size: 24px;
    line-height: 100%;
    margin: 0 20px 0 0;
    padding: 0
}

@media only screen and (max-width: 47.9375em) {
    #banner .cover .title-wrapper .title {
        font-weight: bold;
        margin: 0 auto;
        width: 95%;
        padding: 0
    }
}

#banner .cover .title-wrapper .title-eng {
    color: #fff;
    font-size: 16px;
    font-weight: bold;
    line-height: 100%;
    padding: 0
}

@media only screen and (max-width: 47.9375em) {
    #banner .cover .title-wrapper .title-eng {
        display: none
    }
}

#banner .banner-title {
    background-color: #fff;
    color: #000;
    font-size: 28px;
    font-weight: bold;
    line-height: 100%;
    padding: 30px 0 25px
}

#banner .banner-title h2 {
    color: #000;
    display: block;
    font-size: 12px;
    font-weight: normal;
    line-height: 100%;
    margin-top: 8px
}

#scroll {
    position: fixed;
    right: 125px;
    bottom: 30px;
    cursor: pointer;
    display: none;
    z-index: 99999;
    transition: .3s
}

@media only screen and (max-width: 56.25em) {
    #scroll {
        bottom: 50px;
        right: 50px
    }
}

@media only screen and (max-width: 47.9375em) {
    #scroll {
        bottom: 15px;
        right: 10px;
        width: 45px
    }
}

#scroll:hover .b-top {
    opacity: .7
}

#scroll:hover .b-top::after {
    color: #fff
}

#scroll .b-top {
    background-color: #729a42;
    display: block;
    height: 62px;
    position: relative;
    transition: .3s;
    width: 60px
}

@media only screen and (max-width: 47.9375em) {
    #scroll .b-top {
        background: #729a42;
        height: 40px;
        width: 42px
    }
}

#scroll .b-top::after {
    content: '\f062';
    font-family: 'FontAwesome';
    font-size: 30px;
    color: #fff;
    display: block;
    height: 24px;
    position: absolute;
    left: 0;
    right: 0;
    margin-left: auto;
    margin-right: auto;
    top: 20%;
    width: 30px
}

@media only screen and (max-width: 47.9375em) {
    #scroll .b-top::after {
        font-size: 25px;
        height: 32px;
        margin: 3px auto 0;
        top: 5%;
        transform: scale(0.6);
        width: 22px
    }
}

#scroll p {
    background-color: #333333;
    color: #fff;
    display: block;
    font-size: 10px;
    font-weight: bold;
    margin: 0px 0 0;
    padding: 8px 0;
    text-align: center;
    width: auto
}

@media only screen and (max-width: 47.9375em) {
    #scroll p {
        background-color: transparent;
        color: #333333;
        font-size: 8px;
        margin: 0 0 0 -9px;
        width: 60px
    }
}

#breadcrumbs .breadcrumbs-contents a {
    color: #393939;
    font-size: 12px;
    line-height: 100%
}

#breadcrumbs .breadcrumbs-contents a:after {
    content: '\f105';
    font-family: 'FontAwesome';
    font-size: 14px;
    line-height: 100%;
    margin-left: 8px
}

#breadcrumbs .breadcrumbs-contents a:last-child:after {
    content: ''
}

#breadcrumbs .breadcrumbs-contents a.active {
    font-weight: bold
}

#footer {
    background: url("../images/footer_bg.png");
    background-size: 100%;
    background-repeat: no-repeat;
    height: 420px;
    overflow: hidden;
    padding: 65px 0 100px
}

@media only screen and (max-width: 64em) {
    #footer {
        background-size: cover;
        height: auto;
        padding: 27px 15px 27px
    }
}

@media only screen and (max-width: 47.9375em) {
    #footer {
        background-size: cover;
        height: auto;
        padding: 27px 0 27px
    }
}

#footer .footer-nav {
    display: block;
    margin: 0 auto 60px;
    overflow: hidden;
    width: 310px
}

#footer .footer-nav .footer-nav--item {
    display: block;
    float: left;
    margin-right: 25px;
    transition: .5s
}

#footer .footer-nav .footer-nav--item:last-child {
    margin-right: 0px
}

#footer .footer-nav .footer-nav--item:hover {
    opacity: .7
}

#footer .footer-nav .footer-nav--item p {
    display: block;
    padding: 0 0 0 25px;
    position: relative
}

#footer .footer-nav .footer-nav--item p:before {
    background: url("../images/icon_foot_nav.png");
    background-size: 100%;
    background-repeat: no-repeat;
    content: "";
    display: block;
    height: 17px;
    left: 0px;
    position: absolute;
    top: 0px;
    width: 17px
}

#footer .mail-btn {
    background: url("../images/footer_mail_bg.png");
    background-size: 100%;
    background-repeat: no-repeat;
    border-radius: 15px;
    display: block;
    margin: 0 auto 85px;
    height: 75px;
    line-height: 75px;
    transition: .5s;
    width: 500px
}

@media only screen and (max-width: 47.9375em) {
    #footer .mail-btn {
        background-size: cover;
        margin: 0 auto 30px;
        width: 300px
    }
}

#footer .mail-btn:hover {
    opacity: .9
}

#footer .mail-btn p {
    color: #fff;
    font-size: 19px;
    font-weight: bold;
    margin: 0 auto;
    text-align: center;
    padding: 0 0 0 45px;
    position: relative;
    width: 250px
}

#footer .mail-btn p:before {
    background: url("../images/common/mail_icon.png");
    background-size: 100%;
    background-repeat: no-repeat;
    content: "";
    display: block;
    height: 24px;
    left: 0px;
    position: absolute;
    top: 26px;
    width: 33px
}

#footer .copyright {
    color: #000;
    display: block;
    font-size: 15px;
    line-height: 150%;
    text-align: center
}

@media only screen and (max-width: 64em) {
    #footer .copyright {
        margin: 0 0 0 0
    }
}

@media only screen and (max-width: 47.9375em) {
    #footer .copyright {
        font-size: 13px;
        height: auto;
        margin: 0px auto 0px;
        text-align: center;
        width: 90%
    }
}

@media only screen and (max-width: 47.9375em) {
    #footer .copyright2 {
        font-size: 13px;
        height: auto;
        margin: 0px auto 0px;
        text-align: center;
        width: 90%
    }
}

@media only screen and (max-width: 47.9375em) {
    #footer .cp-thanks {
        font-size: 13px;
        margin: 0px auto 0px;
        text-align: center;
        width: 90%
    }
}

.sticky {
    background-color: #fff;
    border-top: 1px solid #208da9;
    bottom: 0;
    display: none;
    padding: 5px 5px;
    position: fixed;
    width: 100%
}

@media only screen and (max-width: 47.9375em) {
    .sticky {
        display: block
    }
}

.sticky .sticky-content {
    display: block;
    overflow: hidden
}

.sticky .sticky-content .btn-lists {
    display: block;
    overflow: hidden;
    width: 100%;
    z-index: 10
}

@media only screen and (max-width: 47.9375em) {
    .sticky .sticky-content .btn-lists {
        margin: 12px 0 0
    }
}

.sticky .sticky-content .btn-lists .btn-lists--item {
    display: table;
    height: 85px;
    margin-right: 5%;
    float: left;
    transition: .5s
}

.sticky .sticky-content .btn-lists .btn-lists--item:hover {
    opacity: .8
}

.sticky .sticky-content .btn-lists .btn-lists--item p {
    display: table-cell;
    position: relative;
    vertical-align: middle
}

@media only screen and (max-width: 47.9375em) {
    .sticky .sticky-content .btn-lists .btn-lists--item p {
        padding: 0 0 0 25px
    }
}

.sticky .sticky-content .btn-lists .btn-lists--item:first-child {
    border: solid 1px #d7d7d7;
    width: 40%
}

@media only screen and (max-width: 47.9375em) {
    .sticky .sticky-content .btn-lists .btn-lists--item:first-child {
        margin-right: 2%;
        width: 49%
    }
}

.sticky .sticky-content .btn-lists .btn-lists--item:first-child p {
    color: #00263f;
    display: block;
    font-size: 18px;
    font-weight: bold;
    margin: 13px auto 0;
    position: relative;
    text-align: center;
    width: 160px
}

.sticky .sticky-content .btn-lists .btn-lists--item:first-child p::before {
    background: url("../images/common/telnum_icon.png");
    background-size: 100%;
    background-repeat: no-repeat;
    content: "";
    display: block;
    height: 22px;
    left: 5px;
    position: absolute;
    top: 18px;
    width: 18px
}

.sticky .sticky-content .btn-lists .btn-lists--item:first-child p b {
    display: block;
    font-size: 10px;
    margin: 0 0 8px
}

.sticky .sticky-content .btn-lists .btn-lists--item:first-child p span {
    display: block;
    font-size: 10px;
    font-weight: bold;
    margin: 5px 0 0
}

.sticky .sticky-content .btn-lists .btn-lists--item:last-child {
    margin-right: 0px;
    background-color: #feaa12;
    border: solid 1px #feaa12;
    border-radius: 15px;
    float: left;
    transition: .5s;
    width: 55%
}

@media only screen and (max-width: 47.9375em) {
    .sticky .sticky-content .btn-lists .btn-lists--item:last-child {
        width: 49%
    }
}

.sticky .sticky-content .btn-lists .btn-lists--item:last-child p {
    color: #fff;
    display: block;
    font-size: 21px;
    font-weight: bold;
    line-height: 150%;
    margin: 24px auto 0;
    padding: 0 0 0 30px;
    position: relative;
    text-align: center;
    vertical-align: middle;
    width: 160px
}

@media only screen and (max-width: 47.9375em) {
    .sticky .sticky-content .btn-lists .btn-lists--item:last-child p {
        font-size: 13px
    }
}

.sticky .sticky-content .btn-lists .btn-lists--item:last-child p::before {
    background: url("../images/common/mail_icon.png");
    background-size: 100%;
    background-repeat: no-repeat;
    content: "";
    display: block;
    height: 30px;
    left: -2px;
    position: absolute;
    top: 10px;
    width: 25px
}

.sticky .sticky-content .sticky-l {
    float: left;
    display: block;
    margin-right: 2%;
    width: 49%
}

.sticky .sticky-content .sticky-l img {
    height: auto;
    object-fit: contain;
    width: 100%
}

.sticky .sticky-content .sticky-r {
    float: right;
    display: block;
    width: 49%
}

.sticky .sticky-content .sticky-r img {
    height: auto;
    object-fit: contain;
    width: 100%
}

.sticky {
    overflow: hidden
}

.sticky:before {
    content: "";
    z-index: 10;
    position: absolute;
    height: 200%;
    width: 200%;
    top: -120%;
    left: -120%;
    background: linear-gradient(transparent 0%, rgba(255, 255, 255, 0.3) 45%, rgba(255, 255, 255, 0.7) 50%, rgba(255, 255, 255, 0.3) 55%, transparent 100%);
    transition: all 2s;
    transform: rotate(-45deg);
    animation: shine 6s infinite forwards
}

@keyframes shine {
    0% {
        top: -120%;
        left: -120%
    }

    20% {
        left: 100%;
        top: 100%
    }

    40% {
        left: 100%;
        top: 100%
    }

    100% {
        left: 100%;
        top: 100%
    }
}

#nav {
    background-color: #f07595;
    z-index: 10;
    margin: -4px auto 0;
    position: relative
}

@media only screen and (max-width: 64em) {
    #nav {
        display: block;
        width: 100%
    }
}

@media only screen and (max-width: 47.9375em) {
    #nav {
        display: none;
        width: 100%
    }
}

#nav .menu-lists {
    display: block;
    margin: 0 auto;
    padding: 22px 0 16px;
    width: max-content
}

@media only screen and (max-width: 64em) {
    #nav .menu-lists {
        width: max-content
    }
}

@media only screen and (max-width: 47.9375em) {
    #nav .menu-lists {
        width: 95%
    }
}

#nav .menu-lists .menu-list--item {
    border-right: solid 1px #fff;
    cursor: pointer;
    display: inline-block;
    padding: 0 23px;
    text-align: center;
    transition: .5s
}

@media only screen and (max-width: 64em) {
    #nav .menu-lists .menu-list--item {
        padding: 0 15px
    }
}

#nav .menu-lists .menu-list--item:last-child {
    border-right: none;
    margin-right: 0
}

#nav .menu-lists .menu-list--item a {
    color: #fff;
    display: block;
    font-size: 17px;
    height: 32px;
    line-height: 32px;
    position: relative;
    transition: .5s
}

@media only screen and (max-width: 64em) {
    #nav .menu-lists .menu-list--item a {
        font-size: 14px
    }
}

#nav .menu-lists .menu-list--item a:hover {
    opacity: .5
}

#sticky-nav {
    background-color: #f07595;
    box-shadow: 0 6px 4px -4px rgba(0, 0, 0, 0.3);
    left: 0;
    margin: 0 auto;
    position: fixed;
    top: 0;
    width: 100%;
    display: none;
    z-index: 99999
}

@media only screen and (max-width: 64em) {
    #sticky-nav {
        border-bottom: 1px solid #a7a8aa;
        box-shadow: 0 6px 4px -4px transparent;
        height: 60px;
        padding: 10px 0;
        display: none !important
    }
}

@media only screen and (max-width: 47.9375em) {
    #sticky-nav {
        border-bottom: 1px solid #a7a8aa;
        box-shadow: 0 6px 4px -4px transparent;
        height: 60px;
        padding: 10px 0;
        display: none !important
    }
}

#sticky-nav .sticky-wrapper {
    display: block;
    margin: 0 auto;
    position: relative;
    width: 1088px
}

@media only screen and (max-width: 64em) {
    #sticky-nav .sticky-wrapper {
        width: 95%
    }
}

@media only screen and (max-width: 47.9375em) {
    #sticky-nav .sticky-wrapper {
        width: 95%
    }
}

#sticky-nav .sticky-wrapper .hamburger {
    display: none;
    float: right
}

@media only screen and (max-width: 64em) {
    #sticky-nav .sticky-wrapper .hamburger {
        display: block
    }
}

@media only screen and (max-width: 47.9375em) {
    #sticky-nav .sticky-wrapper .hamburger {
        display: block
    }
}

#sticky-nav .sticky-wrapper .h-btn {
    display: block;
    float: right;
    overflow: hidden
}

@media only screen and (max-width: 64em) {
    #sticky-nav .sticky-wrapper .h-btn {
        display: none
    }
}

@media only screen and (max-width: 47.9375em) {
    #sticky-nav .sticky-wrapper .h-btn {
        display: none
    }
}

#sticky-nav .sticky-wrapper .h-btn a.btn {
    display: inline-block;
    float: left;
    margin-top: 10px;
    vertical-align: middle
}

#sticky-nav .sticky-wrapper .h-btn a.btn-primary {
    border-radius: 6px;
    font-size: 12px;
    height: 39px;
    line-height: 39px;
    text-align: center;
    width: 214px
}

#sticky-nav .sticky-wrapper .h-btn a.btn-primary:before {
    background-image: url("../images/common/icon_sm_01.png");
    background-position: center;
    background-repeat: no-repeat;
    background-size: 100%;
    content: '';
    display: inline-block;
    line-height: 12px;
    height: 12px;
    margin-right: 5px;
    vertical-align: text-bottom;
    width: 16px
}

#sticky-nav #navi .menu-lists {
    background-color: #f07595;
    display: block;
    margin: 0 auto 0 auto;
    padding: 22px 0 16px;
    width: max-content
}

@media only screen and (max-width: 64em) {
    #sticky-nav #navi .menu-lists {
        display: none
    }
}

@media only screen and (max-width: 47.9375em) {
    #sticky-nav #navi .menu-lists {
        display: none
    }
}

#sticky-nav #navi .menu-lists .menu-list--item {
    border-right: solid 1px #fff;
    cursor: pointer;
    display: inline-block;
    padding: 0 23px;
    text-align: center;
    transition: .5s
}

#sticky-nav #navi .menu-lists .menu-list--item:last-child {
    border-right: none;
    margin-right: 0
}

#sticky-nav #navi .menu-lists .menu-list--item a {
    color: #fff;
    display: block;
    font-size: 17px;
    height: 32px;
    line-height: 32px;
    position: relative;
    transition: .5s
}

#sticky-nav #navi .menu-lists .menu-list--item a:hover {
    opacity: .5
}

.icon-bar {
    display: none;
    position: fixed;
    top: 50%;
    right: 0;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    transition: .5s;
    z-index: 99999
}

.icon-bar .info-btn--item {
    display: block;
    margin-bottom: 10px;
    overflow: hidden;
    transition: .5s
}

@media only screen and (max-width: 47.9375em) {
    .icon-bar .info-btn--item {
        display: none
    }
}

.icon-bar .info-btn--item:hover .cover {
    background-color: #f07595 !important
}

.icon-bar .info-btn--item:nth-child(2) .cover {
    background-color: #dab17a
}

.icon-bar .info-btn--item:nth-child(2) .cover img {
    height: 17px;
    top: 32%;
    width: 25px
}

@media only screen and (max-width: 47.9375em) {
    .icon-bar .info-btn--item:nth-child(2) .cover img {
        height: auto;
        width: 18px
    }
}

.icon-bar .info-btn--item:last-child {
    margin-right: 0
}

.icon-bar .info-btn--item:last-child .cover {
    background-color: #93cc90
}

.icon-bar .info-btn--item:last-child .cover img {
    height: 27px;
    top: 20%;
    width: 19px
}

@media only screen and (max-width: 47.9375em) {
    .icon-bar .info-btn--item:last-child .cover img {
        height: auto;
        width: 15px
    }
}

.icon-bar .info-btn--item .cover {
    background-color: #73c4cb;
    border-radius: 50%;
    display: inlin-e;
    float: left;
    left: 0;
    right: 0;
    margin-left: auto;
    margin-right: auto;
    margin: 0 auto;
    height: 46px;
    position: relative;
    width: 46px
}

@media only screen and (max-width: 47.9375em) {
    .icon-bar .info-btn--item .cover {
        height: 33px;
        width: 33px
    }
}

.icon-bar .info-btn--item .cover img {
    display: block;
    height: 21px;
    margin: 0 auto;
    top: 28%;
    position: relative;
    width: 21px
}

@media only screen and (max-width: 47.9375em) {
    .icon-bar .info-btn--item .cover img {
        height: auto;
        width: 16px
    }
}

.hamburger {
    background-color: transparent;
    border: 0;
    cursor: pointer;
    display: inline-block;
    margin: 0;
    overflow: visible;
    padding: 8px 0
}

.hamburger-box {
    height: 24px;
    display: inline-block;
    position: relative;
    width: 30px
}

.hamburger-inner {
    display: block;
    margin: -2px;
    position: relative;
    top: 50%
}

.hamburger-inner,
.hamburger-inner:before,
.hamburger-inner:after {
    background-color: #41aea2;
    border-radius: 4px;
    content: "";
    display: block;
    height: 4px;
    position: absolute;
    width: 30px;
    transition-property: transform;
    transition-duration: 0.15s;
    transition-timing-function: ease
}

.hamburger-inner:before {
    top: -10px
}

.hamburger-inner:after {
    bottom: -10px
}

.hamburger--squeeze .hamburger-inner {
    transition-duration: 0.1s;
    transition-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19)
}

.hamburger--squeeze .hamburger-inner:before {
    transition: top 0.1s 0.14s ease, opacity 0.1s ease
}

.hamburger--squeeze .hamburger-inner:after {
    transition: bottom 0.1s 0.14s ease, transform 0.1s cubic-bezier(0.55, 0.055, 0.675, 0.19)
}

.hamburger--squeeze.is-active .hamburger-inner {
    transform: rotate(45deg);
    transition-delay: 0.14s;
    transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1)
}

.hamburger--squeeze.is-active .hamburger-inner:before {
    top: 0;
    opacity: 0;
    transition: top 0.1s ease, opacity 0.1s 0.14s ease
}

.hamburger--squeeze.is-active .hamburger-inner:after {
    bottom: 0;
    transform: rotate(-90deg);
    transition: bottom 0.1s ease, transform 0.1s 0.14s cubic-bezier(0.215, 0.61, 0.355, 1)
}

.sidenav {
    height: 100%;
    width: 100%;
    position: fixed;
    z-index: 99999;
    top: 60px;
    left: -100%;
    background-color: #ffffff;
    overflow-x: hidden;
    transition: 0.5s
}

.sidenav .accordion {
    border-bottom: 1px solid #a7a8aa;
    background: white;
    margin: 0 auto 30px;
    padding-bottom: 40px
}

.sidenav .accordion .accordion-header {
    border-bottom: 2px solid #fff;
    background-color: #a7a8aa;
    color: #fff;
    cursor: pointer;
    font-size: 14px;
    font-weight: bold;
    line-height: 100%;
    padding: 12px 2.5%;
    position: relative
}

.sidenav .accordion .accordion-header:after {
    content: '\f078';
    color: #fff;
    font-family: 'FontAwesome';
    font-size: 14px;
    line-height: 100%;
    display: block;
    position: absolute;
    transform: translate(-50%, -50%);
    right: 2.5%;
    top: 50%
}

.sidenav .accordion .accordion-header.active:after {
    content: '\f077'
}

.sidenav .accordion .accordion-content {
    display: none;
    background-color: #fff;
    padding: 0
}

.sidenav .accordion .accordion-content a {
    border-bottom: 1px solid #a7a8aa;
    color: #393939;
    display: block;
    font-size: 14px;
    line-height: 100%;
    padding: 12px 2.5%
}

.sidenav .accordion .accordion-content a:last-child {
    border-bottom: 0
}

.sidenav.is-active {
    left: 0
}

.sidenav .buttons {
    display: block;
    margin: 0 auto;
    width: 95%
}

.sidenav .buttons .btn-caption {
    display: block;
    font-size: 13px;
    line-height: 100%;
    text-align: center;
    font-weight: bold;
    margin-bottom: 20px
}

.sidenav .buttons .btn {
    border-radius: 6px;
    display: block;
    font-size: 14px;
    font-weight: bold;
    height: 60px;
    line-height: 60px;
    margin-bottom: 10px;
    text-align: center;
    vertical-align: middle;
    width: 100%
}

.sidenav .buttons .btn:before {
    background-position: center;
    background-size: 100% 100%;
    background-repeat: no-repeat;
    content: '';
    display: inline-block;
    vertical-align: middle;
    margin-right: 8px
}

.sidenav .buttons .btn.btn-primary span {
    top: 2px
}

.sidenav .buttons .btn.btn-primary:before {
    background-image: url("../images/common/icon_sm_03.png");
    height: 14px;
    width: 20px
}

.sidenav .buttons .btn.btn-secondary span {
    top: 2px
}

.sidenav .buttons .btn.btn-secondary:before {
    background-image: url("../images/common/icon_sm_02.png");
    height: 18.5px;
    width: 24px
}

.sidenav .buttons .btn.btn-tertiary span {
    top: 2px
}

.sidenav .buttons .btn.btn-tertiary:before {
    background-image: url("../images/common/icon_sm_04.png");
    height: 19px;
    width: 19px
}

.sidenav .buttons .btn span {
    position: relative
}

.page-top {
    margin: 0 0 0
}

.page-top .equip {
    background-color: #ededed;
    background: url("../images/equip_bg.png");
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
    display: block;
    overflow: hidden;
    padding: 100px 0 50px;
    position: relative
}

@media only screen and (max-width: 64em) {
    .page-top .equip {
        background-size: cover;
        padding: 50px 20px 50px
    }
}

@media only screen and (max-width: 47.9375em) {
    .page-top .equip {
        background-size: cover;
        padding: 50px 20px 50px
    }
}

.page-top .equip .equip-contents .title {
    background-color: #ededed;
    background: url("../images/title_bg.png");
    background-size: 100%;
    background-repeat: no-repeat;
    color: #fff;
    display: block;
    font-size: 25px;
    height: 75px;
    line-height: 75px;
    margin: 0 auto 50px;
    overflow: hidden;
    text-align: center;
    width: 445px
}

@media only screen and (max-width: 47.9375em) {
    .page-top .equip .equip-contents .title {
        background-size: cover;
        margin: 0 auto 30px;
        width: 90%
    }
}

.page-top .equip .equip-contents .equip--item {
    background-color: #fbfcff;
    border-radius: 10px;
    display: block;
    margin: 0 0 90px;
    overflow: hidden;
    padding: 40px 0 40px
}

@media only screen and (max-width: 64em) {
    .page-top .equip .equip-contents .equip--item {
        padding: 40px 20px
    }
}

@media only screen and (max-width: 47.9375em) {
    .page-top .equip .equip-contents .equip--item {
        padding: 20px 20px
    }
}

.page-top .equip .equip-contents .equip--item p {
    display: block;
    font-size: 21px;
    line-height: 200%;
    text-align: center
}

@media only screen and (max-width: 47.9375em) {
    .page-top .equip .equip-contents .equip--item p {
        font-size: 15px
    }
}

.page-top .equip .equip-contents .message--item {
    background-color: #fbfcff;
    border-radius: 10px;
    display: block;
    margin: 0 0 0px;
    overflow: hidden;
    padding: 30px 45px 45px 30px
}

@media only screen and (max-width: 47.9375em) {
    .page-top .equip .equip-contents .message--item {
        padding: 20px 20px
    }
}

.page-top .equip .equip-contents .message--item .cover {
    display: block;
    float: left;
    margin: 65px 6% 0 0;
    width: 44%
}

@media only screen and (max-width: 47.9375em) {
    .page-top .equip .equip-contents .message--item .cover {
        margin: 0 0 0;
        width: 100%
    }
}

.page-top .equip .equip-contents .message--item .cover img {
    width: 100%
}

.page-top .equip .equip-contents .message--item .cover .position {
    display: block;
    font-size: 18px;
    margin: 15px 0 0;
    text-align: right
}

@media only screen and (max-width: 47.9375em) {
    .page-top .equip .equip-contents .message--item .cover .position {
        font-size: 15px
    }
}

.page-top .equip .equip-contents .message--item .info {
    display: block;
    float: left;
    width: 50%
}

@media only screen and (max-width: 47.9375em) {
    .page-top .equip .equip-contents .message--item .info {
        width: 100%
    }
}

.page-top .equip .equip-contents .message--item .info p {
    display: block;
    font-size: 18px;
    line-height: 200%;
    margin: 0 0 15px
}

@media only screen and (max-width: 47.9375em) {
    .page-top .equip .equip-contents .message--item .info p {
        font-size: 15px;
        margin: 30px 0 0
    }
}

.page-top .construction {
    background-color: #ededed;
    background: url("../images/construction_bg.png");
    background-size: 100%;
    background-repeat: repeat-y;
    background-position: center center;
    display: block;
    overflow: hidden;
    padding: 100px 0 50px;
    position: relative
}

@media only screen and (max-width: 64em) {
    .page-top .construction {
        background-size: cover;
        padding: 50px 20px 50px
    }
}

@media only screen and (max-width: 47.9375em) {
    .page-top .construction {
        background-size: cover;
        padding: 50px 20px 50px
    }
}

.page-top .construction .construction-contents .title {
    background-color: #ededed;
    background: url("../images/title_bg.png");
    background-size: 100%;
    background-repeat: no-repeat;
    color: #fff;
    display: block;
    font-size: 25px;
    height: 75px;
    line-height: 75px;
    margin: 0 auto 70px;
    overflow: hidden;
    text-align: center;
    width: 445px
}

@media only screen and (max-width: 47.9375em) {
    .page-top .construction .construction-contents .title {
        background-size: cover;
        margin: 0 auto 30px;
        width: 90%
    }
}

.page-top .construction .construction-contents .info--item {
    background-color: #fbfcff;
    border-radius: 10px;
    display: block;
    margin: 0 0 135px;
    overflow: hidden;
    padding: 55px 0 55px
}

@media only screen and (max-width: 47.9375em) {
    .page-top .construction .construction-contents .info--item {
        padding: 20px 20px
    }
}

.page-top .construction .construction-contents .info--item .g-title {
    background-color: #f4fb7e;
    color: #1d800a;
    display: block;
    font-size: 27px;
    font-weight: bold;
    height: 70px;
    line-height: 70px;
    margin: 0 auto 25px;
    text-align: center;
    width: 840px
}

@media only screen and (max-width: 64em) {
    .page-top .construction .construction-contents .info--item .g-title {
        font-size: 22px;
        height: auto;
        line-height: 150%;
        padding: 20px 15px 20px;
        width: 90%
    }
}

@media only screen and (max-width: 47.9375em) {
    .page-top .construction .construction-contents .info--item .g-title {
        font-size: 18px;
        height: auto;
        line-height: 150%;
        padding: 20px 15px 20px;
        width: 100%
    }
}

.page-top .construction .construction-contents .info--item p {
    display: block;
    font-size: 19px;
    line-height: 200%;
    margin: 0 auto;
    text-align: left;
    padding: 0 20px;
    width: 840px
}

@media only screen and (max-width: 64em) {
    .page-top .construction .construction-contents .info--item p {
        font-size: 18px;
        padding: 0 10px;
        width: 90%
    }
}

@media only screen and (max-width: 47.9375em) {
    .page-top .construction .construction-contents .info--item p {
        font-size: 15px;
        padding: 0 10px;
        width: 90%
    }
}

.page-top .construction .construction-contents .time-lists {
    display: block;
    overflow: visible
}

.page-top .construction .construction-contents .time-lists .time-lists--item {
    background-color: #fbfcff;
    border-radius: 10px;
    display: block;
    height: 380px;
    margin: 0 0 140px;
    overflow: visible;
    padding: 45px 30px 30px;
    position: relative
}

@media only screen and (max-width: 47.9375em) {
    .page-top .construction .construction-contents .time-lists .time-lists--item {
        height: auto;
        margin: 0 0 30px;
        overflow: hidden
    }
}

.page-top .construction .construction-contents .time-lists .time-lists--item::after {
    background-image: url("../images/arrw_dwn.png");
    background-size: contain;
    background-repeat: no-repeat;
    content: "";
    display: block;
    position: absolute;
    margin-left: auto;
    margin-right: auto;
    left: 50%;
    right: 50%;
    bottom: -120px;
    height: 55px;
    transform: translate(-50%, -50%);
    width: 300px
}

@media only screen and (max-width: 47.9375em) {
    .page-top .construction .construction-contents .time-lists .time-lists--item::after {
        bottom: -30px;
        overflow: visible
    }
}

.page-top .construction .construction-contents .time-lists .time-lists--item:nth-child(2) .info .time-title:before {
    background: url("../images/icon_time_02.png");
    background-size: 100%;
    background-repeat: no-repeat;
    content: "";
    display: block;
    height: 64px;
    left: 0px;
    position: absolute;
    top: -20px;
    width: 64px
}

.page-top .construction .construction-contents .time-lists .time-lists--item:nth-child(3) .info .time-title:before {
    background: url("../images/icon_time_03.png");
    background-size: 100%;
    background-repeat: no-repeat;
    content: "";
    display: block;
    height: 64px;
    left: 0px;
    position: absolute;
    top: -20px;
    width: 64px
}

.page-top .construction .construction-contents .time-lists .time-lists--item:nth-child(4) .info .time-title:before {
    background: url("../images/icon_time_04.png");
    background-size: 100%;
    background-repeat: no-repeat;
    content: "";
    display: block;
    height: 64px;
    left: 0px;
    position: absolute;
    top: -20px;
    width: 64px
}

.page-top .construction .construction-contents .time-lists .time-lists--item:nth-child(5) {
    margin: 0 0 85px
}

@media only screen and (max-width: 47.9375em) {
    .page-top .construction .construction-contents .time-lists .time-lists--item:nth-child(5) {
        margin: 0 0 30px
    }
}

.page-top .construction .construction-contents .time-lists .time-lists--item:nth-child(5):after {
    display: none
}

.page-top .construction .construction-contents .time-lists .time-lists--item:nth-child(5) .info .time-title:before {
    background: url("../images/icon_time_05.png");
    background-size: 100%;
    background-repeat: no-repeat;
    content: "";
    display: block;
    height: 64px;
    left: 0px;
    position: absolute;
    top: -20px;
    width: 64px
}

.page-top .construction .construction-contents .time-lists .time-lists--item .cover {
    display: block;
    float: left;
    margin: 0 5% 0 0;
    width: 47.5%
}

@media only screen and (max-width: 47.9375em) {
    .page-top .construction .construction-contents .time-lists .time-lists--item .cover {
        width: 100%
    }
}

.page-top .construction .construction-contents .time-lists .time-lists--item .cover img {
    width: 100%
}

.page-top .construction .construction-contents .time-lists .time-lists--item .info {
    display: block;
    float: left;
    padding: 40px 0 0;
    width: 47.5%
}

@media only screen and (max-width: 47.9375em) {
    .page-top .construction .construction-contents .time-lists .time-lists--item .info {
        width: 100%
    }
}

.page-top .construction .construction-contents .time-lists .time-lists--item .info .time-title {
    color: #2a8718;
    display: block;
    font-size: 27px;
    font-weight: bold;
    margin: 0 0 0px;
    padding: 0 0 0 85px;
    position: relative
}

.page-top .construction .construction-contents .time-lists .time-lists--item .info .time-title:before {
    background: url("../images/icon_time_01.png");
    background-size: 100%;
    background-repeat: no-repeat;
    content: "";
    display: block;
    height: 64px;
    left: 0px;
    position: absolute;
    top: -20px;
    width: 64px
}

.page-top .construction .construction-contents .time-lists .time-lists--item .info .p-wrapper {
    display: table;
    height: 240px;
    width: 100%
}

@media only screen and (max-width: 47.9375em) {
    .page-top .construction .construction-contents .time-lists .time-lists--item .info .p-wrapper {
        height: 150px
    }
}

.page-top .construction .construction-contents .time-lists .time-lists--item .info .p-wrapper p {
    display: table-cell;
    font-size: 24px;
    line-height: 150%;
    margin: 0 auto;
    text-align: center;
    vertical-align: middle
}

@media only screen and (max-width: 47.9375em) {
    .page-top .construction .construction-contents .time-lists .time-lists--item .info .p-wrapper p {
        font-size: 18px
    }
}

.page-top .construction .construction-contents .point {
    background-color: #fffcdb;
    border-radius: 10px;
    display: block;
    margin: 0 auto 0px;
    overflow: hidden;
    padding: 45px 45px 60px;
    position: relative;
    width: 780px
}

@media only screen and (max-width: 47.9375em) {
    .page-top .construction .construction-contents .point {
        padding: 30px 30px;
        width: 100%
    }
}

.page-top .construction .construction-contents .point .cover {
    display: block;
    float: left;
    margin: 0 35px 0 0;
    width: 77px
}

@media only screen and (max-width: 47.9375em) {
    .page-top .construction .construction-contents .point .cover {
        float: none;
        margin: 0 auto
    }
}

.page-top .construction .construction-contents .point .cover img {
    width: 100%
}

.page-top .construction .construction-contents .point p {
    display: block;
    float: left;
    font-size: 19px;
    line-height: 175%;
    padding: 20px 0 0
}

@media only screen and (max-width: 47.9375em) {
    .page-top .construction .construction-contents .point p {
        font-size: 15px
    }
}

.page-top .requirements {
    background-color: #ededed;
    background: url("../images/construction_bg.png");
    background-size: 100%;
    background-repeat: repeat-y;
    background-position: center center;
    display: block;
    overflow: hidden;
    padding: 150px 0 0px;
    position: relative
}

@media only screen and (max-width: 64em) {
    .page-top .requirements {
        background-size: cover;
        padding: 50px 20px 0px
    }
}

@media only screen and (max-width: 47.9375em) {
    .page-top .requirements {
        background-size: cover;
        padding: 50px 20px 0px
    }
}

.page-top .requirements .requirements-contents .title {
    background-color: #ededed;
    background: url("../images/title_bg.png");
    background-size: 100%;
    background-repeat: no-repeat;
    color: #fff;
    display: block;
    font-size: 25px;
    height: 75px;
    line-height: 75px;
    margin: 0 auto 70px;
    overflow: hidden;
    text-align: center;
    width: 445px
}

@media only screen and (max-width: 47.9375em) {
    .page-top .requirements .requirements-contents .title {
        background-size: cover;
        margin: 0 auto 30px;
        width: 90%
    }
}

.page-top .requirements .requirements-contents .title.t-inquiry {
    margin: 0 auto 40px
}

@media only screen and (max-width: 47.9375em) {
    .page-top .requirements .requirements-contents .title.t-inquiry {
        margin: 0 auto 30px
    }
}

.page-top .requirements .requirements-contents .table01 {
    background-color: #fff;
    border: solid 1px #d2d2d2;
    display: table;
    margin: 0 auto 80px;
    width: 770px
}

@media only screen and (max-width: 64em) {
    .page-top .requirements .requirements-contents .table01 {
        width: 100%
    }
}

@media only screen and (max-width: 47.9375em) {
    .page-top .requirements .requirements-contents .table01 {
        width: 100%
    }
}

.page-top .requirements .requirements-contents .table01 tr th {
    background-color: #54cddb;
    color: #fff;
    font-size: 19px;
    font-weight: bold;
    padding: 18px 0 15px;
    text-align: center
}

.page-top .requirements .requirements-contents .table01 tr td {
    border: solid 1px #d2d2d2;
    font-size: 17px;
    line-height: 175%;
    padding: 20px 0 15px
}

.page-top .requirements .requirements-contents .table01 tr td:nth-child(1) {
    background-color: #e9fdfc;
    text-align: center;
    width: 210px
}

@media only screen and (max-width: 47.9375em) {
    .page-top .requirements .requirements-contents .table01 tr td:nth-child(1) {
        border-bottom: none;
        display: block;
        width: 100%
    }
}

.page-top .requirements .requirements-contents .table01 tr td:nth-child(2) {
    padding: 20px 45px 15px
}

@media only screen and (max-width: 47.9375em) {
    .page-top .requirements .requirements-contents .table01 tr td:nth-child(2) {
        border-top: none;
        display: block;
        text-align: center;
        width: 100%
    }
}

.page-top .requirements .requirements-contents .table01 tr td span {
    color: #1b8a37;
    display: block;
    margin: 0 0 15px;
    text-decoration: underline;
    text-underline-position: under
}

.page-top .requirements .requirements-contents .p-inquiry {
    color: #010b02;
    font-size: 15px;
    font-weight: bold;
    text-align: center;
    line-height: 150%;
    margin: 45px 0 15px
}

@media only screen and (max-width: 47.9375em) {
    .page-top .requirements .requirements-contents .p-inquiry {
        font-size: 12px;
        margin: 5% 0 5%
    }
}

.page-top .requirements .requirements-contents .p-inquiry .p-inquiry-span {
    color: #bd1b2a
}

.page-top .requirements .requirements-contents .p-inquiry .n-line {
    display: inline-block
}

@media only screen and (max-width: 47.9375em) {
    .page-top .requirements .requirements-contents .p-inquiry .n-line {
        display: block
    }
}

.page-top .requirements .requirements-contents .p-inquiry .n-line1 {
    display: block
}

@media only screen and (max-width: 47.9375em) {
    .page-top .requirements .requirements-contents .p-inquiry .n-line1 {
        display: block
    }
}

.page-top .requirements .requirements-contents .inquiry-form {
    display: block;
    margin: 0 auto;
    padding: 0px 0 0;
    width: 905px
}

@media only screen and (max-width: 67.5em) {
    .page-top .requirements .requirements-contents .inquiry-form {
        padding: 5% 0px 0%;
        width: 100%
    }
}

@media only screen and (max-width: 47.9375em) {
    .page-top .requirements .requirements-contents .inquiry-form {
        padding: 0px 0 0;
        width: 100%
    }
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content {
    margin: 0 0;
    overflow: hidden
}

@media only screen and (max-width: 77.5em) {
    .page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content {
        margin: 0 auto
    }
}

@media only screen and (max-width: 60em) {
    .page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content {
        margin: 0 auto;
        padding: 0px
    }
}

@media only screen and (max-width: 47.9375em) {
    .page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content {
        margin: 0 4%;
        padding: 2% 0 3%
    }
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .pc {
    display: block;
    margin: 0 auto;
    width: 387.5px
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .pc img {
    width: 100%
}

@media only screen and (max-width: 47.9375em) {
    .page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .pc {
        display: none
    }
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .sp {
    display: none
}

@media only screen and (max-width: 47.9375em) {
    .page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .sp {
        display: block;
        width: 100%
    }

    .page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .sp img {
        margin: 0 auto;
        width: 80%
    }
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry {
    border: 1px solid #d2d2d2;
    color: #313334;
    width: 100%
}

@media only screen and (max-width: 64em) {
    .page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry {
        margin: 0 auto;
        width: 95%
    }
}

@media only screen and (max-width: 60em) {
    .page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry {
        margin: 0 auto;
        width: 100%
    }
}

@media only screen and (max-width: 47.9375em) {
    .page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry {
        width: 100%
    }
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr {
    border: 1px solid #d2d2d2
}

@media only screen and (max-width: 47.9375em) {
    .page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr {
        background-color: #fff
    }
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td,
.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th {
    padding: 25px 25px
}

@media only screen and (max-width: 60em) {

    .page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td,
    .page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th {
        padding: 10px 10px
    }
}

@media only screen and (max-width: 47.9375em) {

    .page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td,
    .page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th {
        display: block;
        padding: 10px;
        line-height: 150%
    }
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td:first-child,
.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th:first-child {
    color: #313334;
    background-color: #f9f9f9;
    font-size: 15px;
    font-weight: bold;
    width: 300px
}

@media only screen and (max-width: 64em) {

    .page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td:first-child,
    .page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th:first-child {
        padding: 0 5px
    }
}

@media only screen and (max-width: 60em) {

    .page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td:first-child,
    .page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th:first-child {
        line-height: 150%
    }
}

@media only screen and (max-width: 47.9375em) {

    .page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td:first-child,
    .page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th:first-child {
        display: block;
        text-align: center;
        padding: 15px 0;
        width: 100%
    }
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td:first-child .inquiry-r-required,
.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th:first-child .inquiry-r-required {
    color: #fff;
    background-color: #bd1b2a;
    font-size: 12px;
    border-radius: 3px;
    padding: 4px 2px
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td:first-child .inquiry-b-required,
.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th:first-child .inquiry-b-required {
    color: #fff;
    background-color: #103e93;
    font-size: 12px;
    border-radius: 3px;
    padding: 4px 2px
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td:last-child,
.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th:last-child {
    background-color: #fdfdfd;
    font-size: 14px;
    padding: 15px 22px
}

@media only screen and (max-width: 64em) {

    .page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td:last-child,
    .page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th:last-child {
        padding: 15px 5px
    }
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td .inquiry-input,
.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th .inquiry-input {
    color: #656565;
    border: 1px solid #d2d2d2;
    border-radius: 2px;
    height: 50px;
    line-height: 50px;
    font-size: 16px;
    padding-left: 10px;
    width: 100%;
    -webkit-appearance: none;
    outline: 0
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td .inquiry-input::placeholder,
.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th .inquiry-input::placeholder {
    font-size: 16px;
    line-height: 50px
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td .date-content,
.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th .date-content {
    display: block;
    margin: 0 0 20px
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td .date-content p,
.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th .date-content p {
    font-weight: bold
}

@media only screen and (max-width: 47.9375em) {

    .page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td .date-content p,
    .page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th .date-content p {
        text-align: center
    }
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td .date-content .date-p,
.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th .date-content .date-p {
    border: solid 1px #d2d2d2;
    border-radius: 2px;
    margin: 10px 0 0;
    padding: 15px 5px 15px 15px;
    width: 215px
}

@media only screen and (max-width: 47.9375em) {

    .page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td .date-content .date-p,
    .page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th .date-content .date-p {
        display: block;
        margin: 10px auto 0
    }
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td .date-content [type="date"],
.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th .date-content [type="date"] {
    background: #fff url(https://cdn1.iconfinder.com/data/icons/cc_mono_icon_set/blacks/16x16/calendar_2.png) 97% 50% no-repeat
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td .date-content [type="date"]::-webkit-inner-spin-button,
.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th .date-content [type="date"]::-webkit-inner-spin-button {
    display: none
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td .date-content [type="date"]::-webkit-calendar-picker-indicator,
.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th .date-content [type="date"]::-webkit-calendar-picker-indicator {
    opacity: 0
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td .time-content,
.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th .time-content {
    display: block;
    margin: 0 0 20px
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td .time-content p,
.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th .time-content p {
    font-weight: bold
}

@media only screen and (max-width: 47.9375em) {

    .page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td .time-content p,
    .page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th .time-content p {
        text-align: center
    }
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td .time-content .time-p,
.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th .time-content .time-p {
    -webkit-appearance: none;
    -moz-appearance: none;
    background: transparent;
    background-image: url("data:image/svg+xml;utf8,<svg fill='gray' height='24' viewBox='0 0 24 24' width='24' xmlns='http://www.w3.org/2000/svg'><path d='M7 10l5 5 5-5z'/><path d='M0 0h24v24H0z' fill='none'/></svg>");
    background-repeat: no-repeat;
    background-position-x: 95%;
    background-position-y: 50%;
    border: 1px solid #d2d2d2;
    border-radius: 2px;
    margin-right: 2rem;
    padding: 15px 5px 15px 15px;
    background-color: #fff;
    color: #656565
}

@media only screen and (max-width: 47.9375em) {

    .page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td .time-content .time-p,
    .page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th .time-content .time-p {
        display: block;
        margin: 10px auto 0
    }
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td .time-content .time-p .sel-time,
.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th .time-content .time-p .sel-time {
    color: #d2d2d2;
    display: none
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td .time-content select,
.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th .time-content select {
    border-radius: 2px;
    margin: 10px 0 0;
    width: 215px
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td .inquiry-input--comment,
.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th .inquiry-input--comment {
    border: 1px solid #d2d2d2;
    border-radius: 2px;
    height: 155px;
    padding: 5px 0 0 10px;
    width: 565px;
    -webkit-appearance: none;
    outline: 0
}

@media only screen and (max-width: 47.9375em) {

    .page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td .inquiry-input--comment,
    .page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th .inquiry-input--comment {
        height: 100px;
        width: 100%
    }
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td .inquiry-text,
.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th .inquiry-text {
    color: #313334;
    display: block;
    font-size: 14px
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td .container1 input,
.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th .container1 input {
    top: 0;
    left: 0;
    height: 15px;
    width: 15px;
    background-color: #fff;
    border: solid 1px #d2d2d2
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td .container,
.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th .container {
    display: inline-block;
    font-size: 14px;
    float: left;
    position: relative;
    padding-left: 18px;
    margin: 7px 15px 8px 0;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none
}

@media only screen and (max-width: 47.9375em) {

    .page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td .container,
    .page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th .container {
        display: block;
        float: none;
        margin: 7px auto 8px;
        width: 175px
    }
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td .container input,
.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th .container input {
    position: absolute;
    opacity: 0;
    cursor: pointer;
    height: 0;
    width: 0
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td .container .checkmark,
.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th .container .checkmark {
    position: absolute;
    top: 0;
    left: 0;
    height: 15px;
    width: 15px;
    background-color: #fff;
    border: solid 1px #d2d2d2
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td .container:hover input ~ .checkmark,
.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th .container:hover input ~ .checkmark {
    background-color: #ccc
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td .container input:checked ~ .checkmark,
.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th .container input:checked ~ .checkmark {
    background-color: #2196F3
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td .checkmark:after,
.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th .checkmark:after {
    content: "";
    position: absolute;
    display: none
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td .container input:checked ~ .checkmark:after,
.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th .container input:checked ~ .checkmark:after {
    display: block
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr td .container .checkmark:after,
.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry tr th .container .checkmark:after {
    left: 3.5px;
    top: 1.5px;
    width: 2.5px;
    height: 6px;
    border: solid white;
    border-width: 0 3px 3px 0;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg)
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry-nav {
    display: block;
    margin: 30px auto 40px;
    overflow: hidden;
    width: 310px
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry-nav .inquiry-nav--item {
    display: block;
    float: left;
    margin-right: 25px;
    transition: .5s
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry-nav .inquiry-nav--item:last-child {
    margin-right: 0px
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry-nav .inquiry-nav--item:hover {
    opacity: .7
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry-nav .inquiry-nav--item p {
    display: block;
    padding: 0 0 0 25px;
    position: relative
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .inquiry-nav .inquiry-nav--item p:before {
    background: url("../images/icon_foot_nav.png");
    background-size: 100%;
    background-repeat: no-repeat;
    content: "";
    display: block;
    height: 17px;
    left: 0px;
    position: absolute;
    top: 0px;
    width: 17px
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .submit {
    display: block;
    background-color: #e4474d;
    border-radius: 8px;
    border-bottom: 4px solid #c13a40;
    color: #fff;
    cursor: pointer;
    font-size: 24px;
    font-weight: bold;
    margin: 0px auto 115px;
    padding: 26.5px 0 20px;
    text-align: center;
    transition: .3s;
    width: 290.5px
}

@media only screen and (max-width: 47.9375em) {
    .page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .submit {
        font-size: 17px;
        margin: 23px auto 10px;
        padding: 18.25px 0 15px;
        width: 200px
    }
}

.page-top .requirements .requirements-contents .inquiry-form .inquiry-form-content .submit:hover {
    background-color: #fff;
    border: solid 1px #e4474d;
    border-bottom: solid 4px #e4474d;
    color: #e4474d
}

.page-top .requirements .requirements-contents .cover-access {
    display: block;
    width: 1040px
}

@media only screen and (max-width: 64em) {
    .page-top .requirements .requirements-contents .cover-access {
        width: 100%
    }
}

@media only screen and (max-width: 47.9375em) {
    .page-top .requirements .requirements-contents .cover-access {
        width: 100%
    }
}

.page-top .requirements .requirements-contents .cover-access iframe {
    display: block
}

@media only screen and (max-width: 47.9375em) {
    .page-top .requirements .requirements-contents .cover-access iframe {
        height: 200px;
        width: 100%
    }
}

.page-top .requirements .requirements-contents .cover-access img {
    width: 100%
}

.page-top .thanks {
    background-color: #fff;
    display: block;
    margin: 0;
    padding: 82.5px 0 100px
}

.page-top .thanks .thanks-content {
    margin: 0 30px
}

.page-top .thanks .thanks-content h2 {
    color: #222;
    font-size: 20px;
    font-weight: bold;
    letter-spacing: 1px;
    line-height: 100%;
    margin-bottom: 45px;
    text-align: center
}

.page-top .thanks .thanks-content p {
    color: #010b02;
    font-size: 15px;
    text-align: center;
    line-height: 150%;
    margin: 45px 0 30px
}

@media only screen and (max-width: 47.9375em) {
    .page-top .thanks .thanks-content p {
        font-size: 12px;
        margin: 11.5px 0 15px
    }
}

.page-top .thanks .thanks-content a {
    color: #103e93;
    display: block;
    text-align: center
}

.page-top .thanks .thanks-content a:hover {
    text-decoration: underline
}

.page-top a.anchor {
    display: block;
    position: relative;
    top: -75px;
    visibility: hidden
}

@media only screen and (max-width: 56.25em) {
    .page-top a.anchor {
        top: -30px
    }
}

.confirm .inquiry-form {
    background: url("../images/company_bg.png");
    background-size: 100%;
    background-repeat: repeat-y;
    background-position: bottom center;
    display: block;
    overflow: hidden;
    padding: 40px 0 50px
}

@media only screen and (max-width: 67.5em) {
    .confirm .inquiry-form {
        background-size: cover;
        padding: 5% 20px 5%
    }
}

@media only screen and (max-width: 47.9375em) {
    .confirm .inquiry-form {
        background-size: cover;
        padding: 59.5px 0 0
    }
}

.confirm .inquiry-form .wrapper {
    width: 910px
}

@media only screen and (max-width: 64em) {
    .confirm .inquiry-form .wrapper {
        width: 100%
    }
}

@media only screen and (max-width: 47.9375em) {
    .confirm .inquiry-form .wrapper {
        width: 100%
    }
}

.confirm .inquiry-form .inquiry-form-content {
    margin: 0 0;
    overflow: hidden
}

@media only screen and (max-width: 77.5em) {
    .confirm .inquiry-form .inquiry-form-content {
        margin: 0 auto
    }
}

@media only screen and (max-width: 60em) {
    .confirm .inquiry-form .inquiry-form-content {
        margin: 0 auto;
        padding: 0 20px
    }
}

@media only screen and (max-width: 47.9375em) {
    .confirm .inquiry-form .inquiry-form-content {
        margin: 0 4%;
        padding: 2% 0 3%
    }
}

.confirm .inquiry-form .inquiry-form-content .pc {
    display: block;
    margin: 0 auto;
    width: 387.5px
}

.confirm .inquiry-form .inquiry-form-content .pc img {
    width: 100%
}

@media only screen and (max-width: 47.9375em) {
    .confirm .inquiry-form .inquiry-form-content .pc {
        display: none
    }
}

.confirm .inquiry-form .inquiry-form-content .sp {
    display: none
}

@media only screen and (max-width: 47.9375em) {
    .confirm .inquiry-form .inquiry-form-content .sp {
        display: block;
        width: 100%
    }

    .confirm .inquiry-form .inquiry-form-content .sp img {
        margin: 0 auto;
        width: 80%
    }
}

.confirm .inquiry-form .inquiry-form-content .p-inquiry {
    color: #010b02;
    font-size: 15px;
    font-weight: bold;
    text-align: center;
    line-height: 150%;
    margin: 45px 0 30px
}

@media only screen and (max-width: 47.9375em) {
    .confirm .inquiry-form .inquiry-form-content .p-inquiry {
        font-size: 12px;
        margin: 5% 0 5%
    }
}

.confirm .inquiry-form .inquiry-form-content .p-inquiry .p-inquiry-span {
    color: #bd1b2a
}

.confirm .inquiry-form .inquiry-form-content .p-inquiry .n-line {
    display: inline-block
}

@media only screen and (max-width: 47.9375em) {
    .confirm .inquiry-form .inquiry-form-content .p-inquiry .n-line {
        display: block
    }
}

.confirm .inquiry-form .inquiry-form-content .inquiry {
    border: 1px solid #d2d2d2;
    color: #313334;
    width: 100%
}

@media only screen and (max-width: 47.9375em) {
    .confirm .inquiry-form .inquiry-form-content .inquiry {
        width: 100%
    }
}

.confirm .inquiry-form .inquiry-form-content .inquiry tr {
    border: 1px solid #d2d2d2
}

.confirm .inquiry-form .inquiry-form-content .inquiry tr td,
.confirm .inquiry-form .inquiry-form-content .inquiry tr th {
    padding: 25px 25px
}

@media only screen and (max-width: 60em) {

    .confirm .inquiry-form .inquiry-form-content .inquiry tr td,
    .confirm .inquiry-form .inquiry-form-content .inquiry tr th {
        padding: 10px 10px
    }
}

@media only screen and (max-width: 47.9375em) {

    .confirm .inquiry-form .inquiry-form-content .inquiry tr td,
    .confirm .inquiry-form .inquiry-form-content .inquiry tr th {
        display: block;
        padding: 10px;
        line-height: 150%
    }
}

.confirm .inquiry-form .inquiry-form-content .inquiry tr td:first-child,
.confirm .inquiry-form .inquiry-form-content .inquiry tr th:first-child {
    color: #313334;
    background-color: #f9f9f9;
    font-size: 15px;
    font-weight: bold;
    width: 300px
}

@media only screen and (max-width: 60em) {

    .confirm .inquiry-form .inquiry-form-content .inquiry tr td:first-child,
    .confirm .inquiry-form .inquiry-form-content .inquiry tr th:first-child {
        line-height: 150%
    }
}

@media only screen and (max-width: 47.9375em) {

    .confirm .inquiry-form .inquiry-form-content .inquiry tr td:first-child,
    .confirm .inquiry-form .inquiry-form-content .inquiry tr th:first-child {
        display: block;
        text-align: center;
        width: 100%
    }
}

.confirm .inquiry-form .inquiry-form-content .inquiry tr td:first-child .inquiry-r-required,
.confirm .inquiry-form .inquiry-form-content .inquiry tr th:first-child .inquiry-r-required {
    color: #fff;
    background-color: #bd1b2a;
    font-size: 12px;
    border-radius: 3px;
    padding: 4px 2px
}

.confirm .inquiry-form .inquiry-form-content .inquiry tr td:first-child .inquiry-b-required,
.confirm .inquiry-form .inquiry-form-content .inquiry tr th:first-child .inquiry-b-required {
    color: #fff;
    background-color: #103e93;
    font-size: 12px;
    border-radius: 3px;
    padding: 4px 2px
}

.confirm .inquiry-form .inquiry-form-content .inquiry tr td:last-child,
.confirm .inquiry-form .inquiry-form-content .inquiry tr th:last-child {
    background-color: #fdfdfd;
    font-size: 14px;
    padding: 15px 22px
}

@media only screen and (max-width: 47.9375em) {

    .confirm .inquiry-form .inquiry-form-content .inquiry tr td:last-child,
    .confirm .inquiry-form .inquiry-form-content .inquiry tr th:last-child {
        text-align: center
    }
}

.confirm .inquiry-form .inquiry-form-content .inquiry tr td .inquiry-input,
.confirm .inquiry-form .inquiry-form-content .inquiry tr th .inquiry-input {
    color: #656565;
    border: 1px solid #d2d2d2;
    border-radius: 2px;
    height: 50px;
    line-height: 50px;
    font-size: 16px;
    padding-left: 10px;
    width: 100%;
    -webkit-appearance: none;
    outline: 0
}

.confirm .inquiry-form .inquiry-form-content .inquiry tr td .inquiry-input::placeholder,
.confirm .inquiry-form .inquiry-form-content .inquiry tr th .inquiry-input::placeholder {
    font-size: 16px;
    line-height: 50px
}

.confirm .inquiry-form .inquiry-form-content .inquiry tr td .inquiry-input--comment,
.confirm .inquiry-form .inquiry-form-content .inquiry tr th .inquiry-input--comment {
    border: 1px solid #d2d2d2;
    border-radius: 2px;
    height: 155px;
    padding: 5px 0 0 10px;
    width: 565px;
    -webkit-appearance: none;
    outline: 0
}

@media only screen and (max-width: 47.9375em) {

    .confirm .inquiry-form .inquiry-form-content .inquiry tr td .inquiry-input--comment,
    .confirm .inquiry-form .inquiry-form-content .inquiry tr th .inquiry-input--comment {
        height: 100px;
        width: 100%
    }
}

.confirm .inquiry-form .inquiry-form-content .inquiry tr td .inquiry-text,
.confirm .inquiry-form .inquiry-form-content .inquiry tr th .inquiry-text {
    color: #313334;
    display: block;
    font-size: 14px
}

.confirm .inquiry-form .inquiry-form-content .submit {
    display: block;
    background-color: #e4474d;
    border-radius: 8px;
    border-bottom: 4px solid #c13a40;
    color: #fff;
    cursor: pointer;
    font-size: 24px;
    font-weight: bold;
    margin: 46px auto 50px;
    padding: 26.5px 0 20px;
    text-align: center;
    transition: .3s;
    width: 290.5px
}

@media only screen and (max-width: 47.9375em) {
    .confirm .inquiry-form .inquiry-form-content .submit {
        font-size: 12px;
        margin: 23px auto 10px;
        padding: 13.25px 0 10px
    }
}

.confirm .inquiry-form .inquiry-form-content .submit:hover {
    background-color: #fff;
    border: solid 1px #e4474d;
    border-bottom: solid 4px #e4474d;
    color: #e4474d
}

.confirm .inquiry-form .inquiry-form-content .submit-btn--wrap {
    display: block;
    margin: 46px auto 50px;
    overflow: hidden;
    width: 60%
}

@media only screen and (max-width: 47.9375em) {
    .confirm .inquiry-form .inquiry-form-content .submit-btn--wrap {
        width: max-content
    }
}

.confirm .inquiry-form .inquiry-form-content .submit-btn--wrap .submit-btn--item {
    display: inline-block;
    background-color: #e4474d;
    border-radius: 8px;
    border-bottom: 4px solid #c13a40;
    color: #fff;
    cursor: pointer;
    font-size: 24px;
    font-weight: bold;
    float: left;
    margin-right: 5%;
    padding: 26.5px 0 20px;
    text-align: center;
    transition: .3s;
    width: 47.5%
}

@media only screen and (max-width: 64em) {
    .confirm .inquiry-form .inquiry-form-content .submit-btn--wrap .submit-btn--item {
        font-size: 18px
    }
}

@media only screen and (max-width: 47.9375em) {
    .confirm .inquiry-form .inquiry-form-content .submit-btn--wrap .submit-btn--item {
        font-size: 12px;
        padding: 13.25px 0 10px;
        margin-right: 25px;
        width: 145.25px
    }
}

.confirm .inquiry-form .inquiry-form-content .submit-btn--wrap .submit-btn--item::first-child {
    background-color: #14689e
}

.confirm .inquiry-form .inquiry-form-content .submit-btn--wrap .submit-btn--item.sub-return {
    background-color: #14689e;
    border-bottom: 4px solid #01578f
}

.confirm .inquiry-form .inquiry-form-content .submit-btn--wrap .submit-btn--item.sub-return:hover {
    color: #14689e;
    border: solid 1px #14689e;
    border-bottom: 4px solid #01578f
}

.confirm .inquiry-form .inquiry-form-content .submit-btn--wrap .submit-btn--item:last-child {
    margin-right: 0
}

.confirm .inquiry-form .inquiry-form-content .submit-btn--wrap .submit-btn--item:hover {
    background-color: #fff;
    border: solid 1px #e4474d;
    border-bottom: solid 4px #e4474d;
    color: #e4474d
}

.confirm .inquiry-form .inquiry-form-content .submit-return {
    display: inline-block;
    background-color: #e4474d;
    border-radius: 8px;
    border-bottom: 4px solid #c13a40;
    color: #fff;
    cursor: pointer;
    font-size: 24px;
    font-weight: bold;
    margin: 46px auto 50px;
    padding: 26.5px 0 20px;
    text-align: center;
    transition: .3s;
    width: 290.5px
}

@media only screen and (max-width: 47.9375em) {
    .confirm .inquiry-form .inquiry-form-content .submit-return {
        font-size: 12px;
        margin: 23px auto 10px;
        padding: 13.25px 0 10px;
        width: 145.25px
    }
}

.confirm .inquiry-form .inquiry-form-content .submit-return:hover {
    background-color: #fff;
    border: solid 1px #e4474d;
    border-bottom: solid 4px #e4474d;
    color: #e4474d
}

.contents .thanks {
    background: url("../images/company_bg.png");
    background-size: 100%;
    background-repeat: repeat-y;
    background-position: bottom center;
    overflow: hidden;
    display: block;
    padding: 200px 0 200px
}

@media only screen and (max-width: 67.5em) {
    .contents .thanks {
        background-size: cover
    }
}

@media only screen and (max-width: 47.9375em) {
    .contents .thanks {
        background-size: cover;
        padding: 100px 0 100px
    }
}

.contents .thanks h2 {
    font-size: 22px;
    line-height: 150%;
    text-align: center
}

.contents .thanks p {
    display: block;
    font-size: 15px;
    line-height: 250%;
    text-align: center
}

.contents .thanks .home {
    border: solid 1px #000;
    color: #000;
    display: block;
    font-size: 18px;
    font-weight: bold;
    height: 60px;
    line-height: 60px;
    margin: 30px auto 0;
    padding: 0 50px;
    text-align: center;
    transition: .3s;
    width: max-content
}

.contents .thanks .home:hover {
    background-color: #000;
    color: #fff
}

.thanks-content {
    padding: 0 15px
}

.company {
    background: url("../images/company_bg.png");
    background-size: 100%;
    background-repeat: repeat-y;
    background-position: bottom center;
    display: block;
    overflow: hidden;
    padding: 85px 0 90px
}

@media only screen and (max-width: 64em) {
    .company {
        background-size: cover;
        padding: 50px 20px 50px
    }
}

@media only screen and (max-width: 47.9375em) {
    .company {
        background-size: cover;
        padding: 50px 20px 50px
    }
}

.company .company-contents .table-company {
    background-color: #fff;
    border: solid 1px #d2d2d2;
    display: table;
    margin: 0 auto 80px;
    width: 770px
}

@media only screen and (max-width: 47.9375em) {
    .company .company-contents .table-company {
        width: 100%
    }
}

.company .company-contents .table-company tr th {
    background-color: #54cddb;
    color: #fff;
    font-size: 19px;
    font-weight: bold;
    padding: 18px 0 15px;
    text-align: center
}

.company .company-contents .table-company tr td {
    border: solid 1px #d2d2d2;
    font-size: 17px;
    line-height: 175%;
    padding: 20px 0 15px
}

.company .company-contents .table-company tr td:nth-child(1) {
    background-color: #e9fdfc;
    text-align: center;
    width: 210px
}

@media only screen and (max-width: 47.9375em) {
    .company .company-contents .table-company tr td:nth-child(1) {
        border-bottom: none;
        display: block;
        width: 100%
    }
}

.company .company-contents .table-company tr td:nth-child(2) {
    padding: 20px 45px 15px
}

@media only screen and (max-width: 47.9375em) {
    .company .company-contents .table-company tr td:nth-child(2) {
        border-top: none;
        display: block;
        text-align: center;
        width: 100%
    }
}

.company .company-contents .table-company tr td span {
    color: #1b8a37;
    display: block;
    margin: 0 0 15px;
    text-decoration: underline;
    text-underline-position: under
}

.company .company-contents .inquiry-nav {
    display: block;
    margin: 30px auto 40px;
    overflow: hidden;
    width: 310px
}

.company .company-contents .inquiry-nav .inquiry-nav--item {
    display: block;
    float: left;
    margin-right: 25px;
    transition: .5s
}

.company .company-contents .inquiry-nav .inquiry-nav--item:last-child {
    margin-right: 0px
}

.company .company-contents .inquiry-nav .inquiry-nav--item:hover {
    opacity: .7
}

.company .company-contents .inquiry-nav .inquiry-nav--item p {
    display: block;
    padding: 0 0 0 25px;
    position: relative
}

.company .company-contents .inquiry-nav .inquiry-nav--item p:before {
    background: url("../images/icon_foot_nav.png");
    background-size: 100%;
    background-repeat: no-repeat;
    content: "";
    display: block;
    height: 17px;
    left: 0px;
    position: absolute;
    top: 0px;
    width: 17px
}

.company .company-contents .company-cright {
    display: block
}

.company .company-contents .company-cright p {
    display: block;
    font-size: 14px;
    margin: 75px auto 0;
    text-align: center
}

.privacy {
    background: url("../images/privacy_bg.png");
    background-size: 100%;
    background-repeat: repeat-y;
    background-position: bottom center;
    display: block;
    overflow: hidden;
    padding: 85px 0 45px
}

@media only screen and (max-width: 64em) {
    .privacy {
        background-size: cover;
        padding: 50px 20px 50px
    }
}

@media only screen and (max-width: 47.9375em) {
    .privacy {
        background-size: cover;
        padding: 50px 20px 50px
    }
}

.privacy .privacy-contents .inner-wrapper {
    background-color: #fbfcff;
    border-radius: 10px;
    display: block;
    margin: 0 auto;
    padding: 55px 55px 35px;
    width: 780px
}

@media only screen and (max-width: 64em) {
    .privacy .privacy-contents .inner-wrapper {
        padding: 30px 30px 30px;
        width: 100%
    }
}

@media only screen and (max-width: 47.9375em) {
    .privacy .privacy-contents .inner-wrapper {
        padding: 30px 30px 30px;
        width: 100%
    }
}

.privacy .privacy-contents .inner-wrapper .title {
    display: block;
    font-size: 19px;
    font-weight: bold;
    margin: 0 0 30px;
    text-align: center
}

@media only screen and (max-width: 47.9375em) {
    .privacy .privacy-contents .inner-wrapper .title {
        line-height: 150%
    }
}

.privacy .privacy-contents .inner-wrapper .details {
    display: block;
    font-size: 14px;
    line-height: 200%;
    margin: 0 0 25px
}

.privacy .privacy-contents .inner-wrapper .details span {
    font-weight: bold
}

.privacy .privacy-contents .inner-wrapper .details.no-p {
    margin: 0 0 0
}

.privacy .privacy-contents .inner-wrapper .lists-details {
    display: block;
    margin: 0px 0 25px
}

.privacy .privacy-contents .inner-wrapper .lists-details .lists--item {
    display: block;
    font-size: 14px;
    line-height: 200%;
    padding: 0 0 0 15px;
    position: relative
}

.privacy .privacy-contents .inner-wrapper .lists-details .lists--item:before {
    content: "・";
    display: inline-block;
    height: 2px;
    width: 2px;
    position: absolute;
    left: 0px;
    top: 1px
}

.privacy .privacy-contents .inner-wrapper .s-title {
    display: block;
    font-size: 15px;
    font-weight: bold;
    margin: 0 0 10px
}

.privacy .privacy-contents .inquiry-nav {
    display: block;
    margin: 80px auto 40px;
    overflow: hidden;
    width: 310px
}

.privacy .privacy-contents .inquiry-nav .inquiry-nav--item {
    display: block;
    float: left;
    margin-right: 25px;
    transition: .5s
}

.privacy .privacy-contents .inquiry-nav .inquiry-nav--item:last-child {
    margin-right: 0px
}

.privacy .privacy-contents .inquiry-nav .inquiry-nav--item:hover {
    opacity: .7
}

.privacy .privacy-contents .inquiry-nav .inquiry-nav--item p {
    display: block;
    padding: 0 0 0 25px;
    position: relative
}

.privacy .privacy-contents .inquiry-nav .inquiry-nav--item p:before {
    background: url("../images/icon_foot_nav.png");
    background-size: 100%;
    background-repeat: no-repeat;
    content: "";
    display: block;
    height: 17px;
    left: 0px;
    position: absolute;
    top: 0px;
    width: 17px
}

.privacy .privacy-contents .company-cright {
    display: block
}

.privacy .privacy-contents .company-cright p {
    display: block;
    font-size: 14px;
    margin: 75px auto 0;
    text-align: center
}
