@charset "utf-8";
/*------------------------------------------------------------
	index
------------------------------------------------------------*/
.fixedBtn {
    width: 35px;
    position: fixed;
    bottom: 20px;
    right: 0;
    z-index: 999;
}
.fixedBtn li:not(:last-of-type) {
    margin-bottom: 4px;
}
.fixedNavi {
    padding: 8px 0;
    width: 100%;
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    background-color: #fff;
    z-index: 999;
}
.fixedNavi li {
    padding-bottom: 4px;
    width: 16.66%;
    border-right: 1px solid #666;
    box-sizing: border-box;
}
.fixedNavi li:last-of-type {
    border-right: none;
}
.fixedNavi li a {
    display: block;
    text-align: center;
}
.fixedNavi li img {
    margin: -9px auto 0;
    display: block;
    width: 49px;
}
.fixedNavi li span {
    margin-top: -5px;
    display: block;
    color: #666;
    font-size: 0.9rem;
    font-feature-settings: "palt"; 
    -moz-font-feature-settings: "palt";
}
.phoImg {
    margin: 0 auto 34px;
    width: 85.33%;
}
.phoImg img {
    width: 100%;
}
#main .sec01 {
    padding-bottom: 28px;
    position: relative;
    background-color: #DCF7F6;
}
#main .sec01::before {
    height: 0;
    width: 0;
    display: block;
    position: absolute;
    left: 0;
    bottom: -44px;
    border-color: transparent transparent transparent #DCF7F6;
    border-style: solid;
    border-width: 0 0 44px 99vw;
    content: "";
    z-index: 2;
    overflow: hidden;
}
#main .sec01 h2 {
    margin-bottom: 42px;
    padding: 12px 0 20px 10px;
    position: relative;
    text-align: center;
    background-color: #42BCC6;
}
#main .sec01 h2::before {
    margin-left: -31px;
    width: 63px;
    height: 30px;
    position: absolute;
    bottom: -24px;
    left: 50%;
    background: url("../img/common/icon01.png") no-repeat bottom center / 63px auto;
    content: "";
}
#main .sec01 .inner {
    margin-bottom: 19px;
}
#main .sec01 .inner p {
    margin: 0 -10px 4px;
    text-align: center;
    line-height: 1.5;
    font-feature-settings: "palt"; 
    -moz-font-feature-settings: "palt";
}
#main .sec01 .inner .photoBox img {    
    width: 100%;
}
#main .sec01 .inner ul {
    margin-bottom: 13px;
    text-align: center;
}
#main .sec01 .inner li {
    font-size: 1.1rem; 
    line-height: 1.55;
}
#main .sec01 .inner01 .photoBox {
    margin-left: -5px;
} 
#main .sec02 {
    padding-bottom: 28px;
    background: url("../img/index/bg01.jpg") center center / 15px auto;
}
#main .sec02 h2 {
    margin: -14px auto -3px;
    width: 88%;
    position: relative;
    z-index: 2;
}
#main .sec02 h2 img {
    width: 100%;
}
#main .sec02 .photoBox {
    margin: 0 auto 6px;
    width: 98.4%;
}
#main .sec02 .photoBox img {
    width: 100%;
}
#main .sec02 .title {
    margin-bottom: 10px;
    font-size: 1.7rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 1.5;
    text-align: center;
}
#main .sec02 .inner {
    margin-bottom: 15px;
    border-radius: 6px;
    overflow: hidden;
    background-color: #fff;
}
#main .sec02 .inner:last-of-type {
    margin-bottom: 0;
}
#main .sec02 .inner .innerTtl {
    margin-bottom: 12px;
    text-align: center;
}
#main .sec02 .inner p {
    margin: 0 17px 14px;
    font-size: 1.3rem;
    line-height: 1.78;
}
#main .sec02 .inner .pho img {
    width: 100%;
}
#main .sec03 {
    padding-top: 23px;
    background-color: #FFFFCC;
}
#main .sec03 .inner {
    margin-bottom: 24px;
    padding-bottom: 26px;
    background: url("../img/common/line02.png") repeat-x bottom center/ 6px auto;
}
#main .sec03 .inner:last-of-type {
    margin-bottom: 0;
    padding-bottom: 23px;
    background: none;
}
#main .sec03 .inner .textList {
    margin: 0 5px 20px;
    padding: 10px 5px 11px 5px;
    border: 1px solid #000;
    background-color: #fff;
    border-radius: 12px;
}
#main .sec03 .inner .textList > li {
    padding: 10px 0 17px;
    width: 45.5%;
    display: flex;
    align-items: center;
    justify-content: center;
    border-right: 1px solid #000;
    box-sizing: border-box;
}
#main .sec03 .inner .textList > li .txt {
    font-size: 1.1rem;
    line-height: 1.75;
    text-align: center;
}
#main .sec03 .inner .textList > li .txt > span {
    font-size: 1.6rem;
}
#main .sec03 .inner .textList > li:last-of-type {
    width: 54.5%;
    border-right: none;
}
#main .sec03 .inner .textList > li:last-of-type .txt {
    line-height: 1.7;
}
#main .sec03 .inner01 {
    margin-bottom: 22px;
}
#main .sec03 .inner01 .headLine03 {
    margin-bottom: 11px;
}
#main .sec03 .inner p {
    margin-bottom: 17px;
    font-size: 1.3rem;
    line-height: 1.78;
    text-align: center;
}
#main .sec03 .inner .pho {
    margin: 0 5px 20px;
}
#main .sec03 .inner .pho img {
    width: 100%;
}
#main .sec03 .inner01 .comLink {
    margin-bottom: 11px;
}
#main .sec03 .inner01 .comLink:last-of-type {
    margin-bottom: 0;
}
#main .sec03 .inner .imgList {
    margin: -4px 5px 1px;
}
#main .sec03 .inner .imgList li {
    margin: 4px 1.16% 0; 
    width: 31%;
}
#main .sec03 .inner .imgList li img {
    width: 100%;
}
#main .sec03 .inner02 .headLine03 {
    margin-bottom: 14px;
}
#main .sec03 .inner .note {
    margin-bottom: 7px;
    font-size: 0.9rem;
    text-align: right;
}
#main .sec03 .inner .title {
    margin-bottom: 10px;
    font-size: 2rem;
    letter-spacing: 0.2em;
    text-align: center;
}
#main .sec03 .inner .text {
    margin: 0 -10px 15px;
    font-size: 1.3rem;
    font-feature-settings: "palt"; 
    -moz-font-feature-settings: "palt";
}
#main .sec03 .inner02 {
    margin-bottom: 26px;
}
#main .sec03 .inner02 .textList {
    margin-bottom: 7px;
    padding: 15px 0 17px;
}
#main .sec03 .inner02 .textList > li {
    padding: 0;
    width: 35.5%;
}
#main .sec03 .inner02 .textList > li:last-of-type {
    padding-left: 6%;
    width: 64.5%;
    justify-content: flex-start;
}
#main .sec03 .inner02 .textList > li .innerList {
    margin-top: -6px;
    width: 87%;
}
#main .sec03 .inner02 .textList > li .innerList li {
    padding: 6px 0 5px 6px;
    font-size: 1.1rem;
    border-bottom: 1px solid #000;
}
#main .sec03 .inner02 .textList > li .innerList li:last-of-type {
    border-bottom: none;
}
#main .sec03 .inner02 .textList > li .innerList li span {
    display: inline-block;
    width: 50%;
}
#main .sec03 .inner02 .textList > li .innerList li sup {
    font-size: 0.7rem;
}
#main .sec03 .inner02 .comTxtList {
    margin: 0;
    list-style: none;
}
#main .sec03 .inner02 .comTxtList li {
    margin-bottom: 0;
    line-height: 1.3;
}
#main .sec03 .inner02 .comTxtList li.part01 {
    padding-left: 2em;
    text-indent: -2em;
}
#main .sec03 .inner .textUl {
    margin: 0 15px 17px;
}
#main .sec03 .inner .textUl li {
    padding: 15px 5px 19px;
    width: 46%;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 1.1rem;
    border: 1px solid #000;
    border-radius: 12px;
    background-color: #fff;
    box-sizing: border-box;
}
#main .sec03 .inner03 .headLine03 {
    margin-bottom: 18px;
}
#main .sec03 .inner03 .comTxtList {
    margin: 0;
}
#main .sec04 {
    padding-top: 22px;
    background-color: #F5F8FC;
}
#main .sec04 .headLine03 {
    margin-bottom: 18px;
}
#main .sec04 p {
    margin: 0 -17px 17px;
    font-size: 1.3rem;
    line-height: 1.78;
}
#main .sec04 .comTtl {
    margin: 0;
}
#main .sec04 .text {
    margin-bottom: 3px;
    text-align: center;
}
#main .sec04 .photo {
    margin-bottom: 5px;
    border-radius: 8px;
    overflow: hidden;
}
#main .sec04 .photo img {
    width: 100%;
}
#main .sec04 .phoList {
    margin-bottom: 11px;
}
#main .sec04 .phoList::after {
    width: 32%;
    content: "";
}
#main .sec04 .phoList li {
    width: 32%;
}
#main .sec04 .phoList li img {
    width: 100%;
}
#main .sec04 .comLink {
    margin-bottom: 19px;
    width: 218px;
}
#main .sec04 .comLink a {
    padding: 9px 10px 11px;
}
#main .sec04 .photo01 {
    margin: 5px 0 11px;
}
#main .sec04 .inner {
    margin-top: 29px;
    padding: 24px 0 20px;
    background: url("../img/index/bg02.jpg") center center / 10px auto;
}
#main .sec04 .inner .headLine03 {
    margin-bottom: 14px;
}
#main .sec04 .inner .note {
    font-size: 0.9rem;
    text-align: center;
}
#main .sec04 .inner .photo {
    border-radius: 5px;
}
#main .sec05 {
    padding: 28px 0 27px;
}
#main .sec05 .headLine03 {
    margin-bottom: 17px;
}
#main .sec05 p {
    margin-bottom: 25px;
    font-size: 1.3rem;
    line-height: 1.78;
    text-align: center;
}
#main .sec05 .photo {
    margin: 0 -20px 7px;
}
#main .sec05 .photo img {
    width: 100%;
}
#main .sec05 .comLink {
    margin-bottom: 20px;
    width: 218px;
}
#main .sec05 .tabBox {
    padding: 7px 25px 16px 25px;
    margin: 0 5px 8px;
    border: 1px solid #000;
    border-radius: 12px;
}
#main .sec05 .tabBox .ttl {
    margin-bottom: 10px;
    color: #C40D23;
    font-size: 1.1rem;
    letter-spacing: 0.075em;
}
#main .sec05 .tabBox .ttl span {
    font-size: 1.8rem;
}
#main .sec05 .tabBox table {
    width: 100%;			
    border-collapse: collapse;	
}
#main .sec05 .tabBox th,
#main .sec05 .tabBox td {
    padding: 3px 20px;
    font-size: 1.1rem;
    font-weight: 500;
    text-align: left;			
    vertical-align: top;			
    word-break: break-all;
    border-bottom: 1px solid #000;
}
#main .sec05 .tabBox td {
    text-align: right;
}
#main .sec05 .tabBox tr:last-of-type th,
#main .sec05 .tabBox tr:last-of-type td {
    border-bottom: none;
}
#main .sec05 .comTxtList {
    margin: 0 -5px 20px;
}
#main .sec05 .comTxtList li {
    margin-bottom: 0;
    line-height: 1.54;
}
#main .sec05 .mapBox {
    margin-bottom: 32px;
    width: 100%;
    position: relative;
    padding-bottom: 115%; 
    height: 0; 
    overflow: hidden; 
}
#main .sec05 .mapBox iframe {
    position: absolute; 
    top: 0; 
    left: 0; 
    width: 100%; 
    height: 100%; 
} 
#main .sec05 .inner h3 {
    margin-bottom: 30px;
    text-align: center;
}
#main .sec05 .inner .photo {
    margin: 0 0 9px;
}
#main .sec05 .inner .textUl {
    margin-right: -10px;
}
#main .sec05 .inner .textUl li {
    margin-bottom: 4px;
    padding-left: 18px;
    font-size: 1.1rem;
    line-height: 1.7;
    background: url("../img/index/sec05_img01.jpg") no-repeat left top 3px / 15px auto;
}
#main .sec05 .inner .textUl li.part01 {
    background-image: url("../img/index/sec05_img02.jpg");
}
#main .sec05 .inner .textUl li.part02 {
    background-image: url("../img/index/sec05_img03.jpg");
}
#main .sec05 .inner .textUl li.part03 {
    background-image: url("../img/index/sec05_img04.jpg");
}
#main .sec06 {
    padding-top: 30px;
    background-color: #DCEFF7;
}
#main .sec06 .headLine03 {
    margin-bottom: 26px;
}
#main .sec06 .title {
    margin-bottom: 8px;
    padding: 5px 0 8px 10px;
    color: #fff;
    font-size: 1.7rem;
    letter-spacing: 0.05em;
    background-color: #66CCFF;
    border-radius: 3px;
}
#main .sec06 dl {
    margin-bottom: 8px;
    padding: 0 10px 12px 10px;
    background-color: #fff;
    border-radius: 3px;
}
#main .sec06 dt {
    padding: 8px 20px 0 28px;
    position: relative;
    color: #66CCFF;
    line-height: 1.4;
    letter-spacing: 0.05em;
    background: url("../img/index/sec06_img01.png") no-repeat left top 8px / 17px auto;
    cursor: pointer;
}
#main .sec06 dt::before {
    width: 10px;
    height: 7px;
    position: absolute;
    top: 50%;
    right: 0;
    background: url("../img/index/sec06_img03_on.png") no-repeat center center / 10px auto;
    content: "";
}
#main .sec06 dt.on::before {
    background-image: url("../img/index/sec06_img03.png");
}
#main .sec06 dl:last-of-type {
    margin-bottom: 25px;
}
#main .sec06 dd {
    margin-top: 10px;
    padding-top: 10px;
    padding-left: 26px;
    display: none;
    font-size: 1.1rem;
    line-height: 1.65;
    border-top: 1px solid #66CCFF;
    text-align: justify;
    text-justify:inter-ideograph;
    background: url("../img/index/sec06_img02.png") no-repeat left top 10px / 17px auto;
}
#main .sec06 dd span {
    margin-top: 4px;
    display: block;
    font-size: 0.9rem;
}
#main .sec06 .inner {
    padding: 23px 0 22px;
    background-color: #FFF470;
}
#main .sec06 .inner .h3Ttl01 {
    margin-bottom: 21px!important;
}
#main .sec06 .inner .imgList li {
    margin-bottom: 8px;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    background-color: #fff;
    border-radius: 5px;
    overflow: hidden;
}
#main .sec06 .inner .imgList li:last-of-type {
    margin-bottom: 0;
}
#main .sec06 .inner .imgList li .pho {
    width: 30.5%;
}
#main .sec06 .inner .imgList li .pho img {
    width: 100%;
}
#main .sec06 .inner .imgList li p {
    padding: 0 10px;
    width: 69.5%;
    box-sizing: border-box;
}
#main .sec06 .inner .imgList li p img {
    margin-bottom: 3px;
    display: block;
    width: 203px;
}
#main .sec06 .inner .imgList li p span {
    display: block;
    font-size: 1.1rem;
    line-height: 1.63;
    text-align: justify;
    text-justify:inter-ideograph;
}
#main .sec07 {
    padding: 32px 0 25px;
    background-color: #17C117;
}
#main .sec07 h2 {
    margin-bottom: 18px;
    text-align: center;
}
#main .sec07 p {
    margin-bottom: 18px;
    color: #fff;
    font-size: 2.1rem;
    line-height: 1.83;
    letter-spacing: 0.2em;
    text-align: center;
}
#main .sec07 p span {
    display: block;
}
#main .sec07 .link {
    margin-bottom: 19px;
    width: 100%;
}
#main .sec07 .link a {
    padding: 10px 30px 15px;
    display: block;
    color: #17C117;
    font-size: 2.1rem;
    letter-spacing: 0.2em;
    text-align: center;
    background: #fff url("../img/common/icon03.png") no-repeat right 17px center / 10px auto;
    border-radius: 12px;
}
#main .sec07 .photo {
    margin: 0 auto;
    width: 94%;
}
#main .sec07 .photo img {
    width: 100%;
}
#main .sec08 {
    padding: 34px 0 45px;
    background-color: #FFFBED;
}
#main .sec08 h2 {
    margin: 0 -10px 28px;
    color: #CC0033;
    font-size: 2.3rem;
    letter-spacing: 0.07em;
    text-align: center;
}
#main .sec08 p {
    margin: 0 5px 16px;
    font-size: 1.3rem;
    line-height: 1.78;
}
#main .sec08 .formBox {
    margin: 0 5px;
}
#main .sec08 .formBox table {
    margin-bottom: 22px;
    width: 100%;			
    border-collapse: collapse;
}
#main .sec08 .formBox th,
#main .sec08 .formBox td {
    margin-bottom: 2px;
    display: block;
    width: 100%;
    font-size: 1.1rem;
    font-weight: 500;
    text-align: left;			
    vertical-align: top;			
    word-break: break-all;
}
#main .sec08 .formBox td {
    margin-bottom: 11px;
}
#main .sec08 .formBox tr:last-of-type td {
    margin-bottom: 0;
}
#main .sec08 .formBox td input[type="text"],
#main .sec08 .formBox td input[type="tel"] {
    padding: 1px 5px;
    width: 100%;
    height: 38px;
    font-size: 1.2rem;
    border: 1px solid #CCCCCC;
    border-radius: 0;
    box-sizing: border-box;
    -webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}
#main .sec08 .formBox th span {
    margin-left: 10px;
    padding: 0 3px 1px;
    display: inline-block;
    color: #fff;
    font-size: 0.9rem;
    background-color: #CC0033;
}
#main .sec08 .formBox .textArea {
    margin-bottom: 7px;
    padding: 11px 10px 16px 14px;
    background-color: #fff;
    border: 1px solid #CC0033;
}
#main .sec08 .formBox .textArea p {
    margin-bottom: 8px;
    font-size: 1.3rem;
    line-height: 1.78;
}
#main .sec08 .formBox .textArea .link a {
    display: block;
    color: #CC0033;
    letter-spacing: 0.05em;
    text-align: center;
    text-decoration: underline;
}
#main .sec08 .formBox .agree {
    margin-bottom: 8px;
    text-align: center;
}
#main .sec08 .formBox .agree input[type="checkbox"] {
    display: none;
}
#main .sec08 .formBox .agree input[type="checkbox"] + span {
    padding: 0 0 2px 20px;
    display: inline-block;
    background: url("../img/common/icon04.png") no-repeat left center / 16px auto;
}
#main .sec08 .formBox .agree input[type="checkbox"]:checked + span {
	background-image: url("../img/common/icon05.png");
}
#main .sec08 .formBox .submit {
    text-align: center;
}
#main .sec08 .formBox .submit li {
    margin-bottom: 10px;
    display: block;
}
#main .sec08 .formBox .submit li:last-of-type {
    margin-bottom: 0;
}
#main .sec08 .formBox .submit li input {
    padding: 7px;
    width: 258px;
    color: #fff;
    font-size: 1.7rem;
    letter-spacing: 0.05em;
    -webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
    background: #CC0033 url("../img/common/icon06.png") no-repeat right 15px center / 8px auto;
    box-sizing: border-box;
    border: none;
    border-radius: 21px;
}
#main .sec08 .formBox .confirmBox th,
#main .sec08 .formBox .confirmBox td {
    padding: 2px;
    font-size: 1.3rem;
    font-weight: 700;
}
#main .sec08 .formBox .confirmBox td {
    font-weight: 400;
}
#thanks #main p {
    margin: 0 20px 20px;
    text-align: center;
    line-height: 1.5;
}
.errorMsg {
    margin-bottom: 20px;
    color: #CC0033;
    font-size: 1.2rem;
    line-height: 1.8;
}
@media all and (max-width: 370px) {
    #main .sec01 .inner p {
        margin: 0 -15px 4px;
    }
    #main .sec01 .inner li {
        font-size: 1rem;
    }
    #main .sec03 .inner .text {
        font-size: 1.2rem;
    }
    #main .sec04 .text {
        font-size: 1.2rem;
    }
    #main .sec05 .tabBox th, 
    #main .sec05 .tabBox td {
        padding: 3px 10px;
    }
}
@media all and (max-width: 330px) {
    .fixedNavi li span {
        letter-spacing: -1px;
    }
    #main .sec01 .inner p {
        font-size: 1.3rem;
    }
    #main .sec03 .inner p {
        font-size: 1.2rem;
    }
    #main .sec03 .inner .text {
        font-size: 1.1rem;
    }
    #main .sec03 .inner02 .textList > li .innerList li {
        font-size: 1rem;
    }
    #main .sec04 .text {
        font-size: 1.1rem;
    }
    #main .sec05 p {
        font-size: 1.1rem;
    }
    #main .sec05 .tabBox {
        padding: 7px 10px 16px;
    }
    #main .sec07 p {
        font-size: 1.9rem;
    }
    #main .sec08 h2 {
        font-size: 2rem;
    }
    #main .sec08 .formBox .agree input[type="checkbox"] + span {
        font-size: 1.1rem;
    }
    #main .sec06 .inner .imgList li .pho {
        width: 100px;
    }
    #main .sec06 .inner .imgList li p {
        width: calc(100% - 100px);
    }
}