@import url("https://fonts.googleapis.com/css?family=Nothing+You+Could+Do");
* {
  box-sizing: border-box; }

body {
  color: #212121;
  min-height: 100vh;
  background-color: #fbfbfb; }

#wrap {
  position: relative;
  min-width: 375px;
  min-height: 100vh;
  overflow: hidden; }
  #wrap:after {
    content: "";
    display: block;
    width: 400px;
    height: 3000px;
    background-color: #f2f2f2;
    position: fixed;
    left: 65%;
    top: 50%;
    transform: translateX(-50%) translateY(-50%) rotate(45deg);
    z-index: -1; }

#logo {
  position: fixed;
  left: 20px;
  top: 20px; }
  #logo img {
    height: 21px;
    width: auto; }

address {
  position: fixed;
  bottom: 23px;
  text-align: center;
  width: 100%;
  font-size: 11px;
  color: #6d6d6d; }

main > section {
  position: fixed;
  top: 48%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
  text-align: center; }
  main > section .ttl {
    margin-bottom: 49px;
    font-family: 'Nothing You Could Do', cursive;
    font-size: 60px;
    color: #212121;
    letter-spacing: 0.03em;
    white-space: nowrap; }
  main > section .lead {
    font-size: 14px;
    text-align: center;
    margin-bottom: 33px;
    line-height: 2; }
  main > section .btn {
    display: inline-block;
    position: relative;
    cursor: pointer;
    text-align: center;
    width: 330px;
    border-radius: 60px;
    box-shadow: 0px 0px 30px 0px rgba(0, 0, 0, 0.4);
    overflow: hidden; }
    main > section .btn input,
    main > section .btn button,
    main > section .btn span,
    main > section .btn a {
      display: block;
      width: 100%;
      height: 60px;
      font-size: 15px;
      letter-spacing: 0.07em;
      background-color: #222;
      color: #fff;
      margin: 0 auto;
      padding: 20px 0;
      transition: opacity 0.3s;
      backface-visibility: hidden;
      text-decoration: none; }
      main > section .btn input:after,
      main > section .btn button:after,
      main > section .btn span:after,
      main > section .btn a:after {
        position: absolute;
        left: -130%;
        top: -80%;
        content: "";
        display: block;
        background-color: #fff;
        width: 440px;
        height: 200px;
        transform: rotate(-45deg);
        opacity: 0.18;
        transition: all 1000ms cubic-bezier(0.19, 1, 0.22, 1); }
      main > section .btn input:hover:after, main > section .btn input.hover:after,
      main > section .btn button:hover:after,
      main > section .btn button.hover:after,
      main > section .btn span:hover:after,
      main > section .btn span.hover:after,
      main > section .btn a:hover:after,
      main > section .btn a.hover:after {
        left: 100%; }

.largeTxt {
  font-size: 20px;
  font-weight: bold;
  margin-bottom: 27px;
  letter-spacing: 0.05em; }

.txtError {
  display: none;
  color: #dd2b33;
  font-size: 14px;
  font-weight: bold; }

.inputType01 {
  width: 330px;
  height: 60px;
  border-radius: 60px;
  font-size: 14px;
  color: #333;
  padding: 0 32px;
  background-color: #fff;
  box-shadow: 0px 0px 30px 0px rgba(0, 0, 0, 0.18);
  border: 4px solid #fff;
  transition: 0.2s; }
  .inputType01:focus {
    border: 4px solid rgba(0, 0, 0, 0.07); }

@media screen and (max-width: 768px) {
  #logo {
    position: absolute;
    left: 14px;
    top: 14px; }
    #logo img {
      height: 17px; }

  main > section {
    position: absolute;
    width: 90vw !important; }
    main > section .ttl {
      margin-bottom: 20px;
      font-size: 35px;
      white-space: nowrap; }
    main > section .lead {
      font-size: 12px;
      margin-bottom: 33px; }
    main > section .btn {
      width: 300px;
      border-radius: 60px; }
      main > section .btn input,
      main > section .btn button,
      main > section .btn span,
      main > section .btn a {
        height: 50px;
        padding: 13px 0; }
        main > section .btn input:after,
        main > section .btn button:after,
        main > section .btn span:after,
        main > section .btn a:after {
          display: none; }

  .largeTxt {
    font-size: 17px;
    margin-bottom: 17px; }

  .inputType01 {
    width: 300px;
    font-size: 16px;
    height: 50px; } }
@media screen and (max-height: 500px) {
  main > section {
    position: relative;
    top: inherit;
    left: 50%;
    transform: translateX(-50%) translateY(0);
    margin: 50px 0; }

  address {
    position: relative;
    text-align: center; } }
/* welcome
---------------------------------------------------------------------------------------- */
#welcome {
  width: auto; }
  #welcome .txt {
    padding: 167px 0 66px; }

/* login
---------------------------------------------------------------------------------------- */
#login {
  width: 330px; }
  #login ul {
    margin: 0 auto 30px; }
    #login ul li:nth-child(n+2) {
      margin-top: 20px; }
  #login #btnLogin {
    cursor: pointer;
    text-align: center; }
  #login form {
    position: relative; }
  #login .txtError {
    margin: -22px 0 19px; }

/* fileupload
---------------------------------------------------------------------------------------- */
#fileUpload {
  display: none;
  width: 330px;
  /*
   * jQuery File Upload Plugin CSS
   * https://github.com/blueimp/jQuery-File-Upload
   *
   * Copyright 2013, Sebastian Tschan
   * https://blueimp.net
   *
   * Licensed under the MIT license:
   * http://www.opensource.org/licenses/MIT
   */ }
  #fileUpload #btnUpload {
    width: 100%;
    height: 60px;
    border-radius: 60px;
    overflow: hidden;
    box-shadow: 0px 0px 30px 0px rgba(0, 0, 0, 0.3); }
  #fileUpload .fileinput-button {
    position: relative;
    overflow: hidden; }
    #fileUpload .fileinput-button input {
      position: absolute;
      left: 0;
      top: 0;
      right: 0;
      bottom: 0;
      margin: 0;
      opacity: 0 !important;
      -webkit-appearance: none;
      direction: ltr;
      cursor: pointer;
      transform: scale(3); }

@media screen and (max-width: 768px) {
  #fileUpload {
    width: 300px; }
    #fileUpload #btnUpload {
      height: 50px; } }
/* uploading
---------------------------------------------------------------------------------------- */
#uploading {
  display: none;
  width: 560px; }
  #uploading #graph {
    width: 100%;
    height: 42px;
    margin: 0 auto;
    background-color: #ccc; }
    #uploading #graph span {
      display: block;
      width: 1%;
      height: 42px;
      background-color: #555;
      transition: all  0.3s ease; }

/* thank
---------------------------------------------------------------------------------------- */
#thank {
  display: none;
  width: 560px; }
  #thank .txt {
    text-align: center;
    font-size: 24px; }
    #thank .txt span {
      display: block;
      font-size: 14px;
      padding: 10px 0 60px; }
  #thank ul {
    margin: 0 auto; }
    #thank ul li {
      white-space: nowrap; }
      #thank ul li span {
        display: block;
        font-size: 14px;
        margin-bottom: 7px; }
      #thank ul li input {
        width: 100%;
        height: 60px;
        background-color: #e4e4e4;
        color: #212121;
        font-size: 13px;
        text-align: center;
        letter-spacing: 0.05em;
        padding: 0 20px; }
      #thank ul li:first-child {
        margin-bottom: 38px; }

@media screen and (max-width: 768px) {
  #thank ul li span {
    font-size: 12px; }
  #thank ul li input {
    height: 50px;
    font-size: 13px; }
  #thank ul li:first-child {
    margin-bottom: 30px; } }
/* download
---------------------------------------------------------------------------------------- */
#download {
  display: block;
  width: 560px; }
  #download .file {
    height: 60px;
    background-color: #e4e4e4;
    color: #212121;
    font-size: 13px;
    letter-spacing: 0.05em;
    padding: 20px 20px 0;
    margin: -28px 0 40px;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis; }
  #download .input {
    text-align: center;
    margin-bottom: 30px; }
  #download .txtError {
    margin: -20px 0 33px; }
  #download .btn button {
    background-color: #b91e24; }

@media screen and (max-width: 768px) {
  #download {
    display: block;
    width: 560px; }
    #download .file {
      height: 50px;
      margin: -22px 0 40px;
      padding: 14px 20px 0; } }
/* Other
---------------------------------------------------------------------------------------- */
#message {
  display: none; }

main > section#message .lead, main > section#notFound .lead {
  margin-bottom: 0; }

.pc {
  display: block; }

.sp {
  display: none; }

@media screen and (max-width: 768px) {
  body {
    font-weight: normal; }

  input, textarea, select {
    font-weight: normal; }

  .pc {
    display: none !important; }

  .sp {
    display: block; }

  img {
    width: 100%; } }
