@import url(http://fonts.googleapis.com/earlyaccess/notosansjapanese.css);

html[lang="ja"] {
    font-family: "Noto Sans Japanese", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}

html {
    /* ベースのフォントサイズを10pxとする */
    font-size: 75%;
}

body{
    margin: 0;
}

a {
    text-decoration: none;
    color:inherit;
    text-decoration: none;
}

video {
    filter: drop-shadow(0px 0px rgba(0,0,0,0));
    outline: none;
    border: none;
}

.header-icon {
    padding-left: 30%;
}

.header-sp-icon {
    display: none;
}

.BtoB_oshibana {
    text-align: center;
    padding-right: 2%;
    margin-left: auto;
    margin-top: auto;
    margin-bottom: auto;
    font-size: clamp(0.5rem, 2vw + 1rem,1.5rem);
    color: #F7931E;
}

.BtoB_oshibana:hover {
    color: #37BBD0;
}

.info-box {
    text-align: center;
    padding-right: 30%;
    margin-top: auto;
    margin-bottom: auto;
    display: flex;
}

.mail-icon{
    margin: 0 auto;
    padding-top: 16%;
    width: 125%;
}

.form-text {
    font-size: clamp(0.5rem, 2vw + 1rem,1.5rem);
    color: #F7931E;
    text-align: center;

}

.ohibana_MV {
    width: 100%;
    max-width: 1300px;
    display: block;
    margin: auto;
}

.main-explanation{
    width: 100%;
    padding-top: 2%;
    text-align: center;
}

.main-background{
    text-align: center;
    background-image:url(../img/background_image.png);
    background-size:75%;
    background-repeat: no-repeat;
    background-position: 50% 0%;
    padding-top: 5%;
    padding-bottom: 5%;
}

.link-btn {
    padding-top: 2%;
    padding-bottom: 5%;
}

.sp-link-btn {
    display: none;
}

.sub-caption {
    padding-bottom: 5%;
    font-size: clamp(2rem, 2vw + 1rem, 4.5rem);
}

.orange {
    color: #F7931E;
}

.pink {
    color: #FB7A8D;
}

.third-caption {
    padding-bottom: 5%;
    font-size: clamp(1.75rem, 2vw + 1rem, 4rem);
}

.main-text {
    font-size: clamp(0.75rem, 2vw + 1rem, 2rem);
}

.sub-explanation {
    background-color: #F6F5EF;
    width: 100%;
    padding-top: 3%;
    padding-bottom: 3%;
    text-align: center;
}

.sub-title {
    font-size: clamp(1.5rem, 2vw + 1rem, 3.5rem);
    padding-top: 3%;
    padding-bottom: 3%;
}

.worrie-img {
    width: 35%;
}

.yellow-line {
    background: linear-gradient(transparent 50%, #f1f79f 50%);
}

.sub-text {
    font-size: clamp(0.8rem, 2vw + 1rem, 1.25rem);
}

.sub-end-text p{
    padding-top: 3%;
    padding-bottom: 3%;
    text-align: center;
    font-size: clamp(0.8rem, 2vw + 1rem, 2.5rem);
    margin-bottom: 0%;
}

.main-contents {
    padding-top: 3%;
    width: 100%;
    text-align: center;
    background-image:url(../img/signage.png);
    background-size:100%;
    background-repeat: no-repeat;
    font-size: clamp(0.8rem, 2vw + 1rem, 3rem);
    color: #FFFFFF;
}

.main-contents-text {
    padding-top: 25%;
    padding-bottom: 3%;
    width: 100%;
    text-align: center;
    color: black;
    font-size: clamp(0.8rem, 2vw + 1rem, 1.5rem);
}

.sub-contents {
    width: 100%;
}

.sub-contents-title {
    padding-top: 0.5%;
    padding-bottom: 0.5%;
    width: 100%;
    text-align: center;
    background-color: #FBB03B;
    margin: 0 auto;
    font-size: clamp(0.8rem, 2vw + 1rem, 3rem);
    color:#FFFFFF;
}

.sub-contents-title p{
    margin: 0 auto;
}

.sub-contents-text {
    padding-top: 5%;
    padding-bottom: 1%;
    width: 100%;
    height: auto;
    text-align: center;
    background-image:url(../img/image_back.png);
    background-size:100%;
    background-repeat: no-repeat;
    font-size: clamp(0.8rem, 2vw + 1rem, 2rem);
}

.signage_imagewrap p {
    text-align: right;
}

.signage_image {
    padding-top: 1%;
    width: 45%;
    height: auto;
}

.an-image {
    padding-left: 30%;
    padding-bottom: 1%;
    margin: 0;
    color: #000000;
    font-size: clamp(0.5rem, 2vw + 1rem, 1rem);
}

.operation {
    padding-top: 3%;
    text-align: center;
}

.operation-index {
    font-size: clamp(0.5rem, 2vw + 1rem, 3.7rem);
    color: #F15A24;
}

.operation-table {
    padding-top: 2%;
    text-align: center;
    width: 55%;
    margin: 0 auto;
    box-shadow:rgba(0, 0, 0, 0.059) 4px 4px 4px 4px;
    -webkit-box-shadow:rgba(0, 0, 0, 0.059) 4px 4px 4px 4px;
    -moz-box-shadow:rgba(0, 0, 0, 0.059) 4px 4px 4px 4px;
}

.operation-title {
    background-color: #FBB03B;
    font-size: clamp(0.5rem, 2vw + 1rem, 4rem);
    color:#ffffff;
    padding-top: 1%;
    padding-bottom: 1%;
}
.operation-title p{
    margin: 0px;
}

.flexwarp {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    padding-left: 5%;
    padding-right: 5%;
}

.flexwarp div {
	width: 50%;
}

.flexwarp p {
    font-size: clamp(0.1rem, 2vw + 1rem, 1.6rem);
}

.step-img1,.step-img2,.step-img3,.step-img4 {
    width: 190%;
}

.operation-step1,.operation-step2,.operation-step3,.operation-step4 {
    text-align: left;
}

.operation-info {
    padding-top: 3%;
    padding-bottom: 3%;
    font-size: clamp(0.1rem, 2vw + 1rem, 1.5rem);
}

.qaList {
    padding-top: 3%;
    padding-bottom: 3%;
}

.qa-title {
    background-color: #FBB03B;
    padding-top: 1%;
    padding-bottom: 1%;
    color:#ffffff;
    font-size: clamp(1.5rem, 2vw + 1rem, 2.5rem);
    text-align: center;
    margin-bottom: 3%;
}

.qaWrap {
    width: 45%;
    margin: 15px auto;
    background-color: #F6F5EF;
    text-align: left;
    padding-left: 3%;
    font-size: clamp(1.5rem, 2vw + 1rem, 1.5rem);
}

.question {
    padding-top: 1%;
    margin: 0;
}

.answer {
    padding-bottom: 1%;
}

.answer p {
    margin-bottom: 0px;
}

.q-mark {
    color: white;
    background-color: #F4BE6D;
    display: inline-block;/* ←忘れない！ */
    width: 30px;
    height: 30px;
    border-radius: 50%;
    text-align: center;/* ←文字を左右に中央揃え */
    line-height: 30px;/* ←文字を上下に中央揃え */
    font-size: clamp(1.5rem, 2vw + 1rem, 2rem);
}

.a-mark {
    color: white;
    background-color: #F7931E;
    display: inline-block;/* ←忘れない！ */
    width: 30px;
    height: 30px;
    border-radius: 50%;
    text-align: center;/* ←文字を左右に中央揃え */
    line-height: 30px;/* ←文字を上下に中央揃え */
    font-size: clamp(1.5rem, 2vw + 1rem, 2rem);
}

.detail_info { 
    font-size: clamp(0.5rem, 2vw + 0.5rem, 1rem);
    display:block;
    line-height: 1.5;
}

.color-red {
    color: red;
}

.page-footer {
    background-color: #F6F5EF;
    padding-top: 3%;
    padding-bottom: 3%;
    text-align: center;
}

.sp-br {
    display: none;
}

.hidden-a-mark {
    visibility: hidden;
    display: inline-block;/* ←忘れない！ */
    width: 30px;
    height: 30px;
    border-radius: 50%;
    line-height: 30px;/* ←文字を上下に中央揃え */
    font-size: clamp(1.5rem, 2vw + 1rem, 2rem);
}

.hidden-a-mark-sp {
    display: none;
}

.hidden-q-mark {
    display: none;
}

.hidden-span {
    display: none;
}

.mail-form{
    display: flex;
}

#header{
  width: 100%;
  height: 75px;
  background-color: #F7F5E7;
  display: flex;
}

#header-flexd {
    z-index: 999;/*最前面へ*/
    width: 100%;
    height: 75px;
    background-color: #F7F5E7;
    display: none;
    position:fixed;
    top: 0px;
}

/*　上に上がる動き　*/

#header-flexd.UpMove{
    display: none;
}

@keyframes UpAnime{
  from {
    opacity: 1;
    transform: translateY(0);
  }
  to {
    opacity: 0;
    transform: translateY(-100px);
  }
}

/*　下に下がる動き　*/

#header-flexd.DownMove{
  display: flex;
}
@keyframes DownAnime{
  from {
    opacity: 0;
  transform: translateY(-100px);
  }
  to {
    opacity: 1;
  transform: translateY(0);
  }
}

@media screen and (max-width: 600px) {

    .header-icon {
        display: none;
    }
    
    .header-link {
        display: none;
    }

    #header {
        height: 50px;
    }
    
    .header-sp-icon {
        display: block;
        padding-top: 3px;
        padding-left: 5%;
    }
    
    .header-sp-link {
        text-align: left;
        display: block;
        padding-top: 6px;
        padding-right: 5%;
        margin :0 0 0 auto;
    }

    .BtoB_oshibana {
        text-align: center;
        padding-right: 2%;
        margin-left: auto;
        margin-top: auto;
        margin-bottom: auto;
        font-size: clamp(0.5rem, 2vw + 0.5rem,1.5rem);
        color: #F7931E;
    }

    .BtoB_oshibana p{
        margin: 0 auto;
    }

    .main-caption {
        font-size: clamp(1rem, 2vw + 0.5rem, 5rem);
    }
    
    .main-title {
        font-size: clamp(1rem, 2vw + 0.5rem, 2.5rem);
    }

    .main-caption:before {
        margin-right: 0.5em; /* 文字の右隣 */
    }
    .main-caption:after {
        margin-left: 0.5em; /* 文字の左隣 */
    }
    
    .sub-caption {
        padding-bottom: 5%;
        font-size: clamp(1rem, 2vw + 1rem, 3.5rem);
    }

    .main-text {
        font-size: clamp(0.8rem, 2vw + 0.5rem, 1.25rem);
    }

    .main-text p {
        margin: 0 auto;
    }

    .link-btn {
        display: none;
    }
    
    .sp-link-btn {
        display: block;
        padding-top: 2%;
        padding-bottom: 5%;
    }

    .sub-explanation {
        padding-top: 10%;
    }

    .sub-text {
        font-size: clamp(0.8rem, 2vw + 0.5rem, 1.25rem);
    }

    .sub-end-text p{
        font-size: clamp(0.8rem, 2vw + 0.5rem, 1.25rem);
        margin: 0 auto;
        padding-top: 2%;
        padding-bottom: 6%;
    }

    .main-contents {
        padding-top: 3%;
        width: 100%;
        text-align: center;
        background-image:url(../img/sp_signage.png);
        background-size:100%;
        background-repeat: no-repeat;
        font-size: clamp(0.8rem, 2vw + 1rem, 3rem);
    }

    .main-contents-text {
        padding-top: 55%;
        padding-bottom: 3%;
        width: 100%;
        text-align: center;
        color: black;
        font-size: clamp(0.8rem, 2vw + 0.5rem, 1.5rem);
    }

    .sub-contents-title {
        padding-top: 2%;
        padding-bottom: 2%;
    }
    
    .sub-contents-text {
        background-image:url(../img/sp_image.png);
        font-size: clamp(0.8rem, 2vw + 0.5rem, 2rem);
    }

    .sub-contents-text p {
        margin: 0 auto;
    }

    .signage_image {
        width: 95%;
        height: 100%;
    }

    .operation-table {
        text-align: center;
        width: 90%;
        margin: 0 auto;
        box-shadow: rgb(0 0 0 / 6%) 4px 4px 4px 4px;
        -webkit-box-shadow: rgb(0 0 0 / 6%) 4px 4px 20px 8px;
        -moz-box-shadow: rgba(0, 0, 0, 0.059) 4px 4px 4px 4px;
    }

    .flexwarp div {
        width: 100%;
    }

    .step-img1,.step-img2,.step-img3,.step-img4 {
        width: 100%;
    }

    .qaWrap {
        width: 90%;
        font-size: clamp(0.2rem, 2vw + 0.5rem, 1rem);
    }

    .sp-br {
        display: block;
    }    
    .main-background {
        background-image: none;
    }

    .flexwarp p {
        font-size: clamp(0.1rem, 2vw + 1rem, 1.5rem);
    }

    .sub-title {
        font-size: clamp(1.5rem, 2vw + 0.5rem, 2.5rem);
    }

    .operation-index {
        font-size: clamp(1rem, 2vw + 1.5rem, 2rem);
    }

    .detail_info {
        font-size: clamp(0.2rem, 2vw + 0.2rem, 1rem);
    }

    .form-text {
        display: none;
    }

    .info-box{
        padding-right: 10%;
    }
    
    .mail-icon{
        padding-top: 0%;
        padding-left: 50%;
    }

    .wrap {
        padding-bottom: 2%;
    }

    .Q-title{
        font-size: clamp(1.6rem, 2vw + 0.5rem, 4rem);
    }

    .hidden-span {
        display: inline;
    }

    .hidden-q-mark {
        visibility: hidden;
        display: inline-block;/* ←忘れない！ */
        width: 30px;
        height: 30px;
        border-radius: 50%;
        line-height: 30px;/* ←文字を上下に中央揃え */
        font-size: clamp(1.5rem, 2vw + 1rem, 2rem);
    }

    .credit-info {
        font-size: clamp(0.1rem, 2vw + 0.3rem, 1rem);
    }

    .QR-info {
        font-size: clamp(0.1rem, 2vw + 0.3rem, 1rem);
    }

    .operation-info {
        padding-bottom: 6%;
    }

    .worrie-img {
        padding-top: 5%;
        padding-bottom: 5%;
        width: 90%;
    }

    .pc-br {
        display: none;
    }

    #header {
        height: 45px;
    }

    #header-flexd {
        height: 45px;
    }

    .hidden-a-mark-sp {
        visibility: hidden;
        display: inline-block;/* ←忘れない！ */
        width: 30px;
        height: 30px;
        border-radius: 50%;
        line-height: 30px;/* ←文字を上下に中央揃え */
        font-size: clamp(1.5rem, 2vw + 1rem, 2rem);
    }
}

@media screen and (min-width:600px) and (max-width:1240px){

    .info-box {
        padding-right: 20%;
    }

    .main-contents {
        padding-top: 1%;
    }

    .sub-contents-text {
        padding-top: 1%;
        padding-bottom: 1%;
        font-size: clamp(0.3rem, 2vw + 0.3rem, 1.4rem);
    }

    .operation-table {
        width: 73%;
    }

    .main-background {
        background-position: 50% 50%;
    }

    .flexwarp p {
        font-size: 1rem;
    }

    .main-text {
        font-size: clamp(0.5rem, 2vw + 1rem, 1.4rem);
    }

    .sp-br {
        display: block;
    }   
    
}

@media screen and (min-width:600px) and (max-width:850px){
    .info-box {
        padding-right: 10%;
    }

    .header-icon {
        padding-left: 15%;
    }
}
