@charset "UTF-8";

@media print, screen and (min-width: 768px) {
  body{
    zoom: 80% !important;
  }
  header,footer{
    zoom: 100% !important;
  }
}
  /*
  トップページ
  -------------------------------------*/
  #Main{}
  #Main .mainImg{
    background: url(../img/top/mainimg.jpg)no-repeat;
    background-size: cover;
    background-position: center;
    width: 100%;
    height: 978px;
    position: relative;
  }
  #Main .mainImg .catchCopy{
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    display: flex;
    flex-direction: row-reverse;
    text-align: left;
  }
  #Main .mainImg .catchCopy span{
    background-color: rgba(255,255,255,0.7);
    width: 125px;
    height: 700px;
    padding: 30px 36px 0;
    margin-left: 30px;
    writing-mode: vertical-rl;
    text-orientation: upright;
    font-feature-settings: 'pkna';
    font-size: 34px;
    font-weight: bold;
    letter-spacing: 10px;
    position: relative;
  }
  #Main .mainImg .catchCopy span strong{
    opacity: 0;
  }
  #Main .mainImg .catchCopy .ast{
    background: none;
    position: absolute;
    left: -3px;
    top: 277px;
    font-size: 40px;
    color: #B52B2E;
  }
  #Main .mainImg .catchCopy .copy01{}
  #Main .mainImg .catchCopy .copy02{}
  #Main .mainImg .catchCopy .copy03{
    margin-left: 0;
    letter-spacing: 8px;
  }
  #Main .mainImg .catchCopy .redAst{
    background-color: unset;
    color: #B52B2E;
    padding: 0;
  }
  #Main .mainSubBox .priceBox{
    position: absolute;
    left: 127px;
    bottom: 61px;
  }
  #Main .mainSubBox .priceBox .copyBox{
    display: flex;
    flex-direction: row-reverse;
    justify-content: center;
    margin-bottom: 24px;
  }
  #Main .mainSubBox .priceBox .copyBox span{
    writing-mode: vertical-rl;
    text-orientation: upright;
    font-feature-settings: 'pkna';
    font-size: 18px;
    color: #fff;
    font-weight: bold;
    letter-spacing: 4px;
    width: 52px;
    height: 300px;
    padding: 13px 12px 0px;
    text-align: left;
    margin-left: 13px;
  }
  #Main .mainSubBox .priceBox .copyBox .pCopy01{
    background-color: rgba(101,179,187,0.7);
  }
  #Main .mainSubBox .priceBox .copyBox .pCopy02{
    background-color: rgba(180,151,193,0.7);
  }
  #Main .mainSubBox .priceBox .copyBox .pCopy03{
    background-color: rgba(207,214,48,0.7);
    margin-left: 0;
  }
  #Main .mainSubBox .priceBox .notePc{
    width: 305px;
    height: 222px;
    position: relative;
    left: 11px;
  }
  #Main .mainSubBox .priceBox .price{
    text-align: center;
  }
  #Main .mainSubBox .priceBox .price img{
    width: 203px;
    height: 203px;
    margin-top: -42px;
  }
  #Main .mainSubBox{
    position: relative;
  }
  #Main .mainSubBox .titleBox{
    text-align: center;
  }
  #Main .mainSubBox .titleBox .disp_pc{
    display: inline-block;
  }
  #Main .mainSubBox .titleBox img span{}
  #Main .mainSubBox .shukatsuki{
  }
  #Main .mainSubBox .shukatsuki img{}
  .sec01{
    background-image: url(../img/top/sec1_bg.jpg);
    background-size: cover;
    background-position: center;
    height: 978px;
    position: relative;
  }
  .sec01 p{
    padding-top: 108px;
    font-size: 32px;
    text-align: center;
    line-height: 2;
    letter-spacing: 5px;
  }
  .sec01 .sampleBox{
    background-image: url(../img/top/icon_01.png);
    width: 388px;
    height: 207px;
    position: absolute;
    right: 227px;
    bottom: 75px;
  }
  .sec01 .sampleBox a{
    display: block;
    color: #fff;
    font-size: 18px;
    padding: 63px 0;
    letter-spacing: 3px;
  }
  .sec02{}
  .sec02 .box01{
    background-color: rgba(160,184,185,0.6);
    height: 392px;
  }
  .sec02 .box01 h3{
    padding-top: 140px;
    font-size: 36px;
    letter-spacing: 5px;
  }
  .sec02 .box01 p{
    margin-top: 40px;
    font-size: 21px;
    text-align: center;
    letter-spacing: 3px;
  }
  .sec02 .box02{
    background-image: url(../img/top/sec2_bg.jpg);
    background-position: center;
    background-size: cover;
    padding: 120px 0;
  }
  .sec02 .box02 .inner{
    max-width: 1632px;
    margin: auto;
    padding-left: 30px;
  }
  .sec02 .box02 h3{
    font-size: 32px;
    line-height: 1.5;
    text-align: left;
  }
  .sec02 .box02 p{
    font-size: 21px;
    line-height: 2;
    margin-top: 70px;
  }
  .sec02 .box02 .circlePara{
    padding-left: 1rem;
    position: relative;
  }
  .sec02 .box02 .circlePara::before{
    content: "●";
    color: #9DC138;
    position: absolute;
    left: 0;
    font-size: 12px;
    top: 8px;
  }
  .sec02 .box02 ul{
    display: flex;
  }
  .sec02 .box02 ul li{
    margin-right: 22px;
  }
  .sec02 .box02 ul li:last-of-type{
    margin-right: 0;
  }
  .sec02 .box02 ul h4{
    text-align: left;
    margin-bottom: 8px;
  }
  .sec02 .box02 span{
    display: block;
    text-align: right;
    margin-top: 20px;
  }
  .sec02 .box03{
    padding-top: 110px;
    padding-bottom: 100px;
  }
  .sec02 .box03 h3{
    font-size: 21px;
    letter-spacing: 3px;
    line-height: 2;
  }
  .sec02 .box03 .sampleBox{
    background-image: url(../img/top/icon_02.png);
    width: 279px;
    height: 150px;
    margin: auto;
    margin-top: 15px;
  }
  .sec02 .box03 .sampleBox a{
    display: block;
    color: #fff;
    font-size: 12px;
    padding: 48px 0;
    letter-spacing: 3px;
  }
  .sec03{}
  .sec03 .box01{
    background-image: url(../img/top/sec3_bg.jpg);
    background-position: center;
    background-size: cover;
    padding: 120px 0 227px;
  }
  .sec03 .box01 .inner{
    max-width: 1043px;
    margin-left: auto;
    margin-right: 180px;
  }
  .sec03 .box01 h3{
    text-align: left;
    font-size: 32px;
    letter-spacing: 5px;
    line-height: 2;
    margin-bottom: 50px;
  }
  .sec03 .box01 p{
    font-size: 21px;
    letter-spacing: 3px;
    line-height: 2;
    margin-bottom: 70px;
  }
  .sec03 .box01 ul{
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
  }
  .sec03 .box01 ul li{
    text-align: left;
    font-size: 18px;
    width: 420px;
    height: 56px;
    margin-bottom: 18px;
    padding: 15px 43px;
  }
  .sec03 .box01 ul li.o1{order: 1; margin-right: 203px;}
  .sec03 .box01 ul li.o2{order: 2;}
  .sec03 .box01 ul li.o3{order: 3; margin-right: 203px;}
  .sec03 .box01 ul li.o4{order: 4;}
  .sec03 .box01 ul li.o5{order: 5; margin-right: 203px;}
  .sec03 .box01 ul li.o6{order: 6;}
  .sec03 .box01 ul li.o7{order: 7; margin-right: 203px;}
  .sec03 .box01 ul li.o8{order: 8;}
  .sec03 .box01 ul li.o9{order: 9; margin-right: 203px;}
  .sec03 .box01 ul li.o10{order: 10;}
  .sec03 .box01 ul li.o11{order: 11; margin-left: 623px;}
  .sec03 .box01 ul li.bgBlue{
    background-color: rgba(100,165,221,0.4);
  }
  .sec03 .box01 ul li.bgGray{
    background-color: #C7C8C8;
  }
  .sec03 .box01 .subBox01{
    position: relative;
    left: 623px;
    top: 28px;
  }
  .sec03 .box01 .subBox01 span{
    display: block;
    font-size: 14px;
    text-align: left;
    position: relative;
    padding-left: 30px;
  }
  .sec03 .box01 .subBox01 span:first-of-type{
    margin-bottom: 20px;
  }
  .sec03 .box01 .subBox01 span.blue::before{
    content: "";
    width: 24px;
    height: 24px;
    background-color: rgba(100,165,221,0.4);
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    margin: auto;
  }
  .sec03 .box01 .subBox01 span.gray::before{
    content: "";
    width: 24px;
    height: 24px;
    background-color: #C7C8C8;
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    margin: auto;
  }
  .sec03 .box02{
    padding: 110px 0 95px;
  }
  .sec03 .box02 h3{
    font-size: 21px;
    letter-spacing: 5px;
  }
  .sec03 .box02 .sampleBox{
    background-image: url(../img/top/icon_03.png);
    width: 279px;
    height: 150px;
    margin: auto;
    margin-top: 15px;
  }
  .sec03 .box02 .sampleBox a{
    display: block;
    color: #fff;
    font-size: 12px;
    padding: 48px 0;
    letter-spacing: 5px;
    line-height: 1.8;
  }
  .sec04{}
  .sec04 .box01{
    background-image: url(../img/top/sec4_bg.jpg);
    background-position: center;
    background-size: cover;
    padding: 120px 0 150px;
  }
  .sec04 .box01 .inner{
    max-width: 1600px;
    margin: auto;
    padding-left: 30px;
  }
  .sec04 .box01 h3{
    text-align: left;
    font-size: 32px;
    line-height: 1.5;
    letter-spacing: 8px;
    margin-bottom: 75px;
  }
  .sec04 .box01 p{
    font-size: 21px;
    line-height: 2;
    margin-bottom: 60px;
    letter-spacing: 3px;
  }
  .sec04 .box01 .ast{
    color: #B70050;
    font-size: 12px;
    position: relative;
    top: -7px;
  }
  .sec04 .box01 .subBox01 h4{
    font-size: 21px;
    letter-spacing: 3px;
    text-align: left;
    position: relative;
    padding-left: 1rem;
    margin-bottom: 38px;
  }
  .sec04 .box01 .subBox01 h4::before{
    content: "●";
    color: #1E2160;
    position: absolute;
    left: 0;
    font-size: 12px;
    top: 8px;
  }
  .sec04 .box01 .subBox01{
    width: 1470px;
    margin: auto;
  }
  .sec04 .box01 .subBox01::after{
    content: "";
    display: block;
    clear: both;
  }
  .sec04 .box01 .subBox01 .box{
    width: 660px;
    height: 630px;
    padding-top: 40px;
  }
  .sec04 .box01 .subBox01 .box h5{
    font-size: 18px;
    letter-spacing: 3px;
    text-align: left;
    padding-left: 40px;
    margin-bottom: 40px;
  }
  .sec04 .box01 .subBox01 .box h5::before{
    content: "■";
    color: #1E2160;
    font-size: 18px;
  }
  .sec04 .box01 .subBox01 .box ul{
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  .sec04 .box01 .subBox01 .box ul li{
    width: 360px;
    font-size: 18px;
    letter-spacing: 3px;
    text-align: left;
    margin-bottom: 30px;
    color: #fff;
    padding: 17px 0;
    padding-left: 50px;
  }
  .sec04 .box01 .subBox01 .left{
    float: left;
    background-color: rgba(139,174,178,0.3);
  }
  .sec04 .box01 .subBox01 .left li{
    background-color: #5389B7;
  }
  .sec04 .box01 .subBox01 .right{
    float: right;
    background-color: rgba(101,175,152,0.2);
  }
  .sec04 .box01 .subBox01 .right li{
    background-color: #82A02D;
  }
  .sec04 .box01 .remarkBox{
    width: 1470px;
    margin: auto;
    margin-top: 50px;
  }
  .sec04 .box01 .remarkBox li{
    text-align: left;
    font-size: 14px;
    letter-spacing: 5px;
  }
  .sec04 .box01 .remarkBox li .ast{
    font-size: 9px;
  }
  .sec04 .box02{
    padding: 100px 0;
  }
  .sec04 .box02 h3{
    font-size: 21px;
    letter-spacing: 5px;
    line-height: 2;
  }
  .sec04 .box02 .sampleBox{
    margin-top: 20px;
    display: flex;
    justify-content: center;
  }
  .sec04 .box02 .sampleBox li{
    margin-right: 148px;
    font-size: 13px;
    color: #fff;
    background-image: url(../img/top/icon_05.png);
    width: 279px;
    height: 149px;
    letter-spacing: 3px;
    line-height: 2;
    padding: 41px 0;
  }
  .sec04 .box02 .sampleBox li:last-of-type{
    margin-right: 0;
  }
  .sec04 .box02 .sampleBox li.sampleBlue{
    background-image: url(../img/top/icon_04.png);
  }
  .sec05{}
  .sec05 .box01{
    background-image: url(../img/top/sec5_bg.jpg);
    background-position: center;
    background-size: cover;
    padding: 90px 0 70px;
  }
  .sec05 .box01 .inner{
    max-width: 1600px;
    margin: auto;
    padding-left: 30px;
  }
  .sec05 .box01 h3{
    text-align: left;
    font-size: 32px;
    line-height: 1.5;
    letter-spacing: 8px;
    margin-bottom: 75px;
  }
  .sec05 .box01 p{
    font-size: 21px;
    line-height: 2;
    margin-bottom: 60px;
    letter-spacing: 3px;
  }
  .sec05 .box01 .subBox01{
    position: relative;
    background-color: rgba(255,255,255,0.4);
    width: 1200px;
    margin: auto;
    padding: 98px 0 85px;
    margin-bottom: 75px;
  }
  .sec05 .box01 .subBox01 img{
    position: relative;
    left: -169px;
  }
  .sec05 .box01 .subBox01 .flow{
    font-size: 18px;
    line-height: 2;
    position: absolute;
    text-align: left;
  }
  .sec05 .box01 .subBox01 .flow01{left: 281px; top: 148px;}
  .sec05 .box01 .subBox01 .flow02{right: 150px; top: 256px;}
  .sec05 .box01 .subBox01 .flow03{right: 195px; top: 454px;}
  .sec05 .box01 .subBox01 .flow04{right: 170px; top: 612px;}
  .sec05 .box01 .subBox01 .flow05{right: 235px; top: 772px;}
  .sec05 .box01 .subBox01 .flow06{right: 125px; bottom: 494px;}
  .sec05 .box01 .subBox01 .flow07{left: 305px; bottom: 452px;}
  .sec05 .box01 .subBox01 .flow08{right: 237px; bottom: 303px;}
  .sec05 .box01 .subBox01 ul{
    width: 870px;
    margin: auto;
    margin-left: 230px;
  }
  .sec05 .box01 .subBox01 ul li{
    text-align: left;
    font-size: 14px;
    line-height: 2;
  }
  .sec05 .box01 .subBox01 ul li .ast{
    font-size: 9px;
    color: #B52B2E;
    position: relative;
    top: -3px;
  }
  .sec05 .box01 .underBar{
    border-bottom: 1px solid #B80050;
    width: fit-content;
  }
  .sec05 .box01 .remark{
    margin-bottom: 0;
  }
  .sec05 .box02{
    padding: 100px 10px 40px;
  }
  .sec05 .box02 h3{
    font-size: 21px;
    line-height: 2;
  }
  .sec05 .box02 .sampleBox{
    background-image: url(../img/top/icon_02.png);
    width: 279px;
    height: 150px;
    margin: auto;
    margin-top: 15px;
  }
  .sec05 .box02 .sampleBox a{
    display: block;
    color: #fff;
    font-size: 12px;
    padding: 39px 0;
    letter-spacing: 3px;
    line-height: 2;
  }
  .sec05 .box02 p{
    margin-top: 25px;
    text-align: center;
    font-size: 14px;
    line-height: 1.5;
  }
  .sec06{
    background-color: rgba(101,175,152,0.1);
    padding: 110px 0 138px;
  }
  .sec06 .inner{
    max-width: 1620px;
    margin: auto;
    padding-left: 30px;
  }
  .sec06 h3{
    font-size: 32px;
    text-align: left;
    letter-spacing: 5px;
    margin-bottom: 60px;
    line-height: 2;
  }
  .sec06 p{
    font-size: 21px;
    line-height: 2;
    margin-bottom: 60px;
  }
  .sec06 .box01{
    width: 1365px;
    margin: auto;
  }
  .sec06 .box01::after{
    content: "";
    display: block;
    clear: both;
  }
  .sec06 .box01 h4{
    font-size: 21px;
    margin-bottom: 30px;
    text-align: left;
    letter-spacing: 3px;
  }
  .sec06 .box01 h4:before{
    content: "●";
    color: #9DC138;
    font-size: 12px;
    position: relative;
    top: -3px;
  }
  .sec06 .box01 .left{
    float: left;
    width: 752px;
  }
  .sec06 .box01 .subBox01{
    background-color: rgba(121,145,119,0.3);
    display: flex;
    justify-content: center;
    padding: 35px 0 45px;
  }
  .sec06 .box01 .subBox01 .first{
    margin-right: 158px;
  }
  .sec06 .box01 .subBox01 dl dt{
    font-size: 21px;
    margin-bottom: 10px;
  }
  .sec06 .box01 .subBox01 dl dd{}
  .sec06 .box01 .subBox02{
    background-color: #fff;
    padding-top: 55px;
    height: 500px;
  }
  .sec06 .box01 .subBox02 ul{
    display: flex;
    flex-direction: row-reverse;
    justify-content: center;
  }
  .sec06 .box01 .subBox02 ul li{
    writing-mode: vertical-rl;
    text-orientation: upright;
    margin-left: 55px;
    font-feature-settings: 'pkna';
  }
  .sec06 .box01 .subBox02 ul li:last-of-type{
    margin-left: 0;
  }
  .sec06 .box01 .subBox02 ul li h5{
    font-size: 18px;
    text-align: left;
    margin-left: 5px;
    line-height: 1.5;
  }
  .sec06 .box01 .subBox02 ul li p{
    font-size: 12px;
    margin-top: 70px;
    padding-top: 20px;
    position: relative;
    line-height: 1.8;
  }
  .sec06 .box01 .subBox02 ul li p::before{
    content: "";
    height: 10px;
    width: 100%;
    background-color: #B3B2B2;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    margin: auto;
  }
  .sec06 .box01 .right{
    width: 536px;
    float: right;
  }
  .sec07{}
  .sec07 .box01{
    background-color: rgba(160,184,185,0.6);
    padding: 95px 0 85px;
  }
  .sec07 .box01 h3{
    font-size: 36px;
    letter-spacing: 5px;
    margin-bottom: 25px;
  }
  .sec07 .box01 p{
    text-align: center;
    font-size: 21px;
  }
  .sec07 .box02{
    margin-top: 120px;
  }
  .sec07 .box02 .inner{
  }
  .sec07 .box02 ul{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-evenly;
  }
  .sec07 .box02 ul li{
    width: 886px;
    height: 886px;
    position: relative;
    margin-bottom: 120px;
  }
  .sec07 .box02 ul li h4{
    font-size: 42px;
    letter-spacing: 5px;
    line-height: 1.5;
    text-align: left;
  }
  .sec07 .box02 ul li p{
    font-size: 18px;
    line-height: 2;
    letter-spacing: 3px;
  }
  .sec07 .box02 ul li p .blue{
    color: #64A5DD;
  }
  .sec07 .box02 ul li.o1{
    order: 1;
    background-image: url(../img/top/sec7_1.jpg);
    background-size: cover;
    background-position: center;
  }
  .sec07 .box02 ul li.o1::before{
    content: "";
    background-image: url(../img/top/no1.png);
    position: absolute;
    top: 30px;
    right: 30px;
    width: 70px;
    height: 69px;
  }
  .sec07 .box02 ul li.o1 h4{
    position: absolute;
    top: 60px;
    left: 85px;
  }
  .sec07 .box02 ul li.o1 p{
    position: absolute;
    top: 270px;
    right: 50px;
  }
  .sec07 .box02 ul li.o2{
    order: 2;
    background-image: url(../img/top/sec7_4.jpg);
    background-size: cover;
    background-position: center;
  }
  .sec07 .box02 ul li.o2::before{
    content: "";
    background-image: url(../img/top/no4.png);
    position: absolute;
    top: 30px;
    right: 30px;
    width: 69px;
    height: 69px;
  }
  .sec07 .box02 ul li.o2 h4{
    position: absolute;
    top: 60px;
    left: 60px;
  }
  .sec07 .box02 ul li.o2 p{
    position: absolute;
    top: 270px;
    right: 145px;
  }
  .sec07 .box02 ul li.o3{
    order: 3;
    background-image: url(../img/top/sec7_2.jpg);
    background-size: cover;
    background-position: center;
  }
  .sec07 .box02 ul li.o3::before{
    content: "";
    background-image: url(../img/top/no2.png);
    position: absolute;
    top: 30px;
    right: 30px;
    width: 70px;
    height: 69px;
  }
  .sec07 .box02 ul li.o3 h4{
    position: absolute;
    top: 325px;
    left: 196px;
  }
  .sec07 .box02 ul li.o3 p{
    position: absolute;
    top: 550px;
    right: 170px;
  }
  .sec07 .box02 ul li.o4{
    order: 4;
    background-image: url(../img/top/sec7_5.jpg);
    background-size: cover;
    background-position: center;
  }
  .sec07 .box02 ul li.o4::before{
    content: "";
    background-image: url(../img/top/no5.png);
    position: absolute;
    top: 30px;
    right: 30px;
    width: 69px;
    height: 69px;
  }
  .sec07 .box02 ul li.o4 h4{
    position: absolute;
    top: 325px;
    left: 155px;
  }
  .sec07 .box02 ul li.o4 p{
    position: absolute;
    top: 550px;
    right: 146px;
  }
  .sec07 .box02 ul li.o5{
    order: 5;
    background-image: url(../img/top/sec7_3.jpg);
    background-size: cover;
    background-position: center;
  }
  .sec07 .box02 ul li.o5::before{
    content: "";
    background-image: url(../img/top/no3.png);
    position: absolute;
    top: 30px;
    right: 30px;
    width: 70px;
    height: 69px;
  }
  .sec07 .box02 ul li.o5 h4{
    position: absolute;
    bottom: 50px;
    left: 84px;
  }
  .sec07 .box02 ul li.o5 p{
    position: absolute;
    top: 410px;
    right: 247px;
  }
  .sec07 .box02 ul li.o6{
    order: 6;
    background-image: url(../img/top/sec7_6.jpg);
    background-size: cover;
    background-position: center;
  }
  .sec07 .box02 ul li.o6::before{
    content: "";
    background-image: url(../img/top/no6.png);
    position: absolute;
    top: 30px;
    right: 30px;
    width: 69px;
    height: 69px;
  }
  .sec07 .box02 ul li.o6 h4{
    position: absolute;
    bottom: 50px;
    left: 56px;
  }
  .sec07 .box02 ul li.o6 p{
    font-size: 17px;
    position: absolute;
    top: 109px;
    left: 71px;
  }
  .sec07 .box02 ul li.o6 .remark{
    font-size: 14px;
  }

  @media print, screen and (min-width: 768px) {
    #Main .mainSubBox{
      display: flex;
    min-width: 1670px;
    justify-content: flex-end;
    margin-top: 130px;
    margin-bottom: 145px;
    }
    #Main .mainSubBox .priceBox{}
    #Main .mainSubBox .titleBox{
      display: inline-block;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    }
    #Main .mainSubBox .shukatsuki{
      display: inline-block;
    margin-right: 45px;
}
.sec07 .box02 .inner{
  min-width: 1800px;
    margin: auto;
}
    }
  @media print, screen and (max-width: 767px) {
    .inner{
      padding-left: 0!important;
    }
    #Main{
      /*margin-top: 60px;*/
    }
    #Main .mainImg{
        height: 600px;
    }
    #Main .mainImg .catchCopy span{
      background-color: rgba(255,255,255,0.7);
    width: 70px;
    height: 400px;
    padding: 20px 20px 0;
    margin-left: 30px;
    writing-mode: vertical-rl;
    text-orientation: upright;
    font-feature-settings: 'pkna';
    font-size: 20px;
    font-weight: bold;
    letter-spacing: 5px;
    position: relative;
    }
    #Main .mainImg .catchCopy .copy03{
      letter-spacing: 5px;
    }
    #Main .mainImg .catchCopy .ast{
      left: -15px;
      top: 158px;
      font-size: 20px;
    }
    #Main .mainSubBox .priceBox{
      position: unset;
      margin-top: 30px;
    }
    #Main .mainSubBox .priceBox .copyBox span{
      writing-mode: vertical-rl;
      text-orientation: upright;
      font-feature-settings: 'pkna';
      font-size: 14px;
      color: #fff;
      font-weight: bold;
      letter-spacing: 4px;
      width: 30px;
      height: 247px;
      padding: 7px 5px 0px;
      text-align: left;
      margin-left: 13px;
    }
    #Main .mainSubBox .priceBox .spWrap{
      margin-top: 50px;
    }
    #Main .mainSubBox .priceBox .notePc {
      width: 152px;
      height: 111px;
      position: relative;
      left: 0;
    }
    #Main .mainSubBox .priceBox .price img {
      width: 101px;
      height: 101px;
      margin-top: -20px;
    }
    #Main .mainSubBox .titleBox{
      margin: 0;
      margin-top: 50px;
    }
    #Main .mainSubBox .shukatsuki{
      position: unset;
      margin: 50px 0;
    }
    #Main .mainSubBox .shukatsuki img{
      width: calc( 100% / 2 );
    }
    #Main .mainSubBox .disp_sp{
      width: calc( 100% / 2 );
      margin: auto;
      margin-bottom: 50px;
    }
    #Main .mainSubBox .titleBox .disp_pc{
      display: none;
    }
    .sec01{
      height: 530px;
      padding: 0 10px;
    }
    .sec01 p{
      font-size: 16px;
      padding-top: 40px;
      letter-spacing: 3px;
    }
    .sec01 .sampleBox{
      right: 17px;
      bottom: 24px;
      background-size: cover;
      width: calc( 388px / 1.8 );
      height: calc( 207px / 1.8 );;
    }
    .sec01 .sampleBox a{
      font-size: 11px;
      padding: 33px 0;
    }
    .sec02 .box01{
      height: unset;
      padding: 50px 10px;
    }
    .sec02 .box01 h3{
      padding-top: 0px;
      font-size: 24px;
      letter-spacing: 5px;
    }
    .sec02 .box01 p{
      margin-top: 20px;
      font-size: 16px;
      text-align: center;
      letter-spacing: 3px;
      line-height: 1.5;
      margin-bottom: 0;
    }
    .sec02 .box02{
      padding: 60px 10px;
    }
    .sec02 .box02 h3{
      font-size: 24px;
    }
    .sec02 .box02 p{
      font-size: 16px;
      margin-top: 35px;
    }
    .sec02 .box02 .circlePara::before{
      top: 4px;
    }
    .sec02 .box02 ul{
      display: block;
    }
    .sec02 .box02 ul li{
      margin-right: 0;
      margin-top: 30px;
    }
    .sec02 .box02 ul img{
      width: 100%;
    }
    .sec02 .box02 span{
      text-align: left;
      margin-top: 15px;
    }
    .sec02 .box03{
      padding: 50px 10px 50px;
    }
    .sec02 .box03 h3{
      font-size: 16px;
    }
    .sec03 .box01{
      padding: 60px 10px;
      background-position: right;
    }
    .sec03 .box01 .inner{
      margin: 0;
    }
    .sec03 .box01 h3{
      font-size: 24px;
      line-height: 1.5;
      margin-bottom: 30px;
    }
    .sec03 .box01 p{
      font-size: 16px;
    }
    .sec03 .box01 ul{
      display: block;
    }
    .sec03 .box01 ul li{
      font-size: 16px;
      width: 100%;
      padding: 15px;
    }
    .sec03 .box01 ul li.o11{
      margin-left: 0;
    }
    .sec03 .box01 .subBox01{
      position: unset;
    }
    .sec03 .box01 .subBox01 span.blue::before,.sec03 .box01 .subBox01 span.gray::before{
      top: -20px;
    }
    .sec03 .box02{
      padding: 50px 10px;
    }
    .sec04 .box01{
      padding: 60px 10px;
    }
    .sec04 .box01 h3{
      font-size: 24px;
      margin-bottom: 30px;
    }
    .sec04 .box01 p{
      font-size: 16px;
      margin-bottom: 30px;
    }
    .sec04 .box01 .subBox01{
      width: 100%;
    }
    .sec04 .box01 .subBox01 h4{
      font-size: 16px;
      margin-bottom: 15px;
    }
    .sec04 .box01 .subBox01 h4::before{
      top: 3px;
    }
    .sec04 .box01 .subBox01 .box{
      float: none;
      width: 100%;
      height: auto;
      margin-bottom: 30px;
      padding-top: 30px;
    }
    .sec04 .box01 .subBox01 .box h5{
      font-size: 16px;
      padding: 0 10px;
      margin-bottom: 30px;
    }
    .sec04 .box01 .subBox01 .box ul li{
      width: 100%;
      font-size: 16px;
      text-align: center;
      padding-left: 0;
    }
    .sec04 .box01 .remarkBox{
      margin-top: 25px;
      width: 100%;
    }
    .sec04 .box01 .remarkBox li{
      font-size: 16px;
      margin-bottom: 20px;
    }
    .sec04 .box02{
      padding: 50px 10px;
    }
    .sec04 .box02 h3{
      font-size: 16px;
    }
    .sec04 .box02 .sampleBox{
      display: block;
    }
    .sec04 .box02 .sampleBox li{
      margin: auto;
      margin-bottom: 30px;
    }
    .sec04 .box02 .sampleBox li:last-of-type{
      margin: auto;
      margin-bottom: 0;
    }
    .sec05 .box01{
      padding: 50px 10px;
    }
    .sec05 .box01 h3{
      font-size: 24px;
      margin-bottom: 30px;
    }
    .sec05 .box01 p{
      font-size: 16px;
      margin-bottom: 30px;
    }
    .sec05 .box01 .subBox01{
      width: 100%;
      padding: 50px 10px;
    }
    .sec05 .box01 .subBox01 img{
      width: 100%;
      height: auto;
      left: 0;
    }
    .sec05 .box01 .subBox01 ul{
      width: auto;
      margin-left: 0;
    }
    .sec05 .box01 .underBar{
      text-decoration: underline;
      text-decoration-color: #B80050;
      border: none;
    }
    .sec05 .box02{
      padding: 50px 10px;
    }
    .sec05 .box02 h3{
      font-size: 16px;
    }
    .sec06{
      padding: 50px 10px;
    }
    .sec06 h3{
      font-size: 24px;
      margin-bottom: 30px;
    }
    .sec06 p{
      font-size: 16px;
      margin-bottom: 30px;
    }
    .sec06 .box01{
      width: 100%;
    }
    .sec06 .box01 h4{
      font-size: 16px;
      position: relative;
      padding-left: 1rem;
      margin-bottom: 15px;
    }
    .sec06 .box01 h4:before{
      position: absolute;
      top: 3px;
      left: 0;
    }
    .sec06 .box01 .left,.sec06 .box01 .right{
      width: 100%;
      float: none;
    }
    .sec06 .box01 .subBox01 .first{
      margin-right: 50px;
    }
    .sec06 .box01 .subBox02{
      height: auto;
    }
    .sec06 .box01 .subBox02 ul{
      display: flex;
    flex-direction: column;
    align-items: center;
    }
    .sec06 .box01 .subBox02 ul li{
      margin-left: 0;
      height: 500px;
    }
    .sec06 .box01 .subBox02 ul li h5{
      margin-left: 20px;
      font-size: 22px;
    }
    .sec06 .box01 .subBox02 ul li p{
      font-size: 16px;
    }
    .sec07 .box01{
      padding: 50px 10px;
    }
    .sec07 .box01 h3{
      font-size: 24px;
    }
    .sec07 .box01 p{
      font-size: 16px;
      line-height: 1.5;
    }
    .sec07 .box02{
      margin: 60px 0;
    }
    .sec07 .box02 ul{
      padding: 0 10px;
    }
    .sec07 .box02 ul li{
      width: 100%;
      height: 350px;
      padding: 55px 10px 0;
      position: relative;
      margin-bottom: 30px;
    }
    .sec07 .box02 ul li h4{
      position: unset!important;
      font-size: 18px;
      margin-bottom: 15px;
      position: relative;
      z-index: 1;
    }
    .sec07 .box02 ul li p{
      position: unset!important;
      font-size: 12px;
      position: relative;
      z-index: 1;
      margin-bottom: 0;
    }
    .sec07 .box02 ul li.o6 p,.sec07 .box02 ul li.o6 .remark{
      font-size: 12px;
    }
    .sec07 .box02 ul li.o1::before,
    .sec07 .box02 ul li.o2::before,
    .sec07 .box02 ul li.o3::before,
    .sec07 .box02 ul li.o4::before,
    .sec07 .box02 ul li.o5::before,
    .sec07 .box02 ul li.o6::before{
      background-size: cover;
    top: 15px;
    right: 15px;
    width: 35px;
    height: 35px;
    }
    .sec07 .box02 ul li.o1{
      background-image: url(../img/top/sp_sec7_1.jpg);
      order: 1;
    }
    .sec07 .box02 ul li.o2{
      background-image: url(../img/top/sp_sec7_2.jpg);
      order: 4;
    }
    .sec07 .box02 ul li.o3{
      background-image: url(../img/top/sp_sec7_3.jpg);
      order: 2;
    }
    .sec07 .box02 ul li.o4{
      background-image: url(../img/top/sp_sec7_4.jpg);
      order: 5;
    }
    .sec07 .box02 ul li.o5{
      background-image: url(../img/top/sp_sec7_5.jpg);
      order: 3;
    }
    .sec07 .box02 ul li.o6{
      background-image: url(../img/top/sp_sec7_6.jpg);
      order: 6;
    }
  }
  /*
  記憶葬の構成
  -------------------------------------*/
  #Kousei{
    background-color: rgba(174,197,218,0.3);
  }
  #Kousei #Main{
    background-color: rgba(146,207,211,0.6);
    position: relative;
  }
  #Kousei #Main .inner{
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
  }
  #Kousei #Main h2{
    font-size: 36px;
    letter-spacing: 5px;
    text-align: center;
    margin-bottom: 45px;
  }
  #Kousei #Main p{
    font-size: 21px;
    text-align: center;
  }
  #Kousei .sec{
    max-width: 1400px;
    margin: auto;
    margin-top: 80px;
  }
  #Kousei .sec h3{
    font-size: 48px;
    letter-spacing: 5px;
    border-bottom: 10px solid #9E9E9F;
    width: fit-content;
    margin: auto;
    line-height: 1;
    padding-left: 5px;
    margin-bottom: 70px;
  }
  #Kousei .sec .flexBox{
    display: flex;
  }
  #Kousei .sec .o1{
    width: 700px;
  }
  #Kousei .sec .o1 img{
    display: block;
    width: 700px;
  }
  #Kousei .sec .o2{
    width: 700px;
    text-align: left;
  }
  #Kousei .sec .o2 h4{
    font-size: 42px;
    margin-bottom: 10px;
  }
  #Kousei .sec .o2 .req{
    font-size: 12px;
    display: inline-block;
    text-align: center;
    color: #fff;
    background-color: #2CA6E0;
    border-radius: 5px;
    width: 60px;
    height: 25px;
    padding: 4px 0;
  }
  #Kousei .sec .o2 .any{
    font-size: 12px;
    display: inline-block;
    text-align: center;
    color: #fff;
    background-color: #F7B52C;
    border-radius: 5px;
    width: 60px;
    height: 25px;
    padding: 4px 0;
  }
  #Kousei .sec .o2 .remark{
    font-size: 12px;
    position: relative;
    top: -11px;
    margin-left: 6px;
  }
  #Kousei .sec .o2 ul{
    margin-top: 50px;
  }
  #Kousei .sec .o2 ul li{
    font-size: 18px;
    padding-left: 1rem;
    position: relative;
    margin-bottom: 25px;
    line-height: 2;
    width: 528px;
  }
  #Kousei .sec .o2 ul li::before{
    content: "●";
    font-size: 9px;
    color: #036EB7;
    position: absolute;
    top: 8px;
    left: 0;
  }
  #Kousei .imgLeft .o2 ul li{
    width: unset;
  }
  #Kousei .kouseiSec02 .o2 ul li{
    width: 435px;
  }
  #Kousei .kouseiSec03 .o2 ul li{
    width: 500px;
  }
  #Kousei .kouseiSec06 .o2 ul li{
    width: 505px;
  }
  #Kousei .kouseiSec07 .o2 ul li{
    width: 510px;
  }
  #Kousei .kouseiSec08 .o2 ul li{
    width: 645px;
  }
  #Kousei .sec .o2 p{
    font-size: 12px;
  }
  #Kousei .kouseiSec06 .o2 p{
    margin-left: 125px;
  }
  #Kousei .sec .o2 p .req,
  #Kousei .sec .o2 p .any{
    font-size: 8px;
    padding: 3px 0;
    width: 50px;
    height: 20px;
    display: inline-block;
  }
  #Kousei .imgLeft .o2{
    padding-left: 70px;
  }
  #Kousei .imgRight h4{
    text-align: right;
  }
  #Kousei .imgRight .o1{
    order: 2;
  }
  #Kousei .imgRight .o2{
    order: 1;
    padding-right: 70px;
  }
  #Kousei .imgRight .o2 .req,
  #Kousei .imgRight .o2 .any{
    display: block;
    margin-left: auto;
  }
  #Kousei .imgRight .o2 .remark{
    text-align: right;
    display: block;
    position: relative;
    top: -40px;
    right: -33px;
  }
  #Kousei .imgRight .o2 ul{
    display: flex;
    flex-direction: column;
    align-items: flex-end;
  }
  #Kousei .kouseiSec05 .o1{
    position: relative;
  }
  #Kousei .kouseiSec05 .o1 .flow01{
    position: absolute;
    top: 0;
    bottom: 425px;
    right: 0;
    left: 530px;
    margin: auto;
    width: fit-content;
  }
  #Kousei .kouseiSec05 .o1 .flow02{
    position: absolute;
    top: 780px;
    bottom: 0;
    right: 0;
    left: 495px;
    margin: auto;
    width: fit-content;
  }
  #Kousei .kouseiSec05 .o2 .sup{
    position: relative;
  }
  #Kousei .kouseiSec05 .o2 .sup p{
    position: absolute;
    font-size: 18px;
    line-height: 2;
  }
  #Kousei .kouseiSec05 .o2 .sup p:first-of-type{
    top: 201px;
    left: 0;
  }
  #Kousei .kouseiSec05 .o2 .sup p:last-of-type{
    top: 558px;
    left: 0;
  }
  #Kousei .kouseiSec11{
    margin-bottom: 180px;
  }
  #Kousei .kouseiSec11 .o2 dl{
    padding-left: 20px;
  }
  #Kousei .kouseiSec11 .o2 dt{
    line-height: 2;
    font-size: 12px;
  }
  #Kousei .kouseiSec11 .o2 dd ol{
    list-style-type: none;
    padding-left: 1rem;
  }
  #Kousei .kouseiSec11 .o2 dd ol li{
    font-size: 12px;
    line-height: 2;
  }
  #Kousei .kouseiSec11 .o2 dd ol li a{
    color: #2CA6E0;
    text-decoration:underline;
  }

  @media print, screen and (min-width: 768px) {
  }
  @media print, screen and (max-width: 767px) {
    #Kousei #Main{
      min-height: 250px;
    }
    #Kousei #Main .inner{
      width: 100%;
      padding: 20px 10px 0!important;
    }
    #Kousei #Main h2{
      font-size: 24px;
      margin-bottom: 20px;
    }
    #Kousei #Main p{
      font-size: 16px;
      line-height: 2;
    }
    #Kousei .sec{
      width: 100%;
      padding: 0 10px;
      margin-top: 60px;
    }
    #Kousei .sec h3{
      font-size: 30px;
      border-bottom: 8px solid #9E9E9F;
      margin-bottom: 35px;
    }
    #Kousei .sec .flexBox{
      display: block;
    }
    #Kousei .sec .o1{
      width: 100%;
    }
    #Kousei .sec .o1 img{
      width: 100%;
    }
    #Kousei .sec .o2{
      width: 100%;
      padding: 20px 0 0!important;
    }
    #Kousei .sec .o2 h4{
      font-size: 30px;
      text-align: left!important;
    }
    #Kousei .sec .o2 p{
      margin-top: 30px;
      line-height: 2;
    }
    #Kousei .sec .o2 .req,#Kousei .sec .o2 .any{
      font-size: 10px;
      width: 40px;
      height: 20px;
      padding: 2px 0;
      margin: 0;
    }
    #Kousei .sec .o2 .remark{
      font-size: 10px;
      margin-left: 2px;
    }
    #Kousei .sec .o2 ul{
      margin-top: 25px;
      display: block;
    }
    #Kousei .sec .o2 ul li{
      width: unset!important;
      font-size: 16px;
      margin-bottom: 15px;
    }
    #Kousei .sec .o2 ul li::before{
      top: 6px;
    }
    #Kousei .sec .o2 p .req, #Kousei .sec .o2 p .any{
      width: 40px;
      margin: 0;
      padding: 1px 0;
    }
    #Kousei .kouseiSec05 .o2 .sup{
      display: none;
    }
    #Kousei .kouseiSec06 .o2 p{
      margin-left: 0;
    }
    #Kousei .kouseiSec11{
      margin-bottom: 80px;
    }
  }