@charset "UTF-8";
/*
html5doctor.com Reset Stylesheet
v1.6.1
Last Updated: 2010-09-17
Author: Richard Clark - http://richclarkdesign.com
Twitter: @rich_clark
*/
html,
body,
div,
span,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
abbr,
address,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
samp,
small,
strong,
sub,
sup,
var,
b,
i,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

body {
  line-height: 1;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}

nav ul {
  list-style: none;
}

blockquote,
q {
  quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
  content: "";
  content: none;
}

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

/* change colours to suit your needs */
ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}

/* change colours to suit your needs */
mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold;
}

del {
  text-decoration: line-through;
}

abbr[title],
dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

/* change border colour to suit your needs */
hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #cccccc;
  margin: 1em 0;
  padding: 0;
}

input,
select {
  vertical-align: middle;
}

body {
  font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
  font-size: clamp(14px, 4vw, 16px);
  color: #555;
}
body * {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
body a {
  color: inherit;
  text-decoration: none;
}
body p {
  line-height: 1.6em;
}
body button {
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}
body header {
  width: 100%;
  max-width: 720px;
  margin: 0 auto;
}
body header h1 {
  font-size: clamp(20px, 6vw, 24px);
  padding: 0.5em;
}
@media screen and (min-width: 720px) {
  body header h1 {
    padding: 1em 0 0.5em;
  }

  body header dl{
    display: block;
    flex-wrap: wrap;
    margin-bottom: 0.5rem;
    font-size: clamp(18px, 6vw, 22px);
    font-weight: 600;
  }

  body header dt{
    margin-left: 10px;
    width: 8%;
    display: flex;
  }

  body header dd{
    width: 55%;
    padding:20px 0;
  }

  body header dd:first-of-type{
    width:  38%;
  }

  body header dd:last-of-type{
    width:  52%;
    padding:20px 0;
  }
}

body header h1 span {
  display: inline-block;
}
body header h1 span:first-of-type {
  margin: 0 1em 0.5em 0;
}
/* ステータスバースタイル */
body #stepBar {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
/*  -ms-flex-wrap: wrap;
      flex-wrap: wrap;*/
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  width: 100%;
  margin-bottom: 2em;
  font-size: clamp(14px, 4vw, 16px);
}
body #stepBar li {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 20%;
  height: 36px;
  padding-left: 1em;
  list-style: none;
  text-align: center;
}
body #stepBar li::after {
  position: absolute;
  top: 0;
  right: -18px;
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 18px 0 18px 18px;
}
body #stepBar li:first-of-type {
  padding-left: 0;
  z-index: 5;
  background-color: #eee;
}
body #stepBar li:first-of-type::after {
  border-color: transparent transparent transparent #eee;
}
    body #stepBar li:nth-of-type(2) {
        width: 20%;
        z-index: 4;
        background-color: #e1e1e1;
    }

        body #stepBar li:nth-of-type(2)::after {
            border-color: transparent transparent transparent #e1e1e1;
        }

    body #stepBar li:nth-of-type(3) {
        width: 20%;
        z-index: 3;
        background-color: #d5d5d5;
    }

        body #stepBar li:nth-of-type(3)::after {
            border-color: transparent transparent transparent #d5d5d5;
        }

    body #stepBar li:nth-of-type(4) {
        width: 20%;
        z-index: 2;
        background-color: #c8c8c8;
    }

        body #stepBar li:nth-of-type(4)::after {
            border-color: transparent transparent transparent #c8c8c8;
        }

    body #stepBar li:last-of-type {
        z-index: 1;
        background-color: #bcbcbc;
    }

        body #stepBar li:last-of-type::after {
            display: none;
        }
body #stepBar li#current {
  font-weight: bold;
  color: white;
  background-color: #f6a600;
}
body #stepBar li#current::after {
  border-color: transparent transparent transparent #f6a600;
}
/* body #stepBar {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  width: 100%;
  margin-bottom: 2em;
  font-size: clamp(14px, 4vw, 16px);
}
body #stepBar li {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 20%;
  height: 36px;
  padding-left: 1em;
  list-style: none;
  text-align: center;
}
body #stepBar li::after {
  position: absolute;
  top: 0;
  right: -18px;
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 18px 0 18px 18px;
}
body #stepBar li:first-of-type {
  padding-left: 0;
  z-index: 5;
  background-color: #eee;
}
body #stepBar li:first-of-type::after {
  border-color: transparent transparent transparent #eee;
}
body #stepBar li:nth-of-type(2) {
  width: 30%;
  z-index: 4;
  background-color: #e1e1e1;
}
body #stepBar li:nth-of-type(2)::after {
  border-color: transparent transparent transparent #e1e1e1;
}
body #stepBar li:nth-of-type(3) {
  width: 30%;
  z-index: 3;
  background-color: #d5d5d5;
}
body #stepBar li:nth-of-type(3)::after {
  border-color: transparent transparent transparent #d5d5d5;
}
body #stepBar li:nth-of-type(4) {
  width: 30%;
  z-index: 2;
  background-color: #c6c6c6;
}
body #stepBar li:nth-of-type(4)::after {
  border-color: transparent transparent transparent #c6c6c6;
}
body #stepBar li:last-of-type {
  z-index: 1;
  background-color: #A0A0A0;
}
body #stepBar li:last-of-type::after {
  display: none;
}
body #stepBar li#current {
  font-weight: bold;
  color: white;
  background-color: #f6a600;
}
body #stepBar li#current::after {
  border-color: transparent transparent transparent #f6a600;
} */
body footer {
  width: 100%;
  max-width: 720px;
  margin: 0 auto;
}
body footer p {
  font-size: clamp(14px, 3vw, 18px);
  padding: 0.5em;
}
@media screen and (min-width: 720px) {
  body footer p {
    padding: 1em 0 0.5em;
  }
}

main {
  max-width: 720px;
  margin: 0 auto;
}
main form h2 {
  width: 100%;
  padding: 0.5em 1em;
  font-size: clamp(16px, 5vw, 20px);
  margin-bottom: 2em;
  border-bottom: solid 0.25em #f6a600;
}
main form dl {
  width: calc(100% - (4% * 2));
  margin: 0 auto 1em;
  /* 			&.search {
  	@include m.flex;
  	min-width: 640px;
  	align-items: stretch;
  	dt {
  		width: 40%;
  		height: auto;
  		align-items: flex-start;
  		padding: 1em;
  		border-bottom: none;
  		&:last-of-type {
  			border: solid 1px v.$colorAccent;
  		}
  	}
  	dd {
  		width: 60%;
  		padding: 1em 2em;
  		margin-bottom: 0;
  		border: solid 1px v.$colorAccent;
  		border-left: none;
  		border-bottom: none;
  		&:last-of-type {
  			border-bottom: solid 1px v.$colorAccent;
  		}
  		select {
  			padding: 0.5em;
  			margin: 0 0 1em;
  			&:nth-of-type(2) {
  				& + span {
  					display: inline-block;
  					width: auto;
  					padding: 0;
  					margin: 0;
  					transform: translateY(-0.5em);
  				}
  			}
  		}
  		input {
  			&[type="checkbox"] {
  				margin: 0;
  			}
  		}
  		ul {
  			display: flex;
  			width: 100%;
  			li {
  				display: flex;
  				flex: 1;
  				margin-bottom: 0;
  				input {
  					&[type="checkbox"] {
  						margin: 0 1em 0 0;
  					}
  				}
  				label {
  					margin: 0;
  				}
  			}
  		}
  	}
  } */
}
main form p{
  margin-left: 16px;
}

@media screen and (min-width: 720px) {
  main form dl {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    width: 100%;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
  }
  main form p{
    margin-left: 0px;
  }
  
}


main form dl dt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  width: 100%;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
  height: 4em;
  padding: 0 1em;
  border: solid 1px #f6a600;
  background-color: #fffcf6;
}
@media screen and (min-width: 720px) {
  main form dl dt {
    width: 45%;
    height: auto;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    padding: 1em;
    border-bottom: none;
  }
  main form dl dd.side{
    padding: 1em 2em 0;
  }

  .side .text-danger{
    width:100%
  }
  main form dl dt:last-of-type {
    border: solid 1px #f6a600;
  }
}
main form dl dt.required::after {
  display: block;
  content: "必須";
  padding: 0.5em;
  font-size: clamp(14px, 4vw, 16px);
  color: white;
  border-radius: 1em;
  background-color: #f6a600;
}
main form dl dd {
  border: solid 1px #f6a600;
  border-top: none;
  padding: 1em;
  margin-bottom: 2em;
  word-break: break-word;
}
@media screen and (min-width: 720px) {
  main form dl dd {
    width: 55%;
    padding: 1em 2em 0;
    margin-bottom: 0;
    border: solid 1px #f6a600;
    border-left: none;
    border-bottom: none;
    word-break: break-word;
  }
  main form dl dd:last-of-type {
    border-bottom: solid 1px #f6a600;
  }
}
main form dl dd label {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 0 1em 1em calc(4% * 1.5);
}
main form dl dd input[type=text], main form dl dd input[type=tel], main form dl dd input[type=date] {
  display: block;
  width: 100%;
  padding: 0.5em;
  margin: 0 auto 0.5em;
  border: solid 1px #f6a600;
  border-radius: 0.25em;
  background-color: white;
}
main form dl dd input[type=text]:focus, main form dl dd input[type=tel]:focus, main form dl dd input[type=date]:focus {
  background-color: white;
}
main form dl dd input[type=checkbox] {
  display: block;
  -webkit-transform: scale(2);
          transform: scale(2);
  margin: 0 auto;
}
main form dl dd select {
  padding: 0.5em;
  margin: 0 0.5em 0.5em 1em;
  border: solid 1px #f6a600;
  border-radius: 0.25em;
  background-color: white;
}
main form dl dd select:focus {
  background-color: white;
}
main form dl dd select:first-of-type {
  margin-left: 0;
}
@media screen and (min-width: 720px) {
  main form dl dd select:first-of-type {
    margin-left: 0;
  }
}
main form dl dd select:nth-of-type(2) + span {
  display: inline-block;
  width: auto;
  padding: 0;
  margin: 0;
  -webkit-transform: translateY(-0.1em);
          transform: translateY(-0.1em);
}
main form dl dd p {
  margin-bottom: 0.5em;
}
main form dl dd p i {
  display: inline-block;
  margin-right: 0.5em;
  color: red;
}
main form dl dd p.example {
  width: 100%;
  height: 36px;
  padding: 0.5em 1em;
  margin: 4px auto 0.5em;
  font-size: clamp(14px, 4vw, 16px);
  background-color: #eee;
}
main form dl dd p.example + p {
  padding-left: 16px;
  text-indent: -12px;
  /* margin: 0 0 0.5em 1em; */
}
main form dl dd span {
  /* display: block; */
  width: calc(100% - (4% * 2));
  margin: 0 auto 1em;
  color: red;
}
main form dl dd ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
}
main form dl dd ul li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  margin-bottom: 0;
}
main form dl dd ul li input[type=checkbox] {
  margin: 0 1em 0 0;
}
main form dl dd ul li label {
  margin: 0;
}
main form dl dd button {
  text-decoration: underline;
  color: #006ebc;
  font-size: clamp(14px, 4vw, 16px);
  margin-bottom: 1em;
}
main form .agree {
  width: calc(100% - (4% * 2));
  margin: 0 auto 1em;
  width: 100%;
  padding: 1em;
  margin: 0 auto 1em;
}
main form .agree p {
  width: 100%;
  margin: 0 auto 1em;
}
main form .agree div {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  width: 100%;
  width: 10em;
  height: 3em;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin: 0 auto 1em;
  border-radius: 1em;
  color: #f6a600;
  border: solid 2px #f6a600;
  cursor: pointer;
  background-color: white;
  -webkit-transition: 500ms;
  transition: 500ms;
}
main form .agree div:hover {
  color: white;
  border: solid 1px white;
  background-color: #f6a600;
}
main form .agree div input[type=checkbox] {
  display: inline-block;
  margin-right: 1.5em;
  -webkit-transform: scale(1.5);
          transform: scale(1.5);
  cursor: pointer;
}
main form .agree div label {
  cursor: pointer;
}
main form .agree span {
  display: block;
  width: calc(100% - (4% * 2));
  margin: 0 auto 1em;
  color: red;
}
main form .buttonArea {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  width: 100%;
  -ms-flex-pack: distribute;
      justify-content: space-around;
}
main form .buttonArea button {
  display: table;
  font-size: clamp(16px, 5vw, 20px);
  padding: 0.25em 1em;
  margin-bottom: 1em;
  color: white;
  border-radius: 0.25em;
  letter-spacing: 0.1em;
  -webkit-transition: 500ms;
  transition: 500ms;
  margin: 0 auto 3em;
}
main form .buttonArea button.button {
  color: #006ebc;
  border: solid 1px #006ebc;
  background-color: white;
}
main form .buttonArea button.button:hover {
  color: white;
  border: solid 1px white;
  background-color: #006ebc;
}
main form .buttonArea button.submit {
  background-color: #f6a600;
}
main form .buttonArea button.submit:hover {
  color: #f6a600;
  border: solid 1px #f6a600;
  background-color: white;
}
main form .buttonArea button.wide {
  width: 8em;
  margin: 0 calc((100% - 8em) / 2) 1em;
}
@media screen and (min-width: 720px) {
  main form .buttonArea button.wide {
    margin: 0 auto 3em;
  }
}
main form ul {
  width: calc(100% - (4% * 2));
  margin: 0 auto 1em;
}
main form ul li {
  list-style: none;
  margin-bottom: 0.5em;
}
main form table {
  width: 100%;
  max-height: 100vh;
  white-space: nowrap;
  -webkit-transform: translateX(-200px);
          transform: translateX(-200px);
}
main form table caption {
  font-size: clamp(16px, 5vw, 20px);
  text-align: left;
}
main form table caption .pagination {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: left;
      -ms-flex-pack: left;
          justify-content: left;
  margin: 0.5em 0 1em;
}
main form table caption .pagination li {
  list-style: none;
  padding: 0.75em 1em;
  font-size: clamp(16px, 5vw, 20px);
  border-radius: 0.5em;
  border: solid 1px #eee;
}
main form table caption .pagination li#current {
  color: white;
  background-color: #006ebc;
}
main form table thead tr {
  /* &:nth-of-type(1) {
  	th {
  		top: 0;
  	}
  }
  &:nth-of-type(2) {
  	th {
  		top: 2em;
  	}
  }
  &:nth-of-type(3) {
  	th {
  		top: 4em;
  	}
  } */
}
main form table thead tr th {
  padding: 0.5em;
  border: solid 1px #555;
  color: white;
  background-color: #006ebc;
  position: sticky;
  top: 0;
}
main form table tbody tr td {
  padding: 0.5em;
  border: solid 1px #555;
}
main form table tbody tr:nth-of-type(even) {
  background-color: #eee;
}

div > h4 {
  white-space: pre-line;
}

footer p {
  font-size: clamp(10px, 3vw, 12px);
}

/* ごあんない画面スタイル */
.confirmation p{
  font-size: 20px;
  text-align: center;
  margin-bottom: 16px;
}
@media screen and (min-width: 720px){
  body main form .confirmation .buttonArea button{
    display: table;
    font-size: clamp(16px, 5vw, 20px);
    padding: 0.25em 1em;
    color: white;
    border-radius: 0.25em;
    letter-spacing: 0.1em;    transition: 500ms;
    margin: 0 auto 3em;
    width: auto;
  }
}

.confirmation .buttonArea button{
  display: table;
  font-size: clamp(18px, 5vw, 20px);
  padding: 0.5em 1em;
  margin-bottom: 1em;
  color: white;
  border-radius: 0.25em;
  letter-spacing: 0.1em;
  -webkit-transition: 500ms;
  transition: 500ms;
  margin: 0 auto 3em;
  width: auto;
}

/* 同意確認ボタン */
main form .buttonArea button[type="submit"][disabled] {
  background-color: #fff;
  color: #ccc;
  border-color: #ccc;
  cursor: default;

}

main form .buttonArea button[type="submit"][disabled]:hover{
opacity:1;
}

p.center{
  text-align: center;
  
}

.title{
  font-size: clamp(14px, 4vw, 18px);
  font-weight: 600;
}
p.center.title{
  font-size: clamp(16px, 4vw, 24px);
  font-weight: 600;
}

p.left{
  text-align: left;
}

.confirmationp.left{
  font-size: clamp(14px, 4vw, 16px);
}

.confirm dl{
  margin: 0 auto 1em;
}

.jumppage p.center.title{
  margin-bottom: 16px;
}

.jumppage .buttonArea{
  margin-top: 16px;
}

.contact.information{
  text-align: right;
  margin-top: 8px;
}

.result .center,.result .center.title{
  margin-bottom: 16px;
}

.buttonArea .close{
  display: table;
  font-size: clamp(16px, 5vw, 20px);
  padding: 0.5em 1em;
  color: white;
  border-radius: 0.25em;
  letter-spacing: 0.1em;
  transition: 500ms;
  margin: 0 auto 3em;
  background-color: #f6a600;
  cursor: pointer;
}

.buttonArea a:hover{
  color: #f6a600;
  border: solid 1px #f6a600;
  background-color: white;
}


.text-errormessage{
  color: red;
}

.buttonArea a{
  display: table;
  font-size: clamp(16px, 5vw, 20px);
  padding: 0.5em 1em;
  border-radius: 0.25em;
  letter-spacing: 0.1em;
  transition: 500ms;
  margin: 0 auto 3em;
  cursor: pointer;
}

a.back{
  color: #006ebc;
  border: solid 1px #006ebc;
  background-color: white;
}


.buttonArea a.back:hover{
  color: white;
  border: solid 1px white;
  background-color: #006ebc;
}

/* ヘッダースタイル */

header dl{
  display: flex;
  flex-wrap: wrap;
  font-size: clamp(18px, 6vw, 22px);
  font-weight: 600;
  margin-bottom: 0.5rem;
}
header dt{
  display: flex;
  flex-wrap: wrap;
  width: 15%;
}
header dd{
  /* display: inline-block; */
  width: 80%;
  padding:20px 0;
}
header dd:last-of-type{
  /* display: inline-block; */
  width: 100%;
  padding:10px 0;
}

/* 20230822~新規追加 */
.inline-item{
  display: flex;
  flex-wrap:wrap;
}

.inline-item input[type=text]{
  width: 45%;
  height: 32px;

}


.inline-item p.example{
  width: 45%;
}


.personalauthentication .example{
  height: auto;
}

.inline-item span.itemname{
  display: inherit;
  width: 10%;
  color: black;
  align-items: center;
  margin: 4px 0 0 4px;
}

main form dl dd.side input[type=text]{
  margin: 0;
  width: 38%;
}

main form dl dd.side{
  padding: 1em;
}

.side .text-danger{
  /* width: inherit; */
  margin: 4px 2px 2px 0;
}

.side p.example{
  width:47%;
}

.mailrecipient{
  word-break: break-all;
  color: #000;
}


/* 送信ボタン */
/* main form .example button{
  font-size: clamp(14px, 4vw, 16px);
  padding: 0.15em 0.5em;
  color: white;
  border-radius: 0.25em;
  letter-spacing: 0.1em;
  -webkit-transition: 500ms;
  transition: 500ms;
  margin-bottom: 0px;
  margin-left: 2px;
  text-decoration: none;
}
main form .example button.submit {
  background-color: #f6a600;
}
main form .example button.submit:hover {
  color: #f6a600;
  border: solid 1px #f6a600;
  background-color: white;
} */






   


 




/* @media screen and(min-width: 720px) {
	header,
	main,
	footer {
		width: v.$breakPoint;
		margin: 0 auto;
	}
}
 */
/*# sourceMappingURL=style.css.map */
