@charset "UTF-8";
/* CSS reset */
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-style: normal;
  font-weight: normal;
  font-size: 100%;
  vertical-align: baseline;
}
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}
html {
  overflow-y: scroll;
}
blockquote, q {
  quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
  content: '';
  content: none;
}
input, textarea {
  margin: 0;
  padding: 0;
}
ol, ul {
  list-style: none;
}
/* @group Reset */
.fht-table,
.fht-table thead,
.fht-table tfoot,
.fht-table tbody,
.fht-table tr,
.fht-table th,
.fht-table td {
  /* position */
  margin: 0;
  /* size */
  padding: 0;
  /* text */
  font-size: 100%;
  font: inherit;
  vertical-align: top;
}
.fht-table {
  /* appearance */
  border-collapse: collapse;
  border-spacing: 0;
}
/* @end */
/* @group Content */
.fht-table-wrapper,
.fht-table-wrapper .fht-thead,
.fht-table-wrapper .fht-tfoot,
.fht-table-wrapper .fht-fixed-column .fht-tbody,
.fht-table-wrapper .fht-fixed-body .fht-tbody,
.fht-table-wrapper .fht-tbody {
  /* appearance */
  overflow: hidden;
  /* position */
  position: relative;
}
.fht-table-wrapper .fht-fixed-body .fht-tbody,
.fht-table-wrapper .fht-tbody {
  /* appearance */
  overflow: auto;
}
.fht-table-wrapper .fht-table .fht-cell {
  /* appearance */
  overflow: hidden;
  /* size */
  height: 1px;
}
.fht-table-wrapper .fht-fixed-column,
.fht-table-wrapper .fht-fixed-body {
  /* position */
  top: 0;
  left: 0;
  position: absolute;
}
.fht-table-wrapper .fht-fixed-column {
  /* position */
  z-index: 1;
}
/* @end */
.top5 {
  margin-top: 5px;
}
.top10 {
  margin-top: 10px;
}
.top15 {
  margin-top: 15px;
}
.top20 {
  margin-top: 20px;
}
.top25 {
  margin-top: 25px;
}
.top30 {
  margin-top: 30px;
}
.top35 {
  margin-top: 35px;
}
.top40 {
  margin-top: 40px;
}
.top45 {
  margin-top: 45px;
}
.top50 {
  margin-top: 50px;
}
body {
  font-size: 16px;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  color: #333;
  line-height: 1.6em;
}
@media only screen and (max-width: 767px) {
  body {
    font-size: 14px;
  }}
img {
  max-width: 100%;
  height: auto;
}
a:hover img {
  opacity: 0.8;
  filter: alpha(opacity=80);
  -ms-filter: "alpha( opacity=80 )";
}
.container {
  max-width: 970px;
}
article {
  padding: 50px 0;
}
strong {
  font-weight: bold;
}
/* Header ----------------------------------------------------------------------*/
#header {
  padding: 20px 0 10px;
}
#header .container {
  display: table;
}
#header #header-L {
  display: table-cell;
  width: 460px;
}
@media only screen and (max-width: 767px) {
  #header #header-L {
    width: 100%;
    text-align: center;
  }}
#header #header-L h1 {
  float: left;
}
#header #header-L ul {
  margin-top: 35px;
}
#header #header-L li {
  line-height: 1.1em;
}
#header #header-L li a {
  font-size: 0.85em;
  color: #333;
  font-weight: bold;
}
#header #header-L li a:hover {
  color: #d91515;
  text-decoration: none;
}
#header #header-L li a:before {
  content: "\f144";
  font-family: "fontAwesome";
  margin-right: 3px;
  margin-left: 10px;
}
#header #header-R {
  display: table-cell;
  vertical-align: bottom;
  padding-bottom: 10px;
}
#header #header-R #user-box {
  float: right;
  text-align: left;
}
#header #header-R h3 {
  font-weight: bold;
  font-size: 0.9em;
}
#header #header-R ul {
  margin-top: 10px;
}
#header #header-R li {
  display: inline-table;
}
#header #header-R li a {
  font-size: 0.85em;
  color: #fff;
  font-weight: bold;
  background-color: #d91515;
  border-radius: 5px;
  padding: 12px 15px;
}
#header #header-R li a:first-child {
  margin-right: 5px;
}
#header #header-R li a:hover {
  background-color: #ab1111;
  text-decoration: none;
}
#header #header-R li a:before {
  content: "\f0a9";
  font-family: "fontAwesome";
  margin-right: 3px;
}
#header #my-header h1, #header #my-header p {
  display: inline-table;
  vertical-align: middle;
}
#header #my-header p {
  position: absolute;
  margin-top: 15px;
  margin-left: 10px;
  border: 1px solid #166592;
  color: #166592;
  padding: 13px 20px;
  font-weight: bold;
  font-size: 2em;
  border-radius: 5px;
  text-align: center;
  vertical-align: baseline;
}
@media only screen and (max-width: 767px) {
  #header #my-header p {
    display: block;
    width: 100%;
    font-size: 1.3em;
    margin: 0;
    position: relative;
    padding: 5px;
  }}
/* Main image ----------------------------------------------------------------------*/

/* delete
#main-image {
  background: url(../images/toukyu_haikei.png) center top repeat-x;
  background-size: auto 240px;
}
delete */


#main-image h1 {
  margin: 40px auto 60px;
  text-align: center;
}
#main-image .mainimg {
  margin-top: 18%;
}
@media only screen and (max-width: 767px) {
  #main-image .mainimgBox {
    overflow: hidden;
  }  #main-image .mainimgBox .mainimg {
    margin-left: 10%;
  }}
@media only screen and (min-width: 768px) {
  #main-image {
    background-size: auto 330px;
  }  #main-image h1 {
    margin-top: 50px;
  }  #main-image .mainimg {
    margin-top: 30px;
  }}
#read-box {
  margin-top: 30px;
}
/* Page Header ----------------------------------------------------------------------*/
#page-header {
  background-image: -webkit-gradient(linear, left top, left bottom, color-stop(0, #1D83B3), color-stop(1, #104873));
  background-image: -webkit-linear-gradient(bottom, #1D83B3 0%, #104873 100%);
  background-image: -webkit-linear-gradient(top, #1D83B3 0%, #104873 100%);
  background-image: linear-gradient(to bottom, #1D83B3 0%, #104873 100%);
  padding: 8px 0;
}
#page-header h1 {
  margin: 5px 0 4px;
  color: #fff;
  font-weight: bold;
  font-size: 1.9em;
  font-family: "Hiragino Mincho ProN","HG明朝E","ＭＳ Ｐ明朝", serif;
}
#page-header #page-header-inner {
  border-bottom: 2px solid #fff;
}
/* Mypage Header ----------------------------------------------------------------------*/
#mypage-header, #sp-header {
  background-image: -webkit-gradient(linear, left top, left bottom, color-stop(0, #D5112E), color-stop(1, #B2091A));
  background-image: -webkit-linear-gradient(bottom, #D5112E 0%, #B2091A 100%);
  background-image: -webkit-linear-gradient(top, #D5112E 0%, #B2091A 100%);
  background-image: linear-gradient(to bottom, #D5112E 0%, #B2091A 100%);
  padding: 8px 0;
}
#mypage-header h1, #sp-header h1 {
  margin: 5px 0 4px;
  color: #fff;
  font-weight: bold;
  font-size: 1.9em;
  font-family: "Hiragino Mincho ProN","HG明朝E","ＭＳ Ｐ明朝", serif;
}
#mypage-header #page-header-inner, #sp-header #page-header-inner {
  border-bottom: 2px solid #fff;
}
#sp-header {
  text-align: center;
}
/* Top page ----------------------------------------------------------------------*/
#top #contents #top-btn {
  margin: 0 auto 30px;
  text-align: center;
  color: #d91515;
  font-size: 1.3em;
  font-family: "Hiragino Mincho ProN","HG明朝E","ＭＳ Ｐ明朝", serif;
}
#top #contents #top-btn a {
  display: block;
  margin-top: 10px;
}
@media only screen and (min-width: 768px) {
  #top #contents #top-btn {
    margin: 50px auto 30px;
    /* add */
    margin-top:0;
    /* add */
  }}
#top #contents #read-box p {
  font-size: 1.1em;
}
#top #contents #read-box h3 {
  color: #166592;
  font-size: 1.8em;
  font-family: "Hiragino Mincho ProN","HG明朝E","ＭＳ Ｐ明朝", serif;
  margin-bottom: 10px;
}
#top #contents article h2 {
  position: relative;
  font-weight: bold;
  font-size: 1.7em;
  color: #166592;
  padding: 15px 15px 15px 20px;
  letter-spacing: 0.15em;
  border: 1px solid #ddd;
  margin-bottom: 20px;
  background-image: -webkit-gradient(linear, left top, left bottom, color-stop(0, #FFFFFF), color-stop(1, #F2F2F2));
  background-image: -webkit-linear-gradient(bottom, #FFFFFF 0%, #F2F2F2 100%);
  background-image: -webkit-linear-gradient(top, #FFFFFF 0%, #F2F2F2 100%);
  background-image: linear-gradient(to bottom, #FFFFFF 0%, #F2F2F2 100%);
}
#top #contents article h2:before {
  content: "";
  position: absolute;
  background: #166592;
  top: 50%;
  left: 0;
  margin-top: -22px;
  height: 46px;
  width: 5px;
}
#top #contents article:nth-child(odd) {
  background: url(../images/bg-LightGrey.png) center center;
}
#top #contents #page-navi {
  margin: 50px 0 40px;
}
@media only screen and (min-width: 768px) {
  #top #contents #page-navi {
    margin-bottom: 60px;
  }}
#top #contents #page-navi ul {
  letter-spacing: -.40em;
  /* 文字間を詰めて隙間を削除する */
  background-image: -webkit-gradient(linear, left top, left bottom, color-stop(0, #1D83B3), color-stop(1, #104873));
  background-image: -webkit-linear-gradient(bottom, #1D83B3 0%, #104873 100%);
  background-image: -webkit-linear-gradient(top, #1D83B3 0%, #104873 100%);
  background-image: linear-gradient(to bottom, #1D83B3 0%, #104873 100%);
  border-radius: 5px;
}
#top #contents #page-navi li {
  display: inline-block;
  width: 20%;
  letter-spacing: normal;
  border-right: 1px solid rgba(255, 255, 255, 0.3);
}
@media only screen and (min-width: 768px) {
  #top #contents #page-navi li:last-child {
    border: 0;
  }}
@media only screen and (max-width: 767px) {
  #top #contents #page-navi li {
    border-bottom: 1px solid rgba(255, 255, 255, 0.3);
    width: 50%;
  }  #top #contents #page-navi li:nth-child(2n) {
    border-right: 0;
  }  #top #contents #page-navi li:last-child {
    border-bottom: 0;
  }}
#top #contents #page-navi li a {
  font-weight: bold;
  color: #fff;
  padding: 8px 12px;
  display: block;
}
#top #contents #page-navi li a:hover {
  background-color: rgba(255, 255, 255, 0.1);
  text-decoration: none;
}
#top #contents #page-navi li a:before {
  content: "\f13a";
  font-family: "fontAwesome";
  margin-right: 3px;
}
#top #contents #tokuten dt {
  margin-bottom: 5px;
}
#top #contents #tokuten dd {
  margin-bottom: 30px;
}
#top #contents #tokuten .img-list {
  margin-top: -30px;
  overflow: auto;
}
#top #contents #tokuten .img-list img {
  border: 1px solid #ddd;
  border-radius: 5px;
}
@media only screen and (min-width: 768px) {
  #top #contents #tokuten dd, #top #contents #tokuten dt {
    display: inline-block;
    vertical-align: top;
  }  #top #contents #tokuten .img-list li {
    width: 24%;
    float: left;
    margin-left: 12px;
    margin-top: 12px;
    text-align: center;
  }  #top #contents #tokuten .img-list li:nth-child(4n+1) {
    margin-left: 0;
  }}
@media only screen and (max-width: 767px) {
  #top #contents #tokuten dt img {
    margin-left: -15px;
  }  #top #contents #tokuten .img-list li {
    width: 31%;
    float: left;
    margin-left: 10px;
    margin-top: 10px;
    text-align: center;
  }  #top #contents #tokuten .img-list li:nth-child(3n+1) {
    margin-left: 0;
  }}
#top #contents #faq {
  font-size: 1.15em;
}
#top #contents #faq dt {
  padding: 20px 15px 5px 45px;
  font-weight: bold;
  border-top: 1px solid #ddd;
  background: url(../images/faq-q.png) left 17px no-repeat;
}
#top #contents #faq dd {
  background-image: url(../images/faq-a.png), url(../images/bg-LightGrey.png);
  background-position: left 12px, center center;
  background-repeat: no-repeat, repeat;
  padding: 15px 15px 15px 45px;
  border-radius: 5px;
  margin-bottom: 20px;
}
#top #contents #faq dt:first-child {
  border: 0;
}
#top #contents #faq dl {
  border-bottom: 1px solid #ddd;
  margin-top: -10px;
}
#top #contents #faq h3 {
  margin-top: 50px;
}
#top #contents #faq h3:first-child {
  margin-top: 30px;
}
#top #contents .btn-box {
  text-align: center;
  margin-top: 50px;
}
#top #contents .btn-order {
  display: block;
  margin: 0 auto 10px;
}
#top #contents .read {
  font-weight: bold;
  font-size: 1.15em;
}
#top #contents .price h3, #top #contents #faq h3, #top #contents #info h3, #top #contents #step h3 {
  font-size: 1.2em;
  font-weight: bold;
  color: #fff;
  background: url(../images/bg-sti.png) center center;
  padding: 5px 8px;
  margin: 30px 0 15px;
  border-radius: 5px;
}
#top #contents #naiyo .naiyo-box {
  background: url(../images/bg-LightGrey.png) center center;
  border-radius: 5px;
  padding: 20px;
  margin-bottom: 25px;
  box-shadow: 0 0 5px 0 #999;
}
#top #contents #naiyo .naiyo-box h3 {
  text-align: center;
}
#top #contents #naiyo .naiyo-box h4 {
  color: #166592;
  font-weight: bold;
  font-size: 1.4em;
  margin: 40px 0 10px;
}
#top #contents #naiyo .naiyo-box h4:before {
  content: "\f02e";
  font-family: "fontAwesome";
  margin-right: 3px;
}
#top #contents #naiyo .naiyo-box .img-list {
  overflow: auto;
  margin-top: 20px;
  overflow: auto;
}
@media only screen and (min-width: 768px) {
  #top #contents #naiyo .naiyo-box .img-list li {
    width: 32%;
    float: left;
    margin-left: 12px;
    margin-top: 12px;
    text-align: center;
  }  #top #contents #naiyo .naiyo-box .img-list li:nth-child(3n+1) {
    margin-left: 0;
  }}
@media only screen and (max-width: 767px) {
  #top #contents #naiyo .naiyo-box .img-list li {
    width: 31%;
    float: left;
    margin-left: 10px;
    margin-top: 10px;
    text-align: center;
  }  #top #contents #naiyo .naiyo-box .img-list li:nth-child(3n+1) {
    margin-left: 0;
  }}
#top #contents #naiyo .price h3 {
  margin-top: 50px;
}
#top #contents #naiyo .price th {
  background-color: #f6f6f6;
}
#top #contents #naiyo .price th, #top #contents #naiyo .price #price-table td, #top #contents #naiyo .price #pay-table td:first-child {
  font-weight: bold;
}
#top #contents #naiyo .price th, #top #contents #naiyo .price td {
  text-align: center;
  vertical-align: middle;
}
#top #contents #naiyo .price th:first-child, #top #contents #naiyo .price td:first-child {
  text-align: left;
}
#top #contents #naiyo .price .nouse {
  font-weight: bold;
  color: #d91515;
}
#top #contents #naiyo .price table {
  border-bottom: 1px solid #ddd;
  margin-bottom: 5px;
}
@media only screen and (max-width: 767px) {
  #top #contents #naiyo .price #price-table {
    display: block;
    width: 100%;
  }  #top #contents #naiyo .price #price-table thead {
    display: block;
    float: left;
  }  #top #contents #naiyo .price #price-table tbody {
    display: block;
    width: auto;
    margin: 0 3px;
  }  #top #contents #naiyo .price #price-table th, #top #contents #naiyo .price #price-table td {
    display: block;
    width: auto;
    text-align: center;
  }  #top #contents #naiyo .price #price-table td:first-child, #top #contents #naiyo .price #price-table th:first-child {
    text-align: center;
  }  #top #contents #naiyo .price #price-table tbody tr {
    display: inline-block;
    margin: 0 -3px;
    width: 50%;
  }}
#top #contents #info .capture {
  border: 1px solid #ddd;
}
#top #contents #info h4 {
  margin: 25px 0 10px;
  font-weight: bold;
  font-size: 1.1em;
}
#top #contents #info h4:before {
  content: "\f0c8";
  font-family: "fontAwesome";
  margin-right: 3px;
  color: #166592;
}
#top #contents #helpcall .titImg {
  margin-bottom: 25px;
}
@media only screen and (min-width: 768px) {
  #top #contents #helpcall .titImg {
    margin-bottom: 30px;
  }}
#top #contents #helpcall .flowList {
  margin-bottom: 30px;
}
#top #contents #helpcall .flowList li {
  clear: both;
  position: relative;
  overflow: hidden;
}
#top #contents #helpcall .flowList li + li {
  margin-top: 15px;
}
#top #contents #helpcall .flowList li h3 {
  position: relative;
  min-height: 27px;
  margin-bottom: 12px;
  padding-left: 35px;
  font-size: 1.2em;
  font-weight: bold;
  line-height: 1.5;
  background: url(../images/icon-no01.png) no-repeat left top;
  background-size: 27px;
}
#top #contents #helpcall .flowList li .pic {
  float: left;
  width: 46.21%;
  margin-right: 10px;
}
#top #contents #helpcall .flowList li:nth-of-type(2) h3 {
  background-image: url(../images/icon-no02.png);
}
#top #contents #helpcall .flowList li:nth-of-type(3) h3 {
  background-image: url(../images/icon-no03.png);
}
@media only screen and (min-width: 768px) {
  #top #contents #helpcall .flowList {
    margin-top: 30px;
    margin-bottom: 60px;
  }  #top #contents #helpcall .flowList li {
    min-height: 145px;
    padding-left: 235px;
  }  #top #contents #helpcall .flowList li + li {
    margin-top: 30px;
  }  #top #contents #helpcall .flowList li h3 {
    min-height: 35px;
    margin-top: 5px;
    margin-bottom: 20px;
    padding-left: 45px;
    font-size: 1.4em;
    background-size: 35px;
    letter-spacing: -0.05em;
  }  #top #contents #helpcall .flowList li .pic {
    position: absolute;
    left: 0;
    top: 0;
    width: 210px;
  }  #top #contents #helpcall .flowList li .txt {
    font-size: 1.1em;
    line-height: 1.67;
  }}
#top #contents #helpcall .info .img {
  margin: 20px 0;
}
@media only screen and (min-width: 768px) {
  #top #contents #helpcall .info {
    text-align: center;
  }  #top #contents #helpcall .info .img {
    margin: 25px 0 30px;
  }}
#top #contents #step .comment {
  text-align: right;
  font-size: 12px;
}
#top #contents #step .stepBox + .stepBox {
  margin-top: 15px;
  border-top: solid 1px #ddd;
}
#top #contents #step .stepBox h3 {
  margin-top: 20px;
}
#top #contents #step .stepBox h3 span {
  display: block;
  font-weight: inherit;
  padding-left: 22px;
  background: url(../images/icon-step01.png) no-repeat 0 0;
  background-size: 19px;
}
#top #contents #step .stepBox.step01 h3 {
  margin-top: 10px;
}
#top #contents #step .stepBox.step02 h3 span {
  background-image: url(../images/icon-step02.png);
}
#top #contents #step .stepBox.step03 h3 span {
  background-image: url(../images/icon-step03.png);
}
#top #contents #step .stepBox .notes {
  padding: 15px;
  border: solid 1px #166592;
  font-size: 0.9em;
  font-weight: bold;
  line-height: 1.58;
}
#top #contents #step .stepBox .notes span {
  color: #d00e05;
  font-weight: inherit;
}
@media only screen and (min-width: 768px) {
  #top #contents #step .stepBox + .stepBox {
    margin-top: 20px;
  }  #top #contents #step .stepBox h3 {
    margin-top: 30px;
    font-size: 1.4em;
  }  #top #contents #step .stepBox h3 span {
    padding-left: 30px;
    background-size: 24px;
  }  #top #contents #step .stepBox .notes {
    padding: 25px 30px;
    line-height: 1.67;
    font-size: 1.1em;
  }}
#top #contents #step .question dt {
  font-weight: bold;
  font-size: 1.1em;
  padding: 20px 0 20px 40px;
  line-height: 1.43;
  background: url(../images/faq-q.png) left 17px no-repeat;
}
#top #contents #step .question dd {
  padding: 15px 15px 15px 40px;
  line-height: 1.43;
  background-image: url(../images/faq-a.png), url(../images/bg-LightGrey.png);
  background-position: left 12px, center center;
  background-repeat: no-repeat, repeat;
}
@media only screen and (min-width: 768px) {
  #top #contents #step .question dt, #top #contents #step .question dd {
    font-size: 1.1em;
    line-height: 1.67;
  }  #top #contents #step .question dt {
    padding-top: 30px;
    padding-left: 45px;
    background-position: left 30px;
  }  #top #contents #step .question dd {
    padding: 20px 20px 20px 45px;
  }}
#top #contents #step .summery {
  padding: 15px;
  border: solid 1px #166592;
}
#top #contents #step .summery .txt {
  font-weight: bold;
}
#top #contents #step .summery .advice {
  margin: 15px 0;
  background: url(../images/helpcall-step03.png) no-repeat 0 0;
  background-size: 60px;
}
#top #contents #step .summery .advice .list {
  position: relative;
  margin-left: 80px;
  padding: 15px;
  border: solid 1px #d00e05;
  border-radius: 5px;
}
#top #contents #step .summery .advice .list:before {
  position: absolute;
  left: -15px;
  top: 10px;
  content: "";
  display: block;
  width: 15px;
  height: 12px;
  background: url(../images/helpcall-fukidashi.png) no-repeat 0 0;
  background-size: 100%;
}
#top #contents #step .summery .advice .list li {
  position: relative;
  padding-left: 15px;
  font-weight: bold;
}
#top #contents #step .summery .advice .list li:before {
  position: absolute;
  content: "・";
  display: block;
  left: 0;
  top: 0;
}
#top #contents #step .summery .case {
  margin-top: 15px;
  padding: 15px;
  background: #f0f1eb;
}
#top #contents #step .summery .case dt {
  margin-bottom: 5px;
  font-weight: bold;
  font-size: 1.1em;
  color: #166592;
}
@media only screen and (min-width: 768px) {
  #top #contents #step .summery {
    padding: 30px;
  }  #top #contents #step .summery .txt {
    font-size: 1.1em;
  }  #top #contents #step .summery .advice {
    margin: 30px 0;
    background-size: 100px;
    background-position: 30px 0;
  }  #top #contents #step .summery .advice .list {
    margin-left: 170px;
    padding: 20px 30px;
    border-width: 2px;
    border-radius: 10px;
    font-size: 1.1em;
  }  #top #contents #step .summery .advice .list:before {
    width: 30px;
    height: 25px;
    left: -30px;
  }  #top #contents #step .summery .advice .list li + li {
    margin-top: 5px;
  }  #top #contents #step .summery .case {
    margin-top: 30px;
    padding: 30px;
  }  #top #contents #step .summery .case dt {
    margin-bottom: 10px;
    font-size: 1.4em;
  }  #top #contents #step .summery .case dd {
    font-size: 1.1em;
  }}
#order #contents h2, #mypage #contents h2 {
  color: #166592;
  font-size: 1.6em;
  font-weight: bold;
  line-height: 1.3em;
}
#order #contents h2 span, #mypage #contents h2 span {
  background-color: #166592;
  color: #fff;
  padding: 4px 8px 3px;
  width: 1.5em;
  margin-right: 3px;
  border-radius: 50%;
}
#order #contents h3, #mypage #contents h3 {
  color: #166592;
  font-size: 1.2em;
  font-weight: bold;
  line-height: 1.3em;
  border-left: 5px solid #166592;
  border-bottom: 1px dotted #ddd;
  padding: 7px 7px 7px 10px;
  margin: 50px 0 15px;
}
#order #contents h3.required span, #mypage #contents h3.required span {
  font-size: 0.8em;
  color: #d91515;
  margin-left: 1em;
}
#order #contents h4, #mypage #contents h4 {
  font-weight: bold;
  margin-bottom: 10px;
  font-size: 1.1em;
  line-height: 1.3em;
}
#order #contents .attention, #mypage #contents .attention {
  color: #d91515;
  padding-left: 1em;
  text-indent: -1em;
}
#order #contents #product-name, #mypage #contents #product-name {
  font-weight: bold;
  font-size: 1.3em;
}
#order #contents table, #mypage #contents table {
  border-bottom: 1px solid #ddd;
}
#order #contents .link-list, #mypage #contents .link-list {
  padding-left: 1.2em;
}
#order #contents .dn-pdf a, #mypage #contents .dn-pdf a {
  text-decoration: underline;
}
#order #contents .dn-pdf:before, #mypage #contents .dn-pdf:before {
  content: "\f1c1";
  font-family: "fontAwesome";
  margin-right: 5px;
  color: #d91515;
}
#order #contents th, #mypage #contents th {
  background-color: #dce7ee;
  vertical-align: middle;
  font-weight: bold;
}
#order #contents .confirm-table th, #mypage #contents .confirm-table th {
  font-weight: bold;
}
#order #contents .confirm-table th, #order #contents .confirm-table td, #mypage #contents .confirm-table th, #mypage #contents .confirm-table td {
  vertical-align: middle;
}
#order #contents #price-table td, #order #contents #price-table th, #mypage #contents #price-table td, #mypage #contents #price-table th {
  text-align: center;
  font-weight: bold;
}
#order #contents #hosho-table td, #order #contents #hosho-table th, #mypage #contents #hosho-table td, #mypage #contents #hosho-table th {
  text-align: center;
  font-weight: bold;
}
#order #contents #hosho-table td:first-child, #order #contents #hosho-table th:first-child, #mypage #contents #hosho-table td:first-child, #mypage #contents #hosho-table th:first-child {
  text-align: left;
}
@media only screen and (max-width: 767px) {
  #order #contents #hosho-table, #mypage #contents #hosho-table {
    display: block;
    width: 100%;
  }  #order #contents #hosho-table thead, #mypage #contents #hosho-table thead {
    display: block;
    float: left;
  }  #order #contents #hosho-table tbody, #mypage #contents #hosho-table tbody {
    display: block;
    width: auto;
    margin: 0 3px;
  }  #order #contents #hosho-table th, #order #contents #hosho-table td, #mypage #contents #hosho-table th, #mypage #contents #hosho-table td {
    display: block;
    width: auto;
    text-align: center;
  }  #order #contents #hosho-table td:first-child, #order #contents #hosho-table th:first-child, #mypage #contents #hosho-table td:first-child, #mypage #contents #hosho-table th:first-child {
    text-align: center;
  }  #order #contents #hosho-table tbody tr, #mypage #contents #hosho-table tbody tr {
    display: inline-block;
    margin: 0 -3px;
    width: 50%;
  }}
#order #contents .order-table th, #mypage #contents .order-table th {
  text-align: center;
  font-weight: bold;
}
#order #contents .order-table td:first-child, #mypage #contents .order-table td:first-child {
  font-weight: bold;
}
#order #contents .btn-next, #mypage #contents .btn-next {
  text-align: center;
  margin-top: 50px;
}
#order #contents #setsumei-box, #mypage #contents #setsumei-box {
  background: #ddd;
  padding: 20px;
  position: relative;
  margin: 20px 0 10px;
  border-radius: 5px;
}
#order #contents #setsumei-box li, #mypage #contents #setsumei-box li {
  padding-left: 1.2em;
}
#order #contents #setsumei-box li:before, #mypage #contents #setsumei-box li:before {
  content: "\f111";
  font-family: "fontAwesome";
  margin-right: 3px;
  color: #166592;
}
#order #contents #input-hihokensha, #mypage #contents #input-hihokensha {
  display: none;
}
#order #contents #agree, #order #contents #agree2, #mypage #contents #agree, #mypage #contents #agree2 {
  text-align: center;
  margin-top: 30px;
}
#order #contents #agree .btn, #order #contents #agree2 .btn, #mypage #contents #agree .btn, #mypage #contents #agree2 .btn {
  font-size: 1.2em;
  font-weight: bold;
  color: #fff;
}
#order #contents #agree .btn-agree, #order #contents #agree2 .btn-agree, #mypage #contents #agree .btn-agree, #mypage #contents #agree2 .btn-agree {
  background-color: #d91515;
}
#order #contents #agree .btn-dissent, #order #contents #agree2 .btn-dissent, #mypage #contents #agree .btn-dissent, #mypage #contents #agree2 .btn-dissent {
  background-color: #999;
}
@media only screen and (min-width: 768px) {
  #order #contents #agree .btn-agree, #mypage #contents #agree .btn-agree {
    width: 12em;
  }  #order #contents #agree .btn-dissent, #mypage #contents #agree .btn-dissent {
    width: 8em;
  }  #order #contents #agree2 .btn-agree, #mypage #contents #agree2 .btn-agree {
    width: 15em;
  }  #order #contents #agree2 .btn-dissent, #mypage #contents #agree2 .btn-dissent {
    width: 8em;
  }}
@media only screen and (max-width: 767px) {
  #order #contents #agree .btn-agree, #order #contents #agree .btn-dissent, #order #contents #agree2 .btn-agree, #order #contents #agree2 .btn-dissent, #mypage #contents #agree .btn-agree, #mypage #contents #agree .btn-dissent, #mypage #contents #agree2 .btn-agree, #mypage #contents #agree2 .btn-dissent {
    width: 85%;
  }}
#order #contents .input-box, #mypage #contents .input-box {
  background-color: #ddd;
  padding: 20px;
  border-radius: 5px;
  margin-top: 15px;
}
#order #contents .input-box h4, #mypage #contents .input-box h4 {
  margin: 20px 0 5px;
  color: #166592;
}
#order #contents .input-box h4:first-child, #mypage #contents .input-box h4:first-child {
  margin-top: 0;
}
#order #contents .input-box p, #mypage #contents .input-box p {
  margin-bottom: 5px;
}
#order #contents .input-box .form-inline .form-control, #mypage #contents .input-box .form-inline .form-control {
  display: inline-block;
  width: auto;
  vertical-align: middle;
}
#order #contents .question, #mypage #contents .question {
  margin-top: 50px;
  padding: 20px;
  border: 1px solid #166592;
  border-radius: 5px;
}
#order #contents .question div, #mypage #contents .question div {
  padding: 10px 0;
  border-bottom: 1px dotted #ddd;
}
#order #contents .question div p, #order #contents .question div label, #mypage #contents .question div p, #mypage #contents .question div label {
  padding-left: 1.5em;
}
#order #contents .question .blue, #mypage #contents .question .blue {
  background-color: #ddd;
  padding: 15px;
  border-radius: 5px;
  border: none;
  margin-top: 30px;
}
#order #contents .question .blue h4, #mypage #contents .question .blue h4 {
  color: #166592;
}
#order #contents #flow, #order #contents #flow2 {
  margin-bottom: 40px;
}
@media only screen and (min-width: 768px) {
  #order #contents #flow #flow-header, #order #contents #flow2 #flow-header {
    background: #ecece9;
    border: 1px solid #aaa;
    overflow: hidden;
    width: 100%;
    font-size: 0.95em;
    border-radius: 5px;
  }  #order #contents #flow #flow-header li, #order #contents #flow2 #flow-header li {
    display: inline-table;
    width: 25%;
    padding: 10px 0 10px 1em;
    text-align: center;
    vertical-align: middle;
    float: left;
    text-decoration: none;
    color: #999;
    position: relative;
    background-color: #ecece9;
  }  #order #contents #flow #flow-header li:first-child, #order #contents #flow2 #flow-header li:first-child {
    padding-left: 0;
  }  #order #contents #flow #flow-header li:nth-child(2), #order #contents #flow2 #flow-header li:nth-child(2) {
    width: 33%;
  }  #order #contents #flow #flow-header li:last-child, #order #contents #flow2 #flow-header li:last-child {
    width: 17%;
  }  #order #contents #flow #flow-header li:after, #order #contents #flow #flow-header li:before, #order #contents #flow2 #flow-header li:after, #order #contents #flow2 #flow-header li:before {
    content: "";
    position: absolute;
    top: 50%;
    margin-top: -3em;
    border-top: 3em solid transparent;
    border-bottom: 3em solid transparent;
    border-left: 2em solid;
    right: -1em;
  }  #order #contents #flow #flow-header li:after, #order #contents #flow2 #flow-header li:after {
    z-index: 2;
    border-left-color: #ecece9;
  }  #order #contents #flow #flow-header li:before, #order #contents #flow2 #flow-header li:before {
    border-left-color: #aaa;
    right: -1.05em;
    z-index: 1;
  }  #order #contents #flow #flow-header li.current:after, #order #contents #flow2 #flow-header li.current:after {
    border-left-color: #d91515;
  }  #order #contents #flow #flow-header li.current, #order #contents #flow2 #flow-header li.current {
    background: #d91515;
    color: #fff;
  }  #order #contents #flow #flow-header li.last:after, #order #contents #flow #flow-header li.last:before, #order #contents #flow2 #flow-header li.last:after, #order #contents #flow2 #flow-header li.last:before {
    content: normal;
  }}
@media only screen and (max-width: 767px) {
  #order #contents #flow #flow-header, #order #contents #flow2 #flow-header {
    background: #ecece9;
    border: 1px solid #aaa;
    overflow: hidden;
    width: 100%;
    font-size: 0.95em;
    border-radius: 5px;
  }  #order #contents #flow #flow-header li, #order #contents #flow2 #flow-header li {
    padding: 5px 8px 5px 8px;
    background-color: #ecece9;
    border-bottom: 1px solid #aaa;
  }  #order #contents #flow #flow-header li:last-child, #order #contents #flow2 #flow-header li:last-child {
    border: 0;
  }  #order #contents #flow #flow-header li:first-child:before, #order #contents #flow2 #flow-header li:first-child:before {
    content: "[1] ";
  }  #order #contents #flow #flow-header li:nth-child(2):before, #order #contents #flow2 #flow-header li:nth-child(2):before {
    content: "[2] ";
  }  #order #contents #flow #flow-header li:nth-child(3):before, #order #contents #flow2 #flow-header li:nth-child(3):before {
    content: "[3] ";
  }  #order #contents #flow #flow-header li:last-child:before, #order #contents #flow2 #flow-header li:last-child:before {
    content: "[4] ";
  }  #order #contents #flow #flow-header li.current, #order #contents #flow2 #flow-header li.current {
    background: #d91515;
    color: #fff;
  }}
#order #contents #flow #flow-bottom, #order #contents #flow2 #flow-bottom {
  width: 100%;
  border: 1px solid #999;
  border-top: none;
  padding: 15px 0;
}
#order #contents #flow #flow-bottom li, #order #contents #flow2 #flow-bottom li {
  display: inline-table;
  font-size: 1.2em;
  font-weight: bold;
  color: #999;
  text-align: center;
  padding-left: 27px;
  padding-right: 17px;
  background: url(../images/flow-arrow.png) left center no-repeat;
}
#order #contents #flow #flow-bottom li span, #order #contents #flow2 #flow-bottom li span {
  background-color: #999;
  color: #fff;
  padding: 4px 7px;
  width: 1.3em;
  font-size: 0.9em;
  margin-right: 3px;
  border-radius: 50%;
}
#order #contents #flow #flow-bottom li:first-child, #order #contents #flow2 #flow-bottom li:first-child {
  background: none;
}
#order #contents #flow #flow-bottom li.current, #order #contents #flow2 #flow-bottom li.current {
  color: #d91515;
}
#order #contents #flow #flow-bottom li.current span, #order #contents #flow2 #flow-bottom li.current span {
  background-color: #d91515;
}
#order #contents #flow p, #order #contents #flow2 p {
  margin-top: 5px;
}
#order #contents #flow #flow-bottom li {
  width: 33%;
}
#order #contents #flow2 #flow-header {
  background-color: #d91515;
}
#mypage #contents section:first-child h3 {
  margin-top: 0;
}
#mypage #contents .mypage-table th, #mypage #contents .mypage-table td {
  padding: 10px;
}
#mypage #contents .mypage-table a {
  text-decoration: underline;
}
#mypage #contents .mypage-table .product-name, #mypage #contents .mypage-table .user-name {
  margin-right: 40px;
  font-weight: bold;
  font-size: 1.3em;
  color: #333;
}
@media only screen and (max-width: 767px) {
  #mypage #contents .mypage-table .product-name, #mypage #contents .mypage-table .user-name {
    margin: 0;
  }}
#mypage #contents .mypage-table .payment, #mypage #contents .mypage-table .keizoku {
  font-weight: bold;
}
#mypage #contents .mypage-table .payment {
  width: 9em;
  margin-right: 1em;
  display: inline-block;
}
#mypage #contents .mypage-table .kikan {
  margin-top: 5px;
  font-size: 0.9em;
}
.hosoku {
  font-size: 0.9em;
  padding-top: 15px;
}
/* Footer ----------------------------------------------------------------------*/
#footer {
  background-color: #fff;
  padding: 80px 0 20px;
  font-size: 0.8em;
  line-height: 1;
}
@media only screen and (max-width: 767px) {
  #footer {
    padding: 50px 0 70px;
  }}
#footer #footer-navi ul {
  letter-spacing: -.40em;
  /* 文字間を詰めて隙間を削除する */
}
#footer #footer-navi li {
  display: inline-block;
  border-left: 1px solid #ddd;
  padding: 0 5px;
  letter-spacing: normal;
}
#footer #footer-navi li:first-child {
  border-left: none;
  padding-left: 0;
}
@media only screen and (max-width: 767px) {
  #footer #footer-navi {
    text-align: center;
    margin-bottom: 10px;
  }}
#footer #copyright {
  text-align: right;
  font-size: 0.9em;
}
@media only screen and (max-width: 767px) {
  #footer #copyright {
    text-align: center;
  }}
/* SP Footer ----------------------------------------------------------------------*/
#sp-footer {
  bottom: 0;
  z-index: 999;
  position: fixed;
  background-color: #166592;
  text-align: center;
  width: 100%;
  box-shadow: 0 0 5px 0 #999;
}
#sp-footer ul {
  width: 100%;
  overflow: hidden;
}
#sp-footer li {
  float: left;
  display: block;
  text-align: center;
  width: 25%;
  padding: 10px;
  letter-spacing: normal;
}
#sp-footer li.user {
  background-color: #d91515;
}
#sp-footer a {
  display: block;
  color: #fff;
  line-height: 1.1em;
}
#sp-footer a i {
  font-size: 1.8em;
}
#sp-footer a span {
  font-size: 0.7em;
  display: block;
}
/* SP  ----------------------------------------------------------------------*/
#sp header, #sp footer p#copyright {
  text-align: center;
}
#sp #bookmark {
  font-size: 1.2em;
  font-weight: bold;
  text-decoration: underline;
}
#sp section {
  margin-top: 30px;
}
#sp .btn-red {
  background-color: #d91515;
  color: #fff;
  margin-top: 20px;
  width: 200px;
}
#sp .btn-red:hover {
  background-color: #ee4d4d;
}
#sp .btn-send {
  background-color: #d91515;
  font-weight: bold;
  font-size: 1.5em;
  padding: 15px 30px;
  display: inline-block;
  margin-top: 15px;
  width: 350px;
  border-radius: 10px;
  color: #fff;
  line-height: 1.3em;
  text-decoration: none;
}
#sp .btn-send:hover {
  background-color: #ee4d4d;
}
.btn {
  margin-bottom: 5px;
}
/* bounenkai
-------------------------------------------------*/
#top.bounenkai #contents #helpcall h2 {
  letter-spacing: 0;
}
.bounenkai .row {
  margin: 0;
}
.bounenkai #main-image {
  padding: 30px 0;
  background-size: auto 100%;
}
.bounenkai #intro h1 {
  margin: 50px auto 20px;
}
.bounenkai #helpcall {
  border-bottom: solid 1px #efefef;
  background: url(../images/bg-LightGrey.png) center center;
}
.bounenkai #helpcall h2 {
  letter-spacing: 0;
}
.bounenkai #helpcall .info .catch {
  margin-bottom: 30px;
}
.bounenkai #helpcall .info .list {
  margin-bottom: 30px;
}
.bounenkai #helpcall .info .list .item {
  width: auto;
  padding: 0;
}
.bounenkai #helpcall .info .list .item + .item {
  margin-left: 7px;
}
.bounenkai #trouble {
  margin-bottom: 60px;
}
.bounenkai #trouble .lead {
  margin: 30px 0 40px;
  font-weight: bold;
  line-height: 1.96;
  letter-spacing: 0.06em;
  font-size: 1.3em;
}
.bounenkai #trouble .lead span {
  font-weight: bold;
  color: #166592;
}
.bounenkai #trouble .lead span span {
  position: relative;
}
.bounenkai #trouble .lead span span:before {
  position: absolute;
  top: -5px;
  left: 50%;
  display: block;
  content: "";
  width: 5px;
  height: 5px;
  margin-left: -2px;
  border-radius: 50%;
  background: #166592;
}
.bounenkai #trouble .list > div {
  padding: 0;
}
.bounenkai #trouble .list .item {
  text-align: center;
}
.bounenkai #trouble .list .item figcaption {
  font-weight: bold;
}
.bounenkai #trouble .after {
  margin: 40px 0;
  font-size: 1.5em;
  font-weight: bold;
  color: #166592;
}
.bounenkai #trouble .after:before {
  position: relative;
  width: 100%;
  height: 30px;
  margin-bottom: 30px;
  text-align: center;
  background: url(../images/img_arrow01.png) no-repeat 50% 0;
  background-size: auto 100%;
  display: block;
  content: "";
}
.bounenkai #trouble .graph {
  padding: 50px 0 40px;
  background: #fff;
  text-align: center;
}
.bounenkai #trouble .graph .img {
  margin-bottom: 20px;
}
.bounenkai #trouble .graph .txt {
  font-weight: bold;
  font-size: 1.2em;
}
.bounenkai #trouble .graph .txt em {
  font-weight: bold;
  color: #ce0c03;
}
.bounenkai #free h3 {
  margin-bottom: 20px;
}
.bounenkai #free dt,
.bounenkai #free dd {
  display: inline-block;
  vertical-align: top;
}
.bounenkai #free .read {
  margin-bottom: 20px;
}
@media only screen and (max-width: 767px) {
  .bounenkai #main-image {
    background-repeat: repeat;
  }  .bounenkai #intro .notes {
    margin-bottom: 20px;
    text-align: left;
  }  .bounenkai #helpcall .info .list .item + .item {
    margin-left: 0;
    margin-top: 5px;
  }  .bounenkai #trouble .lead {
    line-height: 1.5;
    margin: 10px 0 15px;
  }  .bounenkai #trouble .lead > span {
    display: inline-block;
    margin-top: 5px;
  }  .bounenkai #trouble .list > div + div {
    margin-top: 15px;
  }  .bounenkai #trouble .list > div .item {
    padding: 0 5px;
  }  .bounenkai #trouble .after {
    margin: 15px 0 20px;
    font-size: 1.3em;
    line-height: 1.5;
  }  .bounenkai #trouble .after:before {
    height: 20px;
    margin-bottom: 15px;
  }  .bounenkai #trouble .graph {
    padding: 15px;
  }  .bounenkai #trouble .graph .txt {
    text-align: left;
    font-size: 1em;
  }  .bounenkai #free .box {
    margin: 0;
  }}
/* shinnenkai
-------------------------------------------------*/
#top.shinnenkai #main-image {
  background: url(../images/bg-main02.png) center top repeat-x;
  background-size: auto 240px;
}

@media only screen and (min-width: 768px) {
  #top.shinnenkai #main-image {background-size: auto 330px;}
}

/* 201911 */ 
#top-btn-season{text-align: center;}

@media only screen and (min-width: 768px) {
	#top #main-image h1{margin: 40px 100px 60px;}
	#top-intro{margin-top: 80px;}
	#top #contents #top-intro .read{text-align: center; margin-top: 20px;}
	.btn-list li{display: inline-block; width: 49%;}
	#top-btn-season p{text-align: right;}
}

@media only screen and (max-width: 767px) {
	#top #main-image h1{margin: 20px 20px 40px;}
	#top #contents #top-intro .read{margin-top: 20px;}
}
