@charset "UTF-8";

/* ------------------------------
BASE
------------------------------ */
html {
    font-size: 62.5%;
}

body {
    position: relative;
    margin: 0;
    padding: 0;
    font-family: "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "ＭＳ ゴシック", sans-serif;
    color: #333;
    background: #fff;
    text-align: center;
}

div, p, h1, h2, h3, h4, h5, h6, form, li, ul, ol, dl, dd, dt, table {
    margin: 0;
    padding: 0;
}

.clear {
    clear: both;
}

/* Micro clearfix */
.clearfix {
    zoom: 1;
}

.clearfix:before,
.clearfix:after {
    content: "";
    display: table;
}

.clearfix:after {
    clear: both;
}

.wrap {
    zoom: 1;
}

.wrap:before,
.wrap:after {
    content: "";
    display: table;
}

.wrap:after {
    clear: both;
}

/* サイズ調整用 */
* {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    -o-box-sizing: border-box;
    -ms-box-sizing: border-box;
    box-sizing: border-box;
}

/* ------------------------------
フォーム共通
------------------------------ */
input[type="submit"]:hover {
    opacity: 0.7;
}

input[type="text"], input[type="password"], button, textarea {
    -webkit-appearance: none;
    border-radius: 0;
}

input[type="text"],
input[type="radio"] {
    margin-right: 0.5em;
}

input[type="text"],
input[type="password"] {
    border: solid 1px #999;
}

input[type="text"].CEMAIL {
    margin: 0.5em 0.5em 0.5em 0;
}

/* 入力フォームサイズ調整 */
input[type="text"].TEL1 {
    width: 80px;
}

input[type="text"].TEL2 {
    width: 120px;
}

input[type="text"].USERID {
    width: 150px;
}

input[type="text"].NAME {
    width: 230px;
    max-width: 100%;
}

input.PWD {
    width: 120px;
}

input[type="text"].PAYID {
    width: 150px;
    margin: 0.5em 0.5em 0.5em 0;
}

/* label */
label {
    margin-right: 1.5em;
}

/* セレクト */
select {
    margin-right: 0.5em;
}

.date select {
    margin-left: 0.5em;
    margin-right: 0.5em;
}

/* ボタン */
input[type="submit"] {
    display: block;
    min-width: 240px;
    margin: 0 auto;
    padding: 15px;
    border: solid 0px #df0127;
    border-bottom: 2px solid #b7001f;
    border-radius: 4px;
    background-color: #df0127;
    color: #fff;
    font-size: 16px;
    font-size: 1.6rem;
    letter-spacing: 1px;
    text-align: center;
    font-weight: bold;
}

input[type="submit"].return {
    border-bottom: 2px solid #888;
    background-color: #aaa;
}

/* ------------------------------
汎用
------------------------------ */
p {
    line-height: 1.8;
}

.small {
    font-size: 10px;
    font-size: 1rem;
}

.large {
    font-size: 16px;
    font-size: 1.6rem;
}

.sp {
    display: none;
}

.pc {
    display: block;
}

.txRight {
    text-align: right;
}

.txLeft {
    text-align: left;
}

.txCenter {
    text-align: center;
}

.red {
    color: #df0128;
}

/* ------------------------------------------------------------- 
基本枠
-------------------------------------------------------------  */

/* ------------------------------- wrap ※全体css */
.wrap {
    width: 700px;
    margin: 0 auto;
    text-align: left;
    font-size: 14px;
    font-size: 1.4rem;
}

/* ------------------------------- header */
#header {
    padding: 10px 0%;
    border-top: solid 3px #df0128;
    border-bottom: solid 1px #df0128;
}

#header img {
    width: 290px;
    height: auto;
}

/* ------------------------------- メインコンテンツ */

#main {
    padding: 40px 0;
}

/* ページタイトル */
h1 {
    margin: 0 0 30px 0;
    padding-left: 10px;
    border-left: solid 3px #df0127;
    font-size: 20px;
    font-size: 2.0rem;
    letter-spacing: 1px;
}

h1 span {
    display: block;
    color: #666666;
    font-weight: normal;
    font-size: 14px;
    font-size: 1.4rem;
}

/* エラーメッセージ */
.error {
    margin: 20px 0;
    color: #df0127;
}

/* 代理店コード */
.code {
    margin: 20px 0;
    padding: 1em;
    border: solid 1px #df0127;
    text-align: center;
    font-size: 16px;
    font-size: 1.6rem;
    font-weight: bold;
    line-height: 1.3;
}

/*小見出し*/
h2 {
    margin: 35px 0 20px 0;
    padding-bottom: 10px;
    border-bottom: solid 2px #df0127;
    font-size: 18px;
    font-size: 1.8rem;
    line-height: 1;
}

p.info {
    margin: 20px 0 20px 0;
}

ul.infoList {
    margin-top: 20px;
    margin-bottom: 20px;
    line-height: 1.6;
    list-style: none;
}

ul.infoList li {
    margin-left: 1em;
    text-indent: -1em;
}

/*注意書き*/
.caution {
    color: #df0127;
}

dl {
}

dt {
    padding: 0.8em;
    background-color: #d5eaff;
    border-top: solid 1px #cccccc;
    border-left: solid 1px #cccccc;
    border-right: solid 1px #cccccc;
    font-weight: bold;
}

dt .notice {
    display: inline-block;
    margin-left: 1em;
    font-size: 13px;
    font-size: 1.3rem;
    font-weight: normal;
}

dd {
    margin-bottom: 1em;
    padding: 0.8em;
    border-bottom: solid 1px #cccccc;
    border-left: solid 1px #cccccc;
    border-right: solid 1px #cccccc;
}

dd table {

}

dd th {
    padding: 0.5em 0.5em 0.5em 0;
    text-align: left;
    font-weight: bold;
}

dd td {
    padding: 0.5em;
}

/* 注釈 */
.note {
    font-size: 12px;
    font-size: 1.2rem;
}

/* 戻るボタン */
a.buttonReturn {
    display: block;
    width: 240px;
    margin: 0 auto;
    padding: 15px;
    border-bottom: 2px solid #888;
    background-color: #aaa;
    border-radius: 4px;
    color: #fff;
    font-size: 16px;
    font-size: 1.6rem;
    letter-spacing: 1px;
    text-align: center;
    text-decoration: none;
    font-weight: bold;
}

/* クレカ区分 */
.kubun {
    margin-bottom: 1em;
    font-weight: normal;
}

.kubun h3 {
    position: relative;
    padding: 0.5em;
    background-color: #acacac;
    color: #fff;
    font-size: 14px;
    font-size: 1.4rem;
}

.kubun h3:hover {
    cursor: pointer;
    background-color: #999;
}

.kubun h3:before {
    content: '？';
    position: absolute;
    top: 0;
    bottom: 0;
    right: 5px;
    width: 25px;
    height: 25px;
    margin: auto 0;
    background-color: rgba(255, 255, 255, 0.4);
    border-radius: 50%;
    text-align: center;
    line-height: 25px;
    font-weight: normal;
    font-size: 17px;
    font-size: 1.7rem;
}

.kubun div {
    display: none;
    padding: 15px 20px;
    border-bottom: solid 1px #acacac;
    border-left: solid 1px #acacac;
    border-right: solid 1px #acacac;
    background: #fff;
}

.kubun div p {
    margin-bottom: 1em;
    font-size: 12px;
    font-size: 1.2rem;
}

.kubun div p:last-child {
    margin-bottom: 0;
}

.kubun div p strong {
    font-size: 14px;
    font-size: 1.4rem;
}

/* ------------------------------- footer */
#footer {
    width: 100%;
    height: auto;
    margin-top: 5em;
    padding: 1em 0;
    background-color: #df0127;
    color: #fff;
}

#footer p {
    text-align: center;
}

/* ---------------------------------------------------------------------------- 

▼▼▼ ウィンドウサイズ680px以下にのみ適用されるcss ▼▼▼

---------------------------------------------------------------------------- */

@media only screen and (max-width: 680px) {

    .sp {
        display: block;
    }

    .pc {
        display: none;
    }

    input[type="submit"] {
        width: 100%;
        max-width: 400px;
        padding: 10px;
        font-size: 14px;
        font-size: 1.4rem;
    }

    input[type="submit"].return {
    }

    /* ------------------------------- wrap ※全体css */
    .wrap {
        width: 94%;
        margin: 0 auto;
        font-size: 14px;
        font-size: 1.4rem;
    }

    /* ------------------------------- header */
    #header {
        padding: 10px 0%;
    }

    #header img {
        width: 70%;
        max-width: 290px;
    }

    /* ページタイトル */
    h1 {
        font-size: 18px;
        font-size: 1.8rem;
        line-height: 1.4;
    }

    h1 span {
        font-size: 12px;
        font-size: 1.2rem;
    }

    /* 代理店コード */
    .code {
        font-size: 15px;
        font-size: 1.5rem;
    }

    h2 {
        font-size: 16px;
        font-size: 1.6rem;
    }

    dt .notice {
        display: block;
        margin-left: 1em;
        text-indent: -1em;
        font-size: 12px;
        font-size: 1.2rem;
    }

    .kubun h3 {
        padding-right: 40px;
        font-weight: normal;
        line-height: 1.3;
    }

    /* 戻るボタン */
    a.buttonReturn {
        width: 100%;
        max-width: 400px;
        padding: 10px;
        font-size: 14px;
        font-size: 1.4rem;
    }

    /* ------------------------------- footer */
    #footer {
        font-size: 10px;
        font-size: 1.0rem;
    }

    #footer p {
        font-size: 8px;
        font-size: 0.8rem;
    }

}

.display_none {
    display: none;
}

.display_inline {
    display: inline;
}

.insurance-begin-date-diable {
    /*color: rgba(238, 238, 238, 1);*/
    color: #888888;
    background-color: #888888;
}
