@charset "UTF-8";
/*//////////////////////////////////////////////////
sscss変数
//////////////////////////////////////////////////*/
/*//////////////////////////////////////////////////
全体
//////////////////////////////////////////////////*/
::-moz-selection {
  color: #fff;
  background-color: #1976d2; }

::selection {
  color: #fff;
  background-color: #1976d2; }

@font-face {
  font-family: NotoSerifJP-M;
  src: url("font/NotoSansJP-Medium.otf") format("opentype"); }
@font-face {
  font-family: NotoSerifJP-B;
  src: url("font/NotoSansJP-Bold.otf") format("opentype"); }
html {
  width: 100%;
  height: 100%;
  font-size: 62.5%; }

body {
  width: 100%;
  height: 100%;
  min-width: 320px;
  position: relative;
  z-index: 1;
  left: 0;
  top: 0;
  background-color: #fff; }

header, main, footer, #loading_cover, #modal_menu, #header_fix, #humb_wrap, #humb_wrap_fix, #pagetop, input, textarea, select, button {
  font-size: 1.4rem;
  line-height: 1.7;
  color: #212121;
  font-weight: 500;
  letter-spacing: .1rem;
  -webkit-text-size-adjust: 100%;
  word-wrap: break-word;
  overflow-wrap: break-word;
  -moz-hyphens: auto;
  -webkit-hyphens: auto;
  hyphens: auto;
  -webkit-font-smoothing: subpixel-antialiased;
  font-family: 'NotoSansJP-M', "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif; }

header, main, footer {
  width: 100%;
  overflow: hidden; }

main, img, video {
  display: block; }

img {
  flex-shrink: 0; }

input, textarea, select, button {
  outline: 0;
  transition: all .4s; }

input[type="submit"], input[type="button"], input[type="radio"], input[type="checkbox"], select, button {
  cursor: pointer; }

input[type="text"], input[type="search"], input[type="email"], input[type="password"], input[type="submit"], input[type="button"], input[type="radio"], input[type="checkbox"], textarea, select, button {
  -moz-appearance: none;
  -webkit-appearance: none;
  appearance: none;
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  outline: none; }

:-ms-input-placeholder {
  color: #757575; }

::-moz-placeholder {
  color: #757575; }

::-webkit-input-placeholder {
  color: #757575; }

a {
  text-decoration: none;
  transition: all .4s; }

a:link, a:visited, a:hover {
  color: #212121; }

pre {
  white-space: pre-wrap; }

.gothic {
  font-family: "Roboto-R", "NotoSansJP-R", "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif !important;
  font-weight: 500 !important; }

.b {
  font-family: "Roboto-B", "NotoSansJP-B", "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif !important;
  font-weight: 700 !important; }

.min {
  font-family: 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, serif !important;
  font-weight: 400 !important; }

.min-b {
  font-family: 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, serif !important;
  font-weight: 600 !important; }

.l-space-n {
  letter-spacing: normal; }

.l-space-1 {
  letter-spacing: .1rem; }

.l-space-2 {
  letter-spacing: .2rem; }

.underline {
  text-decoration: underline; }

.cf:after {
  content: '';
  display: block;
  clear: both; }

.fit-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  font-family: 'object-fit: cover;'; }

.scroll-style {
  overflow: scroll;
  -ms-overflow-style: none;
  scrollbar-width: none; }
  .scroll-style::-webkit-scrollbar {
    display: none; }

.vertical-txt {
  -ms-writing-mode: tb-rl;
  -o-writing-mode: vertical-rl;
  -webkit-writing-mode: vertical-rl;
  writing-mode: vertical-rl; }

.keep-txt {
  word-break: keep-all;
  white-space: nowrap; }

.margin-0 {
  margin: 0 !important; }

.color-white {
  color: #fff !important; }

.color-font {
  color: #212121 !important; }

.color-subfont {
  color: #757575 !important; }

.color-line {
  color: #bdbdbd !important; }

.color-blue {
  color: #1976d2 !important; }

.xx-lg {
  font-size: 2.4rem !important; }

.x-lg {
  font-size: 2rem !important; }

.lg {
  font-size: 1.6rem !important; }

.md {
  font-size: 1.4rem !important; }

.sm {
  font-size: 1.2rem !important; }

.x-sm {
  font-size: 1rem !important; }

.spacer-8 {
  display: block;
  width: 100%;
  height: 8px !important; }

.spacer-10 {
  display: block;
  width: 100%;
  height: 12px !important; }

.spacer-20 {
  display: block;
  width: 100%;
  height: 16px !important; }

.spacer-30 {
  display: block;
  width: 100%;
  height: 20px !important; }

.spacer-40 {
  display: block;
  width: 100%;
  height: 32px !important; }

.spacer-60 {
  display: block;
  width: 100%;
  height: 40px !important; }

.spacer-80 {
  display: block;
  width: 100%;
  height: 44px !important; }

.spacer-120 {
  display: block;
  width: 100%;
  height: 60px !important; }

.spacer-160 {
  display: block;
  width: 100%;
  height: 80px !important; }

@media only screen and (min-width: 640px) {
  header, main, footer, #loading_cover, #modal_menu, #header_fix, #humb_wrap, #humb_wrap_fix, #pagetop, input, textarea, select, button {
    font-size: 1.5rem; }

  .xx-lg {
    font-size: 3rem !important; }

  .x-lg {
    font-size: 2.4rem !important; }

  .lg {
    font-size: 1.8rem !important; }

  .md {
    font-size: 1.5rem !important; }

  .sm {
    font-size: 1.3rem !important; }

  .x-sm {
    font-size: 1.1rem !important; }

  .spacer-10 {
    height: 14px !important; }

  .spacer-20 {
    height: 20px !important; }

  .spacer-30 {
    height: 26px !important; }

  .spacer-40 {
    height: 40px !important; }

  .spacer-60 {
    height: 52px !important; }

  .spacer-80 {
    height: 66px !important; }

  .spacer-120 {
    height: 90px !important; }

  .spacer-160 {
    height: 120px !important; } }
@media only screen and (min-width: 960px) {
  header, main, footer, #loading_cover, #modal_menu, #header_fix, #humb_wrap, #humb_wrap_fix, #pagetop, input, textarea, select, button {
    font-size: 1.6rem; }

  .xx-lg {
    font-size: 3.6rem !important; }

  .x-lg {
    font-size: 2.8rem !important; }

  .lg {
    font-size: 2rem !important; }

  .md {
    font-size: 1.6rem !important; }

  .sm {
    font-size: 1.4rem !important; }

  .x-sm {
    font-size: 1.2rem !important; }

  .spacer-10 {
    height: 16px !important; }

  .spacer-20 {
    height: 24px !important; }

  .spacer-30 {
    height: 32px !important; }

  .spacer-40 {
    height: 48px !important; }

  .spacer-60 {
    height: 64px !important; }

  .spacer-80 {
    height: 88px !important; }

  .spacer-120 {
    height: 120px !important; }

  .spacer-160 {
    height: 160px !important; }

  .hover-48 {
    transition: all .4s; }
    .hover-48:hover {
      opacity: .48; }

  .hover-64 {
    transition: all .4s; }
    .hover-64:hover {
      opacity: .64; } }
/*//////////////////////////////////////////////////
共通レイアウト
//////////////////////////////////////////////////*/
/*//////////////////////////////////////////////////
アニメーション
//////////////////////////////////////////////////*/
@keyframes logo {
  0% {
    opacity: .48; }
  50% {
    opacity: 1; }
  100% {
    opacity: .48; } }
.loading-logo {
  animation: logo 4s infinite; }

/*//////////////////////////////////////////////////
ローディング
//////////////////////////////////////////////////*/
#loading_cover {
  position: fixed;
  z-index: 100;
  left: 0;
  top: 0;
  width: 100%;
  min-width: 320px;
  height: 100vh;
  background-color: #fff;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center; }
  #loading_cover .loading-logo {
    line-height: 1;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center; }
    #loading_cover .loading-logo .devider {
      display: inline-block;
      width: 2px;
      height: 16px;
      background-color: #1976d2;
      margin: 0 12px; }

@media only screen and (min-width: 640px) {
  #loading_cover .loading-logo .devider {
    height: 20px;
    margin: 0 14px; } }
@media only screen and (min-width: 960px) {
  #loading_cover .loading-logo .devider {
    height: 24px;
    margin: 0 16px; } }
/*//////////////////////////////////////////////////
ヘッダー
//////////////////////////////////////////////////*/
header {
  line-height: 1;
  padding: 44px 0;
  background-color: #1976d2;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center; }
  header h1 .devider {
    display: inline-block;
    width: 2px;
    height: 16px;
    background-color: #fff;
    margin: 0 12px; }

@media only screen and (min-width: 640px) {
  header {
    padding: 66px 0; }
    header h1 .devider {
      height: 20px;
      margin: 0 14px; } }
@media only screen and (min-width: 960px) {
  header {
    padding: 88px 0; }
    header h1 .devider {
      height: 24px;
      margin: 0 16px; } }
/*//////////////////////////////////////////////////
フッター
//////////////////////////////////////////////////*/
/*//////////////////////////////////////////////////
フロントページ
//////////////////////////////////////////////////*/
.front-page .login-screen .inner {
  width: 84%;
  margin: 0 auto; }
  .front-page .login-screen .inner #my_login_form {
    max-width: 600px;
    margin: 44px auto; }
    .front-page .login-screen .inner #my_login_form input {
      display: block;
      width: 100%;
      margin: 16px 0 0;
      border: solid 1px #1976d2;
      padding: 6px 12px;
      box-sizing: border-box; }
    .front-page .login-screen .inner #my_login_form button {
      display: block;
      width: 200px;
      margin: 20px auto 0;
      background-color: #1976d2;
      color: #fff;
      padding: 6px 12px;
      box-sizing: border-box;
      border-radius: 2px; }
.front-page .data-screen .csv-btn {
  width: 84%;
  margin: 44px auto 0; }
  .front-page .data-screen .csv-btn input {
    display: block;
    width: 200px;
    background-color: #1976d2;
    color: #fff;
    padding: 6px 12px;
    box-sizing: border-box;
    border-radius: 2px; }
.front-page .data-screen .inner {
  width: 84%;
  margin: 0 auto; }
  .front-page .data-screen .inner table {
    border-top: solid 1px #90caf2;
    border-left: solid 1px #90caf2;
    margin: 20px auto 44px; }
    .front-page .data-screen .inner table tr {
      border-bottom: solid 1px #90caf2; }
      .front-page .data-screen .inner table tr th {
        border-right: solid 1px #90caf2;
        padding: 4px;
        vertical-align: middle;
        background-color: #1976d2;
        color: #fff; }
      .front-page .data-screen .inner table tr td {
        border-right: solid 1px #90caf2;
        padding: 4px; }
        .front-page .data-screen .inner table tr td.center {
          text-align: center; }
        .front-page .data-screen .inner table tr td.right {
          text-align: right; }

@media only screen and (min-width: 640px) {
  .front-page .login-screen .inner {
    width: 88%; }
    .front-page .login-screen .inner #my_login_form {
      margin: 66px auto; }
      .front-page .login-screen .inner #my_login_form input {
        margin: 20px 0 0;
        padding: 7px 14px; }
      .front-page .login-screen .inner #my_login_form button {
        width: 220px;
        margin: 26px auto 0;
        padding: 7px 14px; }
  .front-page .data-screen .csv-btn {
    width: 88%;
    margin: 66px auto 0; }
    .front-page .data-screen .csv-btn input {
      width: 220px;
      padding: 7px 14px; }
  .front-page .data-screen .inner {
    width: 88%; }
    .front-page .data-screen .inner table {
      margin: 26px auto 66px; }
      .front-page .data-screen .inner table tr th {
        padding: 6px; }
      .front-page .data-screen .inner table tr td {
        padding: 6px; } }
@media only screen and (min-width: 960px) {
  .front-page .login-screen .inner {
    width: 92%; }
    .front-page .login-screen .inner #my_login_form {
      margin: 88px auto; }
      .front-page .login-screen .inner #my_login_form input {
        margin: 24px 0 0;
        padding: 8px 16px; }
      .front-page .login-screen .inner #my_login_form button {
        width: 240px;
        margin: 32px auto 0;
        padding: 8px 16px; }
        .front-page .login-screen .inner #my_login_form button:hover {
          opacity: .48; }
  .front-page .data-screen .csv-btn {
    width: 92%;
    margin: 88px auto 0; }
    .front-page .data-screen .csv-btn input {
      width: 240px;
      padding: 8px 16px; }
      .front-page .data-screen .csv-btn input:hover {
        opacity: .48; }
  .front-page .data-screen .inner {
    width: 92%; }
    .front-page .data-screen .inner table {
      margin: 32px auto 88px; }
      .front-page .data-screen .inner table tr th {
        padding: 8px; }
      .front-page .data-screen .inner table tr td {
        padding: 8px; } }
@media only screen and (min-width: 1280px) {
  .front-page .login-screen .inner {
    width: 1200px; } }
