@charset "utf-8";

body {
    padding-top: 0;
}
#header {
    top: 0;
}

/* ────────────────────── *
 *                                              *
 * メインビジュアル                             *
 *                                              *
 * ────────────────────── */

#mainvisual {
    position: relative;
}
#mainvisual img {
    width: 100%;
}
#mainvisual .inner {
    color: #fff;
    text-align: center;
    width: 100.0rem;
    margin: 0 auto;
    position: absolute;
    right: 50%;
    top: 50%;
    z-index: 10;
    transform: translate(50%, -50%);
}
#mainvisual .inner h1 {
    font-size: 4.4rem;
    font-weight: 500;
    margin-bottom: 4.0rem;
}
#mainvisual .inner h1 span {
    display: inline-block;
    position: relative;
}
#mainvisual .inner h1 span:after {
    content: "";
    background: url("../../member/image/free@2x.png") no-repeat center center / cover;
    width: 13.8rem;
    height: 13.8rem;
    position: absolute;
    left: calc(100% - 3.0rem);
    bottom: 1.0rem;
}
#mainvisual .inner p#txt-outline-01 {
    font-size: 2.0rem;
    line-height: 1.4;
    margin-bottom: 2.0rem;
}
#mainvisual .inner p#txt-outline-02 {
    font-size: 1.6rem;
    line-height: 2.5;
    margin-bottom: 3.0rem;
}

/* ボタン */
#mainvisual .inner ul.btn {
    font-size: 1.6rem;
    font-weight: 500;
    text-align: center;
    width: 54.0rem;
    margin: 0 auto;
}
#mainvisual .inner ul.btn li {
    margin-bottom: 2.0rem;
}
#mainvisual .inner ul.btn li:last-child {
    margin-bottom: 0;
}

/* 通常ボタン */
#mainvisual .inner ul.btn li a {
    color: #000;
    background: #fff;
    display: block;
    padding: 1.5rem;
    position: relative;
    transition: background-image .5s, background-color .5s;
}
#mainvisual .inner ul.btn li a:before {
    content: "";
    background-image: url('data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22utf-8%22%3F%3E%3Csvg%20version%3D%221.1%22%20id%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20x%3D%220px%22%20y%3D%220px%22%20viewBox%3D%220%200%2020%2020%22%20style%3D%22enable-background%3Anew%200%200%2020%2020%3B%22%20xml%3Aspace%3D%22preserve%22%3E%3Cpolygon%20points%3D%227.7%2C10%200%2C15.7%200%2C18.2%2011%2C10%200%2C1.9%200%2C4.3%20%22%2F%3E%3C%2Fsvg%3E');
    background-repeat: no-repeat;
    background-position: center center;
    width: 2.0rem;
    height: 2.0rem;
    position: absolute;
    left: 1.0rem;
    top: 50%;
    transform: translateY(-50%);
}
#mainvisual .inner ul.btn li a:hover {
    color: #fff;
    background-color: #000;
}
#mainvisual .inner ul.btn li a:hover:before {
    background-image: url('data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22utf-8%22%3F%3E%3Csvg%20version%3D%221.1%22%20id%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20x%3D%220px%22%20y%3D%220px%22%20viewBox%3D%220%200%2020%2020%22%20style%3D%22enable-background%3Anew%200%200%2020%2020%3B%22%20xml%3Aspace%3D%22preserve%22%3E%3Cstyle%20type%3D%22text%2Fcss%22%3E%20.st0%7Bfill%3A%23FFFFFF%3B%7D%3C%2Fstyle%3E%3Cpolygon%20class%3D%22st0%22%20points%3D%227.7%2C10%200%2C15.7%200%2C18.2%2011%2C10%200%2C1.9%200%2C4.3%20%22%2F%3E%3C%2Fsvg%3E');
}

/* 入会ボタン */
#mainvisual .inner ul.btn li.entry a {
    font-size: 1.8rem;
    color: #fff;
    background: #000;
    padding: 2.5rem;
}
#mainvisual .inner ul.btn li.entry a:before {
    background-image: url('data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22utf-8%22%3F%3E%3Csvg%20version%3D%221.1%22%20id%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20x%3D%220px%22%20y%3D%220px%22%20viewBox%3D%220%200%2020%2020%22%20style%3D%22enable-background%3Anew%200%200%2020%2020%3B%22%20xml%3Aspace%3D%22preserve%22%3E%3Cstyle%20type%3D%22text%2Fcss%22%3E%20.st0%7Bfill%3A%23FFFFFF%3B%7D%3C%2Fstyle%3E%3Cpolygon%20class%3D%22st0%22%20points%3D%227.7%2C10%200%2C15.7%200%2C18.2%2011%2C10%200%2C1.9%200%2C4.3%20%22%2F%3E%3C%2Fsvg%3E');
}
#mainvisual .inner ul.btn li.entry a:hover {
    background-color: #00a7e3;
}
#mainvisual p#scroll {
    width: 4.6rem;
    position: absolute;
    right: 50%;
    bottom: 0;
    z-index: 10;
    transform: translateX(50%);
}

/* ────────────────────── *
 *                                              *
 * 会員サービス紹介                             *
 *                                              *
 * ────────────────────── */

#introduction {
    background: #e8eff0;
    padding: 13.0rem 3.0rem 12.0rem;
}
#introduction > h2 {
    font-size: 2.8rem;
    text-align: center;
    margin: 0 auto 3.0rem;
}
#introduction ol {
    margin: 0 auto 10.0rem;
}
#introduction ol li {
    position: relative;
}
#introduction ol li p.image img {
    width: 100%;
}
#introduction ol li .plate {
    width: 33.0rem;
    position: absolute;
    top: 5.0rem;
    box-sizing: border-box;
}
#introduction ol li .plate.left {
    left: 5.0rem;
}
#introduction ol li .plate.right {
    right: 5.0rem;
}
#introduction ol li .plate .block {
    background: #fff;
    padding: 4.5rem 3.0rem 3.0rem;
    position: relative;
}
#introduction ol li .plate .block h3 {
    width: 10.0rem;
    margin-bottom: 10.0rem;
}
#introduction ol li .plate .block dl dt {
    font-size: 2.4rem;
    font-weight: 500;
    color: #0081c6;
    letter-spacing: 0.05em;
    margin-bottom: 1.5rem;
}
#introduction ol li .plate .block dl dd {
    font-size: 1.6rem;
    line-height: 1.875;
}
#introduction ol li .plate .block.benefit {
    margin-top: 1.5rem;
}
#introduction ol li .plate .block.benefit:before {
    content: "";
    background: url("../../member/image/icon-plus@2x.png") no-repeat center center / cover;
    width: 3.2rem;
    height: 3.2rem;
    position: absolute;
    right: 50%;
    top: -2.35rem;
    transform: translateX(50%);
}
#introduction ol li .plate .block.benefit p.icon {
    width: 13.4rem;
}
#introduction ol li .plate .block.benefit p.txt {
    font-size: 1.6rem;
    line-height: 1.875;
}

/* 特典 */
#introduction #benefit {
    background: #fff;
    text-align: center;
    width: 100.0rem;
    padding: 6.0rem;
    margin: -6.0rem auto 6.0rem;
    position: relative;
    z-index: 20;
    box-sizing: border-box;
}
#introduction #benefit h4 {
    font-size: 2.8rem;
    letter-spacing: 0.1em;
    margin: 0 auto 3.0rem;
}
#introduction #benefit ul {
    font-size: 1.5rem;
    line-height: 1.66666666666666;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}
#introduction #benefit ul li {
    margin: 0 3.0rem;
}
#introduction #benefit ul li img {
    display: block;
    width: 13.0rem;
    margin: 0 auto;
}
#introduction #benefit ul li span.note {
    display: block;
    transform: scale(0.7333333333333333);
}

/* ボタン */
#introduction ul.btn {
    font-size: 1.6rem;
    font-weight: 500;
    text-align: center;
    width: 54.0rem;
    margin: 0 auto;
}
#introduction ul.btn li {
    margin-bottom: 2.0rem;
}
#introduction ul.btn li:last-child {
    margin-bottom: 0;
}

/* 通常ボタン */
#introduction ul.btn li a {
    color: #000;
    background: #fff;
    display: block;
    padding: 1.5rem;
    position: relative;
    transition: background-image .5s, background-color .5s;
}
#introduction ul.btn li a:before {
    content: "";
    background-image: url('data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22utf-8%22%3F%3E%3Csvg%20version%3D%221.1%22%20id%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20x%3D%220px%22%20y%3D%220px%22%20viewBox%3D%220%200%2020%2020%22%20style%3D%22enable-background%3Anew%200%200%2020%2020%3B%22%20xml%3Aspace%3D%22preserve%22%3E%3Cpolygon%20points%3D%227.7%2C10%200%2C15.7%200%2C18.2%2011%2C10%200%2C1.9%200%2C4.3%20%22%2F%3E%3C%2Fsvg%3E');
    background-repeat: no-repeat;
    background-position: center center;
    width: 2.0rem;
    height: 2.0rem;
    position: absolute;
    left: 1.0rem;
    top: 50%;
    transform: translateY(-50%);
}
#introduction ul.btn li a:hover {
    color: #fff;
    background-color: #000;
}
#introduction ul.btn li a:hover:before {
    background-image: url('data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22utf-8%22%3F%3E%3Csvg%20version%3D%221.1%22%20id%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20x%3D%220px%22%20y%3D%220px%22%20viewBox%3D%220%200%2020%2020%22%20style%3D%22enable-background%3Anew%200%200%2020%2020%3B%22%20xml%3Aspace%3D%22preserve%22%3E%3Cstyle%20type%3D%22text%2Fcss%22%3E%20.st0%7Bfill%3A%23FFFFFF%3B%7D%3C%2Fstyle%3E%3Cpolygon%20class%3D%22st0%22%20points%3D%227.7%2C10%200%2C15.7%200%2C18.2%2011%2C10%200%2C1.9%200%2C4.3%20%22%2F%3E%3C%2Fsvg%3E');
}

/* 入会ボタン */
#introduction ul.btn li.entry a {
    font-size: 1.8rem;
    color: #fff;
    background: #000;
    padding: 2.5rem;
}
#introduction ul.btn li.entry a:before {
    background-image: url('data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22utf-8%22%3F%3E%3Csvg%20version%3D%221.1%22%20id%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20x%3D%220px%22%20y%3D%220px%22%20viewBox%3D%220%200%2020%2020%22%20style%3D%22enable-background%3Anew%200%200%2020%2020%3B%22%20xml%3Aspace%3D%22preserve%22%3E%3Cstyle%20type%3D%22text%2Fcss%22%3E%20.st0%7Bfill%3A%23FFFFFF%3B%7D%3C%2Fstyle%3E%3Cpolygon%20class%3D%22st0%22%20points%3D%227.7%2C10%200%2C15.7%200%2C18.2%2011%2C10%200%2C1.9%200%2C4.3%20%22%2F%3E%3C%2Fsvg%3E');
}
#introduction ul.btn li.entry a:hover {
    background-color: #00a7e3;
}

/* ────────────────────── *
 *                                              *
 * キャンペーン                                 *
 *                                              *
 * ────────────────────── */

#introduction #campaign {
    width: 100.0rem;
    padding: 0 8.0rem 7.0rem;
    margin: 0 auto 10.0rem;
    border: 1px solid rgba(0, 0, 0, 0.5);
    border-radius: 2.0rem;
    box-sizing: border-box;
}
#introduction #campaign #title-campaign {
    color: #fff;
    background: #00a7e3;
    padding: 5.0rem 6.0rem;
    margin: -6.0rem auto 5.0rem;
}
#introduction #campaign #title-campaign h2 {
    font-size: 2.8rem;
    line-height: 1.6;
    font-weight: 500;
    text-align: center;
    margin-bottom: 2.0rem;
}
#introduction #campaign #title-campaign h2 em {
    font-size: 3.6rem;
    font-style: normal;
    letter-spacing: 0.2em;
}
#introduction #campaign #title-campaign dl {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
}
#introduction #campaign #title-campaign dl dt {
    font-size: 1.6rem;
    line-height: 1.875;
    width: 37.0rem;
}
#introduction #campaign #title-campaign dl dd {
    font-size: 1.5rem;
    line-height: 1.45;
    font-weight: 500;
    color: #00a7e3;
    background: #fff;
    width: 31.6rem;
    padding: 1.0rem 0;
    text-align: center;
}
#introduction #campaign #title-campaign dl dd span {
    font-size: 1.8rem;
}
#introduction #campaign #title-campaign dl dd span em {
    font-size: 2.6rem;
    font-style: normal;
}
#introduction #campaign .present {
    min-height: 17.0rem;
    padding-left: 7.0rem;
    margin: 0 auto 5.0rem;
    position: relative;
}
#introduction #campaign .present.num-01:before {
    content: "";
    background: url("../../member/image/icon-num-01@2x.png") no-repeat center center / cover;
    width: 5.8rem;
    height: 5.6rem;
    position: absolute;
    left: 0;
    top: 0;
}
#introduction #campaign .present.num-02:before {
    content: "";
    background: url("../../member/image/icon-num-02@2x.png") no-repeat center center / cover;
    width: 5.8rem;
    height: 5.6rem;
    position: absolute;
    left: 0;
    top: 0;
}
#introduction #campaign .present dl.content {
    margin-bottom: 2.0rem;
}
#introduction #campaign .present dl.content dt {
    font-size: 1.6rem;
    margin-bottom: 1.0rem;
}
#introduction #campaign .present dl.content dd {
    font-size: 2.4rem;
}
#introduction #campaign .present dl.content dd em {
    font-size: 2.6rem;
    font-style: normal;
    color: #a58900;
}
#introduction #campaign .present dl.content dd em span.small {
    font-size: 2.0rem;
}
#introduction #campaign .present dl.content dd em span.x-small {
    font-size: 1.3rem;
}
#introduction #campaign .present p.lottery {
    font-size: 1.6rem;
    color: #fff;
    background: #00a7e3;
    text-align: center;
    display: inline-block;
    padding: 0.8rem 2.0rem;
    margin-bottom: 2.0rem;
}
#introduction #campaign .present dl#food {
    width: 45.0rem;
    margin-bottom: 1.5rem;
}
#introduction #campaign .present dl#food dt {
    font-size: 1.6rem;
    display: inline-block;
    padding-bottom: 0.5rem;
    margin-bottom: 1.0rem;
    border-bottom: 1px solid #000;
}
#introduction #campaign .present dl#food dd {
    font-size: 2.0rem;
    line-height: 1.2;
}
#introduction #campaign .present dl#food dd span.small {
    font-size: 1.6rem;
}
#introduction #campaign .present p.notice {
    font-size: 1.3rem;
    line-height: 1.4;
    width: 45.0rem;
}
#introduction #campaign .present p.image {
    width: 30.0rem;
    position: absolute;
    right: 0;
    bottom: 0;
}

/* ────────────────────── *
 *                                              *
 * エントリーフォーム                           *
 *                                              *
 * ────────────────────── */

#entryform {
    padding: 13.0rem 0 9.0rem;
}
#entryform .inner {
    width: 86.0rem;
    margin: 0 auto;
}
#entryform .inner h1 {
    font-size: 3.8rem;
    line-height: 1.1;
    font-weight: 500;
    text-align: center;
    margin: 0 auto 7.0rem;
}
#entryform .inner h1 span.note {
    font-size: 1.3rem;
    display: block;
    padding-top: 1.0rem;
}

/* ステップ */
#entryform .inner ul#step {
    font-size: 1.5rem;
    color: #fff;
    text-align: center;
    margin: 0 auto 4.0rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
#entryform .inner ul#step li {
    background: #000;
    width: 25.0rem;
    padding: 1.5rem;
    box-sizing: border-box;
    position: relative;
}
#entryform .inner ul#step li.current {
    background: #00a7e3;
}
#entryform .inner ul#step li:after {
    content: "";
    background-image: url('data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22utf-8%22%3F%3E%3Csvg%20version%3D%221.1%22%20id%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20x%3D%220px%22%20y%3D%220px%22%20viewBox%3D%220%200%2020%2020%22%20style%3D%22enable-background%3Anew%200%200%2020%2020%3B%22%20xml%3Aspace%3D%22preserve%22%3E%3Cpolygon%20points%3D%227.7%2C10%200%2C15.7%200%2C18.2%2011%2C10%200%2C1.9%200%2C4.3%20%22%2F%3E%3C%2Fsvg%3E');
    background-repeat: no-repeat;
    background-position: center center;
    width: 2.0rem;
    height: 2.0rem;
    position: absolute;
    left: calc(100% + 2.2rem);
    top: 50%;
    transform: translateY(-50%);
}
#entryform .inner ul#step li:last-child:after {
    content: none;
}

/* テキスト */
#entryform .inner p.txt {
    font-size: 2.0rem;
    line-height: 1.8;
    color: #413d3c;
    text-align: center;
    margin: 0 auto 4.0rem;
}

/* 入力エリア */
#entryform .inner table.input {
    font-size: 1.6rem;
    line-height: 1.5;
    color: #413d3c;
    width: 100%;
    margin: 0 auto 6.0rem;
    table-layout: fixed;
    border-collapse: collapse;
    border-spacing: 0;
    border-top: 1px solid rgba(114, 113, 113, 0.5);
}
#entryform .inner table.input th {
    line-height: 3;
    font-weight: 400;
    text-align: left;
    vertical-align: top;
    width: 22.0rem;
    padding: 3.0rem 0;
    border-bottom: 1px solid rgba(114, 113, 113, 0.5);
}
#entryform .inner table.input th span.required {
    display: block;
    position: relative;
}
#entryform .inner table.input th span.required:after {
    content: "必須";
    font-size: 1.2rem;
    line-height: 1;
    color: #fff;
    background: #00a7e3;
    text-align: center;
    width: 4.0rem;
    padding: 0.4rem;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    box-sizing: border-box;
}
#entryform .inner table.input td {
    padding: 3.0rem 0 3.0rem 1.0rem;
    border-bottom: 1px solid rgba(114, 113, 113, 0.5);
}
#entryform .inner table.input td input.input-l {
    font-family: "YakuHanMP_Noto", "Noto Serif JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
    font-size: 1.6rem;
    -webkit-appearance: none;
    appearance: none;
    border: none;
    background: #f4f8f9;
    width: 100%;
    padding: 1.2rem;
    box-sizing: border-box;
    border-radius: 0;
}
#entryform .inner table.input td input.input-s {
    font-family: "YakuHanMP_Noto", "Noto Serif JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
    font-size: 1.6rem;
    -webkit-appearance: none;
    appearance: none;
    border: none;
    background: #f4f8f9;
    width: 11.0rem;
    padding: 1.2rem;
    box-sizing: border-box;
    border-radius: 0;
}
#entryform .inner table.input td ul {
    font-size: 1.6rem;
    line-height: 1.8;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}
#entryform .inner table.input td ul li {
    min-width: calc(100% / 5);
    margin-bottom: 0.5rem;
}
#entryform .inner table.input td ul.job li.two-block {
    min-width: calc(100% / 5 * 2);
}
#entryform .inner table.input td ul.job li input.input-s {
    width: 15.0rem;
    padding: 0.25rem;
    margin-left: 1.0rem;
}
#entryform .inner table.input td ul li input[type=radio] {
    display: none;
}
#entryform .inner table.input td ul li input[type=radio] + label {
    display: inline-block;
    padding-left: 2.0rem;
    position: relative;
}
#entryform .inner table.input td ul li input[type=radio] + label:before {
    content: "";
    background: #f4f8f9;
    width: 1.4rem;
    height: 1.4rem;
    border: 1px solid #00a7e3;
    position: absolute;
    left: 0;
    top: 0.6rem;
}
#entryform .inner table.input td ul li input[type=radio]:checked + label:after {
    content: "";
    background-image: url('data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22utf-8%22%3F%3E%3Csvg%20version%3D%221.1%22%20id%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20x%3D%220px%22%20y%3D%220px%22%20viewBox%3D%220%200%2012%2012%22%20style%3D%22enable-background%3Anew%200%200%2012%2012%3B%22%20xml%3Aspace%3D%22preserve%22%3E%3Cstyle%20type%3D%22text%2Fcss%22%3E%20.st0%7Bfill%3A%23000000%3B%7D%3C%2Fstyle%3E%3Cpolygon%20class%3D%22st0%22%20points%3D%225.3%2C11.5%201.2%2C6.8%202.7%2C5.5%204.9%2C8%209.1%2C0.5%2010.8%2C1.5%20%22%2F%3E%3C%2Fsvg%3E');
    background-repeat: no-repeat;
    background-position: center center;
    width: 1.2rem;
    height: 1.2rem;
    position: absolute;
    left: 0.2rem;
    top: 50%;
    z-index: 1;
    transform: translateY(-50%);
}

#entryform .inner table.input td button {
    background-color: transparent;
    border: none;
    cursor: pointer;
    outline: none;
    padding: 0;
    appearance: none;
}
#entryform .inner table.input td button:focus {
    border: 2px solid #000;
}
#entryform .inner table.input td button.postal-search {
    font-family: "YakuHanMP_Noto", "Noto Serif JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
    font-size: 1.6rem;
    line-height: 1;
    color: #fff;
    background: #727171;
    text-align: center;
    width: 13.0rem;
    padding: 1.3rem;
    margin-left: 2.0rem;
    box-sizing: border-box;
}
#entryform .inner table.input td select {
    font-family: "YakuHanMP_Noto", "Noto Serif JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
    font-size: 1.6rem;
    background: #f4f8f9 url("../../member/image/bg-selectbox@2x.png") no-repeat right 1.0rem center / 1.4rem auto;
    -webkit-appearance: none;
    appearance: none;
    border: none;
    width: 22.0rem;
    padding: 1.2rem;
    box-sizing: border-box;
    border-radius: 0;
}
#entryform .inner table.input td span.reenter {
    display: inline-block;
    padding: 1.0rem 0;
}
#entryform .inner h2 {
    font-size: 2.0rem;
    color: #413d3c;
    text-align: center;
    margin: 0 auto 4.0rem;
}

/* アンケート */
#entryform .inner dl.enquete {
    color: #413d3c;
    margin-bottom: 6.0rem;
}
#entryform .inner dl.enquete > dt {
    font-size: 1.8rem;
    background: #efefef;
    padding: 1.5rem;
    margin-bottom: 2.0rem;
}
#entryform .inner dl.enquete > dd {
    font-size: 1.6rem;
    line-height: 1.8;
    margin-bottom: 4.0rem;
}
#entryform .inner dl.enquete > dd ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}
#entryform .inner dl.enquete > dd ul li {
    margin-right: 3.0rem;
    margin-bottom: 1.5rem;
}
#entryform .inner dl.enquete > dd ul li:last-child {
    margin-right: 0;
}
#entryform .inner dl.enquete > dd ul li input[type=checkbox] {
    display: none;
}
#entryform .inner dl.enquete > dd ul li input[type=checkbox] + label {
    display: inline-block;
    padding-left: 2.0rem;
    position: relative;
}
#entryform .inner dl.enquete > dd ul li input[type=checkbox] + label:before {
    content: "";
    background: #f4f8f9;
    width: 1.4rem;
    height: 1.4rem;
    border: 1px solid #00a7e3;
    position: absolute;
    left: 0;
    top: 0.6rem;
}
#entryform .inner dl.enquete > dd ul li input[type=checkbox]:checked + label:after {
    content: "";
    background-image: url('data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22utf-8%22%3F%3E%3Csvg%20version%3D%221.1%22%20id%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20x%3D%220px%22%20y%3D%220px%22%20viewBox%3D%220%200%2012%2012%22%20style%3D%22enable-background%3Anew%200%200%2012%2012%3B%22%20xml%3Aspace%3D%22preserve%22%3E%3Cstyle%20type%3D%22text%2Fcss%22%3E%20.st0%7Bfill%3A%23000000%3B%7D%3C%2Fstyle%3E%3Cpolygon%20class%3D%22st0%22%20points%3D%225.3%2C11.5%201.2%2C6.8%202.7%2C5.5%204.9%2C8%209.1%2C0.5%2010.8%2C1.5%20%22%2F%3E%3C%2Fsvg%3E');
    background-repeat: no-repeat;
    background-position: center center;
    width: 1.2rem;
    height: 1.2rem;
    position: absolute;
    left: 0.2rem;
    top: 50%;
    z-index: 1;
    transform: translateY(-50%);
}
#entryform .inner dl.enquete > dd dl {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}
#entryform .inner dl.enquete > dd dl dt {
    width: 22.0rem;
    padding-bottom: 1.0rem;
    margin-bottom: 2.5rem;
    flex-shrink: 0;
    border-bottom: 1px solid rgba(114, 113, 113, 0.5);
}
#entryform .inner dl.enquete > dd dl dd {
    width: calc(100% - 22.0rem);
    padding-bottom: 1.0rem;
    margin-bottom: 2.5rem;
    border-bottom: 1px solid rgba(114, 113, 113, 0.5);
}
#entryform .inner dl.enquete > dd dl dt:last-of-type {
    padding-bottom: 0rem;
    margin-bottom: 0;
    border-bottom: none;
}
#entryform .inner dl.enquete > dd dl dd:last-of-type {
    padding-bottom: 0rem;
    margin-bottom: 0;
    border-bottom: none;
}
#entryform .inner dl.enquete > dd dl dd ul li {
    min-width: calc(100% / 5);
    margin-right: 0;
}
#entryform .inner dl.enquete > dd dl dd ul li.two-block {
    min-width: calc(100% / 5 * 2);
}
#entryform .inner dl.enquete > dd textarea {
    font-family: "YakuHanMP_Noto", "Noto Serif JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
    font-size: 1.6rem;
    -webkit-appearance: none;
    appearance: none;
    border: none;
    background: #f4f8f9;
    width: 100%;
    height: 14.0rem;
    padding: 1.2rem;
    box-sizing: border-box;
}

/* 会員規約 */
#entryform .inner dl#document {
    text-align: center;
    padding-bottom: 2.0rem;
    margin-bottom: 1.5rem;
    border-bottom: 1px solid rgba(114, 113, 113, 0.5);
}
#entryform .inner dl#document dt {
    font-size: 2.0rem;
    font-weight: 500;
    margin-bottom: 2.0rem;
}
#entryform .inner dl#document dd {
    font-size: 1.6rem;
    line-height: 1.5;
}
#entryform .inner dl#document dd a {
    color: #00a7e3;
    text-decoration: underline;
}

/* 同意する */
#entryform .inner p#check {
    font-size: 1.6rem;
    text-align: center;
    margin: 0 auto 7.0rem;
}
#entryform .inner p#check input[type=checkbox] {
    width: 0;
    height: 0;
    opacity: 0;
    visibility: hidden;
}
#entryform .inner p#check input[type=checkbox] + label {
    display: inline-block;
    padding-left: 2.0rem;
    position: relative;
}
#entryform .inner p#check input[type=checkbox] + label:before {
    content: "";
    background: #fff;
    width: 1.4rem;
    height: 1.4rem;
    border: 1px solid #00a7e3;
    position: absolute;
    left: 0;
    top: 0;
}
#entryform .inner p#check input[type=checkbox]:checked + label:after {
    content: "";
    background-image: url('data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22utf-8%22%3F%3E%3Csvg%20version%3D%221.1%22%20id%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20x%3D%220px%22%20y%3D%220px%22%20viewBox%3D%220%200%2012%2012%22%20style%3D%22enable-background%3Anew%200%200%2012%2012%3B%22%20xml%3Aspace%3D%22preserve%22%3E%3Cstyle%20type%3D%22text%2Fcss%22%3E%20.st0%7Bfill%3A%23000000%3B%7D%3C%2Fstyle%3E%3Cpolygon%20class%3D%22st0%22%20points%3D%225.3%2C11.5%201.2%2C6.8%202.7%2C5.5%204.9%2C8%209.1%2C0.5%2010.8%2C1.5%20%22%2F%3E%3C%2Fsvg%3E');
    background-repeat: no-repeat;
    background-position: center center;
    width: 1.2rem;
    height: 1.2rem;
    position: absolute;
    left: 0.2rem;
    top: 50%;
    z-index: 1;
    transform: translateY(-50%);
}

/* 送信ボタン */
#entryform .inner ul.btn {
    text-align: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}
#entryform .inner ul.btn li {
    margin: 0 1.0rem;
}
#entryform .inner ul.btn li button {
    background-color: transparent;
    border: none;
    cursor: pointer;
    outline: none;
    padding: 0;
    appearance: none;
}
#entryform .inner ul.btn li button[type=submit],
#entryform .inner ul.btn li button.submit {
    font-family: "YakuHanMP_Noto", "Noto Serif JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
    font-size: 1.6rem;
    color: #fff;
    background: #00a7e3;
    text-align: center;
    width: 25.0rem;
    padding: 1.5rem;
    position: relative;
    border: 1px solid #00a7e3;
    box-sizing: border-box;
    transition: background .5s, border .5s;
}
#entryform .inner ul.btn li button[type=submit]:hover,
#entryform .inner ul.btn li button.submit:hover {
    background: #000;
    border: 1px solid #000;
}
#entryform .inner ul.btn li button[type=submit]:before,
#entryform .inner ul.btn li button.submit:before {
    content: "";
    background-image: url('data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22utf-8%22%3F%3E%3Csvg%20version%3D%221.1%22%20id%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20x%3D%220px%22%20y%3D%220px%22%20viewBox%3D%220%200%2020%2020%22%20style%3D%22enable-background%3Anew%200%200%2020%2020%3B%22%20xml%3Aspace%3D%22preserve%22%3E%3Cstyle%20type%3D%22text%2Fcss%22%3E%20.st0%7Bfill%3A%23FFFFFF%3B%7D%3C%2Fstyle%3E%3Cpolygon%20class%3D%22st0%22%20points%3D%227.7%2C10%200%2C15.7%200%2C18.2%2011%2C10%200%2C1.9%200%2C4.3%20%22%2F%3E%3C%2Fsvg%3E');
    background-repeat: no-repeat;
    background-position: center center;
    width: 2.0rem;
    height: 2.0rem;
    position: absolute;
    left: 1.0rem;
    top: 50%;
    transform: translateY(-50%);
}

#entryform .inner ul.btn li button.back {
    font-family: "YakuHanMP_Noto", "Noto Serif JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
    font-size: 1.6rem;
    color: #00a7e3;
    background: #fff;
    text-align: center;
    width: 25.0rem;
    padding: 1.5rem;
    position: relative;
    border: 1px solid #00a7e3;
    box-sizing: border-box;
    transition: background .5s;
}
#entryform .inner ul.btn li button.back:before {
    content: "";
    background-image: url('data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22utf-8%22%3F%3E%3Csvg%20version%3D%221.1%22%20id%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20x%3D%220px%22%20y%3D%220px%22%20viewBox%3D%220%200%2020%2020%22%20style%3D%22enable-background%3Anew%200%200%2020%2020%3B%22%20xml%3Aspace%3D%22preserve%22%3E%3Cstyle%20type%3D%22text%2Fcss%22%3E%20.st0%7Bfill%3A%2300a7e3%3B%7D%3C%2Fstyle%3E%3Cpolygon%20class%3D%22st0%22%20points%3D%227.7%2C10%200%2C15.7%200%2C18.2%2011%2C10%200%2C1.9%200%2C4.3%20%22%2F%3E%3C%2Fsvg%3E');
    background-repeat: no-repeat;
    background-position: center center;
    width: 2.0rem;
    height: 2.0rem;
    position: absolute;
    left: 1.0rem;
    top: 50%;
    transform: translateY(-50%);
}
#entryform .inner p.top {
    text-align: center;
    margin-top: 7.0rem;
}
#entryform .inner p.top a {
    font-size: 1.6rem;
    color: #fff;
    background: #00a7e3;
    text-align: center;
    display: inline-block;
    width: 25.0rem;
    padding: 1.5rem;
    position: relative;
    box-sizing: border-box;
    transition: background .5s, border .5s;
}
#entryform .inner p.top a:hover {
    background: #000;
}
#entryform .inner p.top a:before {
    content: "";
    background-image: url('data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22utf-8%22%3F%3E%3Csvg%20version%3D%221.1%22%20id%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20x%3D%220px%22%20y%3D%220px%22%20viewBox%3D%220%200%2020%2020%22%20style%3D%22enable-background%3Anew%200%200%2020%2020%3B%22%20xml%3Aspace%3D%22preserve%22%3E%3Cstyle%20type%3D%22text%2Fcss%22%3E%20.st0%7Bfill%3A%23FFFFFF%3B%7D%3C%2Fstyle%3E%3Cpolygon%20class%3D%22st0%22%20points%3D%227.7%2C10%200%2C15.7%200%2C18.2%2011%2C10%200%2C1.9%200%2C4.3%20%22%2F%3E%3C%2Fsvg%3E');
    background-repeat: no-repeat;
    background-position: center center;
    width: 2.0rem;
    height: 2.0rem;
    position: absolute;
    left: 1.0rem;
    top: 50%;
    transform: translateY(-50%);
}

div.error {
    font-size: 1.6rem;
    line-height: 1;
    color: #fff;
    background: #c00;
    display: inline-block!important;
    padding: 0.5rem;
    margin-top: 1.0rem;
}
div#age-error {
    margin-top: 0;
    margin-bottom: 1.0rem;
}
span.check-error {
    color: #c00;
}

/* ────────────────────── *
 *                                              *
 * 会員規約                                     *
 *                                              *
 * ────────────────────── */

#terms {
    padding: 13.0rem 0 9.0rem;
}
#terms .inner {
    width: 86.0rem;
    margin: 0 auto;
}
#terms .inner h1 {
    font-size: 2.5rem;
    font-weight: 500;
    text-align: center;
    margin: 0 auto 7.0rem;
}
#terms .inner ol#terms-detail {
    font-size: 1.2rem;
    line-height: 1.63636363636;
    color: #413d3c;
    text-align: justify;
    margin: 0 auto 6.0rem;
    counter-reset: list;
}
#terms .inner ol#terms-detail > li {
    padding-top: 0.4rem;
    margin-bottom: 2.5rem;
    position: relative;
}
#terms .inner ol#terms-detail > li:before {
    font-size: 1.4rem;
    line-height: 2;
    background: #e8eff0;
    counter-increment: list;
    content: counter(list);
    position: absolute;
    left: -4.5rem;
    width: 2.8rem;
    height: 2.8rem;
    text-align: center;
    top: 0;
}
#terms .inner ol#terms-detail > li > ol.child {
    counter-reset: child;
}
#terms .inner ol#terms-detail > li > ol.child > li {
    padding-left: 2.0rem;
    position: relative;
}
#terms .inner ol#terms-detail > li > ol.child > li:before {
    counter-increment: child;
    content: counter(child) ".";
    position: absolute;
    left: 0;
    top: 0;
}
#terms .inner ol#terms-detail > li > ol.child > li > ol.grandson {
    counter-reset: grandson;
}
#terms .inner ol#terms-detail > li > ol.child > li > ol.grandson > li {
    padding-left: 2.5rem;
    position: relative;
}
#terms .inner ol#terms-detail > li > ol.child > li > ol.grandson > li:before {
    counter-increment: grandson;
    content: "（" counter(grandson) "）";
    position: absolute;
    left: 0;
    top: 0;
}
#terms .inner ol#terms-detail > li > ol.child > li > ol.grandson > li ul.notice li:before {
    content: "※";
}
#terms .inner ol#terms-detail > li a {
    color: #413d3c;
}
#terms .inner ol#terms-detail > li a:hover {
    text-decoration: underline;
}
#terms .inner address {
    font-size: 1.2rem;
    line-height: 1.63636363636;
    color: #413d3c;
    margin: 0 auto 7.0rem;
}
#terms .inner p.close {
    text-align: center;
}
#terms .inner p.close a {
    font-size: 1.6rem;
    color: #fff;
    background: #00a7e3;
    text-align: center;
    display: inline-block;
    width: 25.0rem;
    padding: 1.5rem;
    position: relative;
    box-sizing: border-box;
    transition: background .5s, border .5s;
}
#terms .inner p.close a:hover {
    background: #000;
}
#terms .inner p.close a:before {
    content: "";
    background-image: url('data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22utf-8%22%3F%3E%3Csvg%20version%3D%221.1%22%20id%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20x%3D%220px%22%20y%3D%220px%22%20viewBox%3D%220%200%2020%2020%22%20style%3D%22enable-background%3Anew%200%200%2020%2020%3B%22%20xml%3Aspace%3D%22preserve%22%3E%3Cstyle%20type%3D%22text%2Fcss%22%3E%20.st0%7Bfill%3A%23FFFFFF%3B%7D%3C%2Fstyle%3E%3Cpolygon%20class%3D%22st0%22%20points%3D%227.7%2C10%200%2C15.7%200%2C18.2%2011%2C10%200%2C1.9%200%2C4.3%20%22%2F%3E%3C%2Fsvg%3E');
    background-repeat: no-repeat;
    background-position: center center;
    width: 2.0rem;
    height: 2.0rem;
    position: absolute;
    left: 1.0rem;
    top: 50%;
    transform: translateY(-50%);
}

/* ────────────────────── *
 *                                              *
 * 利用目的                                     *
 *                                              *
 * ────────────────────── */

#purpose {
    padding: 13.0rem 0 9.0rem;
}
#purpose .inner {
    width: 86.0rem;
    margin: 0 auto;
}
#purpose .inner h1 {
    font-size: 2.5rem;
    font-weight: 500;
    text-align: center;
    margin: 0 auto 7.0rem;
}
#purpose .inner h2 {
    font-size: 1.5rem;
    color: #413d3c;
    margin-bottom: 0.5rem;
}
#purpose .inner p.txt {
    font-size: 1.2rem;
    line-height: 1.63636363636;
    color: #413d3c;
    text-align: justify;
}
#purpose .inner p.notice {
    text-indent: -2.2em;
    padding-left: 2.2em;
    margin-bottom: 2.0rem;
}
#purpose .inner p.close {
    text-align: center;
    margin-top: 7.0rem;
}
#purpose .inner p.close a {
    font-size: 1.6rem;
    color: #fff;
    background: #00a7e3;
    text-align: center;
    display: inline-block;
    width: 25.0rem;
    padding: 1.5rem;
    position: relative;
    box-sizing: border-box;
    transition: background .5s, border .5s;
}
#purpose .inner p.close a:hover {
    background: #000;
}
#purpose .inner p.close a:before {
    content: "";
    background-image: url('data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22utf-8%22%3F%3E%3Csvg%20version%3D%221.1%22%20id%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20x%3D%220px%22%20y%3D%220px%22%20viewBox%3D%220%200%2020%2020%22%20style%3D%22enable-background%3Anew%200%200%2020%2020%3B%22%20xml%3Aspace%3D%22preserve%22%3E%3Cstyle%20type%3D%22text%2Fcss%22%3E%20.st0%7Bfill%3A%23FFFFFF%3B%7D%3C%2Fstyle%3E%3Cpolygon%20class%3D%22st0%22%20points%3D%227.7%2C10%200%2C15.7%200%2C18.2%2011%2C10%200%2C1.9%200%2C4.3%20%22%2F%3E%3C%2Fsvg%3E');
    background-repeat: no-repeat;
    background-position: center center;
    width: 2.0rem;
    height: 2.0rem;
    position: absolute;
    left: 1.0rem;
    top: 50%;
    transform: translateY(-50%);
}
