@charset "UTF-8";
@import "base.css";
@import "fonts.css";
@import "style_sp.css";
@import url('https://fonts.googleapis.com/css?family=Noto+Sans+JP:300,400,500,700,900&subset=japanese');
/*==========================================================================*/
/*//////////////////////////////////////////////////////////////////////////*/
/*//////                                                              //////*/
/*//////  Copyright (C) 2009 株式会社フリーセル All Rights Reserved.  //////*/
/*//////                                                              //////*/
/*//////////////////////////////////////////////////////////////////////////*/
/*                                                                          */
/*    base.css  --> スタイルの初期設定を行うため、変更しないで下さい。      */
/*    fonts.css --> フォントの初期設定を行うため、変更しないで下さい。      */
/*                                                                          */
/*==========================================================================*/

/*==========================================================================*/
/*                           Common-Setting                                 */
/*==========================================================================*/

/* 基本タグのフォントサイズを指定（12px -> 120% or 1.2em ） */
h1, h2, h3, h4, h5, h6, input, button, textarea, select, p, blockquote, th, td, pre, address, li, dt, dd {
    font-size: 150%;
    -webkit-text-size-adjust: none;
}
img {
    vertical-align: bottom;
}
h1 {
} /* Header内で設定 */
h2 {
}
h3 {
}
h4 {
}
a {
    color: #666666;
}
a:hover, a:active {
    color: #666666;
    text-decoration: none;
}
a:visited {
}
ul {
}
li {
}
dl {
}
dt {
}
dd {
}
table {
    width: 100%
}
th, td {
}
th {
}
td {
}
p {
    margin: 0 0 1.866em!important;
}
p, dd, td, th, li {
    line-height: 1.866em;
}
.section {
    padding: 0 0 55px 0;
}
.section .section {
    padding: 0 0 35px;
}
.image_l {
    float: left;
    margin: 0 30px 20px 0;
}
.image_r {
    float: right;
    margin: 0 0 20px 20px;
}
#toTop {
    border: none;
    bottom: 80px;
    cursor: pointer;
    overflow: hidden;
    position: fixed;
    right: 20px;
    margin: 0 auto;
    text-decoration: none;
    z-index: 100;
    opacity: 0;
    visibility: hidden;
    transition: all 0.3s;
}
#toTop a {
    margin-bottom: 0px;
    box-sizing: border-box;
    position: relative;
    transition: all 0.3s;
}
#toTop a:hover, .contact_btn:hover {
    opacity: 0.8;
    display: block;
}
#toTop.show, .contact_btn.show {
    opacity: 1;
    visibility: visible;
}
.contact_btn {
    position: fixed;
    right: 10px;
    bottom: 80px;
    transition: all 0.5s;
    overflow: hidden;
    opacity: 0;
}
/* add
------------------------------------------------------------------------*/

/*==========================================================================*/
/*                            Container                                     */
/*==========================================================================*/

html {
    background: none;
}
body {
    color: #0a0a0a;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 400
}
#wrapper {
    min-width: 1260px;
    max-width: 2000px;
    margin: 0 auto;
    overflow: hidden;
}
@media(min-width:751px){
    #wrapper {
        min-width: 1260px;
        max-width: 2000px;
        margin: 0 auto;
        overflow: hidden;
        margin-top: 30px;
    }
}

.inner {
    width: 1080px;
    margin: 0 auto;
}
/*==========================================================================*/
/*                               Header                                     */
/*==========================================================================*/

#header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 999;
    background: rgba(255,255,255,0.9);
}
@media(min-width:751px){
    #header {
        position: fixed;
        top: 0;
        left: 0;
        right: 0;
        z-index: 999;
        background: rgba(255,255,255,0.9);
        padding-top: 90px;
    }
}
#top {
    margin-bottom: 2px;
}
#header h1 {
    font-size: 11px;
    margin-bottom: 5px;
}
#header_t, #header_info {
    display: flex;
    justify-content: space-between;
}
#header_info {
    align-items: center;
    position: relative;
    top: -11px;
}
#header_info li + li {
    margin-left: 40px;
}
/*==========================================================================*/
/*                               Top Info                                   */
/*==========================================================================*/
#top_info {
    background: url("../images/main.png") no-repeat center top;
    height: 700px;
    width: 100%;
    margin-top: 104px;
}
/*==========================================================================*/
/*                               gnavi                                   */
/*==========================================================================*/

/*==========================================================================*/
/*                               box01                                   */
/*==========================================================================*/
.box01_all {
    background: url("../images/box01.png") no-repeat center top;
    height: 260px;
    box-sizing: border-box;
    padding-top: 10px;
    margin-bottom:50px;
}
.box01_all .inner {
    height: 100%;
}
.box01_all ul {
    display: flex;
    height: 100%;
    align-items: center;
    justify-content: center;
}
/*==========================================================================*/
/*                               box02                                   */
/*==========================================================================*/
#box02 {
    background: url("../images/box02.png") no-repeat center top;
    background-size: cover;
    height: 700px;
    box-sizing: border-box;
    padding-top: 116px;
}
.box02_img {
    text-align: center;
}
.box02_img img {
    margin: 0 auto;
}
/*==========================================================================*/
/*                               box22                                   */
/*==========================================================================*/
#box22 {
    background: url("../images/box22.png") no-repeat center top;
    background-size: cover;
    height: 630px;
    box-sizing: border-box;
    padding-top: 116px;
}
.box22_img {
    text-align: center;
}
.box22_img img {
    margin: 0 auto;
}
/*==========================================================================*/
/*                               box03                                   */
/*==========================================================================*/
#box03 {
    background: url("../images/box03.png") no-repeat center top;
    background-size: cover;
    height: 1239px;
    box-sizing: border-box;
    padding-top: 113px;
    position: relative;
}
#box03:before {
    background: url("../images/arr01.png") no-repeat center top;
    width: 60px;
    height: 60px;
    background-size: 60px auto;
    left: 0;
    right: 0;
    margin: 0 auto;
    text-align: center;
    top: 0px;
}
#box03 .inner {
    width: 1200px;
}
.box03_list {
    width: 100%;
    display: flex;

    position: relative;
}
.box03_list:before {
    height: 4px;
    width: 810px;
    background: url("../images/par_line04.png") repeat-x left top;
    left: 0;
    right: 0;
    margin: 0 auto;
    top: -24px;
}
.box03_list li {
    width: 390px;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    margin-right: 15px;
}
.box03_list li:last-child {
    margin-right: 0px;
}
.box03_w {
    background: #fff;
}
.box03_tt01 {
    background: url("../images/tab_bg_01.png") no-repeat center top;
    background-size: 320px auto;
    width: 320px;
    height: 80px;
    font-size: 18px;
    font-weight: 700;
    color: #fff;
    letter-spacing: 1px;
    margin: 0 auto 20px;
    position: relative;
}
.box03_tt02 {
    background: url("../images/par_line03.png") repeat-x left bottom;
    background-size: 8px auto;
    position: relative;
    color: #fff;
    z-index: 1;
    padding-left: 28px;
    font-size: 13px;
    letter-spacing: 1px;
}
.box03_tt02 span {
    font-size: 150%;
}
.box03_tt02:before {
    width: 130px;
    height: 30px;
    background: #ce3702;
    left: 0;
    bottom: 0;
    z-index: -1;
}
.box03_txt01 {
    padding: 0 40px 9px 50px;
    letter-spacing: 1.2px;
    line-height: 1.9;
    height: 149px;
    box-sizing: border-box;
    font-weight: 500;
}
.box03_list li:nth-child(2) .box03_txt01 {
    letter-spacing: 0px;
}
.box03_list li:nth-child(3) .box03_txt01 {
    letter-spacing: 0.7px;
    padding: 0 40px 0px 50px;
    margin-bottom: 29px;
    line-height: 1.7;
}
.box03_txt01 > span {
    position: relative;
    z-index: 1;
    display: inline-block;
    font-weight: 800;
}
.box03_txt01 > span > span {
    font-size: 120%;
    letter-spacing: 5px;
}
.box03_txt01 > span:before {
    width: 100%;
    height: 8px;
    background: #ebaf9a;
    left: 0;
    bottom: 2px;
    z-index: -1;
}
.box03_txt01 > .box03_txt01_sm {
    font-size: 13px;
    margin-top: 12px;
    font-weight: 500;
}
.box03_txt01 > .box03_txt01_sm:before {
    display: none;
}
/*==========================================================================*/
/*                               box04                                   */
/*==========================================================================*/
#box04 {
    padding-top: 70px;
    padding-bottom: 55px;
    background: url("../images/box04.png")#fff no-repeat center bottom -258px;
}
.box04_list {
    width: 100%;
}
.box04_list dl {
    background: url("../images/par_gray.png") repeat center top;
    padding: 30px 40px 0px 30px;
    box-sizing: border-box;
    display: flex;
    margin-bottom: 62px;
    position: relative;
}
.box04_list dl:before {
    background: url("../images/border01.png") no-repeat center bottom;
    width: 1080px;
    height: 21px;
    bottom: -20px;
    left: 0;
}
.box04_list dl dt {
    width: 290px;
    margin-right: 30px;
}
.box04_list dl dd {
    width:calc(100% - 320px);
}
.box04_list dl dt span {
    font-size: 16px;
    font-weight: 800;
    margin-top: 9px;
    display: block;
    letter-spacing: 1px;
}
.box04_txt_pl {
    padding: 15px;
    margin-bottom: 13px;
}
.box04_txt p {
    font-weight: 500;
    letter-spacing: 1.09px;
    background: #fbfbfb;
    /* width: 520px; */
    /* height: 60px; */
    display: flex;
    align-items: center;
}
/*==========================================================================*/
/*                               box05                                   */
/*==========================================================================*/
#box05 {
    padding-top: 85px;
    padding-bottom: 67px;
}
#box05 .inner {
    width: 1155px;
}
.box05_list {
    display: flex;
    flex-wrap: wrap;
}
.box05_list li {
    margin-right: 78px;
    margin-bottom: 65px;
}
.box05_list li:nth-child(3) {
    margin-right: 0px;
}
/*==========================================================================*/
/*                               box06                                   */
/*==========================================================================*/
#box06 {
    padding-top: 43px;
    padding-bottom: 31px;
    background: #f2f2f2;
}
.box06_list {
    display: flex;
}
/*.box06_list li:nth-child(1) {
    width: 490px;
    margin-right: 65px;
}*/
.box06_list li {
    width: 490px;
    margin-right: 65px;
}
.box06_tt01 {
    font-size: 30px;
    font-weight: 700;
    margin-bottom: 37px;
    margin-left: 10px;
    margin-top: -10px;
}
.box06_tt01 span {
    background: url("../images/index_icon_05.png") no-repeat left center;
    background-size: 40px auto;
    padding-left: 55px;
    margin-left: 30px;
    position: relative;
    top: 13px;
    letter-spacing: 2px;
}
/*==========================================================================*/
/*                               box07                                   */
/*==========================================================================*/
#box07 {
    background: url("../images/box05.png") no-repeat center top;
    padding-top: 72px;
    padding-bottom: 82px;
    background-size:cover;
}
.box07_txt {
    font-size: 16px;
    text-align: center;
    font-weight: 500;
    margin-bottom: 64px;
}
.box07_list {
    display: flex;
    justify-content: space-between;
}
.box07_list li {
    width: 325px;
    position: relative;
}
.box07_list li:before {
    height: 100%;
    width: 1px;
    background: #808080;
    right: -27px;
    top: 0;
}
.box07_list li:last-child:before, .box07_list li:last-child:after {
    display: none;
}
.box07_list li:after {
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 8px 0 8px 12px;
    border-color: transparent transparent transparent #808080;
    right: -38px;
    top: calc(50% - 8px);
}
.box07_box {
    background: #fcfcfc;
    padding: 40px 30px;
    box-sizing: border-box;
    height: 292px;
    margin-top: -56px;
}
.box07_tt01 {
    background: #ce3702;
    color: #fff;
    height: 36px;
    text-align: center;
    line-height: 36px;
    font-size: 18px;
    font-weight: 700;
    margin-bottom: 14px;
    letter-spacing: 1px;
}
.box07_img {
    text-align: center;
}
.box07_tt02 {
    margin-bottom: 11px;
}
.box07_tt02 span:nth-child(1) {
    color: #ce3702;
    letter-spacing: 1px;
    margin-bottom: 10px;
    display: block;
}
.box07_tt02 span:nth-child(1) a {
    font-weight: bold;
    color: #ce3702;
    text-decoration: underline;
}
.box07_txt01 {
    margin-bottom: 0px;
    font-weight: 500;
}
/*==========================================================================*/
/*                               box071                                   */
/*==========================================================================*/
#box071 {
    background: url("../images/par_gray.png") no-repeat center top;
    padding-top: 72px;
    padding-bottom: 82px;
    background-size:cover;
}
.box071_txt {
    font-size: 16px;
    text-align: center;
    font-weight: 500;
    margin-bottom: 64px;
}
.box071_list {
    display: flex;
    justify-content: space-between;
}
.box071_list li {
    width: 325px;
    position: relative;
}
.box071_list li:before {
    height: 100%;
    width: 1px;
    background: #808080;
    right: -27px;
    top: 0;
}
.box07_list li:last-child:before, .box07_list li:last-child:after {
    display: none;
}
.box071_list li:after {
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 8px 0 8px 12px;
    border-color: transparent transparent transparent #808080;
    right: -38px;
    top: calc(50% - 8px);
}
.box071_box {
    background: #fcfcfc;
    padding: 40px 30px;
    box-sizing: border-box;
    height: 292px;
    /*margin-top: -56px;*/
    margin-top: -20px;
}
.box071_tt01 {
    background: #ce3702;
    color: #fff;
    height: 36px;
    text-align: center;
    line-height: 36px;
    font-size: 18px;
    font-weight: 700;
    margin-bottom: 14px;
    letter-spacing: 1px;
}
.box071_img {
    text-align: center;
}
.box07_tt02 {
    margin-bottom: 11px;
}
.box071_tt02 span:nth-child(1) {
    color: #ce3702;
    letter-spacing: 1px;
    margin-bottom: 10px;
    display: block;
}
.box071_tt02 span:nth-child(1) a {
    font-weight: bold;
    color: #ce3702;
    text-decoration: underline;
}
.box071_txt01 {
    margin-bottom: 0px;
    font-size: 18px;
    font-weight: 600;
}
/*==========================================================================*/
/*                               box08                                      */
/*==========================================================================*/
#box08 {
    background: #f3f3f4;
    padding-top: 82px;
    padding-bottom: 177px;
}
.box08_txt {
    font-size: 16px;
    text-align: center;
    margin-bottom: 58px;
    font-weight: 500;
}
.box08_list dl {
    padding-bottom: 2px;
}
.box08_list dl dt, .box08_list dl dd {
    display: flex;
}
.box08_list dl dt {
    background: #ffe3b2;
    align-items: center;
    position: relative;
    cursor: pointer;
    transition: all 0.3s;
}
.box08_list dl dt:before, .box08_list dl dt:after {
    width: 30px;
    height: 3px;
    background: #ce3702;
    right: 20px;
    top: calc(50% - 3px);
    transition: all 0.3s;
}
.box08_list dl:nth-child(2) dt:before, .box08_list dl:nth-child(2) dt:after {
    background: #fa9401;
}
.box08_list dl dt:after, .box08_list dl.active:nth-child(1) dt.active:after {
    transform: rotate(90deg);
}
.box08_list dl dd {
    display: none
}
.box08_list dl dd p {
    display: flex;
    align-items: flex-start;
    padding-bottom: 26px;
     padding-right: 70px;
        margin-bottom: 46px;

}
.box08_list dl.active dd {
    display: block;
    background: #f8f8f8;
}
.box08_list dl dt.active:after {
    transform: rotate(0deg);
}
.box08_list dl.active:nth-child(1) dt:after {
    transform: rotate(0deg);
}

.box08_list dl dt .q_icon, .box08_list dl dd .a_icon, .box08_list dl dt .q_tt {
    display: flex;
    align-items: center;
}
.box08_list dl dt .q_icon, .box08_list dl dd .a_icon {
    width: 70px;
    height: 70px;
    justify-content: center;
    font-size: 28px;
    margin-right: 21px;
    flex-shrink: 0;
}
.box08_list dl dt .q_icon {
    background: #ce3702;
    color: #fff;
}
.box08_list dl:nth-child(2) dt {
    background: #fcdc98;
}
.box08_list dl:nth-child(2) dt .q_icon {
    background: #e55f30;
}
.box08_list dl dd .a_icon {
    font-size: 32px;
    color: #ce3702;
    margin-top: 6px;
}
.box08_list dl dt .q_tt {
    height: 100%;
    font-size: 24px;
    font-weight: 500;
}
.a_txt {
    padding-top: 33px;
    border-bottom: 1px #666666 dashed;
    display: block;
    width: calc(100% - 95px);
    font-weight: 500;
    padding-bottom: 11px;
}
/*==========================================================================*/
/*                               box10                                      */
/*==========================================================================*/

/*==========================================================================*/
/*                               box10                                      */
/*==========================================================================*/

/*==========================================================================*/
/*                               h2->h5                                 */
/*==========================================================================*/
.h3_01 {
    position: relative;
    display: flex;
    align-items: center;
    flex-direction: column;
    letter-spacing: 2px;
    width: 1080px;
    margin: 0 auto 25px;
}
.h3_01 > span:nth-child(1) {
    position: absolute;
    left: 45px;
    top: -60px;
}
.h3_01 > span:nth-child(2) {
    font-size: 50px;
    font-weight: 700;
}
.h_color01 {
    color: #ce3702;
}
.h3_01_sm {
    font-size: 80%;
}
.h4_tt01 {
    flex-direction: column;
    color: #fff;
    font-weight: 700;
    text-align: center;
    margin-bottom: 45px;
}
.h4_tt01>span:nth-child(1) {
    font-size: 22px;
    letter-spacing: 1.2px;
    margin-bottom: 31px;
}
.h4_tt01>span:nth-child(2) {
    font-size: 120px;
    font-weight: 900;
    letter-spacing: 1px;
    line-height: 1;
}
.h4_tt01>span:nth-child(2)>span, .h4_tt01>span:nth-child(1) >span {
    font-size: 80%;
}
.h5_tt01 {
    text-align: center;
    font-weight: 900;
    font-size: 22px;
    position: relative;
    z-index: 1;
    margin-bottom: 69px;
}
.h5_tt01:before, .h5_tt01:after, .box03_tt01:before, .box03_tt01:after {
    z-index: -1;
    left: 0;
    right: 0;
    margin: 0 auto;
    text-align: center;
}
.h5_tt01:before {
    background: #fff;
    width: 400px;
    height: 40px;
    transform: skewX(-15deg);
    top: -9px;
}
.h5_tt01:after, .box03_tt01:before, .box03_tt01:after {
    background: url("../images/par_line02.png") repeat-y center top;
    background-size: 4px auto;
    width: 40px;
    height: 62px;
    top: 31px;
}
.box03_tt01:before, .box03_tt01:after {
    z-index: auto;
    height: 20px;
}
.box03_tt01:before {
    top: -20px;
}
.box03_tt01:after {
    top: auto;
    bottom: -19px;
}
.h5_tt01 > span {
    font-size: 80%;
}
.h5_tt02 {
    font-size: 18px;
    font-weight: 800;
    color: #ce3702;
    line-height: 1.55;
    background: url("../images/par_line03.png") repeat-x left bottom;
    background-size: 8px auto;
    display: table;
    padding-bottom: 10px;
    margin-bottom: 13px;
    letter-spacing: 1.4px;
}
.h4_tt02 {
    text-align: center;
    font-size: 50px;
    font-weight: 700;
    background: url("../images/index_icon_01.png") no-repeat center top;
    background-size: 50px auto;
    padding-top: 85px;
    margin-bottom: 43px;
}
.h4_tt02_sm {
    font-size: 80%;
}
.h4_tt03 {
    flex-direction: column;
    font-weight: 800;
    background: url("../images/index_icon_02.png") no-repeat center top;
    background-size: 77px auto;
    padding-top: 98px;
    margin-bottom: 45px;
}
.h4_tt03 > span:nth-child(1) {
    font-size: 38px;
    background: url("../images/index_icon_11.png") no-repeat left center, url("../images/index_icon_11.png") no-repeat right center;
    background-size: 51px auto, 51px auto;
    padding: 0 90px;
    color: #ce3702;
    margin-bottom: 25px;
    letter-spacing: 0.5px;
}
.h4_tt03 > span:nth-child(2) {
    font-size: 22px;
    line-height: 1.7;
    text-align: center;
}
.h4_tt03 > span:nth-child(2) .h4_color02 {
    font-size: 28px;
    color: #ce3702;
}
.h4_tt04 {
    background: url("../images/index_icon_03.png") no-repeat center top;
    background-size: 69px auto;
    text-align: center;
    font-size: 50px;
    font-weight: 700;
    padding-top: 88px;
    margin-bottom: 80px;
}
.h4_tt04_color01 {
    color: #ce3702;
}
.h4_tt04_sm {
    font-size: 80%;
}
.h4_tt04_pb {
    position: relative;
    top: -10px;
}
.h4_tt05 {
    font-size: 50px;
    font-weight: 700;
    color: #ce3702;
    background: url("../images/index_icon_06.png") no-repeat center top;
    background-size: 94px auto;
    padding-top: 87px;
    margin-bottom: 33px;
    text-align: center;
}
.h4_tt05 > span > span {
    font-size: 80%;
}
.h4_tt051 {
    font-size: 50px;
    font-weight: 700;
    color: #ce3702;
    background: url("../images/index_icon_061.png") no-repeat center top;
    background-size: 94px auto;
    padding-top: 87px;
    margin-bottom: 33px;
    text-align: center;
}
.h4_tt051 > span > span {
    font-size: 80%;
}

.h4_tt06 {
    font-size: 50px;
    font-weight: 700;
    background: url("../images/index_icon_10.png") no-repeat center top;
    background-size: 61px auto;
    padding-top: 83px;
    margin-bottom: 28px;
    text-align: center;
}
.h4_tt06 span {
    color: #ce3702;
}
#top_info, .box03_tt01, .h4_tt01, .h4_tt03 {
    display: flex;
    align-items: center;
    justify-content: center;
}
.box03_tt02:before, .box03_txt01 > span:before, .box03_list:before, #box03:before, .box04_list dl:before, .box07_list li:before, .box07_list li:after, .box08_list dl dt:before, .box08_list dl dt:after, .h5_tt01:before, .h5_tt01:after, .box03_tt01:before, .box03_tt01:after {
    position: absolute;
    content: "";
}
/*==========================================================================*/
/*                               YOUTUBE                                    */
/*==========================================================================*/

.video{
  position:relative;
  width:100%;
  padding-top:56.25%;
}
.video iframe{
  position:absolute;
  top:0;
  right:0;
  width:100%;
  height:100%;
}

/*==========================================================================*/
/*                               BUTTON                                 */
/*==========================================================================*/

/*==========================================================================*/
/*                               footer                                   */
/*==========================================================================*/
#footer_top {
    display: flex;
    padding-top: 58px;
    padding-bottom: 46px;
}
#footer_top li:nth-child(1) {
    width: 540px;
}
#footer_top li:nth-child(2) dl {
    margin-bottom: 17px;
}
#footer_top li:nth-child(2) {
    padding-top: 8px;
}
#footer_top li:nth-child(2) dl dt {
    background: #ce3702;
    width: 80px;
    height: 26px;
    line-height: 26px;
    color: #fff;
    font-size: 13px;
    font-weight: 500;
    text-align: center;
    border-radius: 2.5px;
    margin-bottom: 3px;
}
#footer_top li:nth-child(2) dl dd {
    color: #666;
}
#footer_top li:nth-child(2) dl dd span {
    font-weight: 700;
}
#footer_top li:nth-child(2) dl dd {
    font-size: 13px;
}
address {
    height: 50px;
    line-height: 50px;
    background: #1a1a1a;
    color: #fff;
    text-align: center;
    font-size: 12px;
    letter-spacing: 1px;
    font-weight: 100;
}

/*=============================tab box01=========================*/


/*==============FIX GG==================*/
@media screen and (-webkit-min-device-pixel-ratio:0) {
}



/*==============FIX EDGE==================*/
 @supports (-ms-ime-align:auto) {
}

/*==============FIX IE==================*/
@media screen\0 {
}
