@charset "UTF-8";

/*!
 * ress.css • v1.2.2
 * MIT License
 * github.com/filipelinhares/ress
 */
/* # =================================================================
   # Global selectors
   # ================================================================= */
html {
    box-sizing: border-box;
    overflow-y: scroll;
    /* All browsers without overlaying scrollbars */
    -webkit-text-size-adjust: 100%;
    /* iOS 8+ */
}

*,
::before,
::after {
    background-repeat: no-repeat;
    /* Set `background-repeat: no-repeat` to all elements and pseudo elements */
    box-sizing: inherit;
}

::before,
::after {
    text-decoration: inherit;
    /* Inherit text-decoration and vertical align to ::before and ::after pseudo elements */
    vertical-align: inherit;
}

* {
    padding: 0;
    /* Reset `padding` and `margin` of all elements */
    margin: 0;
}

/* # =================================================================
   # General elements
   # ================================================================= */
/* Add the correct display in iOS 4-7.*/
audio:not([controls]) {
    display: none;
    height: 0;
}

hr {
    overflow: visible;
    /* Show the overflow in Edge and IE */
}

/*
* Correct `block` display not defined for any HTML5 element in IE 8/9
* Correct `block` display not defined for `details` or `summary` in IE 10/11
* and Firefox
* Correct `block` display not defined for `main` in IE 11
*/
article,
aside,
details,
figcaption,
figure,
footer,
header,
main,
menu,
nav,
section,
summary {
    display: block;
}

summary {
    display: list-item;
    /* Add the correct display in all browsers */
}

small {
    font-size: 80%;
    /* Set font-size to 80% in `small` elements */
}

[hidden],
template {
    display: none;
    /* Add the correct display in IE */
}

abbr[title] {
    border-bottom: 1px dotted;
    /* Add a bordered underline effect in all browsers */
    text-decoration: none;
    /* Remove text decoration in Firefox 40+ */
}

a {
    background-color: transparent;
    /* Remove the gray background on active links in IE 10 */
    -webkit-text-decoration-skip: objects;
    /* Remove gaps in links underline in iOS 8+ and Safari 8+ */
}

a:active,
a:hover {
    outline-width: 0;
    /* Remove the outline when hovering in all browsers */
}

ul li {
    list-style: none;
}

code,
kbd,
pre,
samp {
    font-family: monospace, monospace;
    /* Specify the font family of code elements */
}

b,
strong {
    font-weight: bolder;
    /* Correct style set to `bold` in Edge 12+, Safari 6.2+, and Chrome 18+ */
}

dfn {
    font-style: italic;
    /* Address styling not present in Safari and Chrome */
}

/* Address styling not present in IE 8/9 */
mark {
    background-color: #ff0;
    color: #000;
}

/* https://gist.github.com/unruthless/413930 */
sub,
sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline;
}

sub {
    bottom: -0.25em;
}

sup {
    top: -0.5em;
}

/* # =================================================================
   # Forms
   # ================================================================= */
input {
    border-radius: 0;
}

/* Apply cursor pointer to button elements */
button,
[type="button"],
[type="reset"],
[type="submit"],
[role="button"] {
    cursor: pointer;
}

/* Replace pointer cursor in disabled elements */
[disabled] {
    cursor: default;
}

[type="number"] {
    width: auto;
    /* Firefox 36+ */
}

[type="search"] {
    -webkit-appearance: textfield;
    /* Safari 8+ */
}

[type="search"]::-webkit-search-cancel-button,
[type="search"]::-webkit-search-decoration {
    -webkit-appearance: none;
    /* Safari 8 */
}

textarea {
    overflow: auto;
    /* Internet Explorer 11+ */
    resize: vertical;
    /* Specify textarea resizability */
}

button,
input,
optgroup,
select,
textarea {
    font: inherit;
    /* Specify font inheritance of form elements */
}

optgroup {
    font-weight: bold;
    /* Restore the font weight unset by the previous rule. */
}

button {
    overflow: visible;
    /* Address `overflow` set to `hidden` in IE 8/9/10/11 */
}

/* Remove inner padding and border in Firefox 4+ */
button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
    border-style: 0;
    padding: 0;
}

/* Replace focus style removed in the border reset above */
button:-moz-focusring,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
    outline: 1px dotted ButtonText;
}

button,
html [type="button"],
[type="reset"],
[type="submit"] {
    -webkit-appearance: button;
    /* Correct the inability to style clickable types in iOS */
}

button,
select {
    text-transform: none;
    /* Firefox 40+, Internet Explorer 11- */
}

/* Remove the default button styling in all browsers */
button,
input,
select,
textarea {
    background-color: transparent;
    border-style: none;
    color: inherit;
}

/* Style select like a standard input */
select {
    -moz-appearance: none;
    /* Firefox 36+ */
    -webkit-appearance: none;
    /* Chrome 41+ */
}

select::-ms-expand {
    display: none;
    /* Internet Explorer 11+ */
}

select::-ms-value {
    color: currentColor;
    /* Internet Explorer 11+ */
}

legend {
    border: 0;
    /* Correct `color` not being inherited in IE 8/9/10/11 */
    color: inherit;
    /* Correct the color inheritance from `fieldset` elements in IE */
    display: table;
    /* Correct the text wrapping in Edge and IE */
    max-width: 100%;
    /* Correct the text wrapping in Edge and IE */
    white-space: normal;
    /* Correct the text wrapping in Edge and IE */
}

::-webkit-file-upload-button {
    -webkit-appearance: button;
    /* Correct the inability to style clickable types in iOS and Safari */
    font: inherit;
    /* Change font properties to `inherit` in Chrome and Safari */
}

[type="search"] {
    -webkit-appearance: textfield;
    /* Correct the odd appearance in Chrome and Safari */
    outline-offset: -2px;
    /* Correct the outline style in Safari */
}

/* # =================================================================
   # Specify media element style
   # ================================================================= */
img {
    border-style: none;
    /* Remove border when inside `a` element in IE 8/9/10 */
}

/* Add the correct vertical alignment in Chrome, Firefox, and Opera */
progress {
    vertical-align: baseline;
}

svg:not(:root) {
    overflow: hidden;
    /* Internet Explorer 11- */
}

audio,
canvas,
progress,
video {
    display: inline-block;
    /* Internet Explorer 11+, Windows Phone 8.1+ */
}

/* # =================================================================
   # Accessibility
   # ================================================================= */
/* Hide content from screens but not screenreaders */
@media screen {
    [hidden~="screen"] {
        display: inherit;
    }

    [hidden~="screen"]:not(:active):not(:focus):not(:target) {
        position: absolute !important;
        clip: rect(0 0 0 0) !important;
    }
}

/* Specify the progress cursor of updating elements */
[aria-busy="true"] {
    cursor: progress;
}

/* Specify the pointer cursor of trigger elements */
[aria-controls] {
    cursor: pointer;
}

/* Specify the unstyled cursor of disabled, not-editable, or otherwise inoperable elements */
[aria-disabled] {
    cursor: default;
}

/* # =================================================================
   # Selection
   # ================================================================= */
/* Specify text selection background color and omit drop shadow */
::-moz-selection {
    background-color: #b3d4fc;
    /* Required when declaring ::selection */
    color: #000;
    text-shadow: none;
}

::selection {
    background-color: #b3d4fc;
    /* Required when declaring ::selection */
    color: #000;
    text-shadow: none;
}

a {
    margin: 0;
    padding: 0;
    font-size: 100%;
    vertical-align: baseline;
    background: transparent;
    text-decoration: none;
    color: #222;
}

a:hover {
    transition: .8s;
}

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

html {
    font-size: 62.5%;
    height: 100%;
}

body {
    font-family: "Lexend Giga", "游明朝", YuMincho, ;
    -webkit-font-smoothing: antialiased;
    font-size: 16px;
    font-size: 1.6rem;
    line-height: 1.7;
    color: #222;
    width: 100%;
    height: 100%;
    background-color: #fff;
    letter-spacing: 1.5px;
}

input,
textarea,
button {
    color: #222;
    font-size: 16px;
    outline: 0;
    border: 1px solid #222;
}

a:focus {
    outline: 0;
}

.clearfix:after {
    content: " ";
    display: block;
    clear: both;
}

.x-large {
    font-size: 20px;
}

.large {
    font-size: 18px;
}

.middle {
    font-size: 14px;
}

.small {
    font-size: 12px;
}

.x-small {
    font-size: 10px;
}

@media screen and (max-width: 768px) {

    .xxx-large,
    .xx-large,
    .x-large {
        font-size: 1.8rem;
    }
}

.fw-tight {
    font-weight: 300;
}

.fw-normal {
    font-weight: normal;
}

.fw-bold {
    font-weight: bold;
}

.align-center {
    text-align: center;
}

.align-left {
    text-align: left;
}

.align-right {
    text-align: right;
}

.align-just {
    text-align: justify;
}

.only-sp {
    display: none !important;
}

@media screen and (max-width: 768px) {
    .only-sp {
        display: block !important;
    }
}

@media screen and (max-width: 768px) {
    .only-pc {
        display: none !important;
    }
}

.pd10 {
    padding: 10px !important;
}

@media screen and (max-width: 768px) {
    .pd10 {
        padding: 10px !important;
    }
}

.pd20 {
    padding: 20px !important;
}

@media screen and (max-width: 768px) {
    .pd20 {
        padding: 10px !important;
    }
}

.pd30 {
    padding: 30px !important;
}

@media screen and (max-width: 768px) {
    .pd30 {
        padding: 10px !important;
    }
}

.mb0 {
    margin-bottom: 0 !important;
}

.mb05 {
    margin-bottom: 5px !important;
}

.mb10 {
    margin-bottom: 10px !important;
}

.mb20 {
    margin-bottom: 20px !important;
}

.mb30 {
    margin-bottom: 30px !important;
}

.mb40 {
    margin-bottom: 40px !important;
}

.mb50 {
    margin-bottom: 50px !important;
}

.mb60 {
    margin-bottom: 60px !important;
}

.mb70 {
    margin-bottom: 70px !important;
}

.mb80 {
    margin-bottom: 80px !important;
}

.mb90 {
    margin-bottom: 90px !important;
}

.mb100 {
    margin-bottom: 100px !important;
}

.mt0 {
    margin-top: 0px !important;
}

.mt5 {
    margin-top: 5px !important;
}

.mt10 {
    margin-top: 10px !important;
}

.mt20 {
    margin-top: 20px !important;
}

.mt30 {
    margin-top: 30px !important;
}

.mt40 {
    margin-top: 40px !important;
}

.mt50 {
    margin-top: 50px !important;
}

.mt60 {
    margin-top: 60px !important;
}

.container {
    max-width: 1200px;
    margin: 0 auto;
}

.container--m {
    max-width: 860px;
    margin: 0 auto;
}

.container--s {
    max-width: 600px;
    margin: 0 auto;
}

.container--xs {
    max-width: 320px;
    margin: 0 auto;
}

.bg-main {
    background-color: #696969;
}

.bg-gray {
    background-color: #222;
    color: #FBFDFC;
}

.bg-white {
    background-color: #f2f2f2;
}

.color-white {
    color: #FBFDFC;
}

.color-pink {
    color: #696969;
}

.color-black {
    color: #000 !important;
}

/*----------TOP----------*/
.header {
    background-color: #222;
    transition: 1.0s;
    z-index: 100;
    width: 100%;
    position: fixed;
    top: 0;
    padding: 10px 20px;
}


.header__wrap {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;

}

.header__logo {
    width: 300px;
    margin: 0 auto;
    text-align: center;
    padding: 2rem;
}

.header__logo img {

    vertical-align: middle;
}


.header__logo--scroll {
    display: none;
}

.header__logo>img {
    display: block;
}

@media screen and (max-width: 768px) {
    .header {
        padding: 0px;
    }

    .header__logo {
        width: 200px;

    }

}

/*ナビメニューのスタイルを指定*/
@media screen and (max-width: 768px) {
    .nav {

        display: none;
    }
}

.nav__list {
    display: flex;
    width: 100%;
    text-align: center;
}

@media screen and (max-width: 768px) {
    .nav__list {
        display: block;
        width: 100%;
    }
}

.nav__item {
    margin-left: 30px;
}

@media screen and (max-width: 768px) {
    .nav__item {}
}

.nav__item--btn {
    background-color: #fff;
    padding: 2px 18px;
    border-radius: 10px;
}

.nav__item--btn a {
    color: #222;
}

.nav__item span {
    text-align: center;
    position: relative;
    text-align: center;
}

.nav a {
    color: #fff;
    font-weight: 500;
    position: relative;
    display: inline-block;
}

@media screen and (max-width: 768px) {
    .nav a {
        font-size: 16px;
    }
}



.nav a:hover::after {
    transform: scale(1, 1);
}

.nav img {
    max-width: 180px;
}

.txt-oswald {
    font-family: "Lexend Giga", serif;
}

.btn-list {
    display: flex;
    justify-content: flex-end;
    position: absolute;
    bottom: -70px;
    right: -10px;
}

@media screen and (max-width: 768px) {
    .btn-list {
        position: fixed;
        bottom: 0px;
        right: 0px;
        width: 100%;
    }
}

.btn-list__item {
    text-align: center;
    margin-left: 10px;
    background-color: rgba(0, 0, 0, 0.8);
}

@media screen and (max-width: 768px) {
    .btn-list__item {
        margin-left: 0px;
        width: 33.333333%;
    }
}

.btn-list__item a {
    display: block;
    color: #FBFDFC;
    padding: 5px 20px;
    border: 1px solid #FBFDFC;
}

.loading {
    position: fixed;
    z-index: 1000000;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background: #fff;
}

.sec {
    position: relative;
    padding: 5% 0;
}

@media screen and (max-width: 768px) {
    .sec {
        padding: 20px 5px;
    }
}



.sec__head1 {
    text-align: center;
    font-size: 40px;
    font-weight: 500;
    display: block;
    margin-bottom: 20px;
}

.sec__head2 {
    font-size: large;
    margin-bottom: 20px;
    padding-bottom: 10px;
    position: relative;
    font-weight: 500;
}

.sec__head2--large {
    font-size: xx-large;
}


.sec__head2::before {
    background-color: #1e90ff;
    /* 線の色 */
    border-radius: 5px;
    /* 線の両端を丸く */
    bottom: 0px;
    /* 線の位置 */
    content: "";
    height: 3px;
    /* 線の高さ */
    left: 50%;
    /* 線の中央寄せ */
    position: absolute;
    transform: translateX(-50%);
    /* 線の中央寄せ */
    width: 30px;
    /* 線の長さ */
}

/* レイアウトのためのcss */




@media screen and (max-width: 768px) {
    .sec__head1 {
        font-size: 24px;
        margin-right: 0%;
        padding-left: 10px;
        margin: 0 auto 10px auto;
        text-align: center;
        max-width: 50%;
    }

    .sec__head2 {
        font-size: medium;
    }
}


.sec__txt {
    line-height: 2;
    padding: 20px;
}

@media screen and (max-width: 768px) {
    .sec__txt {
        font-size: 12px;
        padding: 0 20px;
    }
}

.sec--black {
    color: #000 !important;
}


.sec--white .sec__head {
    color: #FBFDFC;
    border: 4px solid #fff;
}

.sec--white {
    color: #FBFDFC;
}


.footer {
    background-color: #fff;
    padding: 5% 0;
    color: #222;
}

.footer a {
    display: block;
    font-weight: bold;
    color: #fff;
}


@media screen and (max-width: 768px) {
    .footer__wrapper {
        display: block;
        padding-left: 15px;
    }
}

.footer__logo {
    max-width: 200px;
    margin-bottom: 20px;
}

.footer__logo img {
    color: #FFF;
}

@media screen and (max-width: 768px) {
    .footer__logo {
        max-width: 150px;
    }
}

@media screen and (max-width: 768px) {
    .footer__txt {
        margin-bottom: 10px;
        font-size: 12px;
    }
}

.wrapper {
    width: 100%;
}

.kv {
    margin-top: 114px;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

@media screen and (max-width: 768px) {
    .kv {
        margin-top: 94px;
    }
}


.top {
    width: 100%;
    background-attachment: fixed;
}

.top video {
    width: 100%;

}


.top__img {}




.about {
    color: #222;

}

#about>div>div>div {
    width: 50%;
}


.about__left {
    font-size: 14px;
}

.about__right {
    font-size: 14px;
}

.about__prof {
    font-size: 14px;
}

.about__txt {
    padding: 5%;
    text-align: center;
    background-color: #fff;
    border-radius: 20px;
}

.about__mail i {
    font-size: 10px;
}

.about__mail i {
    vertical-align: middle;
}

@media screen and (max-width: 768px) {
    #about>div>div>div {
        width: 100%;
    }

    .about__left {
        margin-bottom: 20px;
    }


    .about__prof {
        margin-bottom: 10px;
    }

    .about__txt {
        padding: 10% 2.5%;
    }
}

.service__txt {
    margin-bottom: 50px;
}




.service__txt p {
    line-height: 2;
    margin-bottom: 20px;
}

.service__txt ul {
    margin-bottom: 20px;
}


.service__item img {
    border-radius: 20px;
}

.service__plan {
    margin-bottom: 50px;
}

.service__scene {
    margin-bottom: 50px;
}

.service__flow {
    margin-bottom: 50px;
    background-color: #fff;
}

.service__flow img {
    padding: 2% 0;

}
.service__flow ul{
   text-align: left;
   padding: 2% 10% ;
   border-top: 2px solid #b3d4fc;
   border-bottom: 2px solid #b3d4fc;
   
}

.service__flow li{
    font-weight: bold;
    
}

@media screen and (max-width: 768px) {
    .service__item {
        width: 50%;
    }

    .service__txt p {
        font-size: 12px;
    }
    .service__flow ul{
        text-align: left;
        padding: 5% ;
       
        
     }
     
     .service__flow li{
         font-weight: bold;
         font-size: 14px;
         
     }


}

.scene-cat {
    background-color: #FFF;
    border-bottom: 2px solid #eee;
    width: 23%;
    /* マージン分を減らして調整 */
    margin: 1%;
    /* マージンを加える */
    padding: 2em;
    box-sizing: border-box;
    /* パディングとボーダーを含める */
    display: inline-block;
    /* 横並び */
    vertical-align: top;
    /* 上揃え */
    height: 376px;
}

.scene-cat__img {

    text-align: center;
}

.scene-cat__txt {}

.scene-cat__txt h4 {
    text-align: center;

}

@media screen and (max-width: 768px) {
    .scene-cat {
        width: 100%;
        height: auto;
        margin:0px 10% 20px 10%;
        padding:5%  10%;
    }
    .scene-cat__txt h4{
        font-size: 16px;
    }
    .scene-cat__txt p{
        font-size: 14px;
    }
    .scene-cat__img {

        width: 50%;
        margin: 0 auto;
    }
}
.works {
    margin-bottom: 50px;
}


.works__item {
    position: relative;
}

.works__txt {
    color: #fff;
    position: absolute;
    bottom: 0;
    background-color: rgba(0, 0, 0, 0.8);
    padding: 2px;
    width: 100%;

}

.works__txt-videonone {
    color: #fff;
    position: absolute;
    bottom: 0;
    background-color: rgba(0, 0, 0, 0.8);
    padding: 5px;
    width: 100%;

}

.works__item img {
    width: 100%;
    transition: 4s;

}

.works__item i {
    font-size: 36px;
    color: #FFF;
    display: none;
    position: absolute;
    top: 50%;
    left: 50%;
    margin-right: -50%;
    -webkit-transform: translate(-50%, -50%);
    /* Safari用 */
    transform: translate(-50%, -50%);

}


.works__item:hover .works__txt-video {
    color: #fff;
    position: absolute;
    background-color: rgba(0, 0, 0, 0.8);
    padding: 0px;
    width: 100%;
    height: 100%;
}


.works__item:hover .works__txt-video span {
    display: none;
}

.works__item:hover .works__txt-video i {
    display: block;
}



.access__map {
    text-align: center;
    margin-bottom: 20px;
}

.access__map iframe {
    width: 100%;
    height: 400px;
}

.access__table {
    padding: 0 5px;
}

.contact {
    text-align: center;
    padding: 5% 0;
    background-color: #222;
}


.contact__innr {
    background-color: #FFFCFA;
    padding: 5% 0;
}

.contact__head span {
    font-size: 14px;
    display: block;
    position: relative;
    top: -12px;
}

.contact__txt {
    font-weight: bold;
    margin-bottom: 10px;
}





@media screen and (max-width: 768px) {
    .contact__innr {
        padding: 10% 0;
    }

    .contact__txt {
        font-size: 12px;
    }

}

.page {
    padding-top: 10%;
}

.head-content {
    font-family: "Lexend Giga", serif;
    font-size: 36px;
    font-weight: normal;
    text-align: center;
}

@media screen and (max-width: 768px) {
    .head-content {
        font-size: 24px;
    }
}

.head-content span {
    font-size: 12px;
    display: block;
    position: relative;
    top: -10px;
}

.img-list span {
    display: block;
    text-align: center;
    font-weight: bold;
}

.img-list__item {
    position: relative;
}

.img-list__genre {
    color: #FBFDFC;
    font-size: 10px;
    background-color: rgba(59, 62, 61, 0.8);
    padding: 5px 10px;
    position: absolute;
    top: 0;
    left: 0;
}

/*トグルボタンが押されたときに付与するクラス*/
.nav.active {
    transform: translateY(0%);
}

/*トグルボタンのスタイルを指定*/
.toggle {
    display: none;
}

@media screen and (max-width: 768px) {
    .toggle {
        display: block;
        position: fixed;
        /* bodyに対しての絶対位置指定 */
        right: 10px;
        top: 10px;
        width: 42px;
        height: 42px;
        cursor: pointer;
        z-index: 3;
    }
}

.toggle span {
    border-bottom: solid 2px #000;
    display: block;
    position: absolute;
    -webkit-transition: .35s ease-in-out;
    /*変化の速度を指定*/
    -moz-transition: .35s ease-in-out;
    /*変化の速度を指定*/
    transition: .35s ease-in-out;
    /*変化の速度を指定*/
    left: 6px;
}

.toggle span:nth-child(1) {
    top: 7px;
    width: 35px;
}

.toggle span:nth-child(2) {
    top: 17px;
    width: 35px;
}

.toggle span:nth-child(3) {
    top: 27px;
    width: 35px;
}

.toggle.active span {
    border-bottom: solid 2px #000;
    box-shadow: 0px 0px 0px #000;
}

.toggle.active span:nth-child(1) {
    top: 18px;
    left: 6px;
    width: 35px;
    -webkit-transform: rotate(-45deg);
    -moz-transform: rotate(-45deg);
    transform: rotate(-45deg);
}

.toggle.active span:nth-child(2) {
    top: 18px;
    width: 35px;
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    transform: rotate(45deg);
}

.toggle.active span:nth-child(3) {
    top: 18px;
    width: 35px;
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    transform: rotate(45deg);
}

@media screen and (max-width: 768px) {
    #scrollfixed {
        width: 100%;
        transition: 1.0s;
    }

    #scrollfixed.scrolled {
        color: white;
        background: #FBFDFC;
        box-shadow: 2px 2px 3px rgba(59, 62, 61, 0.3);
        padding: 10px 15px;
        position: fixed;
        top: 0;
        left: 0;
        z-index: 10;
    }

    #scrollfixed.scrolled .toggle span {
        border-bottom: solid 2px #696969;
        box-shadow: 0px 0px 0px #696969;
    }
}

.fadeBg {
    overflow: hidden;
    position: relative;
}

.fadeBg__item {
    display: block;
    opacity: 0;
    position: relative;
    transition: all .7s .5s ease;
    z-index: 0;
}

.fadeBg:before {
    background: #696969;
    content: '';
    display: block;
    height: 100%;
    position: absolute;
    transform: translateX(-100%);
    transition: all .8s 0s ease;
    width: 100%;
    z-index: 1;
}

/*アニメーションするプロパティを設定します*/
.fadeBg.active * {
    opacity: 1;
}

.fadeBg.active:before {
    transform: translateX(100%);
}

.fadeIn {
    opacity: 0;
    transition: all .8s .5s ease;
}

.fadeIn.active {
    opacity: 1;
    transform: scale(1);
}

.flex--between {
    justify-content: space-between;
}

.flex--around {
    justify-content: space-around;
}

.flex--end {
    justify-content: flex-end;
}

.flex--center {
    justify-content: center;
}

.flex--aligncenter {
    align-items: center;
}

.flex--alignend {
    align-items: flex-end;
}

.flex--direction {
    flex-direction: column;
}

.flex--reverse {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
}

.flex {
    display: flex;
    flex-wrap: wrap;
}

.flex .flex__item--2 {
    width: calc(50% - 10px);
    margin: 5px;
}

.flex .flex__item--3 {
    width: calc(33.3333% - 5px);
    margin: 2.5px;
}

.flex .flex__item--4 {
    width: calc(25% - 5px);
    margin: 2.5px;
}

.flex .flex__item--5 {
    width: calc(20% - 5px);
    margin: 2.5px;
}

@media screen and (max-width: 768px) {
    .flex--sp100>div {
        width: calc(100% - 10px) !important;
        margin: 5px;
    }

    .flex--sp100>article {
        width: calc(100% - 10px) !important;
        margin: 5px;
    }

    .flex--sp100>li {
        width: calc(1000% - 10px) !important;
        margin: 5px;
    }

    .flex--sp50>div {
        width: calc(50% - 10px) !important;
        margin: 5px;
    }

    .flex--sp50>article {
        width: calc(50% - 10px) !important;
        margin: 5px;
    }

    .flex--sp50>li {
        width: calc(50% - 10px) !important;
        margin: 5px;
    }
}

.iframeWrap {
    position: relative;
    width: 100%;
    padding-top: 56.25%;
}

.iframeWrap iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.table {
    width: 100%;
    border-collapse: collapse;
    margin: 0 auto;
    background-color: #fff;

}


.table th {
    width: 20%;
    vertical-align: top;
    border-bottom: 2px solid #AAB0B2;
    background-color: #fff;

}


.table td {
    border-bottom: 2px solid #AAB0B2;
    background-color: #fff;
}

@media screen and (max-width: 768px) {
    .table th {
        width: 35%;
    }
}

.table th,
.table td {
    text-align: left;
    padding: 20px;
}

@media screen and (max-width: 768px) {

    .table th,
    .table td {
        padding: 0px 15px;
        font-size: 12px;
        vertical-align: middle;
    }
}

.table td {
    width: 80%;
    padding: 20px;
}

.table--width {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
}

.table--width th:first-child {
    border-radius: 5px 0 0 0;
}

.table--width th:last-child {
    border-radius: 0 5px 0 0;
    border-right: 1px solid #222;
}

.table--width th {
    text-align: center;
    color: white;
    background: #222;
    border-left: 1px solid #222;
    border-top: 1px solid #222;
    border-bottom: 1px solid #222;
    width: 25%;
    padding: 10px 0;
}

.table--width td {
    text-align: center;
    border-left: 1px solid #222;
    border-bottom: 1px solid #222;
    border-top: none;
    width: 25%;
    padding: 10px 0;
}

.table--width td:last-child {
    border-right: 1px solid #222;
}

.table--width tr:last-child td:first-child {
    border-radius: 0 0 0 5px;
}

.table--width tr:last-child td:last-child {
    border-radius: 0 0 5px 0;
}

.table--container{

}
.table--plan {
    border-collapse: collapse;
    table-layout: fixed;
    width: 100%;
    margin-bottom: 10px;
}

.table--plan tr {
    background-color: #fff;
    padding: .35em;
    border: 2px solid #eee;
}

.table--plan tr:last-child {
    border: none;
}

.table--plan th {
    padding: 2em;
    border-right: 2px solid #fff;
}

.table--plan td {
    padding: 2em .5em;
    border-right: 2px solid #eee;
    font-size: .85em;
}

.table--plan th {
    font-size: .85em;
}

.table--plan thead tr {
    background-color: #696969;
    color: #fff;
}

.table--plan tbody th {
    border-right: 2px solid #eee;
}

.table--plan th.non {
    border-right: none;
}

.table--plan .txt {
    text-align: left;
    font-size: .85em;
}

.table--plan .price {
    color: #000;
    font-weight: bold;
    font-size: 1.3em
}

.table--plan .price span {
    font-size: .6em;
}



@media screen and (max-width: 600px) {
    .table--container {
        overflow-x: auto; /* 横スクロールを有効化 */
        -webkit-overflow-scrolling: touch; /* iOSでスムーズなスクロール対応 */
        width: 100%; /* 親要素の幅に合わせる */
    }
    .table--plan {
        min-width: 1200px; /* 必要な場合の横スクロールを誘発する最小幅 */
    }
    .table--plan .price {
        font-size: 1em
    }
    
    .table--plan .price span {
        font-size: .4em;
    }
    
}


.btn {
    max-width: 320px;
    height: 58px;
    line-height: 60px;
    margin: 0 auto;
    background-color: #696969;
    border-radius: 10px;
}

@media screen and (max-width: 768px) {
    .btn {
        height: 38px;
        line-height: 40px;
    }
}

.btn a,
.btn input {
    color: #fff;
    font-size: 18px;
    text-align: center;
    display: block;
    text-decoration: none;
    letter-spacing: 2px;
    font-weight: 500;
}

@media screen and (max-width: 768px) {

    .btn a,
    .btn input {
        font-size: 14px;
    }
}

.btn i {
    font-size: 20px;
    padding-top: 2px;
}

@media screen and (max-width: 768px) {
    .btn i {
        font-size: 16px;
    }
}

.btn:active {
    border-bottom: none;
}

.btn--main a,
.btn--main input {
    color: #FFFCFA;
    background-color: #696969;
    border: 2px solid #696969;
}

.btn--main a:hover,
.btn--main input:hover {
    background-color: #FFFCFA;
    color: #696969;
    border: 2px solid #696969;
}

.btn--reverse a,
.btn--reverse input {
    color: #696969;
    background-color: #FFFCFA;
    border: 2px solid #FFFCFA;
}

.btn--reverse a:hover,
.btn--reverse input:hover {
    background-color: #696969;
    color: #FFFCFA;
    border: 2px solid #FFFCFA;
}

.tab__item {
    width: 25%;
    background-color: #222;
    border: 1px solid #FBFDFC;
}

@media screen and (max-width: 768px) {
    .tab__item {
        width: 50%;
    }
}

.tab__item a {
    color: #FBFDFC;
    padding: 5px 20px;
    display: block;
    text-align: center;
}

.tab__content {
    display: none;
    padding-top: 20px;
}

.tab .is_active {
    background-color: #000;
}

.tab .is_show {
    display: block;
}

.tag__item {
    color: #bdbdbd;
    margin: 2.5px;
}

.tag__item:before {
    content: "#";
}

.form {
    font-size: 14px;
    text-align: left;
    margin-left: 20%;
}

@media screen and (max-width: 768px) {
    .form {
        margin-left: 0%;
        padding: 20px;
    }
}

.form__head {
    color: #FBFDFC;
}

.form__item {
    margin-bottom: 20px;
}

.form__item--txt textarea {
    width: 100%;
    padding: 10px 0;
    text-indent: 1em;
}

.form__item input,
.form__item button,
.form__item textarea {
    width: 100%;
    border: solid 0px #f1f4f3;
    text-indent: 1em;
    background-color: #FFFCFA;
    color: #000;
}

.form__item input {
    width: 100%;
    display: block;
    text-decoration: none;
    letter-spacing: 2px;
    padding: 12px 0;
    border: 0px;
}

.form__item--contact input {
    background-color: #222;
    color: #FFFCFA;
    cursor: pointer;
}

.form__item--contact input:hover {
    opacity: .8;
}

#ez-map {
    min-height: 150px;
    min-width: 150px;
    height: 420px;
    width: 100%;
}

@media screen and (max-width: 768px) {
    #ez-map {
        height: 300px;
    }
}