body {
  font-family: "Noto Sans JP","ヒラギノ角ゴ Pro","Hiragino Kaku Gothic Pro","メイリオ","Meiryo",sans-serif;
  margin: 0;
  padding: 0;
  font-size: 13px;
}

h1,h2,h3,h4,h5,h6 {
  margin: 0;
  padding: 0;
  line-height: 100%;
  font-size: 1rem;
}

p {
  margin: 0;
  padding: 0;
}

.title {
  color: #1F4E78;
  font-size: 36px;
  margin-left: 15px;
}

.head-explain {
  color: #000;
  font-size: 16px;
  margin-top: 30px;
  line-height: 1.8rem;
}

.wrapper {
  margin: 0 auto;
  max-width: 1200px;
  width: 100%;
  box-sizing: border-box;
  padding: 15px 30px;
}

header {
  background-color: #DDEBF7;
  position: fixed;
  width: 100%;
  top: 0;
}

footer {
  background-color: #fff;
}

header .wrapper {
  font-size: 20px;
  height: 80px;
  position: relative;
  padding: 15px 15px;
}

footer .wrapper {
  text-align: center;
}

input[type="text"],
input[type="password"],
textarea {
  border: 1px solid #888;
  border-radius: 3px;
  padding: 4px 4px;
  box-sizing: border-box;
  height: 31px;
}

label input[type="radio"],
label input[type="checkbox"] {
  margin-right: 8px;
}

.radio-group label ~ label {
  margin-left: 15px;
}

button {
  border: 1px solid #888;
  border-radius: 3px;
  height: 32px;
  padding: 5px 20px;
  box-sizing: content-box;
}

.copyright {
  display: inline-block;
  text-align: left;
}

.copyright .line {
  white-space: nowrap;
}

.copyright::after {
  content: "";
  display: block;
  clear: both;
}

main {
  margin-top: 80px;
}

.input-row {
  margin-bottom: 5px;
}

.float-left {
  float: left;
}

.float-right {
  float: right;
}


.main-wrapper {
  padding-top: 30px;
  padding-bottom: 50px;
}

.main-wrapper h2 {
  color: #0070C0;
  font-size: 24px;
  margin-bottom: 20px;
}

.base-wrapper {
    position: relative;
}


.rdm-file .rdm-check {
  display: none;
  width: 100%;
  box-sizing: border-box;
  transition: all 0.25s cubic-bezier(0.21, 0.51, 0.51, 1);
  text-align: center;
  background-color: #aad0eb;
  z-index: 100;
  padding: 40px 0;
  color: #000;
}
.rdm-file .rdm-check.active {
  display: block;
}
.rdm-file .rdm-drop.active {
  display: block;
}
.rdm-file .rdm-select.active {
  display: block;
}

.progress-wrapper {
  position: absolute;
  padding: 0 30px;
  width: 100%;
  box-sizing: border-box;
}

progress {
  display: none;
  width: 100%;
  box-sizing: border-box;
}


progress.active {
  display: block;
}

.rdm-file .rdm-check,
.rdm-file .rdm-select {
  min-height: 270px;
}

.rdm-file {
  position: relative;
  width: 100%;
  padding: 0;
  text-align: center;
  box-sizing: border-box;
}

.rdm-file .rdm-drop {
  display: none;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  box-sizing: border-box;
  transition: all 0.25s cubic-bezier(0.21, 0.51, 0.51, 1);
  text-align: center;
}

.rdm-file .rdm-select {
  display: none;
  box-sizing: border-box;
  padding: 75px 15px 70px 15px;
  font-size: 16px;
  border: 3px dashed #0070C0;
}

.rdm-file .rdm-drop-message {
  margin-bottom: 10px;
  line-height: 175%;
}

.rdm-file .rdm-drop.dragover {
  border: 2px solid rgb(0, 66, 166);
  background: rgba(20, 93, 201, 0.7);
  z-index: 12;
}
.rdm-file .rdm-drop.dragover::after {
  content: "ここにドロップ";
  display: inline;
  color: #fff;
  font-weight: bold;
  font-size: 4em;
  line-height: 500%;
}

.rdm-file input[type=file] {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 10;
  display: block;
  width: 100%;
  height: 100%;
  opacity: 0;
}
.rdm-file .dragover~.rdm-file-select-wrapper input[type=file] {
  display: none;
}
.rdm-file .dragover~.rdm-file-select-wrapper {
  pointer-events: none;
}

.rdm-file-select-wrapper {
  position: relative;
  display: inline-block;
  width: 100%;
  max-width: 300px;
  box-sizing: border-box;
  border: 1px solid #333;
  border-radius: 4px;
  background-color: #0070C0;
  text-decoration: none;
  color: #fff;
  line-height: 3rem;
}

.btn-cancel {
  border: 1px solid #333;
  position: relative;
  z-index: 11;
}

.check-status {
  display: block;
  font-size: 20px;
  padding: 10px 30px 5px 30px;
  min-height: 35px;
}

.check-file {
  display: block;
  font-weight: bold;
  background-color: #fff;
  font-size: 1.5em;
  padding: 10px;
  margin: 30px 30px;
  border-radius: 10px;
  color: #005664;
}

.contact-details {
  font-size: 16px;
  display: inline-block;
  margin-top: 2px;
  margin-bottom: 15px;
  text-align: left;
}

.check-result {
  font-weight: bold;
}

.check-success {
  color:rgb(0, 83, 147);
}

.check-error {
  color:rgb(253, 63, 0);
}

.circle {
  display: inline-block;
  position: relative;
  top: 2px;
  width: 16px;
  height: 16px;
  text-align:center;
  line-height: 16px;
  border-radius: 50%;
  border: solid 4px rgb(0, 83, 147);
}

.cross {
  position: relative;
  top: -1px;
  display: inline-block;
  width: 24px;
  height: 4px;
  background: rgb(253, 63, 0);
  transform: rotate(45deg);
  vertical-align: middle;
}

.cross::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgb(253, 63, 0);
  transform: rotate(90deg);
}

.loader {
  display: inline-block}
  
@-webkit-keyframes ball-scale-multiple {
  0% {
    -webkit-transform: scale(0);
            transform: scale(0);
    opacity: 0; }
  5% {
    opacity: 1; }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
    opacity: 0; } }

@keyframes ball-scale-multiple {
  0% {
    -webkit-transform: scale(0);
            transform: scale(0);
    opacity: 0; }
  5% {
    opacity: 1; }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
    opacity: 0; } }

.ball-scale-multiple {
  position: relative;
  -webkit-transform: translateY(-30px);
          transform: translateY(-30px); }
  .ball-scale-multiple > div:nth-child(2) {
    -webkit-animation-delay: -0.4s;
            animation-delay: -0.4s; }
  .ball-scale-multiple > div:nth-child(3) {
    -webkit-animation-delay: -0.2s;
            animation-delay: -0.2s; }
  .ball-scale-multiple > div {
    background-color: rgb(44, 106, 250);
    width: 15px;
    height: 15px;
    border-radius: 100%;
    margin: 2px;
    -webkit-animation-fill-mode: both;
            animation-fill-mode: both;
    position: absolute;
    left: -30px;
    top: 3px;
    opacity: 0;
    margin: 0;
    width: 36px;
    height: 36px;
    -webkit-animation: ball-scale-multiple 1s 0s linear infinite;
            animation: ball-scale-multiple 1s 0s linear infinite;
}

@media(max-width: 780px) {

  .title {
    font-size: 22px;
  }

  .main-wrapper {
    padding-top: 10px;
  }

  .main-wrapper h2 {
    font-size: 22px;
  }


  header .wrapper {
    height: 60px;
  }

}