#carlease {
  background: linear-gradient(180deg, #fff 0%, #fff 118.7rem, #f9f9f9 118.7rem, #c4d7d1 100%);
  padding: 6.3rem 0 7.2rem;
  @media (width >= 961px) {
    background: linear-gradient(180deg, #fff 0%, #fff 93.9rem, #f9f9f9 93.9rem, #c4d7d1 100%);
    padding: 9rem 0 10rem;
  }

  .intro {
    margin: 0 auto;
    padding: 0 2rem;
    width: 36rem;
    @media (width >= 961px) {
      width: 96rem;
    }

    .lead {
      font-size: 2.1rem;
      line-height: 1.8;
      margin: 0 0 2.4rem;
      padding: 0;
      @media (width >= 961px) {
        font-size: 2.4rem;
      }
      
      span {
        background: #E6E61F;
        padding: 0 .5rem;
        &:nth-of-type(2) {
          padding: 0 .5rem 0 0;
        }
      }
    }

    .desc {
      font-size: 1.6rem;
      line-height: 1.8;
      margin: 0 0 4rem;
    }

    .link-bt {
      background: #4B4B4B;
      border-radius: 4.1rem;
      color: #fff;
      height: 8.2rem;
      line-height: 1.8;
      margin: 0 auto;
      padding: 1.2rem 0 1.2rem 2.8rem;
      width: 100%;
      @media (width >= 961px) {
        border-radius: 3rem;
        height: 6rem;
        line-height: 5.8rem;
        margin: 0 auto 0 0;
        padding: 0 0 0 3rem;
        width: 41.3rem;
      }

      img {
        transform: translateY(-50%) rotate(-45deg);
      }

      &:hover {
        background: #fff;
        color: #1a1a1a;

        img {
          transform: translateY(-50%) rotate(0);
        }
      }
    }
  }
}

#special {
  background: #F9F9F9;
  padding: 7.2rem 0;
  @media (width >= 961px) {
    padding: 8rem 0 9.5rem;
  }

  .heading {
    margin: 0 auto 3.2rem;
    padding: 0 2rem;
    width: 36rem;
    @media (width >= 961px) {
      width: 96rem;
    }

    p {
      background: #E6E61F;
      border: .2rem solid #1a1a1a;
      border-radius: 2.1rem;
      font-size: 1.8rem;
      font-weight: 700;
      height: 4.2rem;
      line-height: 3.8rem;
      margin: 0 auto .8rem;
      position: relative;
      text-align: center;
      width: 13.2rem;
      @media (width >= 961px) {
        font-size: 2.4rem;
        padding: 0 0 0 .3rem;
        width: 17.5rem;
      }
      
      &::before {
        background: #E6E61F;
        bottom: -.2rem;
        content: "";
        display: block;
        height: .3rem;
        left: 6rem;
        position: absolute;
        width: .5rem;
        @media (width >= 961px) {
          left: 8rem;
        }
      }

      &::after {
        background: #1a1a1a;
        bottom: -.7rem;
        content: "";
        display: block;
        height: 1.2rem;
        left: 6.5rem;
        position: absolute;
        width: .2rem;
        @media (width >= 961px) {
          left: 8.5rem;
        }
      }
    }

    h2 {
      font-size: 2.4rem;
      line-height: 1.8;
      margin: 0 auto 3.2rem;
      text-align: center;
      @media (width >= 961px) {
        font-size: 3.2rem;
      }
    }
  }

  .list {
    counter-reset: number 0;
    margin: 0 auto;
    padding: 0 2rem;
    width: 36rem;
    @media (width >= 961px) {
      display: flex;
      flex-wrap: wrap;
      justify-content: space-between;
      width: 96rem;
    }
    
    > div {
      margin: 0 0 3.2rem;
      position: relative;
      @media (width >= 961px) {
        margin: 0 0 4.4rem;
        width: 44.8rem;
      }

      &::before {
        color: #E6E61F;
        content: counter(number, decimal-leading-zero)"";
        counter-increment: number 1;
        font-size: 6rem;
        font-weight: 700;
        left: -.3rem;
        line-height: 1;
        margin: 0;
        position: absolute;
        top: 17rem;
        z-index: 10;
        @media (width >= 961px) {
          font-size: 8rem;
          top: 24rem;
        }
      }

      &:last-of-type {
        margin: 0;
      }

      img {
        border-radius: 1rem;
        filter: drop-shadow(0 .4rem .7rem #C9C9C9);
        height: auto;
        margin: 0 0 1.6rem;
        width: 100%;
        @media (width >= 961px) {
          margin: 0 0 2.2rem;
        }
      }

      h3 {
        font-size: 1.8rem;
        line-height: 1.8;
        margin: 0 0 .5rem;
        @media (width >= 961px) {
          font-size: 2.4rem;
        }
      }

      p {
        font-size: 1.6rem;
        line-height: 1.8;
        margin: 0;
      }
    }
  }
}

#pack {
  margin: 0;
  padding: 6.4rem 0;
  @media (width >= 961px) {
    margin: 0;
    padding: 10rem 0 8rem;
  }

  .sub-header {
    h2 {
      font-size: 2.3rem;
      font-weight: 500;
      margin: 0 0 1.4rem;
      padding: 0 0 0 2rem;
      white-space: nowrap;
      @media (width >= 961px) {
        font-size: 3.2rem;
        margin: 0 0 1rem;
        padding: 0 0 0 3rem;
      }
    }

    p {
      font-size: 1.6rem;
      line-height: 1.8;
      margin: 0 0 5.5rem;
      @media (width >= 961px) {
        margin: 0 0 6.5rem;
      }
    }
  }

  .intro {
    margin: 0 auto;
    padding: 0 2rem;
    width: 36rem;
    @media (width >= 961px) {
      width: 96rem;
    }
    
    table {
      border: .1rem solid #7E7E7E;
      border-collapse:  collapse;
      margin: 0 0 6.8rem;
      position: relative;
      width: 100%;

      tr {
        th {
          border: .1rem solid #7E7E7E;
          font-size: 1.2rem;
          height: 6.3rem;
          line-height: 1.8;
          text-align: center;
          vertical-align: middle;
          width: 25%;
          @media (width >= 961px) {
            font-size: 1.6rem;
            width: 24rem;
          }
          &:first-of-type {
            border: .1rem solid #fff;
            border-bottom: .1rem solid #7E7E7E;
            @media (width >= 961px) {
              width: 20rem;
            }
            p {
              background: #FA7618;
              border-radius: 1.5rem;
              color: #fff;
              font-size: 1.4rem;
              height: 3rem;
              left: 25%;
              line-height: 2.8rem;
              margin: 0;
              padding: 0 0 0 .5em;
              position: absolute;
              text-align: center;
              top: -3rem;
              width: 25%;
              @media (width >= 961px) {
                font-size: 1.6rem;
                left: 29rem;
                padding: 0 0 0 .5em;
                top: -1.5rem;
                width: 10.2rem;
              }
            }
          }
          &:nth-of-type(2) {
            border-top: .6rem solid #E6E61F;
            border-left: .6rem solid #E6E61F;
            border-right: .6rem solid #E6E61F;
            background: #E6E61F;
          }
          &:nth-of-type(3) {
            background: #C6C6C6;
          }
          &:nth-of-type(4) {
            background: #DFDFDF;
          }
        }

        td {
          border: .1rem solid #7E7E7E;
          font-size: 1.2rem;
          height: 6.9rem;
          text-align: center;
          vertical-align: middle;
          width: 25%;
          @media (width >= 961px) {
            font-size: 1.6rem;
          }

          &:first-of-type {
            background: #FAFAF7;
          }

          &:nth-of-type(2) {
            border-left: .6rem solid #E6E61F;
            border-right: .6rem solid #E6E61F;
          }

          .maru {
            height: 2.5rem;
            width: 2.5rem;
          }
          .batsu {
            height: 2.1rem;
            width: 2.1rem;
          }
        }

        &:last-of-type {
          td {
            &:nth-of-type(2) {
              border-bottom: .6rem solid #E6E61F;
            }
          }
        }
      }
    }
    > div {
      background: #F9F9F9;
      overflow: hidden;
      margin: 0 0 3.2rem;
      padding: 5rem 2rem 3.2rem;
      position: relative;
      @media (width >= 961px) {
        padding: 5rem 4rem;
      }

      &::before {
        background: #E6E61F;
        border-radius: 1.6rem;
        content: "";
        display: block;
        height: 4.8em;
        left: 2rem;
        position: absolute;
        top: -2.4rem;
        width: 10rem;
        @media (width >= 961px) {
          left: 4rem;
        }
      }

      &:last-of-type {
        margin: 0;
      }

      h3 {
        font-size: 2.4rem;
        line-height: 1.8;
        margin: 0 0 1rem;
        @media (width >= 961px) {
          margin: 0 0 .8rem;
        }
      }

      > p {
        font-size: 1.8rem;
        line-height: 1.8;
        margin: 0 0 1.3rem;
        @media (width >= 961px) {
          margin: 0 0 1rem;
        }
      }
      
      > ul {
        background: #fff;
        border-radius: .8rem;
        list-style: none;
        margin: 0 0 3.2rem;
        padding: 1rem;
        position: relative;
        text-align: left;
        width: 100%;
        @media (width >= 961px) {
          margin: 0 0 3.7rem;
          padding: 2.5rem;
        }

        li {
          font-size: 1.6rem;
          line-height: 1.8;
          margin: 0 0 1.2rem;
          padding: 0 0 0 2.8rem;
          position: relative;

          &:last-of-type {
            margin: 0;
          }

          img {
            display: block;
            height: 1.8rem;
            left: 0;
            margin: 0 1rem 0 0;
            object-fit: cover;
            position: absolute;
            top: 50%;
            transform: translateY(-50%);
            width: 1.8rem;
          }
        }
      }

      h4 {
        font-size: 1.8rem;
        line-height: 1.8;
        margin: 0 0 1.6rem;
        @media (width >= 961px) {
          font-size: 2.4rem;
          margin: 0 0 2.4rem;
        }
      }

      > div {
        display: flex;
        flex-wrap: wrap;
        margin: 0 0 2.2rem;
        row-gap: 1.2rem;
        justify-content: space-between;
        @media (width >= 961px) {
          margin: 0 0 4rem;
        }

        > div {
          width: 9rem;
          @media (width >= 961px) {
            width: 12.6rem;
          }

          > img {
            height: auto;
            margin: 0 0 .4rem;
            width: 100%;
            @media (width >= 961px) {
               margin: 0 0 1rem;
            }
          }

          > p {
            font-size: 1.4rem;
            line-height: 1.8;
            margin: 0;
            text-align: center;
            @media (width >= 961px) {
              font-size: 1.6rem;
            }            
          }
        }

        > img {
          height: auto;
          margin: 0;
          vertical-align: bottom;
          width: 100%;
          @media (width >= 961px) {
            width: 26.4rem;
          }
        }

        &:nth-of-type(2) {
          row-gap: 1rem;
          margin: 0;
        }
      }
    }
  }
}
#store {
  padding: 7.2rem 0;
  @media (width >= 961px) {
    padding: 11rem 0 12rem;
  }

  .list {
    margin: 0 auto;
    padding: 0 2rem;
    width: 36rem;
    @media (width >= 961px) {
      display: flex;
      flex-wrap: wrap;
      justify-content: space-between;
      width: 96rem;
    }

    > div {
      background: #F9F9F9;
      border-radius: 1rem;
      margin: 3.2rem 0 0;
      padding: 2rem;
      @media (width >= 961px) {
        margin: 2.1rem 0 0;
        padding: 3.2rem 4rem;
        width: 45rem;

        &:nth-child(-n+2) {
          margin: 0;
        }

      }

      .sub-header {
        padding: 0;
        width: 100%;

        h3 {
          font-size: 2rem;
          padding: 0 0 0 2.4rem;
          @media (width >= 961px) {
            font-size: 2.4rem;
            padding: 0 0 0 3rem;
            &::before {
              top: 1.6rem;
            }
          }
        }
      }

      .access {
        > div {
          dl {
            display: flex;
            font-size: 1.7rem;
            line-height: 1.8;
            margin: 0 0 1rem;
            &:last-of-type {
              margin: 0 0 1.6rem;
            }

            dt {
              margin: 0;
              width: 8.2rem;
            }
        
            span {
              margin: 0 1rem 0 0;
            }
        
            dd {
              margin: 0;
            }
          }
        }

        .map {
          border-radius: .8rem;
          height: 19.7rem;
          margin: 0 0 2.4rem;
          position: relative;
          width: 100%;
          @media (width >= 961px) {
            height: 24.2rem;
            margin: 0;
          }

          iframe {
            height: 9.85rem;
            left: 50%;
            position: absolute;
            top: 50%;
            transform: translate(-50%, -50%) scale(2);
            width: 14rem;
            @media (width >= 961px) {
              height: 100%;
              position: static;
              transform: translate(0, 0) scale(1);
              width: 100%;
            }
          }
        }
      }
    }
  }
}
