@charset "utf-8";

* {
    box-sizing: border-box;
    padding: 0;
    margin: 0;
    word-break: normal;
    word-wrap: break-word;
}

body {
    font-family: 'メイリオ', Meiryo, 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'ＭＳ Ｐゴシック', sans-serif;
    background-color: #e8ffd5;
    color: #000;
}

img {
    vertical-align: top;
    margin: 0;
    padding: 0;
    border: 0;
    max-width: 100%;
}

.clearfix:before,
.clearfix:after {
    display: table;
    content: " ";
}

.clearfix:after {
    clear: both;
}

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

td,
th {
    padding: 0;
}

table {
    background-color: transparent;
}

table col[class*="col-"] {
    position: static;
    display: table-column;
    float: none;
}

table td[class*="col-"],
table th[class*="col-"] {
    position: static;
    display: table-cell;
    float: none;
}

ul li {
    list-style: none;
}

h1,
h2,
h3,
h4,
h5,
h6,
p {
    margin: 0px;
}

h1 {
    font-size: 300%;
}

h2 {
    font-size: 250%;
}

h3 {
    font-size: 200%;
}

h4 {
    font-size: 150%;
}

h5 {
    font-size: 125%;
}

.fixedcontainer {
    width: 960px;  /* size960 */
    margin: 0 auto;
    padding: 0px 0 120px;  /* size960 */
    overflow: hidden;
    background-color: #fff;
}

a:visited,
a:link,
a:hover,
a:active,
a:focus {
    outline: none;
    text-decoration: none;
}

a:hover {
    opacity: 0.8;
    transition: opacity 0.5s ease;
}

.red {
    color: #ed1c24;
}

.bkyellow {
    background-color: #fff100;
}

.bold {
    font-weight: bold;
}

.btline {
    text-decoration: underline;
}

.underline {
    text-decoration: underline;
}

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

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

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

.visible-sp {
    display: none;
}

.hidden-sp {
    display: block;
}

.visible-xs {
    display: none;
}

.hidden-xs {
    display: block;
}

.visible-500 {
    display: none;
}

.hidden-500 {
    display: block;
}

.flex {
    display: -webkit-flex;
    display: -webkit-box;
    display: -moz-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
}

.header {
    position: relative;
}

h1.header .header_tel {
    display: block;
    position: absolute;
    top: 4px;  /* size960 */
    right: 15px;  /* size960 */
    width: 225px;  /* size960 */
}

.btns a {
    display: block;
}

.btns a:hover {
    animation: rumble 0.1s linear infinite;
}

@keyframes rumble {
    0% {
        transform: rotate(0deg) translate(0, 0);
    }

    25% {
        transform: rotate(0.4deg) translate(1px, 1px);
    }

    50% {
        transform: rotate(0deg) translate(0, 0);
    }

    75% {
        transform: rotate(-0.4deg) translate(1px, 1px);
    }

    100% {
        transform: rotate(0deg) translate(0, 0);
    }
}

.lp2 {
    position: relative;
}

.video {
    width: 502px;/* size960 */
    position: absolute;
    left: 50%;
    margin-left: -253px;/* size960 */
    top: 370px;/* size960 */
    height: 280px;/* size960 */
}

.bottom_tel {
    position: fixed;
    bottom: 0;
    z-index: 10;
    width: 100%;
    background: #ffffff;
    box-shadow: 0px -8px 10px 0px #e6e5e5;
}

@media screen and (max-width:960px) { /* size960 */
    .fixedcontainer {
        width: 100%;
		padding: 0 0 100px;   /* size960 */
    }

    h1.header .header_tel {
        display: block;
        position: absolute;
        top: 5px;
        right: 2%;
        width: 23%;
    }

    .video {
        width: 52.5%;
        position: absolute;
        left: 23.5%;
        margin-left: 0;
        top: 7.4%;   /* size960 */
        height: 5.6%;
    }
}

.corpinfo {
    background-color: #fff;
    padding: 30px 0 120px;
}

.corpinfo h2 {
    padding: 100px 0 30px;
    width: 70%;
    font-size: 50px;   /* size960 */
    font-weight: bold;
    text-align: center;
    display: block;
    margin: 0 auto;
    margin-top: -60px;
}

.corpinfo table {
    width: 80%;   /* size960 */
    text-align: center;
    margin: 0 auto;
    font-size: 22px;   /* size960 */
}

.corpinfo th {
    border: solid 1px #666;
    border-left: none;
    border-right: none;
    text-align: center;
    height: 90px;   /* size960 */
    background-color: #79a250;
    color: #fff;
    vertical-align: middle;
    padding: 0 65px;   /* size960 */
    font-weight: normal;
    line-height: 2;
}

.corpinfo td {
    border: solid 1px #666;
    border-left: none;
    border-right: none;
    background-color: #fff;
    text-align: left;
    vertical-align: middle;
    padding: 15px 10px 15px 20px;   /* size960 */
}

.corpinfo a {
    color: inherit;
}

@media screen and (max-width:960px) {   /* size960 */
    .corpinfo {
        padding: 2.5vw 0 10vw;
    }

    .corpinfo h2 {
        padding: 10vw 0 3vw;
        font-size: 4.8vw;
    }

    .corpinfo table {
        width: 70%;
        font-size: 2.1vw;
    }

    .corpinfo th {
        border: solid 0.1vw #666;
        border-left: none;
        border-right: none;
        height: 7.7vw;
        padding: 0 6.1vw;   /* size960 */
    }

    .corpinfo td {
        border: solid 0.1vw #666;
        border-left: none;
        border-right: none;
        padding: 3.5vw 2.1vw;
    }

}



.invideo {
    background-color: #fff;
    padding: 130px 0 0px;   /* size960 */
    margin-bottom: -180px;
}

.invideo>img {
    margin-top: -70px;
    padding: 0px 0 120px;
}

.invideo h2 {
    padding: 70px 0 75px;   /* size960 */
    width: 70%;
    font-size: 55px;   /* size960 */
    font-weight: bold;
    color: #ff0000;
    text-align: center;
    display: block;
    margin: 0 auto;
    margin-top: -70px;
}
.invideo h2:last-of-type {
    margin-top: -120px;
}

.invideo h2 span {
    font-size: 0.7em;
    display: block;
    margin-top: -10px;
}

.invideo>div {
    width: 55%;
    margin: 0 auto;
}

.invideo>div:first-of-type {
    margin-top: -280px;   /* size960 */
    margin-bottom: 120px !important;
}

.invideo>div:last-of-type {
    margin-top: -230px;   /* size960 */
    margin-bottom: 30px;
}

@media screen and (max-width:960px) {   /* size960 */
    .invideo {
        padding: 13.5vw 0 0;
        margin-bottom: -18vw;
    }

    .invideo>img {
        margin-top: -6vw;
        padding: 0px 0 10vw;
    }

    .invideo h2 {
        padding: 70px 0 6.5vw;
        width: 70%;
        font-size: 5.4vw;
        margin-top: -6vw;
    }

    .invideo>div {
        width: 55%;
    }

    .invideo>div:first-of-type {
        margin-top: -27.5vw;
        margin-bottom: 100px !important;
    }

    .invideo>div:last-of-type {
        margin-top: -22vw;
    }
}