@charset "utf-8";
/*--------------------------------------------------------------*/
/* CSS and Graphics are released under Creative Commons Licence */
/* https://www.webplus.jp/                                       */
/* Copyright (C) Kiyonobu Horita @ WEBPLUS Inc.                 */
/*--------------------------------------------------------------*/




/* -----------------------------------------------------------

　header

-------------------------------------------------------------- */
header {
    position: relative;
    width: auto;
    height: 100vh;
    background: rgba(0, 0, 0, 1.0);
    text-align: center;
    overflow: hidden;
}

.carousel-item {
    height: 100vh;
    min-height: 300px;
}

.carousel-item:nth-child(1) {
    background: -o-linear-gradient(top, rgba(0, 0, 0, 0.8) 0%, rgba(0, 0, 0, 0.5) 25%, rgba(0, 0, 0, 0.3) 50%, rgba(0, 0, 0, 0.5) 75%, rgba(0, 0, 0, 0.9) 100%), url(../images/heroimage01.jpg) center left no-repeat scroll;
    background: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, 0.8)), color-stop(25%, rgba(0, 0, 0, 0.5)), color-stop(50%, rgba(0, 0, 0, 0.3)), color-stop(75%, rgba(0, 0, 0, 0.5)), to(rgba(0, 0, 0, 0.9))), url(../images/heroimage01.jpg) center left no-repeat scroll;
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0.8) 0%, rgba(0, 0, 0, 0.5) 25%, rgba(0, 0, 0, 0.3) 50%, rgba(0, 0, 0, 0.5) 75%, rgba(0, 0, 0, 0.9) 100%), url(../images/heroimage01.jpg) center left no-repeat scroll;
    background-size: cover;
}

.carousel-item:nth-child(2) {
    background: -o-linear-gradient(top, rgba(0, 0, 0, 0.8) 0%, rgba(0, 0, 0, 0.5) 25%, rgba(0, 0, 0, 0.3) 50%, rgba(0, 0, 0, 0.5) 75%, rgba(0, 0, 0, 0.9) 100%), url(../images/heroimage02.jpg) center center no-repeat scroll;
    background: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, 0.8)), color-stop(25%, rgba(0, 0, 0, 0.5)), color-stop(50%, rgba(0, 0, 0, 0.3)), color-stop(75%, rgba(0, 0, 0, 0.5)), to(rgba(0, 0, 0, 0.9))), url(../images/heroimage02.jpg) center center no-repeat scroll;
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0.8) 0%, rgba(0, 0, 0, 0.5) 25%, rgba(0, 0, 0, 0.3) 50%, rgba(0, 0, 0, 0.5) 75%, rgba(0, 0, 0, 0.9) 100%), url(../images/heroimage02.jpg) center center no-repeat scroll;
    background-size: cover;
}

.carousel-item:nth-child(3) {
    background: -o-linear-gradient(top, rgba(0, 0, 0, 0.8) 0%, rgba(0, 0, 0, 0.5) 25%, rgba(0, 0, 0, 0.3) 50%, rgba(0, 0, 0, 0.5) 75%, rgba(0, 0, 0, 0.9) 100%), url(../images/heroimage03.jpg) center right no-repeat scroll;
    background: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, 0.8)), color-stop(25%, rgba(0, 0, 0, 0.5)), color-stop(50%, rgba(0, 0, 0, 0.3)), color-stop(75%, rgba(0, 0, 0, 0.5)), to(rgba(0, 0, 0, 0.9))), url(../images/heroimage03.jpg) center right no-repeat scroll;
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0.8) 0%, rgba(0, 0, 0, 0.5) 25%, rgba(0, 0, 0, 0.3) 50%, rgba(0, 0, 0, 0.5) 75%, rgba(0, 0, 0, 0.9) 100%), url(../images/heroimage03.jpg) center right no-repeat scroll;
    background-size: cover;
}

.carousel-item:nth-child(4) {
    background: -o-linear-gradient(top, rgba(0, 0, 0, 0.8) 0%, rgba(0, 0, 0, 0.5) 25%, rgba(0, 0, 0, 0.3) 50%, rgba(0, 0, 0, 0.5) 75%, rgba(0, 0, 0, 0.9) 100%), url(../images/heroimage04.jpg) center center no-repeat scroll;
    background: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, 0.8)), color-stop(25%, rgba(0, 0, 0, 0.5)), color-stop(50%, rgba(0, 0, 0, 0.3)), color-stop(75%, rgba(0, 0, 0, 0.5)), to(rgba(0, 0, 0, 0.9))), url(../images/heroimage04.jpg) center center no-repeat scroll;
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0.8) 0%, rgba(0, 0, 0, 0.5) 25%, rgba(0, 0, 0, 0.3) 50%, rgba(0, 0, 0, 0.5) 75%, rgba(0, 0, 0, 0.9) 100%), url(../images/heroimage04.jpg) center center no-repeat scroll;
    background-size: cover;
}

.carousel-caption {
    position: inherit;
    right: 0;
    bottom: 0;
    left: 0;
    padding: 120px 5% 0;
}

.carousel-caption img {
    margin-bottom: 10px;
    opacity: 0.8;
}

.carousel-caption h2, .carousel-caption h3 {
    color: rgba(255, 255, 255, 0.8);
    font-size: 1.0rem;
    font-weight: 500;
}

.carousel-caption h3 {
    margin-bottom: 30px;
}

#topics {
    position: absolute;
    top: 58%;
    width: 100%;
    color: rgba(255, 255, 255, 1.0);
    text-align: center;
    z-index: 500;
}

#topics > div:nth-child(1) {
    padding: 5px;
    background: rgba(234, 85, 6, 0.8);
    font-family: "smart";
    text-transform: uppercase;
}

#topics > div:nth-child(2) {
    padding: 10px;
    background: rgba(0, 0, 0, 0.5);
    text-align: left;
}

#topics > div:nth-child(2) li {
    list-style-type: none;
}

#topics > div:nth-child(2) a {
    color: rgba(255, 255, 255, 1.0);
}

#topics > div:nth-child(2) a:hover {
    color: rgba(254, 209, 54, 1.0);
}

#topics .date {
    display: block;
}

#topics > div:nth-child(3) a {
    display: block;
    padding: 5px;
    background: rgba(0, 89, 130, 0.8);
    color: rgba(255, 255, 255, 1.0);
}

#topics > div:nth-child(3) a:hover {
    background: rgba(0, 123, 187, 1.0);
}

header .button {
    position: absolute;
    left: 50%;
    bottom: 10%;
    margin-left: -25.5px;
    text-transform: uppercase;
    text-align: center;
    z-index: 500;
}

header .button a {
    color: rgba(255, 255, 255, 1.0);
    font-size: 0.8rem;
}

header .button img {
    display: block;
    margin: 0 auto;
    border: 1px solid rgba(204, 204, 204, 1.0);
    border-radius: 50%;
}

header .button a:hover img {
    border: 1px solid rgba(0, 123, 187, 1.0);
    background: rgba(0, 123, 187, 1.0);
    opacity: 1.0;
}

@media only screen and (min-width:375px) {

    .carousel-caption {
        padding: 150px 5% 0;
    }

}

@media only screen and (min-width:576px) {

    .carousel-caption {
        padding: 150px 13% 0;
    }

    #topics .date {
        display: inline-block;
        margin-right: 10px;
    }

    #topics {
        text-align: center;
    }

    #topics div {
        margin: 0 auto;
        width: 90%;
    }

}

/* iPad */
@media only screen and (min-width:768px) {

    .carousel-caption {
        padding: 200px 13% 0;
    }

    .carousel-caption h2, .carousel-caption h3 {
        font-size: 1.2rem;
    }

    #topics > div:nth-child(2) a {
        text-align: center;
    }

    #topics div {
        width: 70%;
    }

}

@media only screen and (min-width:992px) {

    header {
        min-height: 50rem;
    }

    .carousel-item {
        min-height: 50rem;
    }

    .carousel-caption {
        padding: 200px 13% 0;
    }

    .carousel-caption img {
        width: 550px;
        height: auto;
    }

    #topics {
        top: 0;
        left: 50%;
        margin-top: 500px;
        margin-left: -385px;
        text-align: inherit;
    }

    /*	#topics {
		top:60%;
		left:50%;
		margin-left:-385px;
		text-align:inherit;
	}
*/
    #topics div {
        float: left;
        width: auto;
    }

    #topics > div:nth-child(1) {
        width: 100px;
        max-height: 54px;
        padding: 12px 0 15px;
    }

    #topics > div:nth-child(2) {
        width: 570px;
        max-height: 54px;
        padding: 15px;
    }

    #topics > div:nth-child(2) a {
        text-align: left;
    }

    #topics > div:nth-child(3) a {
        width: 100px;
        max-height: 54px;
        padding: 16.5px 0 13px;
    }

}

@media only screen and (min-width:1200px) {

    .carousel-caption img {
        width: 770px;
        height: auto;
    }

    .carousel-caption h2, .carousel-caption h3 {
        font-size: 1.4rem;
    }

    #topics {
        margin-top: 550px;
    }

}

@media only screen and (min-width:768px) and (-ms-high-contrast:none) {

    /* IEハック */
    #topics > div:nth-child(3) a {
        padding: 18px 0 11px;
    }

}

/* -----------------------------------------------------------

　section

-------------------------------------------------------------- */

/* -----------------------------------------------------------
　Company
-------------------------------------------------------------- */
#company {
    background: -o-linear-gradient(top, rgba(0, 0, 0, 0.5) 0%, rgba(0, 0, 0, 0.5) 100%), url(../images/bg_company.jpg) center center no-repeat;
    background: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, 0.5)), to(rgba(0, 0, 0, 0.5))), url(../images/bg_company.jpg) center center no-repeat;
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0.5) 0%, rgba(0, 0, 0, 0.5) 100%), url(../images/bg_company.jpg) center center no-repeat;
    background-color: rgba(0, 0, 0, 1.0);
    background-size: cover;
    color: rgba(208, 208, 208, 1.0);
}

#company li {
    list-style-type: disc;
    list-style-position: inside;
}

#company .box {
    margin: 30px auto;
    padding: 30px 10px;
    border-radius: 20px;
    background: rgba(255, 255, 255, 1.0);
    color: rgba(51, 51, 51, 1.0);
}

#company .box h4 {
    margin-bottom: 30px;
    color: rgba(234, 85, 6, 1.0);
    text-align: center;
}

#company .box p, #company .box li {
    margin-bottom: 0.5rem;
}

#company .box > p {
    margin-top: 40px;
    margin-bottom: 0;
    text-align: center;
}

/* company data */
#company .card {
    padding: 0;
    border: none;
    background: none;
}

#company .card dt {
    padding: 12px 10px 8px;
    background: rgba(243, 243, 243, 0.8);
    color: rgba(80, 80, 80, 1.0);
}

#company .card dd {
    padding: 10px 10px 10px 0;
}

#company .card p, #company .card li {
    margin-bottom: 0;
}

#company .card a {
    color: rgba(208, 208, 208, 1.0);
}

#company .card a:hover {
    color: rgba(254, 209, 54, 1.0);
}

/* open, close button */
#company .button {
    margin-bottom: 30px;
    text-align: center;
}

#company .button a[aria-expanded="false"] {
    width: 170px;
    -webkit-transition: 0.35s ease-in-out;
    -o-transition: 0.35s ease-in-out;
    transition: 0.35s ease-in-out;
}

#company .button a[aria-expanded="true"] {
    width: 100%;
    -webkit-transition: 0.35s ease-in-out;
    -o-transition: 0.35s ease-in-out;
    transition: 0.35s ease-in-out;
}

#company .button a[aria-expanded="false"] {
    background-color: rgba(0, 89, 130, 0.8);
}

#company .button a[aria-expanded="false"]::before {
    margin-right: 10px;
    font-family: "Font Awesome 5 Free";
    font-weight: 700;
    content: "\f107";
}

#company .button a[aria-expanded="false"]::after {
    margin-left: 10px;
    font-family: "Font Awesome 5 Free";
    font-weight: 700;
    content: "\f107";
}

#company .button a[aria-expanded="true"] {
    background-color: rgba(0, 123, 187, 1.0);
}

#company .button a[aria-expanded="true"]::before {
    margin-right: 10px;
    font-family: "Font Awesome 5 Free";
    font-weight: 700;
    content: "\f106";
}

#company .button a[aria-expanded="true"]::after {
    margin-left: 10px;
    font-family: "Font Awesome 5 Free";
    font-weight: 700;
    content: "\f106";
}

@media only screen and (min-width:768px) {

    #company {
        background: -o-linear-gradient(top, rgba(0, 0, 0, 0.5) 0%, rgba(0, 0, 0, 0.5) 100%), url(../images/bg_company.jpg) center center no-repeat fixed;
        background: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, 0.5)), to(rgba(0, 0, 0, 0.5))), url(../images/bg_company.jpg) center center no-repeat fixed;
        background: linear-gradient(to bottom, rgba(0, 0, 0, 0.5) 0%, rgba(0, 0, 0, 0.5) 100%), url(../images/bg_company.jpg) center center no-repeat fixed;
        background-size: cover;
    }

    #company .box {
        margin: 30px auto 50px;
        padding: 30px;
    }

    #company .card dt {
        padding: 12px 20px 8px;
    }

    #company .card dd {
        padding: 10px 20px 20px 20px;
    }

    #company .button a[aria-expanded="false"] {
        width: 270px;
    }

    #company .button a[aria-expanded="false"]::before {
        margin-right: 30px;
    }

    #company .button a[aria-expanded="false"]::after {
        margin-left: 30px;
    }

    #company .button a[aria-expanded="true"]::before {
        margin-right: 30px;
    }

    #company .button a[aria-expanded="true"]::after {
        margin-left: 30px;
    }

}

@media only screen and (min-width:992px) {

    #company .card dd {
        padding: 10px 20px 30px 20px;
    }

}

@media only screen and (min-width:768px) and (-ms-high-contrast:none) {

    /* IEハック */
    #company .card dt {
        padding: 16px 20px 8px;
    }

}

/* -----------------------------------------------------------
　Contact
-------------------------------------------------------------- */
#contact {
    color: rgba(80, 80, 80, 1.0);
}

#contact .title {
    border-bottom: 1px solid rgba(208, 208, 208, 1.0);
}

#contact h2 {
    color: rgba(80, 80, 80, 1.0);
}

#contact p span {
    font-size: 1.6rem;
    font-weight: 500;
}

/*　フォーム
/*-------------------------------------------*/
#contact #mailformpro {
    margin-top: 20px;
}

#contact #mailformpro dt {
    width: 100%;
    padding: 15px 0 3px;
    font-size: 1.125rem;
    font-weight: 700;
    text-align: left;
}

#contact #mailformpro dt .must {
    float: right;
    padding: 3px 10px;
    border-radius: 4px;
    background: rgba(234, 85, 6, 1.0);
    color: rgba(255, 255, 255, 1.0);
    font-size: 0.8rem;
}

#contact #mailformpro dd {
    padding-left: 0;
    font-size: 1.15rem;
}

#contact #mailformpro dd:last-child {
    border-bottom: 1px solid rgba(204, 204, 204, 1.0);
}

#contact #mailformpro dd span {
    color: rgba(0, 89, 130, 1.0);
    font-size: 1.0rem;
    font-weight: 700;
}

#contact #mailformpro ol li {
    margin-bottom: 10px;
}

#contact #mailformpro ol li:last-child {
    margin-bottom: 0;
}

#contact #mailformpro input, #contact #mailformpro dd.add select {
    width: 100%;
    height: 40px;
    -webkit-box-shadow: none;
    box-shadow: none;
}

#contact #mailformpro dd.add select {
    width: inherit;
}

#contact #mailformpro dd.add #post {
    width: 40%;
}

#contact #mailformpro dd .att {
    display: block;
    color: rgba(255, 0, 0, 1.0);
    font-size: 0.9rem;
    font-weight: 500;
}

#contact #mailformpro textarea {
    width: 100% !important;
    height: 200px !important;
    font-size: 1.15rem;
    -webkit-box-shadow: none;
    box-shadow: none;
}

#contact #mailformpro input.check {
    position: relative;
    top: -2px;
    width: 20px;
    height: 20px;
}

#contact #mailformpro dd.lastcheck p {
    margin-bottom: 20px;
}

#contact #mailformpro dd.lastcheck a::before {
    margin-left: 5px;
    margin-right: 5px;
    font-family: "Font Awesome 5 Free";
    font-weight: 700;
    content: "\f105";
}

form#mailformpro label.mfp_not_checked em {
    color: rgba(0, 123, 187, 1.0);
    font-weight: 700;
    font-style: normal;
}

#contact label.mfp_checked em {
    color: rgba(254, 85, 6, 1.0);
    font-weight: 700;
}

::-webkit-input-placeholder {
    opacity: 1.0;
}

::-moz-placeholder {
    opacity: 1.0;
}

:-ms-input-placeholder {
    opacity: 1.0;
}

:-o-input-placeholder {
    opacity: 1.0;
}

#contact .mfp_buttons button {
    width: 200px;
    height: 60px;
    font-size: 1.4rem;
    font-weight: 700;
    cursor: pointer;
}

#contact .mfp_buttons button:first-child {
    margin-bottom: 10px;
}

@media only screen and (min-width:768px) {

    #contact #mailformpro {
        margin-top: 40px;
    }

    #contact #mailformpro dt {
        width: 240px;
        padding: 10px 0 10px 5px;
    }

    #contact #mailformpro dd {
        padding: 10px 0;
        padding-left: 280px
    }

    #contact #mailformpro input {
        width: 97%;
    }

    #contact #mailformpro select {
        margin-bottom: 5px;
    }

    #contact #mailformpro .add li:nth-child(3) input, #contact #mailformpro .add li:nth-child(4) input, #contact #mailformpro .add li:nth-child(5) input {
        margin-bottom: 5px;
        width: 80%;
    }

    #contact #mailformpro textarea {
        width: 97% !important;
    }

    #contact #mailformpro dd.add #post {
        width: 30%;
    }

}

@media only screen and (min-width:992px) {

    #contact #mailformpro dt {
        width: 260px;
        padding: 10px 0 10px 10px;
    }

    #contact #mailformpro dd {
        padding-left: 300px
    }

    #contact #mailformpro input {
        width: 97%;
    }

    #contact #mailformpro .name input, #contact #mailformpro .com input, #contact #mailformpro .tele input {
        width: 50%;
    }

    #contact #mailformpro .add li:nth-child(3) input, #contact #mailformpro .add li:nth-child(4) input, #contact #mailformpro .add li:nth-child(5) input {
        width: 75%;
    }

    #contact #mailformpro dd.add #post {
        width: 28%;
    }

}

@media only screen and (min-width:1200px) {

    #contact #mailformpro dt {
        width: 300px;
    }

    #contact #mailformpro dd {
        padding-left: 360px
    }

    #contact #mailformpro .add li:nth-child(3) input, #contact #mailformpro .add li:nth-child(4) input, #contact #mailformpro .add li:nth-child(5) input {
        width: 60%;
    }

    #contact #mailformpro dd .att {
        display: inline;
    }

}