@charset "UTF-8";
.pcOnly {
  display: inherit; }
  @media screen and (max-width: 640px) {
    .pcOnly {
      display: none; } }

.spOnly {
  display: none; }
  @media screen and (max-width: 640px) {
    .spOnly {
      display: inherit; } }

* {
  box-sizing: border-box; }

img {
  max-width: 100%; }

body, div, pre, p, blockquote, form, fieldset, input, textarea, select, option, dl, dt, dd, ol, li, h1, h2, h3, h4, h5, h6, table, th, td, embed, object, img, figure {
  margin: 0;
  padding: 0; }

article, aside, canvas, details, figcaption, figure, header, footer, main, menu, nav, section, summary {
  display: block; }

*,
*:before,
*:after {
  box-sizing: border-box;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box; }

html {
  font-size: 62.5%;
  position: relative;
  /*over wifth*/
  overflow: auto;
  /*background gradient*/
  min-height: 100%; }

body {
  font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  color: #29263B;
  font-size: 1.6rem;
  line-height: 1.5;
  background: #FFF;
  background-size: contain;
  /*over width*/
  overflow-x: hidden;
  position: relative; }

#wrap {
  max-width: 940px;
  margin: 0 auto; }

main {
  margin: 0 0;
  padding: 0;
  background: #FFF; }

.over_width {
  /*over wifth*/
  margin-left: -500%;
  margin-right: -500%;
  padding-left: 500%;
  padding-right: 500%; }

/*=========================================
site link color
=========================================*/
a {
  color: #C0CC00;
  text-decoration: none; }

a:hover {
  text-decoration: underline; }

/*=========================================
title
=========================================*/
h2, h3, h4, h5, h6 {
  font-style: normal;
  font-weight: normal;
  font-size: 1.8rem;
  margin: 2rem 0; }

h2 {
  padding: .5em;
  border: 3px solid #1E4145;
  border-radius: 8px;
  font-size: 2.4rem;
  font-weight: bold;
  background: #1E4145;
  text-align: center;
  color: #FFF; }
  @media screen and (max-width: 640px) {
    h2 {
      font-size: 5.6vw; } }

/*小見出し*/
h3 {
  padding: .3em;
  border-bottom: 1px solid #fff;
  font-size: 2rem;
  font-weight: bold;
  color: #fff; }

/*注意文言内見出し*/
h4 {
  padding: .5rem;
  color: #fff; }

/*=========================================
flex list
=========================================*/
.flex, .flex-center {
  display: flex;
  flex-wrap: wrap; }

.flex-nowp {
  display: flex;
  flex-wrap: nowrap; }

.flex-center {
  justify-content: center;
  align-items: center; }

/*item*/
.flex-item-center {
  align-items: center; }

.flex-item-start {
  align-items: flex-start; }

/*justify-content*/
.justify-content-center {
  justify-content: center; }

.justify-content-between {
  justify-content: space-between; }

.justify-content-around {
  justify-content: space-around; }

.justify-content-flex-end {
  justify-content: flex-end; }

/*=========================================
common
=========================================*/
img, figure, video {
  border: none;
  vertical-align: bottom; }

hr {
  height: 0;
  padding: 0;
  border: 0;
  margin: 10px 0;
  border-top: 1px solid rgba(0, 0, 0, 0.9);
  border-bottom: 1px solid rgba(255, 255, 255, 0.3); }

.width_full {
  width: -webkit-fill-available;
  width: -moz-available; }

pre {
  text-align: justify;
  overflow-wrap: break-word;
  word-wrap: break-word;
  white-space: pre-wrap;
  overflow: auto;
  font-family: inherit; }

/* plan
--------------------------------------------------*/
.view_plan {
  text-align: center; }

.view_plan img {
  max-width: 100%; }

/* table common
--------------------------------------------------*/
table img {
  vertical-align: bottom; }

table.tbl_fixed {
  table-layout: fixed; }

/* dl_base common
--------------------------------------------------*/
/*商品説明用*/
dl.dl_base dd:empty {
  display: none; }

/* text
--------------------------------------------------*/
div[class^="txt_"],
span[class^="txt_"],
p[class^="txt_"] {
  vertical-align: middle; }

.txt_s {
  font-size: 90%; }

.txt_ss {
  font-size: 80%; }

.txt_l {
  font-size: 120%; }

.txt_ll {
  font-size: 3rem;
  font-weight: bold; }

/*company*/
.txt_noselect {
  user-select: none;
  -moz-user-select: none;
  /* Firefox */
  -ms-user-select: none;
  /* Internet Explorer */
  -khtml-user-select: none;
  /* KHTML browsers (e.g. Konqueror) */
  -webkit-user-select: none;
  /* Chrome, Safari, and Opera */
  -webkit-touch-callout: none;
  /* Disable Android and iOS callouts*/ }

.txt_red {
  color: #ED6C24; }

.txt_line {
  background: #1E4145;
  color: #fff;
  padding: 5px; }

/* align
--------------------------------------------------*/
.ta_c {
  text-align: center; }

.ta_r {
  text-align: right; }

.ta_l {
  text-align: left; }

/*=========================================
message list
=========================================*/
/*msg_
--------------------------------------------------*/
div[class^="msg_"],
p[class^="msg_"] {
  margin: 20px;
  padding: 10px; }

div[class^="msg_"]:empty,
p[class^="msg_"]:empty {
  display: none; }

/*msg_warning*/
.msg_warning {
  display: block;
  text-align: center;
  background: #790b0b;
  color: #ffffff;
  padding: 10px; }

.msg_warning a {
  color: #ffffff; }

/*isystem-
--------------------------------------------------*/
div[id^="isystem-"],
p[id^="isystem-"] {
  display: block; }

div[id^="isystem-"]:empty,
p[id^="isystem-"]:empty {
  display: none; }

/*isystem-regist_word…登録系メッセージ*/
#isystem-regist_word {
  margin: 2rem auto;
  padding: 1rem;
  width: 90%;
  background: #fff;
  color: #000; }

/*=========================================
input
=========================================*/
input[type="submit"], button {
  cursor: pointer; }

select, input, textarea, button {
  font-family: inherit;
  vertical-align: middle; }

/* type="image"
--------------------------------------------------*/
input[type="image"] {
  display: block;
  margin: 2rem auto; }

/* submit
--------------------------------------------------*/
/*pay/select*/
div[class="payments_block"] input[type="submit"],
input[name="submit[btn][pay_bankagent][add]"],
input[name="submit[btn][pay_bitcash][add]"],
input[name="submit[btn][pay_credit][add]"],
input[name="submit[btn][pay_netbank][add]"],
input[name="submit[btn][pay_point][add]"],
input[name="submit[btn][user_detail_info][set]"],
form[name="user_login_frm"] input[name="submit[btn][doLogin][get]"],
form[name$="_pay"] input[type="submit"],
td.tbl_btn a,
.css_btn {
  border: none;
  /*reset*/
  display: block;
  margin: 1em auto !important;
  width: 80%;
  padding: 10px;
  font-size: 2rem;
  color: #fff !important;
  text-align: center;
  font-weight: bold;
  border-radius: 10px;
  /*bg*/
  background: #820000; }

/*pay/select*/
div[class="payments_block"] input[type="submit"]:hover,
input[name="submit[btn][pay_bankagent][add]"]:hover,
input[name="submit[btn][pay_bitcash][add]"]:hover,
input[name="submit[btn][pay_credit][add]"]:hover,
input[name="submit[btn][pay_netbank][add]"]:hover,
input[name="submit[btn][pay_point][add]"]:hover,
input[name="submit[btn][user_detail_info][set]"]:hover,
form[name="user_login_frm"] input[name="submit[btn][doLogin][get]"]:hover,
form[name$="_pay"] input[type="submit"]:hover,
td.tbl_btn a:hover,
.css_btn :hover {
  /*bg*/
  background: #87009F; }

/*=========================================
pay
=========================================*/
/* select
--------------------------------------------------*/
.payments_block {
  margin: 2rem 0;
  padding: 1rem;
  background: #333333; }

/* agree
--------------------------------------------------*/
.agree_submit {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: center; }

form[name="agree_frm"] input[type="submit"], form[name="agree_frm"] input[type="button"] {
  display: block;
  padding: 5px;
  margin: 5px;
  width: 40%;
  height: 50px;
  font-size: 2rem; }

/*=========================================
table
=========================================*/
/* tbl_base
--------------------------------------------------*/
.tbl_base input {
  display: block;
  margin: 0 auto;
  width: 80%; }

.tbl_base {
  width: 100%;
  border-collapse: collapse;
  border-right: 1px solid #fff;
  border-bottom: 1px solid #fff;
  border-top: 1px solid #fff;
  color: #ffffff; }

.tbl_base th, .tbl_base td {
  padding: .5em; }

.tbl_base th {
  background-color: #1E4145;
  border-left: 1px solid #fff;
  border-top: 1px solid #fff;
  white-space: nowrap; }

.tbl_base td {
  background-color: #E8E8E8;
  border-left: 1px solid #fff;
  border-bottom: 1px solid #fff;
  color: #000; }

.tbl_base td a {
  color: #0E4272; }

/*隣接する場合余白*/
.tbl_base + .tbl_base {
  margin: 20px 0; }

/*=========================================
dl
=========================================*/
dl.dl_base dt {
  padding: 5px;
  margin-bottom: 5px;
  color: #FFFFFF;
  font-weight: bold;
  background: #1E4145;
  text-indent: 1rem; }

dl.dl_base dd {
  padding: 10px 0 10px 10px;
  margin-bottom: 1rem;
  border-left: 2px solid #7C7C7C;
  text-align: justify;
  overflow-wrap: break-word;
  word-wrap: break-word; }

/*=========================================
header
=========================================*/
header table td {
  text-align: center; }

header {
  padding: 2rem 0;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: space-between;
  align-items: center;
  -ms-align-items: center;
  background-image: -moz-linear-gradient(-90deg, #420000 0%, #030000 100%);
  background-image: -webkit-linear-gradient(-90deg, #420000 0%, #030000 100%);
  background-image: -ms-linear-gradient(-90deg, #420000 0%, #030000 100%); }

header h1 {
  margin-right: 5rem; }

/*=========================================
animation
=========================================*/
.parent {
  position: relative; }

.animation {
  animation-timing-function: ease-in-out;
  animation-iteration-count: infinite;
  animation-direction: alternate;
  animation-duration: 1.5s; }

/*1*/
.keyframe1 {
  animation-name: anim_v; }

@keyframes anim_v {
  0% {
    transform: translate(0, 0px); }
  100% {
    transform: translate(0, -15px); } }
/*5*/
.keyframe5 {
  animation-name: anim_sc;
  transform: scale(0.85, 0.85); }

@keyframes anim_sc {
  100% {
    transform: scale(1, 1); } }
/*=========================================
def index
=========================================*/
 /* hero
--------------------------------------------------*/
.hero {
  width: 100%;
  position: relative;
  overflow: hidden;
  height: 1000px;
  background: #000; }
  @media screen and (max-width: 640px) {
    .hero {
      height: 0;
      padding-top: 120%; } }

video {
  display: block;
  width: 100%;
  /* 背景画像の高さ */
  height: 655px;
  /* 高さを維持したまま全体を表示させる */
  object-fit: cover;
  position: absolute;
  left: 0;
  bottom: 0; }
  @media screen and (max-width: 640px) {
    video {
      height: auto;
      width: 150%;
      left: -25%; } }

.card_all {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  /* レイヤー背景の上に乗せる */
  z-index: 3;
  margin: auto;
  width: 100%; }

.card_ct {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  /* レイヤー背景の上に乗せる */
  z-index: 5;
  margin: auto;
  width: 30%; }

.hero_txt {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  /* レイヤー背景の上に乗せる */
  z-index: 10;
  margin: auto; }

 /* section_entryform
--------------------------------------------------*/
.regist_form {
  margin: 3rem 0;
  padding: 2rem;
  /*bg*/
  background: #D3D3D3; }

.section_entryform {
  text-align: center;
  color: #000; }

.section_entryform input[type="text"] {
  width: 100%;
  padding: 20px;
  font-size: 3rem;
  text-align: center;
  margin-top: 4rem; }

/* domein
--------------------------------------------------*/
.domein {
  padding: 2rem;
  margin: 2rem 0;
  background: #D3D3D3;
  color: #000; }

.domein_wrap {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: space-around; }

/*=========================================
user index
=========================================*/
/* section_info
--------------------------------------------------*/
.section_info {
  color: #000;
  padding: 1rem 1rem 1rem 310px;
  margin: 3rem 0;
  width: 100%;
  background: url("../img/info_bg.jpg") no-repeat; }

.section_info .txt_ll {
  font-size: 4rem !important;
  line-height: 1.3;
  margin: 1rem 0; }

/* section_result
--------------------------------------------------*/
.section_result {
  margin-top: 3rem;
  margin-bottom: 3rem;
  padding-top: 3rem;
  padding-bottom: 3rem;
  /*bg*/
  background: #000000 top center url("../img/result_bg.jpg") repeat; }

.result_detail_wrap {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap; }

.result_detail {
  padding: 1rem;
  margin: 1rem;
  width: calc(100% / 2 - 2rem);
  text-align: center;
  /*bg*/
  background-image: -moz-linear-gradient(90deg, black 0%, #2a0a88 100%);
  background-image: -webkit-linear-gradient(90deg, black 0%, #2a0a88 100%);
  background-image: -ms-linear-gradient(90deg, black 0%, #2a0a88 100%); }

.money {
  background: #980072;
  font-size: 5rem;
  font-weight: bold;
  margin: 1rem; }

img.result_title {
  width: 100%; }

/*=========================================
add
=========================================*/
/* question(よくある質問)
--------------------------------------------------*/
dl.question {
  color: black; }

dl.question dt {
  cursor: pointer;
  padding: 5px;
  margin-bottom: 10px;
  font-weight: bold;
  color: #ffffff;
  background: #1E4145;
  display: flex;
  align-items: center; }

dl.question dt.active {
  background: #2D7B76; }

dl.question dd {
  position: relative;
  padding: 0 5px;
  margin-bottom: 10px; }

dl.question span {
  display: inline-block;
  padding: 3px 7px;
  margin-right: 1rem;
  color: #fff;
  font-size: 2.3rem;
  line-height: 1; }

dl.question dt span {
  background: #ED6C24; }

dl.question dd pre {
  display: flex;
  align-items: flex-start; }

dl.question dd span {
  background: #1E4145;
  font-weight: bold; }

/* chara
--------------------------------------------------*/
.section_chara {
  padding: 1rem;
  border-top: 1px solid #970091;
  border-left: 1px solid #970091;
  border-right: 2px solid #660362;
  border-bottom: 2px solid #660362;
  background-image: -moz-linear-gradient(90deg, #3b0043 0%, black 100%);
  background-image: -webkit-linear-gradient(90deg, #3b0043 0%, black 100%);
  background-image: -ms-linear-gradient(90deg, #3b0043 0%, black 100%);
  color: #fff;
  margin-bottom: 2rem; }

.chara_info {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  padding: 2rem 0;
  flex-wrap: wrap;
  justify-content: space-between; }
  .chara_info > div {
    width: 78%; }
    @media screen and (max-width: 640px) {
      .chara_info > div {
        width: 100%; } }
  .chara_info figure {
    width: 20%; }
    @media screen and (max-width: 640px) {
      .chara_info figure {
        width: 100%;
        text-align: center;
        margin-bottom: 1.5em; } }
    .chara_info figure img {
      max-height: 300px;
      width: auto; }
  .chara_info .tbl_base {
    margin-top: 1em; }
    .chara_info .tbl_base th {
      width: 30%; }
      @media screen and (max-width: 640px) {
        .chara_info .tbl_base th {
          display: block;
          width: 100%;
          white-space: normal;
          text-align: center; } }
    @media screen and (max-width: 640px) {
      .chara_info .tbl_base td {
        display: block;
        width: 100%;
        text-align: center; } }

/*name*/
.name {
  font-family: 'ヒラギノ明朝 Pro W3', 'Hiragino Mincho Pro', '游明朝','Yu Mincho', '游明朝体', 'YuMincho','ＭＳ Ｐ明朝', 'MS PMincho', serif;
  font-size: 5rem;
  font-weight: bold;
  line-height: 1;
  color: #ED6C24;
  display: inline;
  margin-right: .5em; }
  @media screen and (max-width: 640px) {
    .name {
      font-size: 8vw;
      display: block;
      text-align: center;
      margin-right: 0; } }

.name2 {
  color: #ED6C24;
  display: inline; }
  @media screen and (max-width: 640px) {
    .name2 {
      display: block;
      text-align: center; } }

/*=========================================
lp
=========================================*/
section {
  margin: 0 auto 3em; }

#sec02 h3 {
  font-size: 2.2rem;
  padding: .5em 1em;
  margin: 0 0 1em;
  border: 3px dotted #2D7B76;
  border-radius: 8px;
  color: #2D7B76;
  text-align: center; }
  @media screen and (max-width: 640px) {
    #sec02 h3 {
      font-size: 4.8vw;
      text-align: center; } }
  #sec02 h3 .result-subtitle {
    font-size: 1.8rem; }
    @media screen and (max-width: 640px) {
      #sec02 h3 .result-subtitle {
        display: block;
        font-size: 4vw; } }
@media screen and (max-width: 640px) {
  #sec02 ul {
    padding: 0; } }
#sec02 ul li {
  margin-bottom: 3em; }
  #sec02 ul li:last-of-type {
    margin-bottom: 0; }
  #sec02 ul li .result-wrap {
    display: flex;
    justify-content: space-between;
    background: #000; }
    #sec02 ul li .result-wrap dl {
      width: 48%; }
      #sec02 ul li .result-wrap dl dt {
        display: block;
        position: relative;
        height: 4em;
        line-height: 4em;
        text-align: center;
        padding: 7px 0;
        font-size: 1.8rem;
        /*フォントサイズ*/
        background: #2D7B76;
        /*背景色*/
        color: #1E4145;
        /*文字色*/
        box-sizing: border-box;
        margin: 0 auto;
        z-index: 3; }
        #sec02 ul li .result-wrap dl dt h4 {
          margin: 0;
          padding: 0 1em;
          border-top: dashed 1px #1E4145;
          /*上の破線*/
          border-bottom: dashed 1px #1E4145;
          /*下の破線*/
          line-height: calc(4em - 14px);
          font-weight: bold;
          text-align: center; }
      #sec02 ul li .result-wrap dl dd {
        padding: 2em 2em 2em;
        position: relative;
        background-color: rgba(0, 0, 0, 0);
        background-image: repeating-linear-gradient(45deg, rgba(175, 95, 0, 0.7) 0px 12px, transparent 12px 24px), repeating-linear-gradient(-45deg, rgba(175, 95, 0, 0.7) 0px 12px, transparent 12px 24px); }
        @media screen and (max-width: 640px) {
          #sec02 ul li .result-wrap dl dd {
            padding: 4%; } }
        #sec02 ul li .result-wrap dl dd table {
          background-color: #FFF;
          border: 1px solid #29263B;
          border-collapse: collapse;
          width: 100%;
          margin: 0 auto; }
          #sec02 ul li .result-wrap dl dd table tbody tr th, #sec02 ul li .result-wrap dl dd table tbody tr td {
            border: 1px solid #29263B;
            padding: .5em 1em;
            text-align: center; }
            @media screen and (max-width: 640px) {
              #sec02 ul li .result-wrap dl dd table tbody tr th, #sec02 ul li .result-wrap dl dd table tbody tr td {
                display: block; } }
          #sec02 ul li .result-wrap dl dd table tbody tr th {
            width: 35%;
            background: #1E4145;
            color: #FFF;
            font-weight: bold; }
            @media screen and (max-width: 640px) {
              #sec02 ul li .result-wrap dl dd table tbody tr th {
                width: 100%; } }
          #sec02 ul li .result-wrap dl dd table tbody tr td {
            color: #29263B; }
            @media screen and (max-width: 640px) {
              #sec02 ul li .result-wrap dl dd table tbody tr td {
                width: 100%; } }
        #sec02 ul li .result-wrap dl dd figure {
          text-align: center;
          margin: 0 auto 1em;
          position: relative; }
          #sec02 ul li .result-wrap dl dd figure img {
            width: 80%;
            max-width: inherit; }
            @media screen and (max-width: 640px) {
              #sec02 ul li .result-wrap dl dd figure img {
                width: 100%; } }
          #sec02 ul li .result-wrap dl dd figure figcaption {
            display: inline-block;
            position: absolute;
            text-align: center;
            box-sizing: border-box;
            left: 0;
            right: 0;
            bottom: 1.5em; }
            @media screen and (max-width: 640px) {
              #sec02 ul li .result-wrap dl dd figure figcaption {
                position: relative;
                margin-top: -1.5em;
                bottom: 0; } }
            #sec02 ul li .result-wrap dl dd figure figcaption::before {
              content: '';
              position: absolute;
              width: 10px;
              bottom: -10px;
              left: -35px;
              z-index: 1;
              border: 20px solid #ff601f;
              border-left-color: transparent;
              /*山形に切り抜き*/ }
            #sec02 ul li .result-wrap dl dd figure figcaption::after {
              content: '';
              position: absolute;
              width: 10px;
              bottom: -10px;
              right: -35px;
              z-index: 1;
              border: 20px solid #ff601f;
              border-right-color: transparent;
              /*山形に切り抜き*/ }
            #sec02 ul li .result-wrap dl dd figure figcaption .caption-wrap {
              display: block;
              position: relative;
              margin: 0;
              padding: .5em .5em;
              line-height: 1.5;
              color: #FFF;
              background: #ED6C24;
              /*真ん中の背景色*/
              overflow: visible;
              z-index: 2;
              text-align: center; }
              #sec02 ul li .result-wrap dl dd figure figcaption .caption-wrap::before {
                position: absolute;
                content: '';
                top: 100%;
                left: 0;
                border: none;
                border-bottom: solid 10px transparent;
                border-right: solid 15px #a53e14;
                /*左の折り返し部分*/ }
              #sec02 ul li .result-wrap dl dd figure figcaption .caption-wrap::after {
                position: absolute;
                content: '';
                top: 100%;
                right: 0;
                border: none;
                border-bottom: solid 10px transparent;
                border-left: solid 15px #a53e14;
                /*右の折り返し部分*/ }
              #sec02 ul li .result-wrap dl dd figure figcaption .caption-wrap .result-val {
                display: inline-block;
                padding: 0 .5em;
                font-size: 2.4rem;
                font-weight: bold; }
                @media screen and (max-width: 640px) {
                  #sec02 ul li .result-wrap dl dd figure figcaption .caption-wrap .result-val {
                    font-size: 4.4vw; } }
#sec02 .important, #sec02 .important2 {
  text-align: center !important;
  font-weight: 800;
  font-size: 2.4rem;
  line-height: 2em;
  margin: 0 auto 1em; }
  @media screen and (max-width: 640px) {
    #sec02 .important, #sec02 .important2 {
      font-size: 4.8vw; } }
  #sec02 .important .under, #sec02 .important2 .under {
    background: -webkit-gradient(linear, left top, left bottom, color-stop(0.8, #ED6C24), color-stop(0.79, rgba(0, 0, 0, 0)));
    background: -webkit-linear-gradient(top, rgba(0, 0, 0, 0) 79%, #ED6C24 80%);
    background: -moz-linear-gradient(top, rgba(0, 0, 0, 0) 79%, #ED6C24 80%);
    background: -o-linear-gradient(top, rgba(0, 0, 0, 0) 79%, #ED6C24 80%);
    background: -ms-linear-gradient(top, rgba(0, 0, 0, 0) 79%, #ED6C24 80%);
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 79%, #ED6C24 80%); }
    #sec02 .important .under .under_large, #sec02 .important2 .under .under_large {
      color: #eb3160;
      font-size: 3.2rem; }
      @media screen and (max-width: 640px) {
        #sec02 .important .under .under_large, #sec02 .important2 .under .under_large {
          font-size: 6.4vw; } }
  #sec02 .important img, #sec02 .important2 img {
    margin-top: 2em; }
#sec02 .important {
  margin-top: -2em; }

/*========================================
Order
========================================*/
.Order {
  margin: 0 auto 8%;
  text-align: center;
  padding: 1%;
  background: #000;
  max-width: 960px; }
  .Order h1 {
    margin: 0 auto;
    max-width: 800px;
    text-align: center; }
    .Order h1 img {
      width: 100%;
      max-width: 570px; }
  .Order .catalogpriceWrap {
    padding: 1em;
    border: 3px solid #2D7B76;
    color: #000;
    width: 80%;
    max-width: 640px;
    margin: 0 auto 4%; }
    .Order .catalogpriceWrap .catalogpriceLabel {
      margin: 0 auto 2%;
      color: #2D7B76;
      font-size: 2.4rem;
      font-weight: bold; }
      @media screen and (max-width: 640px) {
        .Order .catalogpriceWrap .catalogpriceLabel {
          font-size: 4.8vw; } }
    .Order .catalogpriceWrap .catalogpricePrice {
      color: #ED6C24;
      font-size: 3.6rem;
      font-weight: bold;
      text-decoration: line-through; }
      .Order .catalogpriceWrap .catalogpricePrice span {
        color: #2D7B76; }
    .Order .catalogpriceWrap .catalogpriceText {
      margin: 0 auto 1em;
      color: #2D7B76;
      font-size: 2.4rem;
      font-weight: bold; }
      @media screen and (max-width: 640px) {
        .Order .catalogpriceWrap .catalogpriceText {
          font-size: 4.8vw; } }
    .Order .catalogpriceWrap .discountrateText {
      background: #ED6C24;
      padding: 1em; }
      .Order .catalogpriceWrap .discountrateText .discountrateNum {
        color: #000;
        font-size: 4rem;
        font-weight: bold;
        line-height: 0.8;
        line-height: 1; }
        .Order .catalogpriceWrap .discountrateText .discountrateNum span {
          font-size: 1.8rem;
          font-weight: bold; }
  .Order .termWrap {
    position: relative;
    z-index: 0; }
    .Order .termWrap .termText {
      margin: 0 auto .5em;
      color: #2D7B76;
      font-size: 3.6rem;
      font-weight: bold; }
      @media screen and (max-width: 640px) {
        .Order .termWrap .termText {
          font-size: 7.2vw; } }
  .Order .priceWrap {
    width: 100%;
    margin: 0 auto 4%;
    position: relative; }
    .Order .priceWrap .unitpriceWrap {
      width: 100%;
      z-index: 1; }
      .Order .priceWrap .unitpriceWrap .unitpriceImg {
        max-width: 311px;
        width: 40%;
        position: absolute;
        right: 0;
        top: -80%; }
        @media screen and (max-width: 640px) {
          .Order .priceWrap .unitpriceWrap .unitpriceImg {
            right: -4%;
            top: -40%;
            z-index: 3; } }
    .Order .priceWrap .salespriceWrap .salespriceNum {
      font-family: 'Roboto', sans-serif;
      font-size: 12rem;
      font-weight: 900;
      color: #FF7C00;
      margin: auto;
      position: relative;
      z-index: 2;
      background: -webkit-linear-gradient(top, #FFB76B 0%, #FFA73D 50%, #FF7C00 51%, #FF7F04 100%);
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      -webkit-text-stroke-width: 2px;
      -webkit-text-stroke-color: #FFF; }
      .Order .priceWrap .salespriceWrap .salespriceNum span {
        font-size: 50%; }
      @media screen and (max-width: 640px) {
        .Order .priceWrap .salespriceWrap .salespriceNum {
          font-size: 24vw; } }
  .Order .limitedWrap {
    margin: 0 auto 4%; }
    .Order .limitedWrap .limitedNum {
      font-size: 2.4rem;
      color: #ED6C24;
      font-weight: bold; }
      @media screen and (max-width: 640px) {
        .Order .limitedWrap .limitedNum {
          font-size: 4.8vw; } }
  .Order .entryWrap {
    margin: 0 auto 2em; }
    .Order .entryWrap a {
      display: block;
      padding: 0.5em 1em;
      background: -moz-linear-gradient(top, #ff9900 0%, #FFCC00 50%, #FF9900 50%, #ff9900 100%);
      background: -webkit-linear-gradient(top, #ff9900 0%, #FFCC00 50%, #FF9900 50%, #ff9900 100%);
      background: linear-gradient(to bottom, #ff9900 0%, #FFCC00 50%, #FF9900 50%, #ff9900 100%);
      text-shadow: 0px 2px 4px #996600;
      margin: 0 auto;
      border: 3px solid #FC0;
      border-radius: 0.5em;
      color: #FFFFFF;
      font-weight: bold;
      box-sizing: border-box;
      font-size: 2rem;
      line-height: 1.2;
      text-decoration: none;
      width: 90%; }
    .Order .entryWrap a:hover {
      opacity: 0.7; }
    .Order .entryWrap a i {
      font-size: 200%;
      vertical-align: middle;
      position: relative;
      top: -0.1em;
      padding-right: 0.1em; }
  .Order .paymentWrap p {
    text-align: center; }
    .Order .paymentWrap p img {
      width: auto !important;
      max-width: 100%; }

/*========================================
detail_area
========================================*/
.detail_area {
  text-align: center;
  margin: 0 auto 8%; }
  .detail_area .inner {
    padding: 0; }
    .detail_area .inner h4 {
      font-weight: bold;
      margin-bottom: .5em;
      color: #ED6C24; }
    .detail_area .inner table {
      margin: 0 auto;
      border-collapse: collapse;
      width: 100%;
      max-width: 804px;
      text-align: inherit;
      background: #FFF; }
      .detail_area .inner table tbody tr th, .detail_area .inner table tbody tr td {
        border: 1px solid #1E4145;
        padding: 1em;
        text-align: left; }
        @media screen and (max-width: 640px) {
          .detail_area .inner table tbody tr th, .detail_area .inner table tbody tr td {
            display: block; } }
      .detail_area .inner table tbody tr th {
        background: #2D7B76;
        color: #FFF; }
      .detail_area .inner table tbody tr td {
        color: #1E4145; }

/*========================================
payment_area
========================================*/
/*========================================
campaign_area
========================================*/
.campaign_area {
  text-align: center; }
  .campaign_area .inner {
    padding: 1em 2em; }

.warranty_area {
  padding: 0 0;
  margin: 0 auto 3em;
  max-width: 840px;
  width: 100%; }
  .warranty_area .price-refund {
    position: relative;
    z-index: 1;
    margin: 0 auto 2em;
    text-align: center; }
    .warranty_area .price-refund p {
      max-width: 400px;
      width: 60%;
      margin: 0 auto;
      padding: 1em 2em;
      display: inline-block;
      border-bottom: 6px solid #2D7B76; }
      .warranty_area .price-refund p:after {
        content: '';
        display: block;
        position: absolute;
        left: 0;
        right: 0;
        bottom: -20px;
        margin: auto;
        width: 0;
        height: 0;
        border-style: solid;
        border-width: 20px 10px 0 10px;
        border-color: #2D7B76 transparent transparent transparent; }
  .warranty_area h1 {
    border: none;
    text-align: center;
    margin-bottom: 2em; }
    .warranty_area h1:before, .warranty_area h1:after {
      display: none; }
  .warranty_area p {
    padding: 0;
    text-align: justify;
    overflow-wrap: break-word;
    word-wrap: break-word; }

.telorder_area {
  margin-bottom: 3em;
  width: 100%; }
  .telorder_area p {
    text-align: center; }
    .telorder_area p.flow_check {
      margin-bottom: 2em; }
  .telorder_area img {
    max-width: 560px;
    width: 100%; }
  .telorder_area a {
    color: #1E4145; }

.magazine_area {
  width: 100%;
  margin-bottom: 3em; }
  .magazine_area p {
    text-align: center; }

/*--------------------------------------------------------
第二階層
--------------------------------------------------------*/
#wrapperForm,
#wrapperSecond {
  max-width: 960px;
  margin: auto;
  background: #000; }
  #wrapperForm header,
  #wrapperSecond header {
    text-align: center;
    color: #FFF;
    padding: 2%;
    background: #1E4145; }
    #wrapperForm header .shoulder,
    #wrapperSecond header .shoulder {
      font-size: 1.2rem;
      color: #2D7B76; }
    #wrapperForm header .subtitle,
    #wrapperSecond header .subtitle {
      font-size: 1.4rem;
      font-weight: bold;
      color: #2D7B76; }
    #wrapperForm header .maintitle,
    #wrapperSecond header .maintitle {
      font-size: 1.8rem;
      font-weight: bold;
      color: #000; }
  #wrapperForm img,
  #wrapperSecond img {
    width: inherit; }

#Form {
  min-height: 100%;
  height: 100%; }

#Form .formInfo {
  padding: 4% 0;
  text-align: justify;
  overflow-wrap: break-word;
  word-wrap: break-word;
  line-height: 1.5;
  background: #FFF; }

#Form .formInfo h1 {
  font-size: 2rem;
  padding: 0 0 0.25em;
  border-bottom: 1px dotted #1E4145;
  margin: 0 4% 1.5em;
  color: #1E4145;
  font-weight: bold; }

#Form .formInfo h2 {
  font-size: 2.4rem;
  padding: 0 0 0.25em;
  border-bottom: 1px dotted #1E4145;
  margin: 0 4% 1em;
  color: #1E4145; }

#Form .formInfo h3 {
  font-size: 1.8rem;
  margin: 0 0 1em;
  color: #ED6C24; }

#Form .formInfo h4 {
  font-size: 1.6rem;
  margin: 0.5em 0 0.5em;
  color: #ED6C24; }

#Form .formInfo iframe {
  width: 100%; }

#Form .formInfo p {
  line-height: 1.5;
  padding: 0 4% 2%; }

#Second {
  min-height: 100%;
  height: 100%; }

#Second .secondBody {
  padding: 4% 4%;
  text-align: justify;
  overflow-wrap: break-word;
  word-wrap: break-word;
  margin: 0 0 4em;
  line-height: 1.5;
  background: #000; }

#Second .secondBody h1 {
  font-size: 2rem;
  padding: 0 0 0.25em;
  border-bottom: 1px dotted #1E4145;
  margin: 0 0 1.5em;
  color: #1E4145;
  font-weight: bold; }

#Second .secondBody h2 {
  font-size: 1.8rem;
  padding: 0 0 0.25em;
  border-bottom: 1px dotted #1E4145;
  margin: 0 0 1em;
  color: #ED6C24; }

#Second .secondBody h3 {
  font-size: 1.8rem;
  margin: 0 0 1em;
  color: #ED6C24; }

#Second .secondBody h4 {
  font-size: 1.6rem;
  margin: 0.5em 0 0.5em;
  color: #ED6C24; }

#Second .secondBody div {
  margin-bottom: 1.6rem; }

#Second .secondBody p {
  margin-bottom: 1.6rem; }

#Second .secondBody .caption {
  margin: 0 0 24px; }

#Second dl {
  border: 1px solid #1E4145;
  border-collapse: collapse;
  width: 100%;
  margin: 0;
  text-align: justify;
  overflow-wrap: break-word;
  word-wrap: break-word; }

#Second dt {
  padding: 6px 8px;
  border: 1px solid;
  border-color: #CCC #999 #999 #CCC;
  background-color: #1E4145;
  color: #000; }

#Second dd {
  padding: 6px 8px;
  border: 1px solid;
  border-color: #CCC #999 #999 #CCC;
  background-color: #FFF;
  color: #000; }

nav {
  background-color: #2D7B76;
  text-align: justify;
  overflow-wrap: break-word;
  word-wrap: break-word;
  font-size: 0.875em;
  border-top: 1px solid #333; }

nav ul li a {
  border-bottom: 1px solid #333;
  padding: 0.75em 0.75em 0.75em;
  display: block;
  color: #FFF !important;
  text-decoration: none; }

nav ul li a:hover {
  background-color: #ED6C24; }

#copy {
  background-color: #000;
  padding: 0.25em 0;
  color: #ED6C24;
  text-align: center;
  font-size: 1.6rem; }

#page-top {
  position: fixed;
  bottom: 20px;
  right: 20px;
  font-size: 1.2rem;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=75)";
  /* IE */
  filter: alpha(opacity=75);
  /* IE */
  -moz-opacity: 0.75;
  /* Firefox(old) */
  -khtml-opacity: 0.75;
  /* Safari(old) */
  opacity: 0.75; }

#page-top a {
  background: #666;
  text-decoration: none;
  color: #fff;
  width: 3em;
  padding: 0.5em 0;
  text-align: center;
  display: block;
  border-radius: 2px; }

#page-top a:hover {
  text-decoration: none;
  background: #C60; }

@media screen and (min-width: 640px) {
  footer nav {
    color: #fff;
    text-align: justify;
    overflow-wrap: break-word;
    word-wrap: break-word;
    background: -webkit-gradient(linear, left top, left bottom, color-stop(1, #111), color-stop(0, #222));
    background: -webkit-linear-gradient(top, #222 0%, #111 100%);
    background: -moz-linear-gradient(top, #222 0%, #111 100%);
    background: -o-linear-gradient(top, #222 0%, #111 100%);
    background: -ms-linear-gradient(top, #222 0%, #111 100%);
    background: linear-gradient(top, #222 0%, #111 100%);
    background-color: #111;
    padding: 3em 1em; }

  footer nav ul {
    text-align: center;
    margin: 0;
    padding: 0; }

  footer nav ul li {
    display: inline;
    margin: 0 0.5em;
    font-size: 1.4rem; }

  footer nav ul li a {
    border-bottom: none;
    padding: 0;
    background: none;
    display: inline;
    color: #fff; }

  footer nav ul li a:hover {
    background-color: transparent;
    text-decoration: underline; }

  #copy {
    background-color: #000;
    padding: 1em 0;
    color: #ED6C24;
    text-align: center;
    font-size: 1.6rem; } }
