@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: #222;
font-family: "Noto Serif JP", "游明朝", "Yu Mincho", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "ＭＳ Ｐ明朝", "MS PMincho", 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;
}
}

.sans-serif {
font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", YuGothic, -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
}

.sans-serif.bold { /* 見出し等で「游ゴシック Medium」では太すぎる場合 */
font-family: "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
font-weight: 700; /* bold */
}

*,
*::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;
}
@media only screen and (max-width: 767px) { /* 767px以下で適用、スマホ専用CSS */
p {
margin-right: 0.5em;
margin-left: 0.5em;
}
}

p.note {
text-indent: -1em;
padding-left: 1em;
}

p + p {
padding-top: 1em;
}

ul {
list-style: none;
}

a {
text-decoration: none;
color: inherit;
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;
}

span.inline-b {
display: inline-block;
}


/* 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 */
.tab-sp-only {
display: none; 
}
}

@media only screen and (min-width: 1248px) { /* 1248px以上で適用、PCフルサイズ用CSS */
}

@media only screen and (min-width: 1920px) { /* 1920px以上で適用、フルHD以上用CSS */
}

@media only screen and (max-width: 374px) { /* 374px以下で適用、for mini */
}

/* End responsive */


/* header
------------------------------------------------------------*/

#header {
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 60px;
background: #fff;
z-index: 999;
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
#header {
height: 120px;
}
}

#header.scroll {
box-shadow: 0 1px 2px rgba(176,176,176,0.3);
}

.header-inner {
position: relative;
display: flex;
justify-content: space-between;
}

.header-logo {
width: 250px;
margin: 5px 0 0 16px;
}
@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
.header-logo {
margin: 5px 0 0 24px;
}
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
.header-logo {
width: 324px;
margin: 30px 0 0 48px;
}
}
@media only screen and (min-width: 1248px) { /* 1248px以上で適用、PCフルサイズ用CSS */
.header-logo {
margin: 30px 0 0 72px;
}
}

.header-logo a {
display: block;
}

.hamburger {
padding: 29px 16px;
position: relative;
cursor: pointer;
border: none;
background-color: #e9026c;
}
@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
.hamburger {
padding: 29px 24px;
}
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
.hamburger {
display: none; 
}
}

span.hamburger-border,
span.hamburger-border:before,
span.hamburger-border:after {
display: block;
height: 2px;
width: 32px;
transition: 0.6s;
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; /* ヘッダー下に */
left: 0;
width: 100%;
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 (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
.nav {
position: relative;
}
}

.nav-list {
font-size: 1rem;
margin: 0.5em 1.5em;
display: flex;
flex-direction: column;
text-align: center;
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
.nav-list {
flex-direction: row;
margin: 0 48px 0 0;
}
}
@media only screen and (min-width: 1248px) { /* 1248px以上で適用、PCフルサイズ用CSS */
.nav-list {
margin: 0 72px 0 0;
}
}

.nav-item.common {
margin: 1em 0 0 0;
border-bottom: solid 1px #f9c0da;
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
.nav-item.common {
margin: 72px 0 0 0.5em;
border-bottom: none;
}
}
@media only screen and (min-width: 1248px) { /* 1248px以上で適用、PCフルサイズ用CSS */
.nav-item.common {
margin: 72px 0 0 1.5em;
}
}

.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: #fe85bb;
}
}

@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: #fe85bb;
transition: 0.6s;
transform: scale(0, 1);
transform-origin: center top;
}
.nav-item.common a:hover:after {
transform: scale(1, 1);
}
}

@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
.nav-item.tel {
position: absolute;
top: 8px;
right: 48px;
}
}
@media only screen and (min-width: 1248px) { /* 1248px以上で適用、PCフルサイズ用CSS */
.nav-item.tel {
right: 72px;
}
}

.nav-item.tel a {
display: inline-flex;
flex-direction: column;
margin: 3em 0 0 0;
padding: 0.5em 2em;
border: solid 1px #f9c0da;
border-radius: 10px;
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
.nav-item.tel a {
border: none;
margin: 0;
padding: 0;
pointer-events: none;
border-radius: 0;
}
}

.nav-item.tel span.num {
font-size: 1.375rem;
color: #fe85bb;
}

.nav-item.tel span.num:before {
font-family: "Font Awesome 5 Free";
font-weight: 900;
font-size: 1rem;
content: "\f879";
margin-right: 0.5em;
}

.nav-item.tel span.note {
font-size: 0.75rem;
color: #fff;
background: #fe85bb;
border-radius: 100vh;
margin-top: 0.5em;
padding: 2px 1.5em;
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
.nav-item.tel span.note {
margin-top: 2px;
}
}

@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
------------------------------------------------------------*/

main#content {
margin-top: 60px;
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
main#content {
margin-top: 120px;
transition: margin-top 0.6s;
}
}

/* End content */


/* top-common
------------------------------------------------------------*/

#top-common {
position: relative;
background: #ffe7f1;
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
#top-common {
padding: 0 48px 24px;
overflow: hidden;
}
#top-common:before {
content: "";
position: absolute;
top: 0;
left: -5%;
width: 110%;
height: 80%;
background: #fff;
border-radius: 0 0 50% 50%;
}
}

.top-common-inner {
position: relative;
height: 40vw;
background-image: url("../images/common/top_common_bg_sp.jpg");
background-position: top right;
background-repeat: no-repeat;
background-size: cover;
display: flex;
justify-content: center;
align-items: center;
flex-direction: column;
}
@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
.top-common-inner {
height: 280px;
background-image: url("../images/common/top_common_bg_pc.jpg");
}
}
@media only screen and (min-width: 1920px) { /* 1920px以上で適用、フルHD以上用CSS */
.top-common-inner {
height: 400px;
}
}

@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
.top-common-inner:after {
content: "";
position: absolute;
z-index: 1;
top: 0;
left: 0;
width: 220px;
height: 130px;
background-image: url("../images/common/top_common_bg_add_pc.png");
background-position: top left;
background-repeat: no-repeat;
}
}

#top-common h1,
#top-common p.headline {
font-weight: 500;
line-height: 1.5;
color: #e9026c;
font-size: 1.625rem;
margin: 0 16px;
}
@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
#top-common h1,
#top-common p.headline {
font-size: 2.625rem;
margin: 0 24px;
}
}

#top-common span.h1-en {
color: #e9026c;
font-size: 0.875rem;
align-items: center;
display: flex;
justify-content: center;
margin-top: 0.5em;
}
@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
#top-common span.h1-en {
font-size: 1rem;
}
}

#top-common span.h1-en:before,
#top-common span.h1-en:after {
content: "";
background: #e9026c;
height: 1px;
width: 30px;
}

#top-common span.h1-en:before {
margin-right: 12px;
}

#top-common span.h1-en:after {
margin-left: 12px;
}

#top-common span.h1-en {
background: rgba(255,255,255,0.3);
background: -webkit-linear-gradient(left, rgba(255,255,255,0) 2%, rgba(255,255,255,0.3), rgba(255,255,255,0) 98%);
background: linear-gradient(to right, rgba(255,255,255,0) 2%, rgba(255,255,255,0.3), rgba(255,255,255,0) 98%);
}

/* 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-pink {
background: #ffe7f1;
}

.section-common.bg-gray {
background: #f9f9f9;
}

/* End section-common */


/* div_common
------------------------------*/

div.inner-common {
margin: 0 16px;
}
@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
div.inner-common {
margin: 0 24px;
}
}
@media only screen and (min-width: 1248px) { /* 1248px以上で適用、PCフルサイズ用CSS */
div.inner-common {
max-width: 1200px;
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: #e9026c;
font-size: 1.375rem;
text-align: center;
position: relative;
margin: 0 0 2em 0;
}
@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
h2.common {
font-size: 2.125rem;
}
}

h2.common:after {
content: "";
display: block;
width: 80px;
height: 2px;
position: absolute;
left: 50%;
bottom: -0.5em;
margin: 0 0 0 -40px;
background: #fe85bb;
border-radius: 1px;
}

h3.common {
color: #e9026c;
font-size: 1rem;
}
@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
h3.common {
font-size: 1.125rem;
}
}

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: #e9026c;
}

a.link {
color: #d36600;
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-flex {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
}
@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
.btn-flex {
flex-direction: row;
flex-wrap: wrap;
}
}

@media only screen and (max-width: 767px) { /* 767px以下で適用、スマホ専用CSS */
.btn-flex a.btn + a.btn {
margin-top: 2em;
}
}
@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
.btn-flex a.btn {
margin: 0 1em;
}
}

a.btn {
text-align: center;
color: #e9026c;
min-width: 18em;
padding: 14px 4em;
border: solid #e9026c 1px;
background: #fff;
display: inline-block;
position: relative;
}
@media only screen and (max-width: 1024px) { /* 1024px以下で適用、PC以外用CSS */
a.btn {
transition: 0s; /* for hover */
}
}

a.btn:hover {
opacity: 1;
color: #fff;
background: #e9026c;
}
@media only screen and (max-width: 1024px) { /* 1024px以下で適用、PC以外用CSS */
a.btn:hover {
transition: 0s; /* for hover */
}
}

a.btn:before {
content: "";
display: block;
position: absolute;
height: 1px;
background: #e9026c;
top: 50%;
width: 36px;
right: 1em;
}

a.btn:hover:before {
background: #fff;
}

a.btn:after {
content: "";
display: block;
position: absolute;
width: 0;
height: 0;
border-left: solid 10px #e9026c;
border-top: solid 6px transparent;
top: 50%;
right: 1em;
margin-top: -6px;
}

a.btn:hover:after {
border-left: solid 10px #fff;
}

a.btn:before,
a.btn:after {
transition: 0s; /* for hover */
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
a.btn:before,
a.btn:after {
transition: 0.6s;
}
}

a.btn-link {
text-align: center;
color: #e9026c;
min-width: 18em;
padding: 14px 4em;
border: solid #e9026c 1px;
background: #fff;
display: inline-block;
position: relative;
}
@media only screen and (max-width: 1024px) { /* 1024px以下で適用、PC以外用CSS */
a.btn-link {
transition: 0s; /* for hover */
}
}

a.btn-link:hover {
opacity: 1;
color: #fff;
background: #e9026c;
}
@media only screen and (max-width: 1024px) { /* 1024px以下で適用、PC以外用CSS */
a.btn-link:hover {
transition: 0s; /* for hover */
}
}

a.btn-link:before,
a.btn-link:after {
content: "";
display: block;
position: absolute;
width: 8px;
height: 6px;
transition: 0.6s;
}
@media only screen and (max-width: 1024px) { /* 1024px以下で適用、PC以外用CSS */
a.btn-link:before,
a.btn-link:after {
transition: 0s; /* for hover */
}
}

a.btn-link:before {
border: solid 1px #e9026c;
top: 6px;
right: 6px;
}

a.btn-link:hover:before {
border: solid 1px #fff;
}

a.btn-link:after {
border-left: solid 1px #e9026c;
border-bottom: solid 1px #e9026c;
top: 9px;
right: 9px;
}

a.btn-link:hover:after {
border-left: solid 1px #fff;
border-bottom: solid 1px #fff;
}

/* End btn */


/* 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 の設定を追加する */
clip-path: inset(0 100% 0 0);
transition: 1s 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 */


/* 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 #222;
border-left: solid 1px #222;
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 {
background: #fff;
padding: 0 0 80px;
}
@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
#footer {
padding: 0 0 100px;
}
}

.footer-contact {
background-image: url("../images/common/footer_contact_bg_sp.jpg");
background-repeat: no-repeat;
background-size: cover;
background-position: center left;
text-align: center;
padding: 60px 0 70px; /* same section */
}
@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
.footer-contact {
padding: 80px 0 90px; /* same section */
}
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
.footer-contact {
padding: 110px 0 120px; /* same section */
background-image: url("../images/common/footer_contact_bg_pc.jpg");
background-position: center center;
}
}

.footer-contact p{
padding: 0 1em;
}
@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
.footer-contact p{
text-align: center;
}
}

a.footer-tel {
display: inline-flex;
flex-direction: column;
margin: 2em 0 0 0;
padding: 1em 3em;
background: rgba(255,255,255,0.6);
box-shadow: 0 2px 12px 4px rgba(176,176,176,0.3);
border-radius: 10px;
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
a.footer-tel {
pointer-events: none;
padding: 1.5em 12em;
}
}

a.footer-tel span.num {
font-size: 1.375rem;
color: #fe85bb;
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
a.footer-tel span.num {
font-size: 2rem;
}
}

a.footer-tel span.num:before {
font-family: "Font Awesome 5 Free";
font-weight: 900;
font-size: 1rem;
content: "\f879";
margin-right: 0.5em;
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
a.footer-tel span.num:before {
font-size: 1.375rem;
}
}

a.footer-tel span.note {
font-size: 0.75rem;
color: #fff;
background: #fe85bb;
border-radius: 100vh;
margin: 0.5em 0;
padding: 2px 1.5em;
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
a.footer-tel span.note {
font-size: 0.875rem;
}
}

.footer-sitemap {
font-size: 0.875rem;
margin: 60px 0 0 0;
display: flex;
flex-wrap: wrap;
justify-content: space-between;
}
@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
.footer-sitemap {
margin: 80px 0 0 0;
}
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
.footer-sitemap {
margin: 110px 0 0 0;
justify-content: center;
}
}

.footer-sitemap li {
width: 48%;
margin: 0 0 1.5em 0;
}
@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
.footer-sitemap li {
width: auto;
}
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
.footer-sitemap li {
margin: 0 1.5em 1.5em;
}
}

.footer-sitemap li a {
position: relative;
padding: 0 0 0 0.5em;
}

.footer-sitemap li a:before {
content: "";
display: block;
position: absolute;
width: 2px;
height: 100%;
left: 0;
top: 0;
background: #e9026c;
border-radius: 1px;
}

.footer_info {
font-size: 0.875rem;
text-align: center;
}

.footer_info img {
width: 250px;
margin-top: 1em;
}
@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
.footer_info img {
margin-top: 2em;
}
}
@media only screen and (min-width: 1025px) { /* 1025px以上で適用、PC用CSS */
.footer_info img {
width: 324px;
}
}

.footer_info p {
text-align: center;
margin-top: 2em;
}

.footer_info p.add span {
display: block;
}
@media only screen and (min-width: 768px) { /* 768px以上で適用、タブレット～PC用CSS */
.footer_info p.add span {
display: inline-block;
margin: 0 0.25em;
}
}

.footer_info p.copyright {
text-align: center;
margin-top: 1em;
}

/* End footer */







