/** 
* 
**/

@charset "utf-8";

/* reset & common */
:root {
  --root-font-size: 16;
}
html, body, main, aside, article, section, nav, header, footer, div, p, li, dl, dt, dd, address, figure {margin: 0; padding: 0;}
html {
  font-size: 100%;
  touch-action: manipulation;
}
body {
  width: 100%;
  font-size: 100%;
  font-size: calc( 13 / var(--root-font-size) * 1rem );
  color: #000;
  /*background-color: #031e6d;*/
}
header, main, footer {
  display: block;
}
main {
  display: block;
  overflow: hidden;
}
h1, h2, h3, h4, h5, h6 {
  font-size: 1.25rem;
  font-weight: normal;
  margin: 0;
  padding: 0;
}
div, p, a, span, dd, dt, li, address {
  font-size: 1rem;
}
h1 img, h2 img, h3 img, h4 img, h5 img, h6 img {
  max-width: 100%;
}
ul,ol {
  margin-top: 0;
  margin-bottom: 0;
  padding-left: 0;
}
li {
  list-style-type: none;
}
a {
  color: #000;
  text-decoration: none;
}
time {
  display: inline-block;
}
address {
  font-style: normal;
}
button,html [type="button"],[type="reset"],[type="submit"] {
  -webkit-appearance: button;
  appearance: button;
  cursor: pointer;
  border-style: none;
  margin: 0 auto;
}
textarea {
  resize: vertical;
}
img {
  max-width: 100%;
}
video {
  filter: drop-shadow(0px 0px rgba(0,0,0,0));
  outline: none;
  border: none;
}
* {
  font-size: 1rem;
  font-family: "Noto Sans JP", -apple-system, BlinkMacSystemFont, "Helvetica Neue", Helvetica, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  font-weight: 400;
}
*,*::before,*::after {box-sizing: border-box;}

.screen-reader-text {
  clip: rect(1px,1px,1px,1px);
  word-wrap: normal!important;
  border: 0;
  -webkit-clip-path: inset(50%);
  clip-path: inset(50%);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}

.pc {
  display: none;
}
.sp {
  display: block;
}
@media screen and (min-width: 768px) {
  .pc {
    display: block;
  }
  .sp {
    display: none;
  }
}
.upper_case {
  text-transform: uppercase;
}
.container {
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
  padding: 0 10px;
}
@media screen and (min-width: 1000px) {
  .container {
    padding: 0;
  }
}




#visitor_detail {
  visibility: hidden;
  height: 0;
}
fieldset:has(input[name="visitor_type"]:not(#visitor_type_1):checked) #visitor_detail {
  visibility: visible;
  height: auto;
}



.form_agreements {
  max-height: 300px;
  padding: .5em;
  overflow: scroll;
  border: 1px solid #999;
}


.form_agreements p {
  padding: .5em 0;
}
.form_agreements p.center {
  text-align: center;
}
.form_agreements p.right {
  text-align: right;
}

.form_agreements ul {
  padding-left: 1.5em;
}
.form_agreements ul li {
  list-style-type: disc;
}


