/* カスタマイズ用CSS */

/*********base
*******************************************/
html {
  font-family: "Noto Sans jp" , "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic Pro", "Osaka", sans-serif;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  font-size: 62.5%;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  box-sizing: border-box;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

*, *:before, *:after {
  -webkit-box-sizing: inherit;
  box-sizing: inherit;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  word-break: break-all;
}

body {
  margin: 0;
  font-family: "Noto Sans jp","メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic Pro", "Osaka", sans-serif;
  background-color: #fff;
  box-sizing: border-box;
}

article, aside, details, figcaption, figure, footer, header, main, menu, nav, section, summary {
  display: block;
}

h1,h2,h3,h4,h5,p,ul,ol,li,dl,dt,dd,table,tr,td,th,address,hr,input,select,textarea,button,form,label {
  padding: 0;
  margin: 0;
}

ul,li,ol {
  list-style: none;
}

img {
  height: auto;
  max-width: 100%;
}

a {
  color: #003c4e;
  background-color: transparent;
  text-decoration: none;
}

a,a img {
    transition:0.3s;
}

a:hover, a:hover img {
    opacity: 0.8;
}


/************  layout
*********************************************************/

body, button, input, select, textarea {
  color: #333;
  font-family: "Noto Sans jp","メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic Pro", "Osaka", sans-serif;
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.4;
  font-weight: 450;
}

@media only screen and (min-width: 760px) {
  body, button, input, select, textarea {
    font-size: 16px;
    font-size: 1.6rem;
  }
}

.none {
    display: none;
}



#wrapper {
  position: relative;
  min-height: 100vh;
  /* padding: 1px 0 260px; */
}

.innerBox {
  padding: 0 15px;
  max-width: 1350px;
  margin: 0 auto;
}

section {
  padding: 20px 0 20px 0;
}

section .sectionTtl {
  font-size: 24px;
  padding: 10px 0px 5px;
  font-family:"Noto Serif jp" ;
  font-weight: 800;
}

section .cardInfo {
  margin: 0px 0 20px 0;
  padding: 0 0 0 20px;
}

.btnRed-small a {
  display: inline-block;
  padding: 4px 10px;
  font-size:1.3rem;
  background: #8E1C37;
  border-radius: 4px;
  color: #fff;
}

.btnRed-medium a {
  display: inline-block;
  /* padding: 10px 40px; */
  font-size:1.8rem;
  background: #8E1C37;
  border-radius: 4px;
  color: #fff;
}

.btnRed-medium button {
  display: block;
  padding: 10px 40px;
  margin: 10px 0;
  font-size:1.8rem;
  background: #8E1C37;
  border-radius: 4px;
  color: #fff;
  width: 100%;
}

.btnBlue-medium input {
  display: inline-flex;
  /* margin: 7px 5px; */
  padding: 10px 15px;
  font-size: 15px;
  font-weight: bold;
  background: #0069A5;
  border-radius: 4px;
  color: #fff;
  align-items: center;
}

.btnBlue-medium a {
  padding: 10px 40px;
  font-size:1.8rem;
  background: #0069A5;
  border-radius: 4px;
  color: #fff;
  display:block;
  width: 100%;
}

.btnBlue-medium button {
  padding: 10px 40px;
  font-size:1.8rem;
  background: #0069A5;
  border-radius: 4px;
  color: #fff;
  display:block;
  width: 100%;
}

.btnGray-medium a {
  display: inline-block;
  /* padding: 10px 40px; */
  font-size:1.8rem;
  background: #c4c4c4;
  border-radius: 4px;
  color: #fff;  
}

@media screen and (max-width: 960px) {
    #wrapper {
      position: relative;
      min-height: 100vh;
      /* padding: 1px 0 450px; */
      overflow: hidden;
    }

    .innerBox {
      width: 100%;
      margin: 0 auto;
      padding: 0 10px;
      box-sizing: border-box;
    }

    section {
      padding:  20px 0 20px 0;
    }

    section .sectionTtl {
      font-size: 24px;
      padding: 10px 0px 5px;
      font-family:"Noto Serif jp" ;
      font-weight: 800;
    }

    section .cardInfo {
      margin: 0px 0 20px 0;
      padding: 0 0 0 20px;
    }

    .btnRed-small a {
      display: inline-block;
      padding: 4px 10px;
      font-size:1.3rem;
      background: #8E1C37;
      border-radius: 4px;
      color: #fff;
    }

    .btnRed-medium a {
      display: inline-block;
      /* padding: 10px 20px; */
      font-size:1.6rem;
      background: #8E1C37;
      border-radius: 4px;
      color: #fff;
    }

    .btnBlue-medium a {
      display: inline-block;
      padding: 10px 20px;
      font-size:1.6rem;
      background: #0069A5;
      border-radius: 4px;
      color: #fff;
    }

    .btnGray-medium a {
      display: inline-block;
      /* padding: 10px 20px; */
      font-size:1.6rem;
      background: #c4c4c4;
      border-radius: 4px;
      color: #fff;  
    }

    .btnBlue-medium input {
      width: 100%;
      height: 60px;
    }
}

/******************************************/

.header-band {
  background: #fff;
  box-shadow: 0px 3px 6px rgba(0,0,0,0.2);
  height: 50px;
  padding: 2px 0 0 0;
  margin: 0 0 5px 0; 
}

header .innerBox {
  display: flex;
  justify-content: space-between;
}

header h1 img {
  width: 270px;
}

header nav {
  display: flex;
  font-size:1.4rem;
}

header nav ul {
  display: flex;
  padding: 13px 0 0 0;
}

header nav ul li {
  padding: 0 20px 0 0;
}

header nav ul li a {
  color: #333;
  font-weight: 600;
}

#headerNav .btnRed-small {
  padding: 10px 0 0 0;
}


@media screen and (max-width: 960px) {
    .header-band {
      background: #fff;
      box-shadow: 0px 3px 6px rgba(0,0,0,0.2);
      height: 48px;
      padding: 0 0 0 0;
    }

    header .innerBox {
      display: flex;
      justify-content: space-between;
    }

    header h1 img {
      width: clamp(210px, 60vw, 270px);;
    }

    #nav-open {
        position: absolute;
        top: 15px;
        right: 20px;
        display: flex;
        height: 20px;
        width: 22px;
        justify-content: center;
        align-items: center;
        z-index: 90;
        cursor: pointer;
    }

    #nav-open span,
    #nav-open span:before,
    #nav-open span:after {
        content: '';
        display: block;
        height: 2px;
        width: 22px;
        border-radius: 3px;
        background-color: #000;
        position: absolute;
    }
    #nav-open span:before {
        bottom: 8px;
    }
    #nav-open span:after {
        top: 8px;
    }

    #nav-input:checked ~ .header-nav {
    }

    #nav-input:checked ~ #nav-close {
        display: block;
    }

    #nav-input:checked ~ .header-nav {
        transform: translateX(0%);/*メニューを画面内へ*/
    }

    .header-nav {
        width: 100%;
        height: 100vh;
        position: fixed;
        top:0;
        left: 0;
        z-index: 9999;
        transform: translateX(105%);/*-105*/
        transition: all 0.3s;
        display: block;
        padding: 15px 20px 0 20px;
        background:#f6f6f6;
        font-size: 2.4rem;
    }

    .header-nav nav {
        display: block;
    }

    .nav-ttl {
        display: block;
        font-size: 2.0rem;
        font-weight: 900;
        padding: 0 0 50px 0;
        font-family: "Noto Serif jp";
    }

    .nav-ttl span {
      font-size: 1.7rem;
      padding: 0 0 0 3px;
    }

    .header-nav ul {
        display: flex;
        flex-wrap: wrap;
        margin: 0 0 0 0;
    }

    .header-nav ul li {
        margin: 0 0 60px 0;
        width: 50%;
        text-align: left;
    }

    .header-nav ul li a {
        display: inline-block;
        font-size: 2.0rem;
    }

    .header-nav .btnRed-small a {
      display: block;
      padding: 8px 10px;
      font-size:1.3rem;
      background: #8E1C37;
      border-radius: 4px;
      color: #fff;
      font-size: 2.0rem;
      text-align: center;
    }

    .header-nav__btn {
        display: block;
        padding: 20px 0 40px 0;
    }

    .header-nav__btn a {
        display: block;
        text-align: center;
        color: #fff;
        background: #20456A;
        border-radius: 40px;
        padding: 5px 0;
        font-weight: 300;
        font-size: 2.2rem;
    }

    #nav-close {
        position: fixed;
        width: 20px;
        height: 20px;
        margin: 0 0 0 0;
        /*background: url("../img/ico_nav_close.svg") no-repeat;
        background-size: contain;*/
        vertical-align: middle;
        top:20px;
        right: 20px;
        z-index: 999999;
        cursor: pointer;
        font-size:2.4rem;
    }
}

/********************************************/
#mainImgBox {
  height: 380px;
  /* height: 530px; メインコピーがあるとき*/
  /* background: #e4e4e4; */
  position: relative;
  margin: 0 0 25px 0;
}

.slideItem {
  width: 100%;
  height: 550px;
}

.slideItem img {
  object-fit: cover;
  object-position: center center;
  width: 100%; 
  height: 380px;
  /* height: 550px; メインコピーがあるとき*/
}

.top-slideItem img {
    object-fit: cover;
    object-position: center center;
    width: 100%; 
    height: 400px;
  }

.slick-dots {
    background-color: #F5F3EF;
}

.slick-dots li button:before {
    color:#C7C7C7;
    opacity: 0.6;
}

.slick-dots li.slick-active button:before {
  color:#FF9955;
}

#mainImgBox .innerBox {
  max-width: 100%;
  width: 100%;
  position: absolute;
  top: 115px;
  /* left: calc(50VW - 463px); */
}

.mainCopy {
  width:900px;
  color: #fff;
  font-size:5.0rem;
  font-family: "Noto Serif JP";
  font-weight: 600;
  line-height: 1.3;
  text-shadow: 0px 3px 6px #000;
  margin: 0 auto;
  padding: 0 0 20px 0;
}

.mainCopy-top {
    width:900px;
    color: #fff;
    font-size:5.0rem;
    font-family: "Noto Serif JP";
    font-weight: 600;
    line-height: 1.3;
    text-shadow: 0px 3px 6px #000;
    margin: 0 auto;
    padding: 0 0 20px 0;
  }

.subCopy {
  width:900px;
  color: #fff;
  font-size:2.6rem;
  font-family: "Noto Serif JP";
  font-weight: 600;
  line-height: 1.2;
  padding-bottom: 20px;
  text-shadow: 0px 3px 6px #000;
  margin: 0 auto;
}

.loginBtnBox {
  width:930px;
  padding: 40px 0 40px 0;
  display: flex;
  justify-content: space-between;
  margin: 0 auto;
}

.btnEntry,.btnLogin,.btnProd,.btnID, .btnNone, .btnContact {
  display: inline-block;
  font-size: 1.8rem;
  width: 450px;
}

.btnChange {
    display: block;
    font-size: 15px;
    width: 100%;
    padding: 5px 0 5px 0;
    margin-top: 10px;
  }

.btnEntry a,.btnProd a {
    color: #fff;
    background: #FB9A1B;
    border-radius: 4px;
    display: block;
    text-align: center;
    padding: 15px 0;
}

.btnLogin a,.btnID a {
    color: #fff;
    background: #0C8FD9;
    border-radius: 4px;
    display: block;
    text-align: center;
    padding: 15px 0;
}

.btnContact a {
    color: #fff;
    background: #8E1C37;
    border-radius: 4px;
    display: block;
    text-align: center;
    padding: 15px 0;
}

.btnLog {
    margin: 0 auto;
    font-size: 1.8rem;
    width: 400px;
  }

.btnLog a {
    color: #fff;
    background: #8E1C37;
    border-radius: 4px;
    display: block;
    text-align: center;
    padding: 15px 0;
}

.btnNone p {
    color: #000;
    background: #c4c4c4;
    border-radius: 4px;
    display: block;
    text-align: center;
    padding: 15px 0;
}

.btnChange p{
    color: #000;
    background: #c4c4c4;
    border-radius: 4px;
    display: block;
    text-align: center;
    padding: 1% 3%;
    margin-inline: auto;
    max-inline-size: max-content;
    }

.memberInfo {
  width:900px;
  font-size: 1.6rem;
  font-weight: 450;
  color: #fff;
  text-shadow: 2px 2px 4px #000;
  margin: 0 auto;
  line-height: 25px
}

@media screen and (max-width: 960px) {
    #mainImgBox {
      height: 380px;
      /* height: 500px; メインコピーがあるとき*/
      /* background: #e4e4e4;
      position: relative;
      margin: 0; */
    }

    .SearchIn {
        height: 470px!important;
    }

    .slideItem {
      width: 100%;
      height: 420px;
    }

    .slideItem img {
      object-fit: cover;
      object-position: center center;
      width: 100%; 
      height: 380px;
      /* height: 500px; メインコピーがあるとき*/
    }

    .top-slideItem img {
        object-fit: cover;
        object-position: center center;
        width: 100%; 
        height: 470px;
      }

    #mainImgBox .innerBox {
      width: 100%;
      position: absolute;
      top: 40px;
      left: 0;
    }

    .mainCopy {
      width:auto;
      color: #fff;
      font-size:clamp(25px, 4vw, 30px);
      font-family: "Noto Serif JP";
      font-weight: 600;
      line-height: 1.4;
      text-shadow: 2px 2px 4px #000;
      padding: 3% 6%;
    }

    .mainCopy-top {
        width:auto;
        color: #fff;
        font-size:clamp(30px, 5.5vw, 40px);
        font-family: "Noto Serif JP";
        font-weight: 600;
        line-height: 1.4;
        text-shadow: 2px 2px 4px #000;
        padding: 1% 6%;
      }

    .subCopy {
      color: #fff;
      font-size:2.75vw;
      font-family: "Noto Serif JP";
      font-weight: 800;
      line-height: 1.2;
      text-shadow: 2px 2px 4px #000;
    }

    .loginBtnBox {
      padding: 10px 0 10px 0;
      display: block;
      margin: 0 auto;
      width: 90%;
    }

    .btnEntry,.btnLogin,.btnProd,.btnID,.btnNone, .btnContact {
      display: block;
      font-size: 1.8rem;
      width: 100%;
      padding: 30px 0 30px 0;
    }

    .btnEntry a,.btnProd a {
        color: #fff;
        background: #FB9A1B;
        border-radius: 4px;
        display: block;
        margin:auto;
        width:280px;
        text-align: center;
        padding: 15px 20px;
        margin-inline: auto;
        max-inline-size: max-content;
    }

    .btnLogin a,.btnID a{
        color: #fff;
        background: #0C8FD9;
        border-radius: 4px;
        display: block;
        margin:auto;
        width:280px;
        text-align: center;
        padding: 15px 20px;
        margin-inline: auto;
        max-inline-size: max-content;
    }

    .btnContact a {
        color: #fff;
        background: #8E1C37;
        border-radius: 4px;
        display: block;
        margin:auto;
        width:280px;
        text-align: center;
        padding: 2% 20px;
        margin-inline: auto;
        max-inline-size: max-content;
    }


    .btnLog {
        display: block;
        font-size: 1.8rem;
        width: 100%;
        margin: 5px auto;
      }

      .btnLog a {
          color: #fff;
          background: #8E1C37;
          border-radius: 4px;
          display: block;
          margin:auto;
          width:280px;
          text-align: center;
          padding: 2% 10px;
          margin-inline: auto;
          max-inline-size: max-content;
      }

      .btnNone p{
        color: #000;
        background: #c4c4c4;
        border-radius: 4px;
        display: block;
        text-align: center;
        padding: 3% 10%;
        margin-inline: auto;
        max-inline-size: max-content;
        }


    .memberInfo {
      font-size: 1.4rem;
      color: #fff;
      width: 90%;
      margin: 0 auto;
    }
}

/*********************************************/
#serchBox {
  width: 90%;
  max-width: 1100px;
  margin: 40px auto 40px;
  padding: 20px;
  border-radius: 8px;
  box-shadow: 2px 3px 6px 2px rgba(0, 0, 0, 0.3);
  background: #fff;
  justify-content: space-between;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: flex-start;
  justify-content: flex-start;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
}

#serchBox-row{
    width:50%;
  display: block;
  justify-content: space-between;
  padding: 4px 5px 4px;
}

#serchBoxPoint-row{
    width:30%;
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: flex-start;
    justify-content: flex-start;
}

#serchBoxText-row{
  width: 50%;
  display: flex;
  
}

#serchBoxBtn-row{
    width: 20%;
    display: flex;
    
  }

#serchBoxText{
    -webkit-flex-grow: 2;
    flex-grow: 2;
  margin: auto 0;
  text-align: center;
}

.serchCategory,.serchArea {
    width:100%;
    display: inline-flex;
    align-items: center;
    position: relative;
}

.serchCategory::after,.serchArea::after {
    content: "";
    position: absolute;
    top: 25px;
    right: 35px;
    border-right: 7px solid transparent;
    border-left: 7px solid transparent;
    border-top: 12px solid #000;
    border-bottom: 0;
    pointer-events: none;
}

.serchCategory select,.serchCategory option,.serchCategory a,.serchArea select,.serchArea option,.serchArea a {
    appearance: none;
    width: clamp(100px, 20vw, 230px);
    height: 40px;
    padding: .4em 38px .4em 30px;
    border: 1px solid #d0d0d0;
    border-radius: 4px;
    background-color: #fff;
    color: #333333;
    font-size: 16px;
    font-weight:bold;
    cursor: pointer;
    display: flex;
    align-items: center;
}
.serchArea a,.serchCategory a {
  height: 60px;
  width: 100%;
}


.serchKeywords {
  width: 100%;
  margin: 7px 5px;
    display: inline-flex;
    align-items: center;
    border: 1px solid #cacaca;
    border-radius: 3px;
    position: relative;
}

.serchKeywords input {
  width: 100%;
    padding: .4em 15px .4em 35px;
    border: none;
    box-sizing: border-box;
    font-size: 16px;
    font-weight:bold;
    outline: none;
}

.serchKeywords input::-webkit-search-cancel-button {
    -webkit-appearance: none; 
}

.serchKeywords input::placeholder {
    color: #777777;
}

.serchCategory .point {
  position: absolute;
  left:10px;
  color: #0790DF;   
}

.serchArea .point {
  position: absolute;
  left:10px;
  color: #0790DF;  
}

.serchKeywords .point {
  position: absolute;
  left:10px;
  color: #0790DF;
}

.serchPoints {
    -webkit-flex-grow: 4;
    flex-grow: 4;
  margin: 7px 5px;
  display: inline-flex;
  align-items: center;
  border: 1px solid #cacaca;
  border-radius: 3px;
  position: relative;
}

.serchPoints select {
    height: 60px;
  width: 100%;
  padding: .3em 10px .3em 35px;
  border: none;
  box-sizing: border-box;
  font-size: 18px;
  font-weight:bold;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-image: none;
  background-repeat: no-repeat;
  position: relative;
}

.serchPoints select::placeholder {
    color: #777777;
}

.serchPoints::after {
    content: "";
    position: absolute;
    top: 25px;
    right: 23px;
    border-right: 7px solid transparent;
    border-left: 7px solid transparent;
    border-top: 12px solid #000;
    border-bottom: 0;
    pointer-events: none;
}


.serchPoints .point {
  position: absolute;
  left:10px;
  color: #0790DF;
}

.serchBtn, .serchBtn input{
    height: 60px;
    width: 100%;
}


@media screen and (max-width: 960px) {
    #serchBox {
      width: 95%;
      margin: 20px auto 20px;
      padding: 15px;
      border-radius: 8px;
      box-shadow: 2px 3px 6px 2px rgba(0, 0, 0, 0.25);
      background: #fff;
      display: block;
      justify-content: space-between;
      flex-wrap: wrap;
    }

    #serchBox-row{
        width: 100%;
      display: flex;
      justify-content: space-between;
      padding: 0;
    }

    #serchBoxPoint-row{
        width: 100%;
        display: flex;
        justify-content: space-between;
      }

    #serchBoxText-row{
      width: 100%;
      display: flex;
      justify-content: space-between;
    }

    #serchBoxBtn-row{
        width: 100%;
        display: flex;
        justify-content: space-between;
      }

    .serchCategory,.serchArea, .serchBtn {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        position: relative;
        width: 100%;
        margin: 4px 5px 4px;
    }

    .serchBtn {
      display: inline-flex;
      align-items: center;
      position: relative;
      width: 100%;
      height: 60px;
      margin: 4px 5px 4px;
    }

    .serchCategory select,.serchCategory option,.serchCategory a,.serchArea select,.serchArea option,.serchArea a  {
        appearance: none;
        width: 100%;
        height: 60px;
        padding: .4em 38px .4em 30px;
        border: 1px solid #d0d0d0;
        border-radius: 4px;
        background-color: #fff;
        color: #333333;
        font-size: clamp(15px, 4vw, 18px);
        cursor: pointer;
        display: flex;
        -webkit-appearance: none;
        -moz-appearance: none;
        align-items: center;

    }


    .serchKeywords {
        display: inline-block;
        align-items: center;
        overflow: hidden;
        border: 1px solid #cacaca;
        border-radius: 3px;
        position: relative;
        width: 100%;
        margin: 4px 5px 4px;
        display: flex;
    }

    .serchKeywords input {
        width: 100%;
        height: 60px;
        padding: .5em 5px .5em 30px;
        border: none;
        box-sizing: border-box;
        font-size: clamp(13.5px, 4vw, 18px);
        outline: none;
    }

    .serchKeywords input::placeholder {
        color: #777777;
        font-size: clamp(13.5px, 4vw, 18px);
    }

    #serchBox .btnBlue-medium a {
      display: block;
      width: 100%;
      padding: 10px 40px;
      font-size:1.8rem;
      background: #0069A5;
      border-radius: 4px;
      color: #fff;
      text-align: center;
    }

    /*.spBlock {
      display: flex;
      justify-content: space-between;
    }*/

    .serchCategory .point {
      position: absolute;
      left:10px;
      color: #0790DF;   
    }

    .serchArea .point {
      position: absolute;
      left:10px;
      color: #0790DF;  
    }

    .serchKeywords .point {
      position: absolute;
      left: 5px;
      color: #0790DF;
      top:20px;
      margin: 4px 0;
    }

    .serchPoints {
      display: inline-flex;
      align-items: center;
      overflow: hidden;
      border: 1px solid #cacaca;
      border-radius: 3px;
      position: relative;
      width: 100%;
      margin: 4px 5px 4px;
    }

    .serchPoints select {
      width: 100%;
      height: 60px;
      padding: .5em 15px .5em 34px;
      border: none;
      box-sizing: border-box;
      font-size: 18px;
      outline: none;
    }

    .serchPoints select::placeholder {
      color: #777777;
    }

    .serchPoints .point {
      position: absolute;
      left:10px;
      color: #0790DF;
      top:22px;
    }
}

/******************************************/
.cardBox {
  margin: 0 0 0 0;
}

.cardBox:nth-child(2n+1){
  background-color: #F5F3EF;
}

.cardBox:nth-child(2n){
  background-color: #FFFFFF;
}

.cardBoxList {
    margin: 0 0 0 0;
    padding: 20px 0 150px 0;
  }

.bgGray {
  background: #F5F3EF;
}

.cardListSlider {
  position: relative;
  margin-bottom: -60px;
}

.prevBtn,.nextBtn {
  background: #fff;
  width: 40px;
  height: 40px;
  display: flex;
  justify-content: center;
  align-items: center;
  border:1px solid #0790DF;
  border-radius: 50%;
  color: #0790DF;
  font-size: 1.9rem;
  position: absolute;
  z-index: 300;
  cursor: pointer;
}

.prevBtn {
  top:150px;
  left: -50px;
}

.nextBtn {
  top:150px;
  right: -50px;
}

.cardList {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: -60px;
}

.cardList .cardItem {
  width: 300px;
  border-radius: 8px;
  box-shadow: 2px 3px 6px 2px rgba(0, 0, 0, 0.3);
  overflow: hidden;
  margin: 30px 10px 30px 10px;

}

.cardListSlider .cardItem {
  width: 300px;
  border-radius: 8px;
  box-shadow: 2px 3px 6px 2px rgba(0, 0, 0, 0.3);
  overflow: hidden;
  margin: 5px 20px 60px 10px;
}

/* .cardList .cardItem:nth-child(4n) {
  margin: 0 0 60px 0;
} */

.card-TopComment {
  background-color: #ffffff;
  /* color:#FFFFFF; */
  padding:5px 5px 0 5px;
}

.card-img {
  width: 100%;
  height: 200px;
  position: relative;
}

.card-img img {
  object-fit: cover;
  object-position: center center;
  width: 100%;
  height: 200px;
}

.ribbon {
  position: absolute;
  top:-3px;
  left: 0;
  z-index: 100;
}

.ribbon {
  font-size: 20px;
  font-weight: bold;
  color: #fff;
}
.ribbon {
  --r: .3em; /* control the cutout */ 
  border-inline: .5em solid #0000;
  padding: .5em .6em calc(var(--r) + .2em);
  clip-path: polygon(0 0,100% 0,100% 100%,calc(100% - .5em) 100%,50% calc(100% - var(--r)),.5em 100%,0 100%);
  width: fit-content;
}

.rank1 {
  background:radial-gradient(50% .2em at top,#000a,#0000) border-box,#FBBD51 padding-box; /* the color  */
} 

.rank2 {
  background:radial-gradient(50% .2em at top,#000a,#0000) border-box,#A4A4A4 padding-box; /* the color  */
}

.rank3 {
  background:radial-gradient(50% .2em at top,#000a,#0000) border-box,#945226 padding-box; /* the color  */
}

.rankNot {
  background:radial-gradient(50% .2em at top,#000a,#0000) border-box,#1B549F padding-box; /* the color  */
}

.likeBtn {
  position: absolute;
  top:10px;
  right: 10px;
  background: #fff;
  height: 30px;
  width: 30px;
  border-radius: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
  cursor: pointer;
}

.likeBtn .fas {
  color: #EC3B6B;
}

.card-info {
  padding: 10px 10px 15px 10px;
  background: #fff;
  height: 100%;
}

.card-label {
  display: flex;
  justify-content: space-between;
  padding: 0 0 10px 0;
}

.card-area {
    padding: 2px 5px 0 0;
    font-size: 1.3rem;
    color: #999;
}

.card-category {
  font-size: 1.1rem;
  border: 1px solid #0790DF;
  color: #0790DF;
  display: inline-block;
  padding: 3px 8px;
  border-radius: 10px;
  line-height: 1.0;
  margin: 0 5px 0 0;
  font-weight: 600;
}

.card-title {
  padding: 0 0 15px 0;
}

.card-title a {
  color: #333;
}

.card-title span {
    display: block;
}

.titleName {
  font-size: 20px;
  font-weight: 900;
  font-family: "Noto Serif JP";
}

.planName {
  font-size: 16px;
  font-weight: 700;
}
.card-title .planName {
    margin-top: 3px;
}

.card-grade span {
  font-size: 9px;
  font-weight: 500;
  color: #fff;
  display: inline-block;
  padding: 3px 8px;
  border-radius: 10px;
  line-height: 1.0;
  background: #8D8C8C;
}

.card-comment {
  padding: 5px 0 0 0;
  font-size: 1.6rem;
  color: #b43232;
}

/* .tag_6 {
  background: #8D8C8C;
}

.tag_5 {
  background: #63171E;
}

.tag_4 {
  background: #163346;
}

.tag_3 {
  background: #421A2F;
}

.tag_2 {
  background: #153B2C;
} */

.card-point {
  font-size: 14px;
  font-weight: 500;
  color: #999;
  margin-top: 5px;
}

.card-point i {
  color: #FFBE26;
}

.pagerBox {
  width: 700px;
  margin: 0 auto;
  padding: 80px 0 60px;
}

.pagerBox ul {
  display: flex;
  justify-content: space-between;
}

.pagerBox li a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 60px;
  height: 60px;
  border:1px solid #8F8F8F;
  border-radius: 50%;
  color: #8F8F8F;
  font-size: 2.0rem;
}

.pagerPrev {
  margin: 0 40px 0 0;
}

.pagerNext {
  margin: 0 0 0 40px;
}

.pagerBox li.act {
  border:1px solid #C9C9C9;
  background: #C9C9C9;
  border-radius: 50%;
  color: #8F8F8F;
  font-size: 2.0rem;
  color: #fff; 
}


@media screen and (max-width: 960px) {
    .cardBox {
      margin: 0 0 0 0;
    }
    
    .cardListSlider {
      position: relative;
      margin-bottom: -40px;
    }
    
    .prevBtn,.nextBtn {
      background: #fff;
      width: 40px;
      height: 40px;
      display: flex;
      justify-content: center;
      align-items: center;
      border:1px solid #0790DF;
      border-radius: 50%;
      color: #0790DF;
      font-size: 1.9rem;
      position: absolute;
      z-index: 300;
      cursor: pointer;
    }
    
    .prevBtn {
      top:150px;
      left: -5px;
    }
    
    .nextBtn {
      top:150px;
      right: -5px;
    }
    
    .cardList {
      display: flex;
      flex-wrap: wrap;
      margin-bottom: -40px;
    }
    
    .cardList .cardItem {
      width: 300px;
      border-radius: 8px;
      box-shadow: 2px 3px 6px 2px rgba(0, 0, 0, 0.3);
      overflow: hidden;
      margin: 25px;
    }
    
    .cardListSlider .cardItem {
      width: 100vw;
      border-radius: 8px;
      box-shadow: 2px 3px 6px 2px rgba(0, 0, 0, 0.3);
      overflow: hidden;
      margin: 5px 10px 60px 10px;
    }
    
    /* .cardList .cardItem:nth-child(4n) {
      margin: 0 0 40px 0;
    } */
    
    .card-img {
      width: 100%;
      height: 200px;
      position: relative;
    }
    
    .card-img img {
      object-fit: cover;
      object-position: center center;
      width: 100%;
      height: 200px;
    }
    
    .likeBtn {
      position: absolute;
      top:10px;
      right: 10px;
      background: #fff;
      height: 30px;
      width: 30px;
      border-radius: 50%;
      display: flex;
      justify-content: center;
      align-items: center;
      cursor: pointer;
    }
    
    .likeBtn .fas {
      color: #EC3B6B;
    }
    
    .card-info {
      padding: 10px 10px 15px 10px;
      background: #fff;
      height: 100%;
    }
    
    .card-label {
      display: flex;
      justify-content: space-between;
      padding: 0 0 10px 0;
    }
    
    .card-area {
        padding: 2px 5px 0 0;
        font-size: 1.3rem;
        color: #999;
    }
    
    .card-category {
        font-size: 1.1rem;
        border: 1px solid #0790DF;
        color: #0790DF;
        display: inline-block;
        padding: 3px 8px;
        border-radius: 10px;
        line-height: 1.0;
    }
    
    .card-title {
      padding: 0 0 15px 0;
    }
    
    .card-title a {
      color: #333;
    }
    
    .card-title span {
        display: block;
    }
    
    .titleName {
      font-size: 20px;
      font-weight: 900;
    }
    
    .planName {
      font-size: 16px;
      font-weight: 700;
    }
    
    .card-grade span {
      font-size: 9px;
      font-weight: 500;
      color: #fff;
      display: inline-block;
      padding: 3px 8px;
      border-radius: 10px;
      line-height: 1.0;
    }
    
    .card-comment {
      padding: 5px 0 0 0;
      font-size: 1.6rem;
      color: #b43232;
    }
}

@media screen and (max-width: 768px) {
    .pagerBox {
        width: 90%;
        margin: 0 auto;
        padding: 40px 0 30px;
      }
      
      .pagerBox ul {
        display: flex;
        flex-wrap :wrap;
        justify-content: space-between;
      }
      
      .pagerBox li a {
        display: flex;
        justify-content: center;
        align-items: center;
        width: 50px;
        height: 50px;
        border:1px solid #8F8F8F;
        border-radius: 50%;
        color: #8F8F8F;
        font-size: 2rem;
        margin-bottom: 15px;
      }
      
      .pagerPrev {
        margin: 0 20px 0 0;
      }
      
      .pagerNext {
        margin: 0 0 0 20px;
      }
      
      .pagerBox li.act {
        width: 50px;
        height: 50px;
        border:1px solid #C9C9C9;
        background: #C9C9C9;
        border-radius: 50%;
        color: #8F8F8F;
        font-size: 2.0rem;
        color: #fff; 
      }
      
      .pagerBox li.right {
          margin-left: auto;
        }
      
        .pagerBox li.left {
          margin-right: auto;
        }

  .cardList .cardItem {
    width: 90%;
    margin: 30px 0 30px 0;
  }
}


/******************************************/
#contents.bgGray {
  padding: 0 20px 20px;
}

.whiteCardBox {
    width: 98%;
    margin: 0 auto;
}

.whiteCardBox .innerBox {
    background: #fff;
    padding: 30px 30px 160px;
    border-radius: 30px;
    box-shadow: 2px 3px 6px 2px rgba(0, 0, 0, 0.3);
    position: relative;
}

.itemDetail-contents {
  display: flex;
  justify-content: space-between;
}

.itemDetail-article,.item-title,.itemDetail-info {
  font-family: "Noto Serif JP";
}

.itemDetail-header {
  padding: 0 0 30px 0;
}

.item-area {
  font-size: 1.6rem;
  /* color: #999; */
  padding: 0 0 20px 0;
  display: inline-block;
}

.item-title .titleName {
  font-size: 26px;
  font-weight: 800;
  display: block;
}

.item-title .planName {
  font-size: 2.0rem;
  margin-top: 10px;
}


.item-point {
  padding: 20px 0 0 0;
  font-size: 1.1rem;
}

.item-point i {
  color: #FFBE26;
}

.itemDetail-photo {
  width: 500px;
  margin-right: 30px;
}

.itemImg {
  width: 500px;
  position: relative;
}

.itemImg img {
  width: 100%;
  height: 375px;
  object-fit: contain;
  object-position: center center; 
}

.itemImgList ul {
  padding: 20px 0 30px;
  /* display: flex;
  flex-wrap: wrap;
  justify-content: space-between; */
}

.itemImgList ul li {
  width: 130px;
  margin:0 5px 0;
}

.itemImgList ul li img {
  width: 100%;
  height: 90px;
  object-fit: cover;
  object-position: center center;   
}

.itemDetail-contents .prevBtn,
.itemDetail-contents .nextBtn {
  background: #fff;
  width: 20px;
  height: 20px;
  display: flex;
  justify-content: center;
  align-items: center;
  border:1px solid #0790DF;
  border-radius: 50%;
  color: #0790DF;
  font-size: 1.2rem;
  position: absolute;
  z-index: 300;
  cursor: pointer;
}

.itemDetail-contents .prevBtn {
  top:55px;
  left: -20px;
}

.itemDetail-contents .nextBtn {
  top:55px;
  right: -20px;
}

.itemDetail-read {
  font-size: 2rem;
  font-weight: 700;
  padding: 0 0 20px 0;
}

.itemDetail-txt {
  font-size: 15px;
  padding: 0 0 20px 0;
  line-height: 1.6;
  font-weight: 600;
}

.itemDetail-info {
  width: 600px;
}

.itemDetail-info h2 {
  font-size: 20px;
  font-weight: 700;
  padding: 0 0 10px 0;
}

.itemTable {
  display: grid;
  grid-template-columns: 1fr 2fr;  
  margin: 0 0 30px 0;
  background: #F9F9F9;
}

.itemTable div {
  padding: 15px 20px;
  font-size: 18px;
  font-weight: 600;
  /* border: 1px solid #000000; */
}

.itemTable div:nth-child(2n-1) {
  background: #efefef;
}

/* .itemTable div:nth-child(2n) {
  background: #f9f9f9;
} */

.itemDetail-btn {
  position: absolute;
  top:20px;
  right:30px;
  text-align: right;
}

.btnTtl {
  padding: 0 0 5px 0;
}

.itemDetail-btn .btnRed-small,.itemDetail-btn.btnRed-medium {
  display: inline-block;
}

.itemTable span.day_info {
    display:block;
    font-size: 14px;
    padding: 5px 0 0;
}

@media screen and (max-width: 960px) {
    #contents.bgGray {
      padding: 0 20px 20px;
    }
    
    .whiteCardBox {
        width: 100%;
        margin: 0 auto;
    }
    
    .whiteCardBox .innerBox {
        background: #fff;
        padding: 20px 20px 40px;
        border-radius: 30px;
        box-shadow: 2px 3px 6px 2px rgba(0, 0, 0, 0.3);
        position: relative;
    }
    
    .itemDetail-contents {
      display: block;
      justify-content: space-between;
    }
    
    .itemDetail-header {
      padding: 0 0 30px 0;
    }
    
    .item-area {
      font-size: 15px;
      /* color: #ccc; */
      padding: 5px 0 10px 0;
      display: inline-block;
    }
    
    .item-title .titleName {
      font-size: 22px;
      font-weight: 800;
      display: block;
    }
    
    .item-title .planName {
      font-size: 18px;
      margin-top: 5px;
    }
    
    
    .item-point {
      padding: 20px 0 0 0;
      font-size: 1.1rem;
    }
    
    .item-point i {
      color: #FFBE26;
    }
    
    .itemDetail-photo {
      width: 100%;
    }
    
    .itemImg {
      width: 100%;
      position: relative;
    }
    
    .itemImg img {
        margin: 0 auto;
      width: auto;
      height: auto;
      object-fit: contain;
      object-position: center center; 
    }
    
    .itemImgList ul {
      padding: 20px 0 30px;
      display: flex;
      flex-wrap: wrap;
      justify-content: space-between;
    }
    
    .itemImgList ul li {
      width: 20%;
    }
    
    .itemImgList ul li img {
      width: 100%;
      height: 50px;
      object-fit: cover;
      object-position: center center;   
    }
    
    .itemImgList .itemImgList-slider {
      margin-right: auto;
      margin-left: auto;
      width: 80%!important;
    }
    
    .itemImgList .itemImgList-slider .slick-list{
      margin-right: auto;
      margin-left: auto;
      width: 100%!important;
    }
    
    .itemImgList .itemImgList-slider .slick-list .slick-track{
      margin-right: auto;
      margin-left: auto;
    }
    
    
    .itemDetail-contents .prevBtn {
      top:36px;
      left: -20px;
    }
    
    .itemDetail-contents .nextBtn {
      top:36px;
      right: -20px;
    }
    
    .itemDetail-read {
      font-size: 18px;
      font-weight: 700;
      padding: 0 0 20px 0;
    }
    
    .itemDetail-info {
      width: 90%;
      margin: 0 auto;
      padding: 20px 0 0 0;
    }
    
    .itemDetail-info h2 {
        font-size: 17px;
        font-weight: 700;
      padding: 0 0 10px 0;
    }
    
    .itemTable {
      display: grid;
      grid-template-columns: 1fr;  
      padding: 5px;
      background: #efefef;
    }
    
    .itemTable div {
      /* padding: 15px 20px; */
      font-size: 18px;
      padding: 1px 10px;
      /* border: 1px solid #000000; */
      /* margin-bottom:-1px; */
    }
    
    .itemTable div:nth-child(2n-1) {
      /* background: #efefef; */
      font-size: 15px;
      /* border-top: 1px solid #000000; */
      padding-top: 10px;
      font-weight: 800;
    }
    
    .itemTable div:nth-child(2n) {
      /* background: #efefef; */
      /* background: #F9F9F9; */
      /* border-bottom: 1px solid #000000; */
      font-size: 14px;
      line-height: 22px;
      padding-left: 30px;
      padding-bottom: 10px;
      /* margin-bottom:-1px; */
      /* font-family: "Noto Sans jp"; */
      font-weight: 600;
    }

    .itemTable span.day_info {
        font-size: 11px;
        padding: 3px 0;
    }
    
    .itemDetail-btn {
      position: static;
      text-align: center;
      padding: 10px 0 0 0;
    }
    
    .btnTtl {
      padding: 0 0 5px 0;
    }
    
    .itemDetail-btn .btnRed-small,.itemDetail-btn.btnRed-medium {
      display: block;
      padding: 0 0 15px 0;
    }
    
    .itemDetail-btn .btnRed-small a,.itemDetail-btn.btnRed-medium a {
      width: 100%;
      font-size:1.6rem;
      padding: 10px 0 10px;
    }

}

/**********************************************/

.cartTtl,.item-selected-name .titleName,.planName,.calcBox .text,.cartInfo,.calcPoint .text {
  font-family: "Noto Serif JP";
}

.cartTtl {
  font-size: 2.4rem;
  font-weight: 600;
  padding: 0 0 40px 0;
}

.cartBox {
  padding: 0 0 80px 0; 
}

.cartTable {
  display:table;
  border-collapse:collapse;
  table-layout:auto;
  width: 100%;
  margin:0 0 20px 0;
}

.cartTable-row {
  display:table-row;
}

.cartTable-row > div {
 display:table-cell;
 padding: 20px;
 border:1px solid #f5f5f5;
 vertical-align: top;
}

.cartTable-row.head {
  background: #f5f5f5;
  font-weight: 400;
  text-align: center;
  border:1px solid #f5f5f5;
}

.item-num.cell,.item-point.cell,.item-del.cell {
  vertical-align: middle;
  text-align:center;
  
}

.item-selected-flex {
  display: flex;
}

.item-selected-img {
  width: 10vw;
  max-width: 150px;
  margin: 0 20px 0 0;  
}

.item-selected-img img {
  width: 100%;
  height: 120px;
  object-fit: contain;
  object-position: center center; 
}

.item-selected .item-area {
  display: block;
  font-size: 14px;
  padding: 0 0 5px 0;
}

.item-selected .titleName {
  display: block;
  font-size: 24px;
  padding: 0 0 5px 0;
}

.item-selected .planName {
  display: block;
  font-size: 16px;
  padding: 0 0 5px 0;
}

.item-num label {
  display: block;
  font-size: 17px;
  padding: 0 0 10px 0;
}

.item-num label span {
  display: block;
  padding: 0 0 5px 0;
}

.item-num label input {
  margin: 0 0 0 10px;
  padding: 3px 10px;
}

.item-num label.numCount input {
  margin: 0 20px 0 0;
  padding: 3px 10px;
  width: 100px;
}

.item-num label.numCount button {
  font-size: 1.8rem;
  padding: 3px 10px;
  width: 35px;
  color: #8e8e8e;
  border:1px solid #ccc;
  background: #EEEEEE;
  border-radius: 4px;
  cursor: pointer;
  margin: 20px 0 0 0; 
}

.item-del button {
  display: block;
  font-size: 1.2rem;
  padding: 4px 15px;
  color: #8e8e8e;
  border:1px solid #EEEEEE;
  background: #EEEEEE;
  border-radius: 4px;
  cursor: pointer;
  margin: 0 0 0 0;
}

.item-point {
  font-size: 1.6rem;
}

.cartTable .item-point {
  text-align: center;
}

.calcBox {
  text-align: right;
  width: 280px;
  margin-left: auto;
  padding: 0;
}

.calcNum {
  font-size: 1.4rem;
  padding: 0 0 20px 0;
}

.calcPoint {
  display: flex;
  justify-content: space-between;
  border-bottom: 1px solid #999;
  padding: 0 5px 5px 5px;
  margin: 0 0 10px 0;
  font-size: 18px;
}

.calcPoint i {
  color: #FFBE26;
}

.cartBtnBox {
  width: 800px;
  margin: 0 auto;
}

.cartInfo {
  padding: 40px 0 40px 0;
}

.cartBtn {
  display: flex;
  justify-content: space-between;
}

.cartBtn .btnGray-medium a ,.cartBtn .btnRed-medium a {
    width: 380px;
    text-align: center;
}

@media screen and (max-width: 960px) {

    .cartTtl {
      font-size: 2.2rem;
      font-weight: 600;
      padding: 0 0 10px 0;
    }

    .cartBox {
      padding: 0 0 60px 0;
    }

    .cartTable {
      display: block;
      border-collapse: collapse;
      border:none;
      padding: 0;
      width: 100%;
      margin: 0 0 20px 0;
      border-top:1px solid #dddddd;
    }

    .cartTable-row {
      display: block;
    }

    .cartTable-row > div {
      display: block;
      border:none;
      padding: 10px;
    }

    .cartTable .head {
     display: none;
    }

    .item-selected,.item-num {
      padding: 10px;
      width: 100%;
      border:none;
    }

    .cartTable-row div.item-selected {
      width: 100%;
      padding: 0 10px;
    }

    .item-num {
      width: 100%;
    }

    .item-usepoint {
      width: 100%;
      border-bottom:1px solid #f5f5f5;
    }

    .item-selected-flex {
      display: flex;
      padding: 25px 0 0 0;
    }

    .item-selected-img {
      width: 90px;
      margin: 0 20px 0 0;  
    }

    .item-selected-img img {
      width: 100%;
      height: 60px;
      object-fit: cover;
      object-position: center center; 
    }

    .item-selected-name{
      width: 100%
    }

    .item-selected .item-area {
      display: block;
      font-size: 13px;
      color:#ccc;
      padding: 0 0 5px 0;
    }

    .item-selected .titleName {
      display: block;
      font-size: 22px;
      padding: 0 0 5px 0;
    }

    .item-selected .planName {
      display: block;
      font-size: 16px;
      padding: 0 0 5px 0;
    }

    .item-num label {
      display: block;
      padding: 0;
      font-size:1.8rem;
      text-align:right;
    }

    .item-num label span {
      display: block;
      padding: 0 0 5px 0;
    }

    .item-num label input {
      margin: 0 0 0 0;
      width: 100%;
      padding: 3px 10px;
    }

    .item-num label.numCount input {
      margin: 0 20px 0 0;
      padding: 3px 10px;
      width: 40%;
    }

    .item-num label.numCount button {
      font-size: 1.8rem;
      padding: 3px 10px;
      width: 35px;
      color: #8e8e8e;
      border:1px solid #ccc;
      background: #EEEEEE;
      border-radius: 4px;
      cursor: pointer;
      margin: 20px 0 0 0; 
    }

    .cartTable .item-num {
      padding: 10px 10px 10px 0;
    }

    .item-selected button {
      display: block;
      font-size: 1.2rem;
      padding: 3px 10px;
      color: #8e8e8e;
      border:1px solid #EEEEEE;
      background: #EEEEEE;
      border-radius: 4px;
      cursor: pointer;
      margin: 5px 0 0 0;
    }

    .item-point {
      font-size: 15px;
    }

    .cartTable .item-point {
      text-align: right;
      padding: 0 10px 0 0;
    }

    .cartTable-row div.item-del {
      text-align:center;
      padding: 15px 0 20px 0;
      border-bottom: 1px solid #dddddd;
      margin:0;
    }


    .calcBox {
      text-align: right;
      width: 100%;
      margin-left: auto;
      padding: 40px 0 40px 0;
    }

    .calcNum {
      font-size: 1.4rem;
      padding: 0 0 20px 0;
    }

    .calcPoint {
      display: flex;
      justify-content: space-between;
      border-bottom: 1px solid #999;
      padding: 0 0 5px 0;
      margin: 0 0 10px 0;
    }

    .calcPoint i {
      color: #FFBE26;
    }

    .cartBtnBox {
      width: 100%;
      margin: 0 auto;
    }

    .cartInfo {
      padding: 0 0 40px 0;
    }

    .cartBtn {
      display: block;
      justify-content: space-between;
    }

    .cartBtn .btnGray-medium,.cartBtn .btnRed-medium {
      padding: 0 0 20px 0;
    }

    .cartBtn .btnGray-medium a ,.cartBtn .btnRed-medium a {
        width: 100%;
        text-align: center;
    }
}


/******************************************/
.faqListBox {
    padding:0 0 30px 10px;
}

.faqListBox a{
    padding-left: 50px;
    text-decoration: underline 1px #999;
    text-underline-offset: 5px;
    text-decoration-skip-ink: none;
}

.faqBox dt {
  font-family: "Noto Serif JP";
  font-size: 20px;
  font-weight: 600;
  border-bottom: 1px solid #999;
  margin: 0 0 10px 0;
  padding: 0 0 5px 0;
}

.faqBox dd {
  padding:0 0 30px 20px;
  display: block;
  font-size: 16px;
  font-weight: 500;
  line-height: 25px;
}

.faqBox .sectionTtl{
    margin-bottom: 20px;
}

.faqBox dt::before {
  content: "Q";
  font-family: "Noto Serif JP";
  font-size: 26px;
  font-weight: 700;
  color: #8F1414;
}

.faqBox dd::before {
  content: "A";
  font-family: "Noto Serif JP";
  font-size: 26px;
  font-weight: 700;
  color: #14358F;
}

.faqBox dt::before,.faqBox dd::before {
    margin-right: .5em;
}

.faqBox .btn {
  text-align: center;
  margin: 30px 0 60px 0;
}

@media screen and (max-width: 960px) {

    .faqBox dt {
      font-family: "Noto Serif JP";
      font-size: 18px;
      font-weight: 700;
      border-bottom: 1px solid #999;
      margin: 0 0 10px 0;
      padding: 0 0 5px 0;
    }

    .faqBox dd {
        padding:0 0 30px 20px;
        display: block;
        font-size: 15px;
        font-weight: 500;
        line-height: 22px;
    }

    .faqBox dt::before,.faqBox dd::before {
        margin-right: .5em;
    }

    .faqBox .btn {
      text-align: center;
      margin: 30px 0 40px 0;
    }
}

/******************************************/

.guideBox {
  background: #F1F1F1;
}

.guideBox dt {
  font-family: "Noto Serif JP";
  font-size:2.0rem;
  font-weight: 650;
  border-bottom: 1px solid #999;
  margin: 0 0 10px 0;
  padding: 0 0 5px 0;
}

.guideBox dd {
  padding: 0 0 70px 30px;
  line-height:1.7;
  display: block;
}

.guideBox .btn {
  text-align: center;
  margin: 30px 0 60px 0;
}

.guideBox h3 {
  padding: 20px 0 10px 0;
}

@media screen and (max-width: 960px) {
    .guideBox {
      background: #F1F1F1;
    }

    .guideBox dt {
      font-family: "Noto Serif JP";
      font-size:1.8rem;
      border-bottom: 1px solid #999;
      margin: 0 0 10px 0;
      padding: 0 0 5px 0;
    }

    .guideBox dd {
      padding: 0 20px 50px 30px;
      display: block;
      font-size: 1.4rem;
    }

    .guideBox .btn {
      text-align: center;
      margin: 30px 0 40px 0;
    }

    .guideBox h3 {
      padding: 10px 0 20px 0;
    }
}


/******************************************/
#pageTop {
  position: fixed;
  bottom:100px;
  right: 50px;
  z-index: 100;
}

#pageTop a {
  background: #fff;
  width: 90px;
  height: 90px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #0790DF;
  font-size:4.0rem;
  box-shadow: 0px 3px 6px rgba(0,0,0,0.2);
  border-radius: 50%;
}

footer {
  /* position: absolute;
  bottom: 0;
  left: 0; */
  width: 100%;
  margin: 0;
  padding: 30px 0 10px;
  background-color: #303233;
  color: #fff;
}

.footerHead {
  text-align:  center;     
  padding: 0 0 30px 0;
}

.footerLogo {
  width: 225px;
  text-align: center;
  padding: 0 0 10px 0;
  margin: 0 auto;
}

.footerInfo {
  font-size: 1.4rem;
  text-align: center;
  margin: 0 auto;
}

#footerNav ul {
  display: flex;
  padding: 0 0 30px 0;
  justify-content: center; 
}

#footerNav ul li {
  padding: 0 15px 0 15px;
}

#footerNav ul a {
  color: #fff;
  font-size:1.4rem;
}

footer p {
  text-align: center;
} 

@media screen and (max-width: 960px) {
    #pageTop {
      position: fixed;
      bottom:80px;
      right: 10px;
      z-index: 100;
    }

    #pageTop a {
      background: #fff;
      width: 40px;
      height: 40px;
      display: flex;
      align-items: center;
      justify-content: center;
      color: #0790DF;
      font-size:2.6rem;
      box-shadow: 0px 3px 6px rgba(0,0,0,0.2);
      border-radius: 50%;
    }

    footer {
      /* position: absolute;
      bottom: 0;
      left: 0; */
      width: 100%;
      margin: 0;
      padding: 30px 0 10px;
      background-color: #303233;
      color: #fff;
    }

    .footerHead {
      display: block;
      justify-content: space-around;
      padding: 0 0 30px 0;
    }

    .footerLogo {
      width: 225px;
      margin: 0 auto;
      padding: 0 0 10px 0;
    }

    .footerInfo {
      font-size: 1.4rem;
      padding: 0 0 0 0;
    }

    #footerNav ul {
      display: block;
      padding: 0 0 20px 0;
    }

    #footerNav ul li {
      padding: 10px 20px;
    }

    #footerNav ul a {
      color: #fff;
      font-size:1.4rem;
    }
}

/************************************************/
.blockCenter { margin: 0 auto;}
.txtCenter { text-align: center;}
.txtLeft { text-align: left;}
.txtRight { text-align: right;}

.spPT10 { padding-top:10px;}
.spPT20 { padding-top:20px;}
.spPT30 { padding-top:30px;}
.spPT40 { padding-top:40px;}
.spPT50 { padding-top:50px;}

.spPL10 { padding-left:10px;}
.spPL20 { padding-left:20px;}
.spPL30 { padding-left:30px;}
.spPL40 { padding-left:40px;}
.spPL50 { padding-left:50px;}

.spPR10 { padding-right:10px;}
.spPR20 { padding-right:20px;}
.spPR30 { padding-right:30px;}
.spPR40 { padding-right:40px;}
.spPR50 { padding-right:50px;}

.spPB10 { padding-bottom:10px;}
.spPB20 { padding-bottom:20px;}
.spPB30 { padding-bottom:30px;}
.spPB40 { padding-bottom:40px;}
.spPB50 { padding-bottom:50px;}

.spMT10 { margin-top:10px; }
.spMT20 { margin-top:20px; }
.spMT30 { margin-top:30px; }
.spMT40 { margin-top:40px; }
.spMT50 { margin-top:50px; }

.spMB10 { margin-bottom:10px; }
.spMB20 { margin-bottom:20px; }
.spMB30 { margin-bottom:30px; }
.spMB40 { margin-bottom:40px; }
.spMB50 { margin-bottom:50px; }

.spML10 { margin-left:10px; }
.spML20 { margin-left:20px; }
.spML30 { margin-left:30px; }
.spML40 { margin-left:40px; }
.spML50 { margin-left:50px; }

.spMR10 { margin-right:10px; }
.spMR20 { margin-right:20px; }
.spMR30 { margin-right:30px; }
.spMR40 { margin-right:40px; }
.spMR50 { margin-right:50px; }

/************************************************/
/************************************************/

.ec-pageHeader{
    padding: 0;
}
.ec-pageHeader h1, .ec-pageHeader .h1 {
    margin: 10px;
    border-bottom: 1px dotted #ccc;
    border-top: initial;
    padding: 8px 0 12px;
    font-size: 2.4rem;
    font-family:"Noto Serif JP", serif;
    font-weight: 900;
    font-optical-sizing: auto;
    font-style: normal;
}
.ec-para-normal {
    margin: 10px;
  }
h1, .h1, h2, .h2, h3, .h3 {
    margin-top: initial;
    margin-bottom: initial;
    font-weight: initial;
}
.ec-inlineBtn,.ec-inlineBtn--primary,
.ec-inlineBtn--action,.ec-inlineBtn--cancel,
.ec-blockBtn,.ec-blockBtn--primary,
.ec-blockBtn--action,.ec-blockBtn--cancel {
    font-weight: initial;
    font-size: initial;
}
.ec-input .ec-errorMessage,
.ec-birth .ec-errorMessage,
.ec-select .ec-errorMessage,
.ec-telInput .ec-errorMessage,
.ec-zipInput .ec-errorMessage,
.ec-numberInput .ec-errorMessage,
.ec-halfInput .ec-errorMessage {
    margin-bottom: 5px;
    font-size: 16px;
}
.ec-zipInput .ec-icon {
    text-align: center;
}
.ec-zipInputHelp {
    text-align: right;
}
@media screen and (max-width: 768px) {
    .ec-zipInputHelp {
      width: 100%;
    }
}
.ec-zipInputHelp .ec-zipInputHelp__icon .ec-icon img {
    left: initial;
}
.ec-input input, .ec-birth input,
.ec-select input, .ec-halfInput input,
.ec-numberInput input, .ec-zipInput input,
.ec-telInput input {
    font-size: 17px;
}
.ec-input input, .ec-birth input,
.ec-select input, .ec-halfInput input,
.ec-numberInput input, .ec-zipInput input,
.ec-telInput input {
    height: 50px;
    font-size: 17px;
}
.ec-zipInput input {
    max-width: 100%;
}
@media screen and (max-width: 600px) {
    .ec-radio div {
      /* display: inline-block; */
      display: flex;
      flex-wrap: wrap;
    }
    .ec-radio label {
      width: 41%;
      margin-right: 5px;
    }
    .ec-radio input {
      width: 4%;
      margin-right: 10px;
      margin-bottom: 0px;
    }
}
.ec-select {
    margin-bottom: 5px;
}
.ec-select select {
    font-size: 18px;
}
.ec-label {
    font-size: 17px;
}
.ec-required {
    font-size: 13px;
    font-weight: bold;
}
.ec-imageGrid {
    padding: 5px 0;
}
.ec-imageGrid .ec-imageGrid__img {
    width: 25%;
}
.ec-imageGrid__content{
    padding-left: 20px;
}
.ec-imageGrid .ec-imageGrid__content .title {
    font-size: 18px;
    margin-bottom: 15px;
}
.ec-login {
    padding: 30px 5% 20px;
}
.ec-topicpath {
    border-bottom: initial;
    padding: initial;
    font-size: initial;
    margin-top: 5px;
}
.ec-totalBox .ec-totalBox__spec {
    margin: 15px 0 30px 0;
}
.ec-navlistRole .ec-navlistRole__navlist {
    margin: 0 30px 10px;
}
.ec-navlistRole .ec-navlistRole__item a {
    padding: 10px 10px;
}
.ec-welcomeMsg {
    margin: 0 0 20px 0;
    padding: 0 15px 10px;
}
.ec-favoriteRole {
    padding: 0 40px 0;
}
.ec-favoriteRole .ec-favoriteRole__header {
    margin: -20px 0 16px;
    padding-top: 20px;
}
.ec-role {
    padding-bottom: 0;
}
.ec-mypageRole {
    padding-left: 0;
    padding-right: 0;
    padding-bottom: 10px;
}
.ec-layoutRole .ec-layoutRole__contents {
    max-width: initial;
}
.ec-searchnavRole .ec-searchnavRole__infos {
    max-width: initial;
    margin-bottom: initial;
}
.ec-modal .ec-modal-wrap {
    padding: 40px 10px 0;
}
.ec-cartRole {
    padding: 0 5px 10px;
}
.ec-cartCompleteRole {
    padding-bottom: 20px;
}
.ec-orderRole {
    padding-bottom: 20px;
    font-size: 17px;
}
.ec-orderAccount .ec-orderAccount__account {
    padding-left: 10px;
}
.ec-orderAccount .ec-orderAccount__account p{
    margin-bottom: 5px;
}
.ec-orderConfirm .ec-input,.ec-orderDelivery__item .preferredDate {
    padding: 0 0 20px;
}
  
.ec-orderNumberOfGuest p {
    padding: 5px 0 15px 10px;
}
  
.ec-orderNumberOfGuest .ec-numberInput {
    padding-left: 20px;
}
  
.ec-orderNumberOfGuest__numbers {
    margin-bottom: 20px;
}
.ec-historyRole .ec-historyRole__contents {
    margin: 0 20px 0;
    padding: 10px 0px 10px;
}
.ec-historyRole .ec-historyRole__detail .ec-historyRole__detailTitle {
    font-size: 1.7rem;
    font-weight: initial;
}
.ec-historyRole .ec-historyRole__detail .ec-historyRole__detailPrice {
    font-size: 1.7rem;
    font-weight: initial;
}
.ec-registerRole {
    padding-bottom: 50px;
}
.ec-registerCompleteRole {
    padding-bottom: 50px;
}
.ec-contactRole {
    padding-bottom: 100px;
    padding-left: 30px;
    padding-right: 30px;
}
.ec-customerRole {
    max-width: initial;
    font-size: 16px;
}
.ec-withdrawRole, .ec-withdrawConfirmRole {
    margin: -50px auto 0;
    padding: 0 25px 50px;
  }
.ec-forgetCompleteRole {
    margin: 0 20px;
}
@media only screen and (min-width: 768px) {
    .ec-pageHeader{
      padding: 0 30px 0;
    }
    .ec-pageHeader h1, .ec-pageHeader .h1 {
        margin: 15px 0px 20px;
        font-size: 2.4rem;
    }
    .ec-input input, .ec-birth input, .ec-select input, .ec-telInput input, .ec-zipInput input, .ec-numberInput input, .ec-halfInput input {
        font-size: initial;
    }
    .ec-input select, .ec-birth select, .ec-select select, .ec-telInput select, .ec-zipInput select, .ec-numberInput select, .ec-halfInput select {
        font-size: initial;
    }
    .ec-input textarea, .ec-birth textarea, .ec-select textarea, .ec-telInput textarea, .ec-zipInput textarea, .ec-numberInput textarea, .ec-halfInput textarea {
        font-size: initial;
    }
    .ec-login .ec-login__link {
        margin-left: initial;
    }
    .ec-topicpath {
        padding: initial;
    }
    .ec-mypageRole {
        padding-left: initial;
        padding-right: initial;
        max-width: 1000px;
    }
    .ec-mypageRole .ec-pageHeader h1, .ec-mypageRole .ec-pageHeader .h1 {
        margin: 15px 0px 20px;
        padding: 5px 0 5px;
    }
    .ec-searchnavRole {
        max-width: initial;
    }
    .ec-searchnavRole .ec-searchnavRole__infos {
        padding-top: 5px;
    }
    .ec-searchnavRole .ec-searchnavRole__counter {
        padding-left: 10px;
    }
    .ec-modal .ec-modal-wrap {
        padding: 40px 10px 0;
    }
    .ec-orderRole .ec-orderRole__detail {
        margin-bottom: 30px;
    }
}


#quantity::-webkit-inner-spin-button,
#quantity::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0;
    -moz-appearance:textfield;
}

.ec-editRole{
  padding: 0 30px 0;
}



/* 必須マーク */
.required-mark, .ec-required {
    display: inline-block;
    margin-left: 12px;
    vertical-align: 2px;
    color: #DE5D50;
    font-size: 14px;
    font-weight: bold;
    border: 1.5px solid #DE5D50;
  }

/* offcanvas */

.offcanvas {
    position: fixed;
    bottom: 0;
    z-index: 1045;
    display: flex;
    flex-direction: column;
    max-width: 100%;
    visibility: hidden;
    background-color: #fff;
    background-clip: padding-box;
    outline: 0;
    transition: transform 0.3s ease-in-out;
  }
  .offcanvas-backdrop {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 1040;
    width: 100vw;
    height: 100vh;
    background-color: #000;
  }
  .offcanvas-backdrop.fade {
    opacity: 0;
  }
  .offcanvas-backdrop.show {
    opacity: 0.5;
  }
  .offcanvas-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem 1rem;
  }
  .offcanvas-header .btn-close {
    padding: 0.5rem 0.5rem;
    margin-top: -0.5rem;
    margin-right: -0.5rem;
    margin-bottom: -0.5rem;
  }
  .offcanvas-title {
    margin-bottom: 0;
    line-height: 1.42857142;
  }
  .offcanvas-body {
    flex-grow: 1;
    padding: 1rem 1rem;
    overflow-y: auto;
  }
  .offcanvas-start {
    top: 0;
    left: 0;
    width: 400px;
    border-right: 1px solid rgba(0, 0, 0, 0.2);
    transform: translateX(-100%);
  }
  .offcanvas-end {
    top: 0;
    right: 0;
    width: 400px;
    border-left: 1px solid rgba(0, 0, 0, 0.2);
    transform: translateX(100%);
  }
  .offcanvas-top {
    top: 0;
    right: 0;
    left: 0;
    height: 30vh;
    max-height: 100%;
    border-bottom: 1px solid rgba(0, 0, 0, 0.2);
    transform: translateY(-100%);
  }
  .offcanvas-bottom {
    right: 0;
    left: 0;
    height: 30vh;
    max-height: 100%;
    border-top: 1px solid rgba(0, 0, 0, 0.2);
    transform: translateY(100%);
  }
  .offcanvas.show {
    transform: none;
  }

  .innerBox h1{
    font-size:2em;
}

/* ナビ */

.header-nav{
    display:inline-block;
}

/* 検索BOX */

.searchCat ul,.searchArea ul{
    position: relative;
}
  
.searchCat ul li,.searchArea ul li, .searchArea p ,.searchArea li, .searchArea label{
  line-height: 1.5;
  padding: 15px 15px 15px 10px;
  list-style-type: none!important;
  border-bottom: 1.5px solid #000;
  font-size: 20px;
  justify-content: center;
  cursor:pointer;
}

.searchCat label{
    cursor:pointer;
}

.searchCat li i,.searchArea li i{
    padding: 0 15px 0 0;
    color:#000;
    position:static;
    
}

.offcanvas{
    padding: 10px;
}

.offcanvas-title {
    font-size: 18px;
    font-family: "Noto Serif JP";
    font-weight: 800;
}

.searchArea input {
	display: none;
}
.searchArea label {		/*タイトル*/
	display: block;
}
.searchArea label::before{		/*タイトル横の矢印*/
	content:"";
	width: 6px;
	height: 6px;
	border-top: 2px solid #000;
	border-right: 2px solid #000;
	-webkit-transform: rotate(45deg);
	position: absolute;
	top:calc( 50% - 3px );
	right: 20px;
	transform: rotate(135deg);
}
.accordion-Label,
.accordion-content {
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	transform: translateZ(0);
	transition: all 0.3s;
}
.accordion-content {		/*本文*/
	height: 0;
	padding:0 20px;
	overflow: hidden;
}
.accordion-toggle:checked + .accordion-Label + .accordion-content {	/*開閉時*/
	height: auto;
	padding:20px ;
	transition: all .3s;
}
.accordion-toggle:checked + .accordion-::before {
	transform: rotate(-45deg) !important;
}

/* トップページのボタン */

.loginBtnBox span, .btnLog span{
    display: inline-block;
    margin-inline: auto;
    max-inline-size: max-content;
}

/* トップページのご利用ガイド */
.TopGuide{
    width:100%;
}
.TGtitle{
    font-family: "Noto Serif JP";
    font-size: 29px;
    font-weight: 700;
    margin: 0 0 30px 0;
    padding: 0 0 7px 10px;
    border-bottom: 1.5px solid #999;
}
.TG-info{
    padding-left: 20px;
    line-height: 25px;
    margin-bottom: 30px;
}

.TGtitle-sub{
    padding: 0 0 30px 20px;
}

.TopGuide .TGcontainer{
    max-width:1000px;
    margin:0px auto;
    padding:20px 20px;
}

.TopGuide .TGcontent {
    padding:0 5%;
}

.TopGuide .TGcontent-img {
    width:100%;
    max-width: 450px;
    min-width: 200px;
    max-height: 300px;
    margin: 10px auto;
}

.TopGuide .TGimage{
    display:block;
    min-width: 200px;
    max-height: 300px;
    margin:0px auto;
    object-fit: contain;
}

.TopGuide .TGcontent-item {
    padding: 10px 0;
}

.TopGuide .TGheading{
    font-family: "Noto Serif JP";
    font-size: 23px;
    font-weight: 700;
    margin: 0 0 25px 0;
}

.TopGuide .TGexplain, .TGexplain-num {
    font-size: 17px;
    line-height: 28px;
}

.TopGuide .TGexplain {
    margin: 0 0 0 20px;
}

.TopGuide .TGexplain-sub {
    margin: 10px 0 40px 20px;
}

.TopGuide .TGexplain h1, .TGexplain-num h1{
    font-size: 18px;
    font-weight: bold;
    padding:10px 0;
    /* border-bottom: 1.5px solid #999; */
}

.TGexplain p, .TGexplain-num p {
    margin-bottom: 15px;
}

.TGexplain-num .num-info {
    padding-left: 30px;
}

.TopGuide .TGarrow{
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100px;
}

.TopGuide .TGarrow i{
    font-size: 25px;
    text-shadow: 2px 2px 4px #808080;
}

@media (min-width: 768px) {
    .TopGuide .TGcontainer .TGcontent {
        display: flex;
        align-items: center;
        justify-content: center;
    }
    .TopGuide .TGcontent-img {
        width:40%;
    }
    .TopGuide .TGcontent-item{
        width:60%;
        padding: 10px 0 10px 30px;
    }
}

/* 入力画面 */

.ec-login__actions{
    margin: 20px 10px;
}

.ec-dateRole {
    margin: 0 auto;
    padding: 0 20px 20px 20px;
    box-sizing: border-box;
    font-size: 17px;
    line-height: 1.6;
    color: #525263;
    -webkit-text-size-adjust: 100%;
    width: 100%;
    max-width: 600px;
    display: flex;
    flex-direction: column;
    margin-top: 0;
}

.inputInfo{
    margin: 0 0 30px;
    padding: 0 10px;
}

.inputInfo-Heading{
    background: #F3F3F3;
    padding: 8px 12px;
    font-size: 20px;
    font-weight: bold;
}

.ec-input p {
    font-size: 17px;
    padding: 8px 8px;
    font-weight: 500;
    line-height: 30px;
}

.ec-input h1, .ec-label {
    font-size: 18px;
    font-weight: 700;
    padding-bottom: 10px;
}

.ec-input h2 {
    font-size: 17px;
    font-weight: 700;
    padding-bottom: 10px;
}

.input-item {
    padding: 20px 0 10px;
}

.input-item .search-btn {
    text-align: right;
    margin-bottom: 10px;
}

.input-item .ec-inlineBtn {
    height: 50px;
    width: 120px;
    font-weight: 500;
}

.ec-pageHeader span, .inputInfo span, .ec-progress__label span,
 #ec-modal-header span, .customerInfo-content span,.ec-welcomeMsg span,
 .TGexplain span, .ec-breadcrumb span, .DeliveryChange span,
 .nav-star span, .btnContact span, .item-area span{
    display: inline-block;
}

.preview-product{
    border: solid 1.5px #000;
    font-size: 14px;
    padding: 10px;
    background-color: #ddd;
    margin-bottom: 10px;
}

.preview-none{
    font-size: 16px;
}

.preview-img{
    text-align: center;
}

.preview-img img {
    margin: auto;
  display: block;
}

.preview-name p {
    font-size: 20px;
    font-weight: 600;
    padding-left: 15px;
}

.preview-plan p, .preview-star p {
    font-size: 18px;
    font-weight: 500;
    padding-left: 15px;
}

.preview-loading{
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100px;
    font-size:20px;
}

.hide {
    display: none;
  }

.margin-bottom40{
    margin-bottom: 40px;
}

.invalid-feedback {
    font-size: 18px;
    font-weight:bold;
}

.ec-progress__label{
    padding: 3px;
}

.ec-blockBtn--action {
    margin: 30px 0;
}

.ec-blockBtn--cancel {
    margin: 30px auto;
    width: 170px;
    font-size: 15px;
}

.ec-orderConfirm .ec-input textarea{
    height: 180px;
    font-size: 17px;
    margin-top: 10px;
}

.ec-orderNumberOfGuest__numbers select{
    width: 100px;
    height:60px;
    margin:10px;
    padding: 5px;
    border: 1px solid #d0d0d0;
    border-radius: 4px;
    background-color: #fff;
    color: #333333;
    font-size: 19px;
    cursor: pointer;
    text-align: center;
    position:  relative; 
}

.select-area {
    display: inline-block;
    position: relative;
    margin: 0em 0em 0em 0em;
    /* float: left; */
  }

.select-area::after {
    position: absolute;
    right: 18px;
    height: 8px;
    width: 12px;
    top: 37px; 
    background-color: #535353;
    clip-path: polygon(0 0, 100% 0, 50% 100%);
    content: '';
    pointer-events: none;
}

.child-info{
    text-align: center;
    margin-bottom: 30px;
}

.child-info a{
    border-bottom: 1px solid #0d6efd;
    /* text-decoration:underline; */
    color:#0d6efd;
}
.child-info i{
    margin-right: 5px;
}

.star-info{
    text-align: center;
    margin: 20px 0 30px;
}

.star-info a{
    border-bottom: 1px solid #0d6efd;
    /* text-decoration:underline; */
    color:#0d6efd;
}
.star-info i{
    margin-right: 5px;
}

.numberInputArea{
    text-align: center;
}

.numberInputAreaBlock{
    display: inline-block;
    text-align: right;
}

.last-info{
    width: 90%;
    margin:0 auto;
    margin-bottom: 30px;
}
.last-info p{
    display: inline-block;
    margin-inline: auto;
    max-inline-size: max-content;
}
.last-info a{
    text-decoration:underline;
    color:#0d6efd;
}

/* 申込最終確認ページ */
.customerInfo-title, .orderNo .orderNo-title{
    font-size: 18px;
    font-weight: 700;
    padding-bottom: 10px;
}

.customerInfo-content, .orderNo .orderNo-Num{
    font-size: 17px;
    padding: 0 0 20px 10px;
}

.ec-rectHeading h2{
    margin-top: 0;
}

.PasswordCheck{
    margin-bottom: 30px;
}

.PasswordInput{
    padding: 0 10px 0 20px;
}

.PasswordInput .checkform{
    padding: 20px 0 20px 20px;
}

.password .ec-input input{
    width: 100%;
    max-width: 400px;
    margin: 10px 0;
}

.password .ec-input input::placeholder{
    font-size: clamp(11px, 3.8vw, 16px);
}

.password .ec-errorMessage {
    margin-top: 3px;
    font-size: 16px;
    font-weight: bold;
    color: #DE5D50;
  }

@media only screen and (min-width: 768px) {
    .ec-orderRole .ec-orderRole__summary {
        width: 35%;
        padding: 0 16px;
    }
}

/* 完了ページ */

.ec-reportHeading h2, .ec-cartCompleteRole p {
    text-align:left;
    margin-inline: auto;
    max-inline-size: max-content;
}
.ec-cartCompleteRole .ec-reportDescription a{
    text-decoration:underline;
    color:#0d6efd;
}

@media only screen and (min-width: 768px) {
    .ec-cartCompleteRole .ec-off4Grid__cell{
        width: 33.333%;
    }
}

.Delivery-info {
    margin-bottom: 16px;
    padding-left: 10px;
}

.DeliveryChange{
    /* font-weight: bold; */
    margin: 0 0 20px 10px;
}

.ec-addressList__address p {
    margin-bottom: 8px;
}

.ec-addressList .ec-addressList__remove {
    padding: 8px;
}

.ec-addressList .ec-addressList__address {
    padding: 8px;
    width: 85%;
}

.serchBoxNavi{
    width: 90%!important;
    margin: 10px auto 10px !important;
}

.itemDetail-article h2{
    font-size: 18px;
    font-weight: 700;
    padding: 30px 5px 0 0;
}

.ec-role {
    font-size:18px;
    line-height: 33px;
}

.ec-login p{
    font-size:18px;
    font-weight:600;
}

.ec-forgotRole .ec-forgotRole__intro {
    font-size: 18px;
}
  
.btnReset {
    color: #fff;
    background: #777;
    border-radius: 4px;
    display: block;
    text-align: center;
    padding: 10px 10px;
    margin: 15px 10px 0;
    
}

@media only screen and (min-width: 960px) {
    .btnReset {
        padding: 5px 10px;
        margin: 5px 10px 0;
        margin-right: auto;
    }
}

.clear-category,.clear-area {
    position: absolute;
    right: 0px;
    color: #aaa;
    z-index:1;
    padding:15px 10px 15px 5px;
    cursor:pointer;
}

.clear-point1,.clear-point2 {
    position: absolute;
    right: -7px;
    color: #aaa;
    z-index:1;
    padding:15px 10px 15px 5px;
    cursor:pointer;
}

.clear-keywords {
    position: absolute;
    right: -2px;
    color: #aaa;
    z-index:1;
    padding:15px 10px 15px 5px;
    cursor:pointer;
}

.error-message{
    margin:10px 0;
    color:#ED1A3D;
    font-size: 18px;
    font-weight: 500;
}

.card-category {
    margin: 5px 5px 5px 0;
    padding: 7px 10px;
  }

.card-category a{
    font-size: 13px;
    color: #0790DF;
  }

.ec-topicpath span{
    display: inline-block;
    margin-top: 7px;
}
@media only screen and (min-width: 960px) {
    .btnNone {
        display: inline-block;
        font-size: 1.8rem;
        width: 80%;
        margin: 0 auto;
    }
}

.nav-star {
    font-size: 15px;
    font-weight: 600;
    padding-top: 13px;
  }
  
.nav-star i {
    color: #FFBE26;
}

.ec-orderNumberOfGuest__numbers p ,.PasswordInput, .ec-numberInput{
    font-size:17px;
    font-weight:500;
    line-height:30px;
}

/* GoogleMaps */
.itemTable iframe {
    width: 100%;
    height: 400px;
}

.guideBtn {
    width: 280px;
    margin: 0 auto;
}

@media screen and (max-width: 960px) {
    .header-nav ul li {
        margin: 0;
        width: 100%;
        text-align: center;
        border-bottom: 1.5px solid #000;
        line-height: 1.5;
        padding: 15px;
        list-style-type: none !important;
    }
}

#headerNav .nav-star{
    font-size: 14px;
    text-align: center;
    padding: 13px 20px 0;
    
}

@media screen and (max-width: 960px) {
    #headerNav .nav-star{
        font-size: 20px;
        text-align: center;
        margin-bottom: 20px;
    }
}

.ec-historyRole .ec-historyRole__detail {
    border-top: none;
    width: 100%;
}

.ec-historyRole__detail .ec-historyListHeader__action {
    margin: 5px 5% 5px 0;
    text-align: right;
}

@media screen and (min-width: 760px) {
  .ec-historyRole .ec-historyRole__detail {
    width: 50%;
    border-top: none;
  }
  .ec-historyRole .ec-historyRole__header {
    width: 50%;
    margin-left: 50px;
  }

  .ec-historyRole__detail .ec-historyListHeader__action {
    text-align: right;
    margin: 20px 20% 0 0;
  }

}

.ec-layoutRole .ec-layoutRole__contentsHistory {
    margin-right: auto;
    margin-left: auto;
    width: 100%;
    max-width: 1000px;
}

@media screen and (min-width: 768px) {
    .ec-orderRole .ec-orderRole__detailHistory {
        padding: 0 16px;
        margin-bottom: 30px;
        width: 100%;
        max-width: 800px;
        margin: 0 auto;
    }
}

.ec-definitions dt {
    vertical-align: top;
}

.ec-definitions dd {
    padding-left: 10px;
}

.ec-definitions {
    margin: 10px 0;
}

.ec-orderDelivery .ec-orderDelivery__title {
    padding: 5px 0 5px 10px;
}

.ec-orderDelivery .ec-orderDelivery__address {
    margin: 10px 0 18px 15px;
}

.ec-orderConfirm p{
    padding: 0 10px;
    margin-bottom: 10px;
}

.serchBtn{
    display: inline-flex;
    align-items: center;
    position: relative;
    margin: 7px 5px;
}

.ec-breadcrumb{
    margin: 0 auto;
    padding: 10px 0 0 10px;
    max-width: 1350px;
    line-height: 25px;
    font-size: 15px;
}

.ec-breadcrumb a {
    text-decoration: underline;
}

.item-area a{
    text-decoration: underline;
}

.ec-login__link{
    text-align: center;
}

.mypage .ec-role_back {
    text-align: center;
    margin-bottom:50px;
}

.point-table {
    margin: auto;
    width: fit-content;
    box-sizing: border-box;
    width: 700px;
    margin-bottom: 50px;
}

.point-table .point-info{
    margin-bottom: 10px;
}

.point-table table {
    margin: auto;
    padding: 0 10px;
    width: 100% ;
}

.point-table thead th {
    background: #efefef;
    padding: 10px 10px;
    text-align: center;
}

.point-table tbody td {
    font-size: 1.5rem;
    padding: 10px 10px;
    background: #F9F9F9;
    text-align: center;
    border-top: 0.5px solid #000;
    border-bottom: 0.5px solid #000;
}

.point-table .date {
    text-align: left;
    width: 23%;
}

.point-table .status {
    width: 15%;
}

.point-table .product {
    width: 47%;
}

.point-table .point {
    width: 15%;
}

@media screen and (max-width: 800px) {
    .point-table {
        padding:0 10px;
        min-width: 300px;
        width: 330px;
    }

    .point-table thead {
        display: inline-block;
        background: #efefef;
        margin-bottom: 30px;
    }

    .point-table th, td {
        display: inline-block;
    }

    .point-table thead th{
        padding: 2px 15px;
    }

    .point-table tbody td {
        border-top: none;
        border-bottom: none;
    }

    .point-table td.line1{
        border-top:1px solid #000;
    }

    .point-table td.line2{
        border-bottom:1px solid #000;
        margin-bottom: -1px;
        height: 55px;
    }

    .point-table thead th.row1, .point-table td.row1{
        text-align: left;
        width: 65%;
    }

    .point-table thead th.row2, .point-table td.row2{
        text-align: right;
        width: 35%;
    }

    .point-table td.point{
        font-size: 20px;
    }
}

.contents_table {
    padding:0 50px;
    margin: auto;
    width: fit-content;
    box-sizing: border-box
}

.contents_table h2 {
    margin: 0 0 10px 0;
}

.contents_table thead th {
    background: #efefef;
    padding: 10px 10px;
    text-align: center;
}

.contents_table tbody td {
    font-size: 18px;
    font-weight: 500;
    padding: 12px 10px;
    background: #F9F9F9;
}

@media screen and (max-width: 960px) {
    .contents_table {
        padding:0px;
    }

    .contents_table th, td {
        display: block;
        width: 100%;
    }

    .contents_table th.name{
        text-align: left;
        padding: 5px 15px;
    }

    .contents_table td.name{
        text-align: left;
        border-top:1px solid #000000;
        background: #efefef;
    }

    .contents_table th.info{
        text-align: right;
        padding: 1px 15px;
        border:1px solid #ffffff;
        background: #F9F9F9;
    }

    .contents_table td.info{
        text-align: right;
        border:1.5px solid #ffffff;
    }
}

.contents_list{
    font-family: "Noto Serif JP";
    /* padding:20px 50px 0;
    margin: 0 auto;
    width: 90%; */
}
.contents_list h2 {
    font-size: 20px;
    font-weight: 700;
    margin: 0 0 10px 0;
}
.contents_list dl{
    padding: 5px;
    background: #F9F9F9;
}
.contents_list dt {
    padding: 10px 0  0 10px;
    font-size: 18px;
}
.contents_list dt li{
    list-style-type: disc;
}
.contents_list dd {
    padding: 0 15px 10px 50px;
    font-weight: 600;
}
.contents_list span {
    display: inline-block;
}
@media screen and (max-width: 960px) {
    .contents_list{
        padding:0;
    }
    .contents_list h2 {
        font-size: 17px;
    }
    .contents_list dl{
        background: #efefef;
    }
    .contents_list dt {
        font-size: 15px;
        font-weight: 800;
    }
    .contents_list dd {
        font-size: 14px;
        font-weight: 600;
        line-height: 22px;
        padding-left: 40px;
    }
}

.help-page{
    min-height: 500px;
    padding: 10px;
    font-size: 14px;
    font-weight: 400;
}

.help-page h1 {
    font-size: 24px;
    padding: 10px 0px 40px;
    font-family:"Noto Serif jp" ;
    font-weight: 800;
}

.help-page h2 {
    font-size: 22px;
    padding-bottom: 30px;
    font-family:"Noto Serif jp" ;
    font-weight: 700;
}

.agreementBox{
    max-width: 900px;
    margin: 0 auto;
    padding: 0 15px;
    box-sizing: border-box;
}

.agreementBox section{
    padding: 0 0 30px 0;
}

.agreementBox h2 {
    font-size: 16px;
    padding-bottom: 10px;
    font-family:"Noto Sans jp" ;
    font-weight: 500;
}

.agreementBox ol li{
    list-style: decimal;
    font-size: 14px;
    margin: 0 0 10px 25px;
}

.agreementBox ul li{
    list-style: disc;
    font-size: 14px;
    margin: 0 0 10px 25px;
}

.agreementBox ul.sub li{
    list-style: disc;
    font-size: 14px;
    margin: 0 0 5px 45px;
}

.agreementBox p {
    font-size: 14px;
    font-family:"Noto Sans jp" ;
    font-weight: 400;
}

.infoBox{
    max-width: 900px;
    margin: 0 auto 30px;
    padding: 0 15px;
    box-sizing: border-box;
}

.infoBox h1 {
    padding: 10px 0px 40px;
}

.infoBox section{
    padding: 0 0 15px 0;
}

.infoBox h2 {
    font-size: 24px;
    padding: 20px 0 5px 0;
    margin-bottom: 25px;
    font-family:"Noto Serif jp" ;
    font-weight: 700;
    border-bottom: 1px solid #999;
}

.infoBox h3 {
    font-size: 20px;
    margin-top: 10px;
    padding-bottom: 15px;
    font-family:"Noto Serif jp" ;
    font-weight: 700;
    text-decoration: underline 1px #999;
    text-underline-offset: 5px;
}

.infoBox h4 {
    font-size: 16px;
    padding-bottom: 15px;
    font-family:"Noto Sans jp" ;
    font-weight: 600;
}

.infoBox ul li{
    list-style: disc;
    font-size: 15px;
    margin: 0 0 15px 20px;
}

.infoBox ol li{
    list-style: decimal;
    font-size: 15px;
    margin: 0 0 5px 45px;
}

.infoBox p {
    font-size: 15px;
    font-family:"Noto Sans jp" ;
    font-weight: 400;
    line-height: 22px;
}

.contentsList {
    margin: 0 auto 40px;
    border-bottom: 1px solid #999;
    max-width: 400px;
    padding-bottom: 10px;
}

.contentsList h3 {
    text-decoration: none;
    border-bottom: 1px solid #999;
    padding-bottom: 5px;
    margin: 0 0 15px 0;
    font-family:"Noto Serif jp" ;
    font-size: 20px;
    font-weight: 700;
}

ul.contentsList1 {
    margin-left: 30px;
}

ul.contentsList1 li{
    list-style: none;
    margin: 0 0 20px 0;
}

ul.contentsList1 a{
    font-size: 16px;
    font-family:"Noto Serif jp" ;
    font-weight: 700;
    line-height: 22px;
    text-decoration: underline 1px #999;
    text-underline-offset: 5px;
    text-decoration-skip-ink: none;
}

ul.contentsList1 i{
    text-decoration: underline 1px #999;
    text-underline-offset: 5px;
    text-decoration-skip-ink: none;
}

ul.contentsList2 {
    margin-left: 40px;
}