@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: "Jost", sans-serif;
    -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: #FFF;
    transition: 1.0s;
    z-index: 100;
    width: 100%;
    position: fixed;
    top: 0;
    padding: 10px 20px;
}

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

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

}

.header__logo {
    width: 180px;
}

.header__logo img {

    vertical-align: middle;
}


.header__logo--scroll {
    display: none;
}

@media screen and (max-width: 768px) {
    .header__logo {
        width: 150px;
        margin: -20px auto;
    }
}

.header__logo>img {
    display: block;
}

/*ナビメニューのスタイルを指定*/
@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: #000;
    padding: 2px 18px;
    border-radius: 10px;
}

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

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

.nav a {
    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: 'Noto Sans JP', sans-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__head {
    text-align: center;
    font-size: 40px;
    font-weight: 500;
    display: block;
    margin-bottom: 20px;
}

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


.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;
    }
}

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

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

    }
}


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


.top__bg {

}

.top__img div{
    width: 16%;
    margin: 5px 0;
}


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

.top video {
    width: 100%;

}

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

.about {
    color: #222;

}

.about__prof {
    font-size: 14px;
    width: 50%;
}
.about__img {
   padding: 12%;
   width: 50%;
  }
.about__img img{
  border-radius:50px;
}
.about__txt {
    padding: 5%;
    text-align: center;
    background-color: #fff;
    margin-bottom: 40px;
    border-radius: 20px;
}

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

.about__mail i {
    vertical-align: middle;
}

@media screen and (max-width: 768px) {
    .about__prof {
        margin-bottom: 10px;
    }

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

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


}

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

}


.service>div p {
    font-weight: bold;
    text-align: center;
    margin: 0 auto;
    padding: 10px;
}

.works {
    background-color: #222;
}

.works__head {
    color: #FFF;
}

.works__wrap {

    padding: 10px;
    margin-bottom: 20px;
}

.works__item {
    position: relative;
    background-color: #000;
}

.works__txt {
    color: #fff;
    position: absolute;
    bottom: 0;
    background-color: rgba(0, 0, 0, 0.8);
    padding: 5px;
    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;
    height: 320px;
}

.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;
}

.works-detal{
    padding: 20px;
}
.works-detal__item{
    background-color: #FFF;
    height: 400px; /* 親要素に高さを指定 */
    width: calc(25% - 20px);
    margin: 10px;
    padding: 10px;
}

.works-detal__item h3{

    border-bottom: 2px solid #AAB0B2;
    margin-bottom: 10px;
}


.works-detal__item p{
    overflow-y: auto;
    height: 100%;
    max-height: 400px; 
    font-size: small;
    padding: 0 10px 50px 10px;
}

.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: 'Unica One', cursive;
    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;
}

.flex .flex__item--6 {
    width: calc(16% - 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;
}

.btn {
    max-width: 320px;
    height: 58px;
    line-height: 60px;
    margin: 0 auto;
    background-color: #222;
    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;
    }
}