@charset "utf-8";

/* -------------------------------------------------------------------------------- */
/*	0. CSS Reset
/* -------------------------------------------------------------------------------- */

html, body { margin:0; padding:0;}

h1, h2, h3, h4, h5, h6, p, blockquote, address, big, cite, code, em, font, img, small, strike, sub, sup, li, ol, ul, fieldset, form, label, legend, button, table, caption, tr, th, td {
margin:0;
padding:0;
border:0;
font-weight:normal;
font-style:normal;
font-size:100%;
line-height: 1.7;
font-family:inherit;
text-align:left;
}

table {
border-collapse:collapse;
border-spacing:0;
}

ol, ul { list-style:none;}

blockquote:before, 
blockquote:after { content:""; }

a { outline:none; text-decoration: none;}

input[type=search] {
-moz-appearance:none;
-webkit-appearance:none;
}

input[type="search"]::-webkit-search-decoration,
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-results-button,
input[type="search"]::-webkit-search-results-decoration {
display: none;
}
#pagetop{ position: fixed; bottom: 40px; right: 2%; z-index: 101; display: none;}
#pagetop img{ width: 90%;}

/* -------------------------------------------------------------------------------- */
/*	1. Document setup
/* -------------------------------------------------------------------------------- */
.block-pc{
    display: block; 
    }  


.hide-pc {
    display: none;
  }

#wrapper{
text-align:left;
font-weight: bold;
/* font-family: 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', Meiryo, メイリオ, Osaka, 'MS PGothic', arial, helvetica, sans-serif; */
font-family: -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans",sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";
position: relative;
font-size: 18px;
max-width: 1000px;
width: 100%;
margin: 0 auto;
}

#container{
max-width: 1000px;
width: 100%;
margin: 0 auto;
text-align: center;
}

h1{
display: none;
}

li{list-style-type: none;}
a { outline:none; color: #333;}

/* pageBtn */
#pageBtn{
border: 1px solid #000;
border-radius: 10px;
clear: both;
width: 50px;
height: 50px;
z-index: 3;
position: fixed;
bottom: 20px;
right: 20px;
text-align: center;
}

.fa{
display: block !important;
text-indent: 0;
margin: 12px 0 0 0;
}

.fa-2 {
font-size: 1.5em !important;
}

/* -------------------------------------------------------------------------------- */
/*	2. Custom code
/* -------------------------------------------------------------------------------- */
body {
    font-family: -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans",sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";
    /*background-color: #e9e9e9;*/
}

img { 
    image-rendering: auto;
    image-rendering: -webkit-crisp-edges;
    image-rendering: -moz-crisp-edges;
    -ms-interpolation-mode: nearest-neighbor; 

}


/*#container img{
    width: 100%;
}*/

img.top-img{
width: 100%;  
}
.top-banner {
    margin: 20px auto;
}

.info{
    margin:20px 5px 20px 5px; 
    padding:15px;
    border:1px solid #605C5C; 
    line-height:1.5em; 
    text-align:center; 
    background-color:#FFF;
}

.info p{
    padding: 0 0 0 10px;
    font-size:14px;
    color: #605C5C; 
    text-align:left;
}

.btitle{
    background-color: #F3F0F0;
    text-align: left;
    border-left: #009261 5px solid;
    border-bottom: #009261 1px solid;
    border: 1px solid #ccc;
  background: #f1e767;
  background: -webkit-gradient(linear, left top, left bottom, from(#fdfbfb), to(#ebedee));
  background: -webkit-linear-gradient(top, #fdfbfb 0%, #ebedee 100%);
  background: linear-gradient(to bottom, #fdfbfb 0%, #ebedee 100%);
  -webkit-box-shadow: inset 1px 1px 1px #fff;
  box-shadow: inset 1px 1px 1px #fff;
    font-size: 14px;
    font-weight: bold;
    color: #131313;
    font-family: -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans",sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";
}

.btitle2{
    background-color: #F3F0F0;
    text-align: left;
    border-left: #009261 5px solid;
    border-bottom: #009261 1px solid;
    border: 1px solid #ccc;
  background: #f1e767;
  background: -webkit-gradient(linear, left top, left bottom, from(#fdfbfb), to(#ebedee));
  background: -webkit-linear-gradient(top, #fdfbfb 0%, #ebedee 100%);
  background: linear-gradient(to bottom, #fdfbfb 0%, #ebedee 100%);
  -webkit-box-shadow: inset 1px 1px 1px #fff;
  box-shadow: inset 1px 1px 1px #fff;
    font-size: 14px;
    font-weight: bold;
    color: #3E3D3D;
}

.btitle2:hover{
    background-color: #3E3D3D;
}

.btn-secondary:hover {
    color: #605C5C;
    background-color: #fff;
    border-color: #D8D8D8;
}


.read{
    padding: 0 20px;
    font-size: 14px;
}

.orange{
    background-color: #FB7743;
    border: 1px #FB7743 solid;
    text-align: center;
    color: #605C5C;
    font-weight: bold;
}

.orange2{
    background-color: #fff2df;
    border: 1px #FB7743 solid;
    text-align: center;
    height: 60px;
    color: #605C5C;
    font-weight: bold;
}

.orange3{
    color: #605C5C;
    font-weight: bold;
}

.orange4{
    color: #FB7743;
}

.d-orange{
    background-color:#ff8900;
    border: 1px #FB7743 solid;
    text-align: center;
    
}

.d-orange2{
    background-color:#FFB141;
    border: 1px #FFB141 solid;
    text-align: center;
    height: 100px;
}

.green{
    background-color: #E8FCE8;
    border: 1px #28a745 solid;
    text-align: center;
    height: 60px;
    color: #605C5C;
    font-weight: bold;
}

.green2{
    background-color: #28a745;
    border: 1px #28a745 solid;
}

.green3{
   color: #28a745; 
}

.d-green{
    background-color:#92d050;
    border: 1px #92d050 solid;
    text-align: center;
    height: 100px;
}


.demo {
    margin: 20px;
}
.demo__title{
    margin: 20px;
    font-size: 18px;
    background: linear-gradient(transparent 70%, #fbd1d2 30%);
}
.demo__sub-text{
    margin: 20px 20px 40px;
    font-size: 13px;
}
.tab__area{
    color: #333;
    margin: 30px 0px;
    /*width: 985px;*/
    font-size: 14px;
    line-height: 1.6;
    box-shadow: 0 -2px 3px -2px rgb(0 0 0 / 5%), 0 2px 2px rgb(0 0 0 / 5%);
    padding: 0 5px;
}
.tab__list{
    display: table;
    margin: 0 auto;
    width: 100%;
    zoom: 1;
    table-layout: fixed;
    border-spacing: 0;
}
.tab__item{
    display: table-cell;
    text-align: center;
    font-size: 12px;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.tab__item2{
    display: table-cell;
    text-align: center;
    font-size: 12px;
    font-weight: bold;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.tab__item a{
    display: block;
    padding: 15px;
    /*margin: 0 2px;*/
    overflow: hidden;
    position: relative;
    color: #28a745;
    background-color: #E8FCE8;
    border-top: 1px solid #28a745;
    border-left: 1px solid #28a745;
    border-right: 1px solid #28a745;
    border-radius: 10px 10px 0 0;
    font-size: 16px;
    text-decoration: none;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.tab__item2 a{
    display: block;
    padding: 15px;
    /*margin: 0 2px;*/
    overflow: hidden;
    position: relative;
    color: #D34801;
    background-color: #fff2df;
    border-top: 1px solid #FB7743;
    border-left: 1px solid #FB7743;
    border-right: 1px solid #FB7743;
    border-radius: 10px 10px 0 0;
    font-size: 16px;
    text-decoration: none;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* hover時の背景色（グレー）の指定 */
.tab__item a:hover{
    /*background-color: #eee;*/
    border-top:5px #28a745 solid;
    border-right: #28a745 1px solid;
    border-left: #28a745 1px solid;
}

.tab__item2 a:hover{
    /*background-color: #eee;*/
    border-top:5px #FB7743 solid;
    border-right: #FB7743 1px solid;
    border-left: #FB7743 1px solid; 
    
}
/* タブ選択時の文字色の指定 */
.tab__item a.selected{
  color: #28a745;
  padding-top: 15px;
  border-top:5px #28a745 solid;
  border-right: #28a745 1px solid;
  border-left: #28a745 1px solid; 
     
}

.tab__item2 a.selected{
  color: #D34801;
  padding-top: 15px;
  border-top:5px #FB7743 solid;
  border-right: #FB7743 1px solid;
  border-left: #FB7743 1px solid;    
}
/* タブ01（ピンク）の背景色と文字色の指定 */
.tab__item:first-child a.selected{
    background-color: #E8FCE8;
}
/* タブ02（オレンジ）の背景色と文字色の指定 */
.tab__item2:nth-child(2) a.selected{
    background-color: #fff2df;
}
/* タブ03（グリーン）の背景色と文字色の指定 */
.tab__item:nth-child(3) a.selected{
    background-color: #afe9d7;
}
.tab__inner{
    /*border-left: 1px solid #ccc;
    border-right: 1px solid #ccc;
    border-bottom: 1px solid #ccc;*/
    margin-top: -1px;
}
/* タブ01（ピンク）選択時のコンテンツ内の背景色の指定 */
.tab__inner .pink{
    padding: 20px;
    background-color: #E8FCE8;
    border: #28a745 1px solid;
}
/* タブ02（オレンジ）選択時のコンテンツ内の背景色の指定 */
.tab__inner .orange{
    padding: 20px;
    background-color: #fff2df;
    border: #FB7743 1px solid;
}
/* タブ03（グリーン）選択時のコンテンツ内の背景色の指定 */
.tab__inner .green{
    padding: 20px;
    background-color: #e9f4f0;
}


.box{
    display: flex;
    flex-wrap: wrap;
}

.inner-box{
    flex-shrink: 0;
    flex-basis: 33%;
    border: 1px solid #ccc;
    background-color: #fff;
    padding: 8px;
    margin: 3px 2px 0 1px;
    max-width: 33%;
}

button.inner-box:hover {
    background-color: #D8D8D8;
}

 
.title{
    background-color: #28a745;
    padding: 3px 3px 3px 8px;
    color: #fff;
    display: flex;
    justify-content: space-between;
    align-items: center;
    text-align: left;
    
}

.title2{
    background-color: #FB7743;
    padding: 3px 3px 3px 8px;
    color: #fff;
    display: flex;
    justify-content: space-between;
    align-items: center;
    text-align: left;
}

.item{
   display: flex; 
}

.icon img{
    width: 60px;
    height: 60px;
    padding: 15px 10px 10px 10px;
}

.txt{
    padding: 10px 3px 3px 3px;
    font-size: 12px;
}

button a{
    text-decoration: none;
    color: #00015F;
    
}

.bg-orange{
    background-color:#fff2df;
    /*margin: 10px 5px;*/
    padding: 30px;
    text-align: left;
    border-top: 1px #FB7743 solid;
    border-right: 1px #FB7743 solid;
    border-bottom: 1px #FB7743 solid;
    border-left: 1px #FB7743 solid;
    border-radius: 10px 10px 0 0;
    margin-bottom: 30px;
}

.bg-white{
    background-image: url("../images/orange.png");
    background-repeat: repeat-x;
    margin: 0 0 10px 2px;
    padding: 20px 30px 30px 30px;
    text-align: left;
    border-top: 7px #FB7743 solid;
    border-right: 1px #FB7743 solid;
    border-bottom: 1px #FB7743 solid;
    border-left: 1px #FB7743 solid;
    border-radius: 10px 10px 0 0;
}

.bg-orange button{
    margin-bottom: 5px;
    text-align: left; 
}


.bg-green{
    background-image: url("../images/green.png");
    background-repeat: repeat-x;
    margin: 0 2px 10px 0;
    padding: 20px 30px 30px 30px;
    text-align: left;
    border-top: 7px #28a745 solid;
    border-right: 1px #28a745 solid;
    border-bottom: 1px #28a745 solid;
    border-left: 1px #28a745 solid;
    border-radius: 10px 10px 0 0;
}

.bg-green button{
    margin-bottom: 5px;
    text-align: left; 
}



.btn-outline-success{
   width: 100%;
   background-color: #fff;  
}
.btn-outline-onange{
   color: #D34801;
   border-color: #FB7743;
   width: 100%; 
   background-color: #fff;
   text-align: left;
   margin-bottom: 5px;
    
}
.btn-outline-onange:hover{
    color: #fff;
   background-color:#FB7743;  
}

.btn-outline-gray{
   color: #2D2D2D;
   border: 2px #FB7743 solid;
   width: 100%; 
   background-color: #fff;
   text-align: left;
   margin-bottom: 5px;
   font-size: 18px;    
}
.btn-outline-gray:hover{
    color: #2D2D2D;
   background-color:#FB7743;  
}
.btn-outline-gray2{
   color: #2D2D2D;
   border: 2px #28a745 solid;
   width: 100%; 
   background-color: #fff;
   text-align: left;
   margin-bottom: 5px;
   font-size: 18px;    
}
.btn-outline-gray2:hover{
    color: #2D2D2D;
   background-color:#28a745;  
}



.co{
  font-size:20px;
  color: #D34801; 
  font-weight: bold;
  text-align: center;    
}

.coi{
  font-size:12px;
  color: #D34801; 
  font-weight: bold;
  text-align: center;     
  padding-right: 2px;  
}

.cg{
  font-size:20px;
  color: #28a745; 
  font-weight: bold;
  text-align: center;
}

.cgi{
  font-size:12px;
  color: #28a745; 
  font-weight: bold;
  text-align: center;
  padding-right: 2px;
}

.cw{
  font-size:22px;
  color: #FFF; 
  font-weight: bold;
  text-align: center;
}

.round{
    border-radius: 50px;
    padding: 20px;
    background-color: #D34801;
    color: #fff;
    border-color: #D34801;
}

.round:hover{
    background-color: #FBDDC3;
    border-color: #D34801;
    color: #D34801;
}


.slideshow{
    width: 300px;
    text-align: center;
}

.bar{
    border-left: 4px #28a745 solid;
    padding-left: 10px;
}

.banner img{
    max-width: 100%;
}

/*追記*/
.waku{
    background-color: #FFF8CA;
    color: #3B3B3B;
    font-size: 12px;
    padding: 2px 5px;
    text-align: right;
    margin-right: 5px;
}

.waku2{
    background-color:#C5DAFF;
    color: #3B3B3B;
    font-size: 12px;
    padding: 2px 5px;
    text-align: right;
    margin-right: 5px;
}

.waku3{
    background-color:#FFF0F5;
    color: #3B3B3B;
    font-size: 12px;
    padding: 2px 5px;
    text-align: right;
    margin-right: 5px;
}

.icon-img{
    width: 35px;
    background-color: #fff;
    margin-right:10px;
    padding: 2px;
}

.txt a{
    text-decoration: underline;
    color: #0200FF;
    font-weight: bold;
}

.smal{
    font-size: 7px;
}

.munu{
    height: 45px;
    padding-top: 5px;
}

.inner-munu{
    line-height: 1.2em;
    padding-top: 3px;
    padding-left:1px;
    width: 150px;
}

.mitsumori{
    color: #FF0000;
}

.mitsumori a{
    color: #FF0000;
}

.box2{
    display: flex;
    flex-wrap: wrap;
}

.inner-box2{
    flex-shrink: 0;
    flex-basis: 33%;
    border: 1px solid #ccc;
    background-color: #fff;
    padding: 8px;
    margin: 20px 2px 0 1px;
}

.inner-box2 a{
    color: #0200FF;
    font-weight: bold;
}

.title3{
    background-color: #127BE9;
    padding: 3px 3px 3px 8px;
    color: #fff;
    display: flex;
    justify-content: space-between;
    align-items: center;
    text-align: left;   
}

.fc{
    color: #2ba24b;
    margin-right: 8px;
}

.visibility{
    visibility: hidden;
}

.mat{
    margin-top: -13px;
    margin-bottom: 10px;
}

@font-face {
    font-family: hiraginoSans;
    src: url(../font/HiraginoSansW7.otf);
}
#qa h2{
    background-color: #F3F0F0;
    text-align: left;
    border-left: #009261 5px solid;
    border-bottom: #009261 1px solid;
    border: 1px solid #ccc;
  background: #f1e767;
  background: -webkit-gradient(linear, left top, left bottom, from(#fdfbfb), to(#ebedee));
  background: -webkit-linear-gradient(top, #fdfbfb 0%, #ebedee 100%);
  background: linear-gradient(to bottom, #fdfbfb 0%, #ebedee 100%);
  -webkit-box-shadow: inset 1px 1px 1px #fff;
  box-shadow: inset 1px 1px 1px #fff;
    font-size: 14px;
    font-weight: bold;
    color: #131313;
    position: relative;
    padding: 0.75rem 1.25rem;
    margin-bottom: 1rem;
    border-radius: 0.25rem;
}

#qa h2 span {
    border-left: 4px #28a745 solid;
    padding-left: 10px;
}
#qa .row{
    margin: 0;
    padding: 0 0 27px;
    text-align: left;
    border-top: 7px #32A04B solid;
    border-right: 1px #32A04B solid;
    border-bottom: 1px #32A04B solid;
    border-left: 1px #32A04B solid;
    border-radius: 10px 10px 0 0;
    position: relative;
}
#qa .row-2{
    border-color: #FA7741;
}
#qa .row-1{
    margin-bottom: 30px;
}

#qa h4{
    color: #2AA744;
    text-align: center;
    font-size: 20px;
    letter-spacing: 0;
    font-weight: bold;
    display: block;
    width: 100%;
    padding: 25px 0 25px;
    margin-bottom: 24px;
    background: #E9FCE8;
    border-radius: 6px 6px 0 0;
    font-family: hiraginoSans;
    border: none;
}
#qa .row-2 h4{
    color: #D14604;
    background: #FFF2DF;
}
#qa .row.row-2 .box .flbox{
    background: #FB7643;
}
#qa .row .col{
    padding: 0 27px;
    display: flex;
    flex-wrap: wrap;
}
#qa .row .box{
    width: 312px;
    box-sizing: border-box;
    margin: 0 4px 5px 0;
    border: 1px solid #CBCEC8;
    letter-spacing: 0.05em;
    font-family: hiraginoSans;
    display: block;
}
#qa .row .box a{
    display: block;
    width: 100%;
    height: 100%;
    box-sizing: border-box;
    padding: 9px 9px 16px;
}
#qa .row .box a:hover{
    color: inherit;
    text-decoration: none;
}
#qa .row .box a *{
    transition: all .3s ease;
}
#qa .row .box a:hover > *{
    opacity: .9;
} 
#qa .row .box:nth-child(3n){
    margin-right: 0;
}
#qa .row .box .flbox{
    display: flex;
    align-items: center;
    background: #29A744;
    color: #fff;
    width: 100%;
    padding: 8px;
    box-sizing: border-box;
    height: 51px;
}
#qa .row .box .flbox-1{
    display: flex;
}
#qa .row .box .flbox-1 ul{
    width: 50%;
}

#qa .row .box p.ic{
    margin-right: 24px;
}
#qa .row .box .flbox p.txt{
    padding: 0;
    font-size: 14px;
    line-height: 21px;
}
#qa .row .box .menu-ul{
    margin-top: 11px;
    width: 100%;
}
#qa .row .box ul li{
    font-size: 12px;
}



/*@media screen and (max-width: 1024px) and (orientation: portrait){
  #wrapper,#container{
     width:100%;   
    }
    
    .info{
     margin: 5% 2%;   
    }
    
    .tab__area{
        margin: 5% 2%;
    }
    
    .inner-box{
      margin: 3px 1px 0 1px ;  
    }
}*/

/*@media only screen and (min-width: 767px) {

    .container{
     max-width: 950px; 
    }
    
    .tab__area{
        margin: 5% 2%;
    }
    
    .inner-box{
      margin: 3px 1px 0 1px ;  
    }
    
.orange-inner{
    width: 100%;
    margin-right: 0px;
    margin-left: 0px;
}
    
}*/
@media only screen and (max-width: 767px) {
    .block-sp{
        display: block; 
        }
        
        .hide-sp{
        display: none;
      } 
        .hide-pc{
        display: block; 
      }     
        
    #wrapper{
    text-align:left;
    font-weight: bold;
    
    position: relative;
    font-size: 18px;
    width: 100%;
    }
    
    .inner-box{
    flex-shrink: 0;
    flex-basis: 100%;
    padding: 2%;
    margin-bottom: 2%;    
    } 
    
    
    
    #container{
    width: 100%;
    }   
        
    img.top-img{
    width: 100%;
    margin-bottom: 0;    
    }
    .top-banner {
        margin: 6% auto;
    }
        
    .tab__area {
    margin: 30px 0;
    padding: 0 2%;
    width: 100%;    
    }  
        
    .tab__inner .pink,
    .tab__inner .orange    {
     padding: 2%;
    }    
        
    summary {
      cursor: pointer;
      font-size: 14px;    
    }
    details {
      margin: 3%;
      padding: 10px;
      border: 1px #000 solid;
    }
    
    details p{
      border-top:1px #000 dotted;
      text-align: left;
      padding: 3%;
      font-size: 14px;    
    }
        
    details[open] {
      background: #fff;
      
    }
        
        
    .bg-green,.bg-orange,.bg-white{
      margin: 0 2%;
      padding: 3%;
    }
    
    .orange-inner img{
        width: 100%;        
    }
    
    /* TOP - おすすめキャンペーン */
    .wrap .row {
        flex-wrap: wrap;
        margin: 0;
        justify-content: center;
    }
    .wrap .row .banner {
        width: 48%;
        max-width: 48%;
        -ms-flex: inherit;
        flex: inherit;
        padding: 0;
        margin: 0 1% 27px;
        border-radius: 10px;
        overflow: hidden;
    }    
}