@media only screen and (min-width: 768px) {
  .spbr {
    display: none; } }

body {
  margin: 0; }

header {
  overflow: hidden; }

main {
  overflow: hidden; }
  main.sticky {
    overflow-y: auto; }

.section {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 1em;
  margin-bottom: 1em; }
  .section:last-child {
    margin-bottom: 0; }

.block {
  margin: 0 auto 1em;
  display: block;
  width: 100%; }
  .block:last-child {
    margin-bottom: 0; }
  @media only screen and (min-width: 768px) {
    .block {
      max-width: 1200px; } }
  @media only screen and (min-width: 768px) {
    .block-full {
      max-width: none;
      width: 100%; } }
  @media only screen and (min-width: 768px) {
    .block-large {
      width: calc(66% - 1em); } }
  @media only screen and (min-width: 768px) {
    .block-medium {
      width: calc(50% - 1em); } }
  @media only screen and (min-width: 768px) {
    .block-small {
      width: calc(33% - 1em); } }

.headline * {
  width: 100%; }

@media only screen and (max-width: 767px) {
  .gallery.standardize-sp-2:after {
    content: "";
    display: inline-block;
    height: 0; }
  .gallery.standardize-sp-3:after {
    content: "";
    display: inline-block;
    height: 0; }
  .gallery.standardize-sp-4:after {
    content: "";
    display: inline-block;
    height: 0; }
  .gallery.standardize-sp-5:after {
    content: "";
    display: inline-block;
    height: 0; }
  .gallery.standardize-sp-2:after {
    flex: 1 0 34%; }
  .gallery.standardize-sp-3:after {
    flex: 1 0 26%; }
  .gallery.standardize-sp-4:after {
    flex: 1 0 21%; }
  .gallery.standardize-sp-5:after {
    flex: 1 0 17%; } }

@media only screen and (min-width: 768px) {
  .gallery.standardize-pc-2:after {
    content: "";
    display: inline-block;
    height: 0; }
  .gallery.standardize-pc-3:after {
    content: "";
    display: inline-block;
    height: 0; }
  .gallery.standardize-pc-4:after {
    content: "";
    display: inline-block;
    height: 0; }
  .gallery.standardize-pc-5:after {
    content: "";
    display: inline-block;
    height: 0; }
  .gallery.standardize-pc-2:after {
    flex: 1 0 34%; }
  .gallery.standardize-pc-3:after {
    flex: 1 0 26%; }
  .gallery.standardize-pc-4:after {
    flex: 1 0 21%; }
  .gallery.standardize-pc-5:after {
    flex: 1 0 17%; } }

.infographic {
  display: flex;
  align-items: flex-start; }
  .infographic.flop {
    display: block; }
  @media only screen and (min-width: 768px) {
    .infographic.flop {
      display: flex; } }

.chart {
  display: flex;
  align-items: flex-start; }
  .chart.flop {
    display: block; }
  @media only screen and (min-width: 768px) {
    .chart.flop {
      display: flex; } }

.textarea {
  width: 100%;
  text-align: justify; }

p {
  margin: 0; }

a {
  text-decoration: none; }
  a:hover {
    opacity: .5; }

.item {
  margin-bottom: 1em;
  display: flex;
  flex-wrap: wrap;
  gap: 1em; }
  .item:last-child {
    margin-bottom: 0; }
  .item a picture:hover {
    opacity: .5; }
  .item .sp1 {
    flex: 1 0 51%; }
  .item .sp2 {
    flex: 1 0 34%; }
  .item .sp3 {
    flex: 1 0 26%; }
  .item .sp4 {
    flex: 1 0 21%; }
  .item .sp5 {
    flex: 1 0 17%; }
  @media only screen and (min-width: 768px) {
    .item .sp1 {
      flex: 1 1 0px; }
    .item .sp2 {
      flex: 1 1 0px; }
    .item .sp3 {
      flex: 1 1 0px; }
    .item .sp4 {
      flex: 1 1 0px; }
    .item .sp5 {
      flex: 1 1 0px; }
    .item .pc1 {
      flex: 1 0 51%; }
    .item .pc2 {
      flex: 1 0 34%; }
    .item .pc3 {
      flex: 1 0 26%; }
    .item .pc4 {
      flex: 1 0 21%; }
    .item .pc5 {
      flex: 1 0 17%; } }

picture {
  display: contents;
  width: 100%; }
  picture img {
    width: 100%;
    height: auto;
    border-style: none;
    vertical-align: middle; }
  picture.vertical:not(.auto) {
    display: block;
    position: relative;
    padding-bottom: 100%; }
    picture.vertical:not(.auto) img {
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      width: auto;
      height: 100%; }
  picture.auto img {
    width: auto; }

.frame {
  display: flex;
  width: 100%;
  padding-bottom: 100%;
  position: relative;
  margin-bottom: .5em;
  transform-style: preserve-3d; }
  .frame iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    backface-visibility: hidden;
    transform: scale(1);
    transform-origin: 0 0;
    will-change: transform; }
  .frame.ultra {
    padding-bottom: calc(9 / 21 * 100%); }
  .frame.hd {
    padding-bottom: calc(9 / 16 * 100%); }
  .frame.vga {
    padding-bottom: calc(3 / 4 * 100%); }

ul li a {
  display: block; }

.a-picture {
  width: 100%; }

.slot {
  flex: 1 1 0px; }

.reverse {
  flex-direction: row-reverse; }

.image {
  flex: 1 1 0px;
  margin-bottom: .5em; }

table {
  border-collapse: collapse;
  box-sizing: border-box;
  width: 100%;
  margin: .5em 0; }
  table tr td {
    padding: .125em .5em; }
  @media only screen and (max-width: 767px) {
    table.bullet tr {
      border: none;
      border-top: 1px solid; }
      table.bullet tr:first-child {
        border-top: none; }
    table.bullet td {
      display: block;
      border: none;
      border-top: 1px solid; }
    table.bullet td:first-child {
      border-top: none; } }

.table {
  box-sizing: border-box;
  border-collapse: collapse;
  display: table;
  flex: 1 1 0px;
  width: 100%; }

.row {
  display: table-row; }

.column {
  display: table-cell;
  border: 1px solid gray;
  padding: .125em .5em; }
  .column.bullet {
    display: block; }
    .column.bullet:first-child {
      background: gray;
      color: white; }
  @media only screen and (min-width: 768px) {
    .column {
      display: table-cell;
      vertical-align: middle;
      padding: .25em .5em; }
      .column.bullet {
        display: table-cell; }
        .column.bullet:first-child {
          background: inherit;
          color: inherit; } }

.headline {
  margin-bottom: .5em; }

.textarea img {
  max-width: 100%; }
  .textarea img.mt {
    margin-top: .5em; }
  .textarea img.mr {
    margin-right: .5em; }
  .textarea img.mb {
    margin-bottom: .5em; }
  .textarea img.ml {
    margin-left: .5em; }

.bottom-none {
  margin-bottom: 0; }

.bottom-thin {
  margin-bottom: .5em; }

.bottom-normal {
  margin-bottom: 1em; }

.bottom-thick {
  margin-bottom: 1.5em; }

.emoji {
  width: 1em;
  vertical-align: middle; }

.left {
  display: flex;
  justify-content: left; }

.center {
  display: flex;
  justify-content: center; }
  @media only screen and (min-width: 768px) {
    .center .part.pc1 {
      flex: 0 0 100%; }
    .center .part.pc2 {
      flex: 0 0 calc(50% - 1 * 1em); }
    .center .part.pc3 {
      flex: 0 0 calc(33% - 2 * 1em); }
    .center .part.pc4 {
      flex: 0 0 calc(25% - 3 * 1em); }
    .center .part.pc5 {
      flex: 0 0 calc(20% - 4 * 1em); } }

.right {
  display: flex;
  justify-content: right; }

.hidden {
  visibility: hidden !important; }

.none {
  display: none !important; }

@media only screen and (max-width: 767px) {
  .fill.pc {
    display: none; } }

@media only screen and (min-width: 768px) {
  .fill.sp {
    display: none; } }

.no-border {
  border: none; }
  .no-border table {
    border: none; }
    .no-border table tr {
      border: none; }
      .no-border table tr td {
        border: none; }
  .no-border .table {
    border: none; }
    .no-border .table .row {
      border: none; }
      .no-border .table .row .column {
        border: none; }

.flex {
  display: flex; }
  @media only screen and (max-width: 767px) {
    .flex {
      flex-direction: column; } }
  .flex > * {
    flex: 1 1 0px; }

.capsule {
  border-radius: 100vmax; }

.grow-1 {
  flex-grow: 1; }

.shrink-1 {
  flex-shrink: 1; }

.grow-2 {
  flex-grow: 2; }

.shrink-2 {
  flex-shrink: 2; }

.grow-3 {
  flex-grow: 3; }

.shrink-3 {
  flex-shrink: 3; }

.grow-4 {
  flex-grow: 4; }

.shrink-4 {
  flex-shrink: 4; }

.grow-5 {
  flex-grow: 5; }

.shrink-5 {
  flex-shrink: 5; }

.grow-6 {
  flex-grow: 6; }

.shrink-6 {
  flex-shrink: 6; }

.grow-7 {
  flex-grow: 7; }

.shrink-7 {
  flex-shrink: 7; }

.grow-8 {
  flex-grow: 8; }

.shrink-8 {
  flex-shrink: 8; }

.grow-9 {
  flex-grow: 9; }

.shrink-9 {
  flex-shrink: 9; }

.form-modal-wrapper {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 100;
  width: 100%;
  height: 100%; }
  .form-modal-wrapper .form-modal-cover {
    background: rgba(0, 0, 0, 0.3);
    width: 100%;
    height: 100%;
    position: fixed; }
  .form-modal-wrapper .form-modal-content {
    position: absolute;
    top: 50%;
    left: 50%;
    background-color: white;
    width: 100%;
    margin: auto;
    transform: translate(-50%, -50%);
    padding: .25em;
    overflow-y: auto;
    max-height: 80vh; }
    @media only screen and (min-width: 768px) {
      .form-modal-wrapper .form-modal-content {
        min-width: 500px;
        width: auto; } }
    .form-modal-wrapper .form-modal-content .form-modal-close {
      position: relative;
      margin: 0 0 0 auto;
      width: 1em;
      height: 1em; }
      .form-modal-wrapper .form-modal-content .form-modal-close:before, .form-modal-wrapper .form-modal-content .form-modal-close:after {
        content: "";
        position: absolute;
        top: 50%;
        left: 50%;
        width: .125em;
        height: 1em;
        background: darkgray; }
      .form-modal-wrapper .form-modal-content .form-modal-close:before {
        transform: translate(-50%, -50%) rotate(45deg); }
      .form-modal-wrapper .form-modal-content .form-modal-close:after {
        transform: translate(-50%, -50%) rotate(-45deg); }
  .form-modal-wrapper .form-modal-confirmation {
    margin: 0 .75em .5em; }
    .form-modal-wrapper .form-modal-confirmation p {
      display: flex;
      flex-wrap: wrap;
      gap: 1em; }
  .form-modal-wrapper .form-modal-submit {
    text-align: center; }
  .form-modal-wrapper .button-submit {
    border: 1px solid transparent;
    border-radius: .25em;
    margin: .5em;
    padding: .25em 1em;
    color: white;
    background: gray;
    display: inline-block; }

samp.vumor-samp {
  position: relative;
  width: calc(100% - 1em - 2px);
  aspect-ratio: 16 / 9;
  padding: .5em;
  border: 1px solid gray;
  color: black;
  background: transparent;
  display: flex;
  align-items: center;
  justify-content: center; }
  samp.vumor-samp:before {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    content: "no image";
    color: white;
    font-size: calc(100% + 2vw);
    background: whitesmoke;
    z-index: -1; }

a:hover samp.vumor-samp {
  color: white;
  background: gray; }

@media only screen and (min-width: 768px) {
  .pc-none {
    display: none; } }

@media only screen and (max-width: 767px) {
  .sp-none {
    display: none; } }

.breadcrumbs {
  margin: 0 auto;
  max-width: 1200px; }
  .breadcrumbs p {
    font-size: .8rem;
    color: dimgray; }
    @media only screen and (min-width: 768px) {
      .breadcrumbs p {
        margin: .5rem 0; } }
    @media only screen and (max-width: 1200px) {
      .breadcrumbs p {
        margin: .5rem; } }
    @media only screen and (max-width: 767px) {
      .breadcrumbs p {
        margin: .25rem .5rem; } }
    .breadcrumbs p a {
      text-decoration: none;
      color: darkgray; }
      .breadcrumbs p a:hover {
        color: black; }
    .breadcrumbs p span.separator {
      margin: 0 .25rem; }

.page-navigation {
  display: flex;
  gap: .5rem;
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto; }
  .page-navigation .prev {
    display: inline-block;
    cursor: pointer;
    color: white;
    background-color: darkgray;
    padding: .25rem .5rem;
    border: 1px solid gray; }
  .page-navigation .next {
    display: inline-block;
    cursor: pointer;
    color: white;
    background-color: darkgray;
    padding: .25rem .5rem;
    border: 1px solid gray; }
  .page-navigation .pages {
    display: flex;
    gap: .5rem; }
    .page-navigation .pages .pagenum {
      cursor: pointer;
      display: inline-block;
      padding: .25rem .5rem;
      color: white;
      background-color: darkgray;
      border: 1px solid gray; }
      .page-navigation .pages .pagenum.current {
        color: darkgray;
        background-color: white;
        cursor: inherit; }
  .page-navigation .disable {
    color: whitesmoke;
    background-color: white;
    border-color: whitesmoke;
    cursor: inherit; }

.svg-adjust {
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  width: 100%;
  height: 0;
  padding-top: 10%;
  padding-bottom: 10%; }
  .svg-adjust svg {
    width: 100%;
    overflow: hidden; }
    .svg-adjust svg text {
      text-anchor: middle; }

.login {
  max-width: 1200px;
  margin: 0 auto;
  text-align: center; }
  .login #loginform {
    display: inline-block; }
    .login #loginform p {
      display: flex;
      gap: 1rem; }
      .login #loginform p label, .login #loginform p input {
        text-align: left;
        margin: .25rem 0; }
      .login #loginform p.login-username label, .login #loginform p.login-username input, .login #loginform p.login-password label, .login #loginform p.login-password input {
        min-width: 15rem; }
      .login #loginform p.login-remember, .login #loginform p.login-submit {
        display: inline-block;
        vertical-align: middle;
        margin: .5rem; }

footer {
  overflow: hidden; }

rem {
  display: none; }
