@charset "utf-8";

/* normalize
------------------------------------------------------------*/

html {
line-height: 1.5;
-webkit-text-size-adjust: 100%;
}

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.5;
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; /* 1 */
font: inherit; /* 2 */
}

details {
display: block;
}

summary {
display: list-item;
}

template {
display: none;
}

[hidden] {
display: none;
}

/* End normalize */


/* formatting style
------------------------------------------------------------*/

* {
margin: 0;
padding: 0;
font-style: normal;
}

html {
font-size: 100%;
height: 100%;
}

body {
color: #333;
font-family: "Open Sans", "Noto Sans JP", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
font-optical-sizing: auto; /* for Variable Fonts */
font-variation-settings: "wdth" 100; /* for Variable Fonts */
font-style: normal; /* from Google fonts */
font-weight: 400; /* normal */
font-size: 0.875rem;
line-height:1.5;
margin: 0;
padding: 0;
height: 100%;
text-size-adjust: 100%;
-webkit-text-size-adjust: 100%; /*スマホのランドスケープで文字を拡大させない*/
background: #fff;
}
@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
body {
font-size: 1rem;
}
}

*,
*::before,
*::after {
box-sizing: border-box;
}

h1, h2, h3, h4, h5, h6 {
font-weight: 400; /* normal */
font-size: 1rem;
line-height:1.5;
}

p {
line-height:1.8;
text-align: justify;
}

p.note {
text-indent: -1em;
padding-left: 1em;
}

p + p {
padding-top: 1em;
}

ul {
list-style: none;
}

a {
text-decoration: none;
color: inherit;
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
a {
transition: 0.6s;
}
}

a:hover {
opacity: 0.6;
}

a img {
border: none;
}

a:link,
a:visited,
a:hover,
a:active {
text-decoration: none;
color: inherit;
}

img {
vertical-align: bottom; /* aタグ等の余白対策 */
max-width: 100%;
height: auto;
}

a[href^="tel:"] {
cursor: default;
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
a[href^="tel:"] {
pointer-events: none;
}
}

a[href^="tel:"]:hover {
opacity: 1;
}

span.inline-b {
display: inline-block;
}

a:focus, *:focus {
outline: none;
}

/* End formatting style */


/* responsive
------------------------------------------------------------*/

@media only screen and (max-width: 767px) { /* 767px以下で適用、スマホ専用CSS */
.sp-none {
display: none;
}
.sp-br-none br {
display: none;
}
}

@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
.sp-only {
display: none;
}
}

@media only screen and (max-width: 1024px) { /* 1024px以下で適用、PC以外用CSS */
.pc-only {
display: none;
}
}

@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
.pc-none {
display: none; 
}
}

@media only screen and (min-width: 1264px) { /* 1264px以上で適用、PCフルサイズ用CSS */
}

@media only screen and (min-width: 1440px) { /* 1440px以上で適用、bg_max用CSS */
}

@media only screen and (min-width: 1920px) { /* 1920px以上で適用、フルHD以上用CSS */
}

@media only screen and (max-width: 374px) { /* 374px以下で適用、for mini */
}

/* End responsive */


/* scroll-in（または、scroll-in-top） を付けて使用 基本はinnerに使用
------------------------------------------------------------*/

.fadein-up { /* scroll-in fadein-up */
opacity : 0;
transform : translate(0, 30px);
transition : 1.2s;
}
.fadein-up.on {
opacity : 1;
transform : translate(0, 0);
}

.fadein-right { /* 親要素に overflow: hidden; */
opacity : 0;
transform : translate(50px, 0);
transition : 1.2s;
}
.fadein-right.on {
opacity : 1;
transform : translate(0, 0);
}

.slidein-left { /* 必要に応じて display: inline-block; 等の設定を追加してスピード調整 */
clip-path: inset(0 100% 0 0);
transition: 1.2s ease-in-out;
will-change: clip-path; /* ブラウザに事前通知 */
opacity: 0;
}
.slidein-left.on {
clip-path: inset(0);
opacity: 1;
}

.hoge {
transition-delay: 0.3s;
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
.hoge > .hogehoge:nth-of-type(2) {
transition-delay: 0.3s;
}
}

/* End scroll-in */


/* header
------------------------------------------------------------*/

#header {
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 60px;
z-index: 999;
transition: 1.2s;
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
#header {
height: 90px;
}
}

.scroll #header {
background: #fff;
box-shadow: 0 1px 2px rgba(176,176,176,0.3);
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
.scroll #header {
background: rgba(255,255,255, 0.8);
}
}

.nav-open #header {
background: #fff;
}

.header-inner {
position: relative;
display: flex;
justify-content: space-between;
margin: 0 0 0 24px;
}
@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
.header-inner {
margin: 0 0 0 32px;
}
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
.header-inner {
margin: 0 32px;
}
}
@media only screen and (min-width: 1264px) { /* 1264px以上で適用、PCフルサイズ用CSS */
.header-inner {
margin: 0 3%;
}
}
@media only screen and (max-width: 374px) { /* 374px以下で適用、for mini */
.header-inner {
margin: 0 0 0 16px;
}
}

.header-logo {
width: 184px;
margin: 10px 0 0 0;
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
.header-logo {
width: 230px;
margin: 20px 0 0 0;
}
}

.header-logo a {
display: block;
}

.hamburger {
padding: 29px 16px;
position: relative;
cursor: pointer;
border: none;
transition: 1.2s;
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
.hamburger {
display: none; 
}
}

.scroll .hamburger,
.nav-open .hamburger{
background-color: #0080ff;
}

span.hamburger-border,
span.hamburger-border:before,
span.hamburger-border:after {
display: block;
height: 2px;
width: 32px;
transition: 0.6s;
background-color: #0080ff;
}

.slug-front span.hamburger-border,
.slug-front span.hamburger-border:before,
.slug-front span.hamburger-border:after,
.scroll span.hamburger-border,
.scroll span.hamburger-border:before,
.scroll span.hamburger-border:after,
.nav-open span.hamburger-border,
.nav-open span.hamburger-border:before,
.nav-open span.hamburger-border:after {
background-color: #fff;
}

span.hamburger-border:before,
span.hamburger-border:after {
content: "";
position: absolute;
}

span.hamburger-border:before {
margin-top: -12px;
}

span.hamburger-border:after {
margin-top: 12px;
}

.nav-open span.hamburger-border {
background-color: transparent;
}

.nav-open span.hamburger-border:before,
.nav-open span.hamburger-border:after {
margin-top: 0;
}

.nav-open span.hamburger-border:before {
transform: rotate(225deg);
}
.nav-open span.hamburger-border:after {
transform: rotate(-225deg);
}

@media only screen and (max-width: 1024px) { /* 1024px以下で適用、PC以外用CSS */
body.nav-open {
overflow: hidden;
}
}

@media only screen and (max-width: 1024px) { /* 1024px以下で適用、PC以外用CSS */
.nav {
position: fixed;
top: 60px; /* ヘッダー下に */
right: 0;
width: 60%;
height: calc(100vh - 60px); /* ヘッダーの高さを差し引く */
background-color: #fff;
transition: transform 0.6s;
z-index: 950;
overflow-y: auto;
transform: translateX(100%);
border-top: solid 1px #e1e1e1;
}
.nav-open .nav {
transform: translateX(0);
}
}
@media only screen and (max-width: 767px) { /* 767px以下で適用、スマホ専用CSS */
.nav {
width: 100%;
}
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
.nav {
position: relative;
}
}

.nav-list {
font-size: 1rem;
margin: 0.5em 24px;
display: flex;
flex-direction: column;
text-align: center;
}
@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
.nav-list {
margin: 0.5em 32px;
}
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
.nav-list {
flex-direction: row;
margin: 0;
}
}

.nav-item {
color: #00207f;
margin: 1em 0 0 0;
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
.nav-item {
margin: 25px 0 0 1em;
}
}
@media only screen and (min-width: 1264px) { /* 1264px以上で適用、PCフルサイズ用CSS */
.nav-item {
margin: 25px 0 0 1.5em;
}
}

.nav-item.common {
border-bottom: solid 1px #e1e1e1;
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
.nav-item.common {
border-bottom: none;
}
}

.nav-item.common a {
display: block;
padding: 0.5em;
position: relative;
}

@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
.nav-item.common a:hover {
opacity: 1;
color: #0080ff;
}
}

@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
.nav-item.common a:after {
content: "";
display: block;
position: absolute;
width: 100%;
height: 1px;
bottom: 0;
left: 0;
background: #0080ff;
transition: 0.6s;
transform: scale(0, 1);
transform-origin: center top;
}
.nav-item.common a:hover:after {
transform: scale(1, 1);
}
}

.nav-item.contact a {
display: inline-block;
color: #fff;
background: #0080ff;
margin: 0.5em 0 0 0;
padding: 0.5em 1.5em;
position: relative;
border-radius: 100vh;
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
.nav-item.contact a {
display: block;
margin: 0 0 0 0.5em;
}
}

.nav-item.contact a:before {
font-family: "Font Awesome 5 Free";
font-weight: 900;
content: "\f0e0";
margin-right: 0.5em;
}

@media only screen and (max-width: 1024px) { /* 1024px以下で適用、PC以外用CSS */
.black-bg {
position: fixed;
left: 0;
top: 60px; /* ヘッダー下に */
width: 100vw;
height: calc(100vh - 60px); /* ヘッダーの高さを差し引く */
z-index: 900;
background-color: #333;
opacity: 0;
visibility: hidden;
transition: 0.6s;
cursor: pointer;
}
.nav-open .black-bg {
opacity: 0.8;
visibility: visible;
}
}

/* End header */


/* content
------------------------------------------------------------*/

/* End content */


/* top-common
------------------------------------------------------------*/

#top-common {
margin-top: 60px;
height: 56vw;
background-image: url("../images/common/top_common_bg_sp.jpg");
background-position: center center;
background-repeat: no-repeat;
background-size: cover;
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
#top-common {
margin-top: 90px;
transition: margin-top 0.6s;
height: 30vw;
min-height: 432px;
background-image: url("../images/common/top_common_bg_pc.jpg");
}
}

#top-common .inner-common {
position: relative;
height: 100%;
display: flex;
justify-content: center;
}

#top-common p.headline {
line-height: 1.5;
}

#top-common h1,
#top-common p.headline {
color: #fff;
margin: auto 0 8vw 0;
text-align: center;
}
@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
#top-common h1,
#top-common p.headline {
margin: auto 0 10vw 0;
}
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
#top-common h1,
#top-common p.headline {
margin: auto 0 4em 0;
}
}
@media only screen and (min-width: 1440px) { /* 1440px以上で適用、bg_max用CSS */
#top-common h1,
#top-common p.headline {
margin: auto 0 4.5vw 0;
}
}

#top-common h1 span.en,
#top-common p.headline span.en {
display: block;
font-weight: 700;
font-size: 2rem;
}
@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
#top-common h1 span.en,
#top-common p.headline span.en {
font-size: 3rem;
}
}

#top-common h1 span.jp,
#top-common p.headline span.jp {
display: inline-block;
font-size: 0.75rem;
padding: 0 2em;
position: relative;
}
@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
#top-common h1 span.jp,
#top-common p.headline span.jp {
font-size: 0.875rem;
}
}

#top-common h1 span.jp:before,
#top-common h1 span.jp:after,
#top-common p.headline span.jp:before,
#top-common p.headline span.jp:after {
content: "";
display: block;
position: absolute;
width: 1.5em;
height: 1px;
background: #fff;
top: 50%;
}

#top-common h1 span.jp:before,
#top-common p.headline span.jp:before {
left: 0;
}

#top-common h1 span.jp:after,
#top-common p.headline span.jp:after {
right: 0;
}

/* End top-common */


/* section-common
------------------------------*/

.section-common {
padding: 60px 0 70px;
}
@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
.section-common {
padding: 80px 0 90px;
}
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
.section-common {
padding: 110px 0 120px;
}
}

.section-common.bg-blue {
background: #f5faff;
}

.section-common.bg-gray {
background: #f5f5f5;
}

/* End section-common */


/* div-common
------------------------------*/

div.inner-common {
margin: 0 24px;
}
@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
div.inner-common {
margin: 0 32px;
}
}
@media only screen and (min-width: 1264px) { /* 1264px以上で適用、PCフルサイズ用CSS */
div.inner-common {
max-width: 1200px;
margin: 0 auto;
}
}
@media only screen and (max-width: 374px) { /* 374px以下で適用、for mini */
div.inner-common {
margin: 0 16px;
}
}

@media only screen and (max-width: 767px) { /* 767px以下で適用、スマホ専用CSS */
div.inner-common.sp-exp {
margin: 0 16px;
}
}

@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
div.inner-common.pc-900 {
max-width: 900px;
margin: 0 auto;
}
}

@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
div.flex-1-2,
ul.flex-1-2 {
display: flex;
justify-content: space-between;
flex-wrap: wrap;
}
}

@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
div.flex-1-2 > div,
ul.flex-1-2 > li {
width: 48%;
}
}

@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
div.flex-1-3,
ul.flex-1-3 {
display: flex;
justify-content: space-between;
flex-wrap: wrap;
}
div.flex-1-3:after,
ul.flex-1-3:after {
content: "";
display: block;
width: 31%;
height: 0;
}
}

@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
div.flex-1-3 > div,
ul.flex-1-3 > li {
width: 31%;
}
}

/* End div-common */


/* common
------------------------------*/

h2.common {
color: #00207f;
margin: 0 0 2em 0;
line-height: 1.2;
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
h2.common {
margin: 0 0 4em 0;
}
}

h2.common.center {
text-align: center;
}

h2.common .en {
display: block;
font-weight: 700;
font-size: 2rem;
}
@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
h2.common .en {
font-size: 3rem;
}
}

h2.common .en:first-letter {
color: #0080ff;
}

h2.common .jp {
display: block;
font-size: 0.75rem;
padding: 0.5em 0 0 1.5em;
}
@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
h2.common .jp {
font-size: 0.875rem;
}
}

h2.common.center .jp {
padding: 0.5em 0 0 0;
}

p.point {
position: relative;
padding: 0 0 0 1em;
}

p.point:before {
content: "";
display: block;
position: absolute;
width: 0.5em;
height: 0.5em;
top: 0.65em;
left: 0;
background: #333;
}

a.link {
color: #0080ff;
text-decoration: underline;
text-underline-offset: 0.2em;
}

/* End common */


/* btn
------------------------------*/

.btn-wrap {
text-align: center;
margin-top: 3em;
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
.btn-wrap {
margin-top: 4em;
}
}

.btn-wrap.nomargin {
margin-top: 0;
}

.btn-wrap.left {
text-align: inherit;
}

.btn-wrap.flex {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
}
@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
.btn-wrap.flex {
flex-direction: row;
flex-wrap: wrap;
}
}

@media only screen and (max-width: 767px) { /* 767px以下で適用、スマホ専用CSS */
.btn-wrap.flex a.btn-common + a.btn-common {
margin-top: 2em;
}
}
@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
.btn-wrap.flex a.btn-common {
margin: 0 1em;
}
}

a.btn-common {
text-align: center;
color: #0080ff;
min-width: 18em;
padding: 14px 4em;
border: solid #0080ff 1px;
background: #fff;
display: inline-block;
position: relative;
}

a.btn-common:hover {
opacity: 1;
color: #fff;
background: #0080ff;
}

a.btn-common:before {
content: "";
display: block;
position: absolute;
height: 1px;
background: #0080ff;
top: 50%;
width: 2em;
right: 1em;
}

a.btn-common:hover:before {
background: #fff;
}

a.btn-common:after {
content: "";
display: block;
position: absolute;
width: 0;
height: 0;
border-left: solid 10px #0080ff;
border-top: solid 6px transparent;
top: 50%;
right: 1em;
margin-top: -6px;
}

a.btn-common:hover:after {
border-left: solid 10px #fff;
}

@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
a.btn-common:before,
a.btn-common:after {
transition: 0.6s;
}
}

a.btn-link {
text-align: center;
color: #0080ff;
min-width: 18em;
padding: 14px 4em;
border: solid #0080ff 1px;
background: #fff;
display: inline-block;
position: relative;
}

a.btn-link:hover {
opacity: 1;
color: #fff;
background: #0080ff;
}

a.btn-link:before,
a.btn-link:after {
content: "";
display: block;
position: absolute;
width: 8px;
height: 6px;
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
a.btn-link:before,
a.btn-link:after {
transition: 0.6s;
}
}

a.btn-link:before {
border: solid 1px #0080ff;
top: 6px;
right: 6px;
}

a.btn-link:hover:before {
border: solid 1px #fff;
}

a.btn-link:after {
border-left: solid 1px #0080ff;
border-bottom: solid 1px #0080ff;
top: 9px;
right: 9px;
}

a.btn-link:hover:after {
border-left: solid 1px #fff;
border-bottom: solid 1px #fff;
}

a.btn-tel {
display: inline-flex;
flex-direction: column;
margin: 2em 0 0 0;
padding: 1em;
min-width: 18em;
border: solid #0080ff 1px;
background: #fff;
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
a.btn-tel {
pointer-events: none;
border: none;
background: none;
margin: 1em 0 0 0;
}
}

@media only screen and (max-width: 767px) { /* 767px以下で適用、スマホ専用CSS */
.nav a.btn-tel {
font-size: 0.875rem; /* for header */
}
}

a.btn-tel span.num {
font-size: 1.375rem;
color: #0080ff;
margin: 0 auto;
}
@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
a.btn-tel span.num {
font-weight: 500;
}
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
a.btn-tel span.num {
font-size: 2rem;
font-weight: 600;
}
}

a.btn-tel span.num:before {
font-family: "Font Awesome 5 Free";
font-weight: 900;
font-size: 1rem;
content: "\f879";
margin-right: 0.5em;
display: inline-block;
transform: translateY(-2px);
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
a.btn-tel span.num:before {
font-size: 1.375rem;
}
}

a.btn-tel span.note {
font-size: 0.75rem;
color: #fff;
background: #0080ff;
border-radius: 100vh;
margin: 0.5em auto 0;
padding: 2px 1.5em;
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
a.btn-tel span.note {
font-size: 0.875rem;
margin: 0 auto;
padding: 2px 2em 2px 2.2em;
}
}

/* End btn */


/* page-top
------------------------------------------------------------*/

#page-top{
position: fixed;
bottom: 16px;
right: 16px;
width: 46px;
height: 46px;
border-radius: 100vh;
background: #fff;
box-shadow: 0 0 0 1px #dcdcdc;
opacity:0;
transform : translate(0, 100px);
transition : 1.2s;
z-index: 700;
}
@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
#page-top{
bottom: 24px;
right: 24px;
}
}

#page-top.on{
opacity:1;
transform : translate(0, 0);
}

#page-top a {
display: block;
width: 100%;
height: 100%;
color: #ffffff;
}

#page-top a:before {
content: "";
width: 15px;
height: 15px;
border: 0;
border-top: solid 1px #333;
border-left: solid 1px #333;
position: absolute;
top: 50%;
left: 50%;
margin: -7px 0 0 0;
transform: rotate(45deg);
transform-origin:0 0;
}

/* End page-top */


/* fotter-fix
------------------------------------------------------------*/

body {
display: flex;
flex-direction: column;
min-height: 100vh;
}

#footer {
margin-top: auto;
}

/* End fotter-fix */


/* footer
------------------------------------------------------------*/

#footer-contact {
text-align: center;
background-image: url("../images/common/footer_contact_bg_sp.jpg");
background-repeat: no-repeat;
background-size: cover;
background-position: bottom center;
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
#footer-contact {
background-image: url("../images/common/footer_contact_bg_pc.jpg");
}
}

#footer-contact p{
color: #00207f;
}
@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
#footer-contact p{
text-align: center;
}
}

.footer-contact-area {
max-width: 900px;
margin: 3em auto 0;
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
.footer-contact-area {
background: rgba(255,255,255,0.6);
box-shadow: 0 2px 12px 4px rgba(176,176,176,0.3);
border-radius: 10px;
margin: 4em auto 0;
padding: 4em 0 2em;
}
}

@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
.footer-info {
display: flex;
justify-content: center;
align-items: center;
}
}

.footer-info .logo img {
width: 184px;
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
.footer-info .logo img {
width: 230px;
}
}

.footer-info .para {
margin: 1em 0 0 0;
}
@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
.footer-info .para {
margin: 0 0 0 2em;
}
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
.footer-info .para {
margin: 0 0 0 4em;
}
}

.footer-info .para p {
font-size: 0.875rem;
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
.footer-info .para p {
font-size: 1rem;
}
}

.footer-info .para p + p {
padding-top: 0;
}

.footer-info .para p.name {
font-weight: 700;
}

.footer-sitemap {
margin: 0.5em 0 0 0;
display: flex;
flex-wrap: wrap;
justify-content: space-between;
}
@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
.footer-sitemap {
justify-content: center;
}
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
.footer-sitemap {
margin: 1.5em 0 0 0;
}
}

.footer-sitemap li {
font-size: 0.875rem;
width: 48%;
margin: 1.5em 0 0 0;
position: relative;
}
.footer-sitemap li:last-of-type {
width: 100%;
}
@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
.footer-sitemap li {
width: auto;
text-align: center;
}
.footer-sitemap li:last-of-type {
width: auto;
}
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
.footer-sitemap li {
font-size: 1rem;
}
}

.footer-sitemap li:before {
content: "";
display: block;
position: absolute;
width: 1px;
height: 100%;
left: 0;
top: 0;
background: #333;
}

@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
.footer-sitemap li:last-of-type:after {
content: "";
display: block;
position: absolute;
width: 1px;
height: 100%;
right: 0;
top: 0;
background: #333;
}
}

.footer-sitemap li a {
display: inline-block;
padding: 0 0.5em;
}
@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
.footer-sitemap li a {
margin: 0 0.5em;
}
}

p.copyright {
text-align: center;
font-size: 0.875rem;
margin-top: 3em;
}
@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
p.copyright {
font-size: 0.875rem;
margin-top: 4em;
}
}

/* End footer */







