@charset "utf-8";

/* ------------------------------------------------------------------------------
     reset
-------------------------------------------------------------------------------*/
* {
  box-sizing: border-box;
}
::before,
::after {
  box-sizing: inherit;
}
html {
  line-height: 1.15;
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent;
}
body {
  margin: 0;
}
main {
  display: block;
}
p,table,blockquote,address,pre,
iframe,form,figure,dl {
  margin: 0;
}
h1,h2,h3,h4,h5,h6 {
  font-size: inherit;
  line-height: inherit;
  font-weight: inherit;
  margin: 0;
}
ul,ol {
  margin: 0;
  padding: 0;
  list-style: none;
}
dt {
  font-weight: bold;
}
dd {
  margin-left: 0;
}
hr {
  box-sizing: content-box;
  height: 0;
  overflow: visible;
  border: 0;
  border-top: 1px solid;
  margin: 0;
  clear: both;
  color: inherit;
}
pre {
  font-family: monospace, monospace;
  font-size: inherit;
}
address {
  font-style: inherit;
}
a {
  background-color: transparent;
  text-decoration: none;
  color: inherit;
}
abbr[title] {
  border-bottom: none;
  text-decoration: underline;
  text-decoration: underline dotted;
}
b,strong {
  font-weight: bolder;
}
code,kbd,samp {
  font-family: monospace, monospace;
  font-size: inherit;
}
small {
  font-size: 80%;
}
sub,sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}
sub {
  bottom: -0.25em;
}
sup {
  top: -0.5em;
}
img {
  max-width: 100%;
  border-style: none;
  vertical-align: bottom;
}
embed,object,iframe {
  border: 0;
  vertical-align: bottom;
}
button,input:not([type="radio"]):not([type="checkbox"]),
optgroup,textarea {
  -webkit-appearance: none;
  appearance: none;
  vertical-align: middle;
  color: inherit;
  font: inherit;
  border: 0;
  background: transparent;
  padding: 0;
  margin: 0;
  outline: 0;
  border-radius: 0;
  text-align: inherit;
}
button,input {
  overflow: visible;
}
button {
  text-transform: none;
}
button,[type="button"],
[type="reset"],[type="submit"] {
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
}
button[disabled],[type="button"][disabled],
[type="reset"][disabled],[type="submit"][disabled] {
  cursor: default;
}
button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}
button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText;
}
option {
  padding: 0;
}
fieldset {
  margin: 0;
  padding: 0;
  border: 0;
  min-width: 0;
}
legend {
  color: inherit;
  display: table;
  max-width: 100%;
  padding: 0;
  white-space: normal;
}
progress {
  vertical-align: baseline;
}
textarea {
  overflow: auto;
}
[type="checkbox"],
[type="radio"] {
  padding: 0;
  margin: 0;
  outline: 0;
}
[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto;
}
[type="search"] {
  outline-offset: -2px;
}
[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}
::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}
details {
  display: block;
}
summary {
  display: list-item;
}
[contenteditable] {
  outline: none;
}
table {
  border-collapse: collapse;
  border-spacing: 0;
}
caption {
  text-align: left;
}
td,th {
  vertical-align: top;
  padding: 0;
}
th {
  text-align: left;
  font-weight: bold;
}
template {
  display: none;
}
[hidden] {
  display: none;
}

/* ------------------------------------------------------------------------------
     base
-------------------------------------------------------------------------------*/
html {
  font-size: 62.5%;
  font-family: 'ヒラギノ角ゴ ProN','Hiragino Kaku Gothic Pro','ヒラギノ角ゴ Pro W3','メイリオ',Meiryo,'ＭＳ Ｐゴシック',sans-serif;
  color: #000000;
  line-height: 1.8;
}
body {
  font-size: 18px;
  font-size: 1.8rem;
}
@media only screen and (max-width:767px) {
  body {
    font-size: 14px;
    font-size: 1.4rem;
  }
}
a {
  color: #000000;
  transition: opacity 0.2s linear;
}
a:hover { opacity:0.7; }
a:visited { color: #000000; }
a img:hover {
  opacity: 0.8;
  -ms-filter: "alpha(opacity=80)" !important;
  -webkit-transition-duration: .5s;
  -moz-transition-duration: .5s;
  -ms-transition-duration: .5s;
  transition-duration: .5s;
}
a.link-01 {
  color: #00B4CB;
  text-decoration: underline;
}
a.link-01:visited {
  color: #00B4CB;
}
.pc_none { display: none!important; }
@media screen and (max-width:767px) {
  .pc_none { display: block!important; }
  br.pc_none,
  span.pc_none,
  img.pc_none {
    display: inline!important;
  }
  .sp_none { display: none!important; }
}
.bold {  font-weight: bold; }
.underline { text-decoration: underline!important;}
.center { text-align: center!important; }
.left { text-align: left!important; }
.right { text-align: right!important; }

.red { color: #ff0000; }

.mt0 { margin-top: 0!important; }
.mt20 { margin-top: 20px!important; }
.mb20 { margin-bottom: 20px!important; }

.marker {
  background: linear-gradient(transparent 65%, #F5FF00 65%);
}
.marker2 {
  padding: 0 6px;
  background: linear-gradient(transparent 65%, #1AD1E8 65%);
}

.strike-through {
  text-decoration: line-through;
}

.indent { text-indent: 1em; }

.border-bottom {
  margin-bottom: 50px;
  padding-bottom: 50px;
  border-bottom: 1px solid #000;
}

.block {
  display: block!important;
}
.inline {
  display: inline!important;
}

.ol-list {
  padding-left: 1em;
  list-style-type: decimal;
}

.border-none {
  border: none!important;
}

@media (min-width: 768px) {
  a[href*="tel:"] {
    pointer-events: none;
    cursor: default;
    text-decoration: none;
  }
}

/* ------------------------------------------------------------------------------
     icon
-------------------------------------------------------------------------------*/
.icon-blank {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 21px;
  height: 21px;
  margin: auto 8% auto auto;
  vertical-align: middle;
  background: url(/images/icon_blank.png) no-repeat 50%;
  background-size: contain;
}
@media screen and (max-width:1000px) {
  .icon-blank {
    width: 16px;
    height: 16px;
    margin: auto 8% auto auto;
  }
}
@media screen and (max-width:767px) {
  .icon-blank {
    width: 10px;
    height: 10px;
    margin: auto 8% auto auto;
  }
}

.table-01 .icon-blank {
  display: inline-block;
  position: static;
  width: 14px;
  height: 14px;
  margin: 0 0 0 8px;
  vertical-align: middle;
  background: url(/images/icon_blank.png) no-repeat 50%;
  background-size: contain;
}

.icon-down {
  position: absolute;
  top: -6px; bottom: 0;
  right: 30px;
  display: block;
  border-bottom: solid 2px #000;
  border-right: solid 2px #000;
  width: 12px;
  height: 12px;
  margin: auto;
  transform: rotate(45deg);
}
@media screen and (max-width:767px) {
  .icon-down {
    position: absolute;
    top: -3px; bottom: 0;
    right: 8%;
    display: block;
    border-bottom: solid 2px #000;
    border-right: solid 2px #000;
    width: 8px;
    height: 8px;
    margin: auto;
    transform: rotate(45deg);
  }
}

.icon-pdf {
  display: inline-block;
  width: 18px;
  height: 18px;
  margin: -4px 8px 0;
  vertical-align: middle;
  background: url(/images/icon_pdf.png) no-repeat 50%;
  background-size: contain;
}
@media screen and (max-width:767px) {
  .icon-pdf {
    width: 14px;
    height: 14px;
    margin: -4px 4px 0;
  }
}

.icon-word {
  display: inline-block;
  width: 18px;
  height: 18px;
  margin: -4px 0 0 8px;
  vertical-align: middle;
  background: url(/images/icon_word.png) no-repeat 50%;
  background-size: contain;
}

.icon-excel {
  display: inline-block;
  width: 18px;
  height: 18px;
  margin: -4px 0 0 8px;
  vertical-align: middle;
  background: url(/images/icon_excel.png) no-repeat 50%;
  background-size: contain;
}

.icon-ppt {
  display: inline-block;
  width: 18px;
  height: 18px;
  margin: -4px 0 0 8px;
  vertical-align: middle;
  background: url(/images/icon_ppt.png) no-repeat 50%;
  background-size: contain;
}

/* ------------------------------------------------------------------------------
     frame
-------------------------------------------------------------------------------*/
.main-contents {
  position: relative;
  padding: 0 0 120px;
}
@media screen and (max-width:767px) {
  .main-contents {
  padding: 0 0 80px;
  }
}
.contents-inner {
  max-width: 1220px;
  margin: 0 auto;
  padding: 40px 60px 180px;
  background-color:rgba(255,255,255,0.9);
}
@media screen and (max-width:767px) {
  .contents-inner {
    padding: 20px 5px 80px;
  }
}
.contents-section {
  padding: 60px 20px;
}
@media screen and (max-width:767px) {
  .contents-section {
    padding: 40px 20px;
  }
}
.inner {
  max-width: 1100px;
  margin: 0 auto;
}

/* ------------------------------------------------------------------------------
     title
-------------------------------------------------------------------------------*/
.contents-title {
  position: relative;
  margin-bottom: 30px;
  padding-left: 10px;
  border-left: 10px solid #1AD1E8;
  font-size: 40px;
  font-weight: bold;
  line-height: 1.1;
}
@media screen and (max-width:767px) {
  .contents-title {
    margin-bottom: 20px;
    padding-left: 5px;
    border-left: 5px solid #1AD1E8;
    font-size: 24px;
  }
}
.number-title {
  font-size: 24px;
  font-weight: bold;
}
@media screen and (max-width:767px) {
  .number-title {
    font-size: 16px;
  }
}
.number-title > .number {
  font-weight: bold;
  margin-right: 10px;
  color: #1AD1E8;
}
p + .number-title,
ul + .number-title {
  margin-top: 30px;
}
@media screen and (max-width:767px) {
  p + .number-title,
  ul + .number-title {
    margin-top: 30px;
  }
}
.border-title-01 {
  margin-bottom: 35px;
  font-size: 20px;
  padding-bottom: 5px;
  border-bottom: 2px solid #ccc;
}
@media screen and (max-width:767px) {
  .border-title-01 {
    margin-bottom: 20px;
    font-size: 16px;
    padding-bottom: 2px;
    border-bottom: 2px solid #ccc;
  }
}
.border-title-02 {
  position: relative;
  margin-top: 50px;
  padding-left: 50px;
}
.border-title-02::before {
  content: "";
  position: absolute;
  top: -5px;
  left: 0;
  display: block;
  width: 38px;
  height: 42px;
  background: url(/images/border_title_img.png) no-repeat;
}
.normal-title {
  font-size: 24px;
}
@media screen and (max-width:767px) {
  .normal-title {
    font-size: 18px;
  }
}
.normal-center-title {
  font-size: 36px;
  text-align: center;
}
@media screen and (max-width:1000px) {
  .normal-center-title {
    font-size: 28px;
  }
}
@media screen and (max-width:767px) {
  .normal-center-title {
    font-size: 18px;
  }
}
.contents-main-title {
  color: #fff;
  font-size: 48px;
  text-align: center;
  text-shadow: 3px 4px 6px #000;
}
@media screen and (max-width:900px) {
  .contents-main-title {
    font-size: 36px;
  }
}
@media screen and (max-width:767px) {
  .contents-main-title {
    font-size: 20px;
  }
}
.icon-title {
  position: relative;
  margin: 50px 0 30px;
  padding-left: 50px;
  font-size: 20px;
}
@media screen and (max-width:767px) {
  .icon-title {
    padding-left: 30px;
    margin: 30px 0 10px;
    font-size: 16px;
  }
}
.icon-title::before {
  content: "";
  position: absolute;
  top: -5px;
  left: 0;
  display: block;
  width: 38px;
  height: 42px;
  background: url(/images/border_title_img.png) no-repeat;
}
@media screen and (max-width:767px) {
  .icon-title::before {
    top: 0;
    width: 19px;
    height: 21px;
    background: url(/images/border_title_img.png) no-repeat;
    background-size: contain;
  }
}

/* ------------------------------------------------------------------------------
    text
-------------------------------------------------------------------------------*/
.text-01 {
  margin-top: 30px;
}
@media screen and (max-width:767px) {
  .text-01 {
    margin-top: 20px;
  }
}

/* ------------------------------------------------------------------------------
    button
-------------------------------------------------------------------------------*/
.button-01 {
  padding: 20px;
  background: #fff;
  border: 2px solid #000;
  border-radius: 14px;
  font-size: 24px;
  text-align: center;
  cursor: pointer;
}
@media screen and (max-width:767px) {
  .button-01 {
    padding: 14px;
    border-radius: 12px;
    font-size: 14px;
  }
}
.button-01:hover {
  background: #F8FE54;
  transition: .5s;
}
.button-02 {
  position: relative;
  display: block;
  width: 300px;
  margin: 0 auto;
  padding: 10px 20px;
  background: #fff;
  border: 2px solid #000;
  border-radius: 100px;
  font-size: 20px;
  text-align: center;
}
@media screen and (max-width:767px) {
  .button-02 {
    width: 250px;
    font-size: 16px;
  }
}
.button-02:hover {
  opacity: 1;
  background: #F8FE54;
  transition: .5s;
}
.button-02::after {
  content: "";
  position: absolute;
  top: 0; bottom: 0;
  right: 20px;
  display: block;
  border-top: solid 2px #000000;
  border-right: solid 2px #000000;
  width: 8px;
  height: 8px;
  margin: auto;
  transform: rotate(45deg);
}
.button-02.disabled {
  opacity: 0.3;
}
.button-02.disabled:hover {
  opacity: 0.3;
  background: inherit;
  transition: unset;
}
.button-05 {
  position: relative;
  display: block;
  width: 400px;
  margin: 0 auto;
  padding: 10px 20px;
  background: #8FFAA4;
  border: 2px solid #000;
  border-radius: 100px;
  font-size: 20px;
  font-weight: bold;
  text-align: center;
}
@media screen and (max-width:767px) {
  .button-05 {
    width: 250px;
    font-size: 16px;
  }
}
.button-05:hover {
  opacity: 1;
  background: #3BF05F;
  transition: .5s;
}
.button-05::after {
  content: "";
  position: absolute;
  top: 0; bottom: 0;
  right: 20px;
  display: block;
  border-top: solid 2px #000000;
  border-right: solid 2px #000000;
  width: 8px;
  height: 8px;
  margin: auto;
  transform: rotate(45deg);
}
.button-06 {
  position: relative;
  display: block;
  width: 100%;
  max-width: 130px;
  margin: 0 auto;
  padding: 2px 10px;
  background: #F8FE54;
  border: 2px solid #000;
  border-radius: 100px;
  font-size: 16px;
  text-align: center;
}
@media screen and (max-width:767px) {
  .button-06 {
    font-size: 14px;
  }
}
.button-06:hover {
  opacity: 0.7;
  transition: .5s;
}
.button-06::after {
  content: "";
  position: absolute;
  top: 0; bottom: 0;
  right: 14px;
  display: block;
  border-top: solid 2px #000000;
  border-right: solid 2px #000000;
  width: 8px;
  height: 8px;
  margin: auto;
  transform: rotate(45deg);
}
.button-07 {
  position: relative;
  display: block;
  width: 100%;
  max-width: 350px;
  margin: 0 auto;
  padding: 18px 18px;
  background: #F8FE54;
  border: 2px solid #000;
  border-radius: 100px;
  font-size: 20px;
  text-align: center;
  line-height: 1;
}
@media screen and (max-width:767px) {
  .button-07 {
    font-size: 16px;
  }
}
.button-07::after {
  content: "";
  position: absolute;
  top: 0; bottom: 0;
  right: 25px;
  display: block;
  border-top: solid 2px #000000;
  border-right: solid 2px #000000;
  width: 8px;
  height: 8px;
  margin: auto;
  transform: rotate(45deg);
}
.button-07.button-fs {
  font-size: 16px;
}
.button-end {
  border: 2px solid #B4B1B1;
  background: #fff;
  color: #B4B1B1;
  font-weight: normal;
}
.button-end::after {
  border-top: solid 2px #B4B1B1;
  border-right: solid 2px #B4B1B1;
}
.button-end:hover {
  background: #fff;
}

/* ------------------------------------------------------------------------------
    list
-------------------------------------------------------------------------------*/
.list-01, .list-02 {
  margin-top: 30px;
}
.list-01 > li {
  position: relative;
  padding-left: 1.2em;
}
.list-01 > li > .mark {
  position: absolute;
  top: 0;
  left: 0;
}
.list-02 > li {
  position: relative;
  padding-left: 2em;
}
.list-02 > li > .mark {
  position: absolute;
  top: 0;
  left: 0;
}
.list-03 {
  margin-top: 30px;
}
.list-04 {
  margin-top: 30px;
}
.list-04 > li + li {
  margin-top: 30px;
}

/* ------------------------------------------------------------------------------
    note
-------------------------------------------------------------------------------*/
.note-01 {
  width: 100%;
  font-size: 16px;
}
@media screen and (max-width:767px) {
  .note-01 {
    font-size: 14px;
  }
}

/* ------------------------------------------------------------------------------
    table
-------------------------------------------------------------------------------*/
@media screen and (min-width:768px) {
  .table-01 {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin-top: 30px;
  }
}
@media screen and (max-width:767px) {
  .table-01 {
    margin-top: 20px;
  }
}
.table-01 > dt {
  background: #00B4CB;
  color: #fff;
  text-align: center;
}
@media screen and (min-width:768px) {
  .table-01 > dt {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-flow: column;
    width: 25.5%;
    padding: 26px;
    background: #00B4CB;
    color: #fff;
    text-align: center;
  }
}
@media screen and (max-width:767px) {
  .table-01 > dt {
    padding: 10px 24px;
    background: #00B4CB;
    color: #fff;
    text-align: center;
  }
}
.table-01 > dd {
  background: #E9FAFD;
}
@media screen and (min-width:768px) {
  .table-01 > dd {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    flex-flow: column;
    width: 74%;
    padding: 26px;
    background: #E9FAFD;
  }
}
@media screen and (max-width:767px) {
  .table-01 > dd {
    margin-top: 2px;
    padding: 10px 24px;
  }
}
@media screen and (min-width:768px) {
  .table-01 > dd + dt,
  .table-01 > dd + dt + dd {
    margin-top: 0.5%;
  }
}
@media screen and (max-width:767px) {
  .table-01 > dd + dt {
    margin-top: 10px;
  }
}
@media screen and (max-width:767px) {
  .table-01 > .sp-center {
    text-align: center;
  }
}
.table-01 > dd.center {
  justify-content: center;
}

.table-02 {
  margin-top: 24px;
}
@media screen and (min-width:768px) {
  .table-02 {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
}
@media screen and (min-width:768px) {
  .table-02 > dt {
    position: relative;
    width: 110px;
    font-weight: normal;
  }
}
.table-02 > dt::after {
  content: "：";
  position: absolute;
  right: 0;
}
@media screen and (max-width:768px) {
  .table-02 > dt::after {
    left: 7em; right: auto;
  }
}
@media screen and (min-width:768px) {
  .table-02 > dd {
    width: calc(100% - 120px);
  }
}
.table-03 {
  display: flex;
  border-top: 1px solid #00B4CB;
  border-left: 1px solid #00B4CB;
  border-right: 1px solid #00B4CB;
}
.table-03-th {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 20px 10px;
  width: 200px;
  background: #E9FAFD;
  font-size: 22px;
  font-weight: bold;
  flex-shrink: 0;
  text-align: center;
}
@media screen and (max-width:768px) {
  .table-03-th {
    padding: 10px 2px;
    width: 108px;
    background: #E9FAFD;
    font-size: 14px;
    font-weight: bold;
  }
}
.table-03-th.th-long {
  width: 100%;
  flex-shrink: 1;
  border-left: 1px solid #00B4CB;
}
.table-03-td {
  display: flex;
  align-items: center;
  padding: 20px 32px;
  border-left: 1px solid #00B4CB;
}
@media screen and (max-width:768px) {
  .table-03-td {
    width: calc(100% - 100px);
    padding: 10px;
  }
}
.table-03:last-of-type {
  border-bottom: 1px solid #00B4CB;
}


/* ------------------------------------------------------------------------------
     box
-------------------------------------------------------------------------------*/
.gray-box {
  padding: 30px 20px;
  background: #eee;
}
@media screen and (max-width:767px) {
  .gray-box {
    padding: 20px 12px;
  }
}

/* ------------------------------------------------------------------------------
     header
-------------------------------------------------------------------------------*/
.header {
  position: sticky;
  top: 0;
  padding: 0 20px;
  background: #fff;
  z-index: 999;
  -webkit-box-shadow: 0 1px 3px 0 rgba(0,0,0,.2);
  box-shadow: 0 1px 3px 0 rgba(0,0,0,.2);
}
@media screen and (max-width:350px) {
  .header {
    padding: 0 10px;
  }
}
.header-inner {
  height: 118px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  max-width: 1200px;
  margin: 0 auto;
  padding: 25px 0;
}
@media screen and (max-width:767px) {
  .header-inner {
    height: 14vw;
    padding: 12px 0;
  }
}
.header-left {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.header-menu {
  margin-left: 80px;
  font-size: 0;
}
@media screen and (max-width:767px) {
  .header-menu {
    margin-left: 25px;
  }
}
.header-menu > li {
  display: inline-block;
  font-size: 20px;
}
@media screen and (max-width:767px) {
  .header-menu > li {
    font-size: 14px;
  }
}
@media screen and (max-width:400px) {
  .header-menu > li {
    font-size: 12px;
  }
}
.header-menu > li + li {
  margin-left: 30px;
}
@media screen and (max-width:767px) {
  .header-menu > li + li {
    margin-left: 10px;
  }
}
.header-menu a {
  text-decoration: underline;
}
@media screen and (max-width:767px) {
  .header-logo {
    width: 25.73vw;
  }
  .header-logo img {
    max-height: 36px;
    vertical-align: middle;
  }
}
.header-lang-list {
  display: none;
  font-size: 0;
}
.header-lang-list > li {
  display: inline-block;
  font-size: 22px;
  color: #02B4CB;
}
@media screen and (max-width:767px) {
  .header-lang-list > li {
    font-size: 14px;
  }
}
@media screen and (max-width:400px) {
  .header-lang-list > li {
    font-size: 12px;
  }
}
.header-lang-list > li + li {
  margin-left: 15px;
  padding-left: 15px;
  border-left: 2px solid #ccc;
}
@media screen and (max-width:767px) {
  .header-lang-list > li + li {
    margin-left: 10px;
    padding-left: 10px;
  }
}
.header-lang-list > li > a {
  text-decoration: underline;
}

/* ------------------------------------------------------------------------------
     contents
-------------------------------------------------------------------------------*/
.contents-section > p + p {
  margin-top: 30px;
}
@media screen and (max-width:767px) {
  .contents-section > p + p {
    margin-top: 20px;
  }
}
.contents-mainvisual {
  padding: 85px 0;
  background: url(/images/contents_mainvisual.jpg) no-repeat center;
  background-size: cover;
}
@media screen and (max-width:767px) {
  .contents-mainvisual {
    padding: 25px 0;
  }
}
.contents-wrap + .contents-wrap {
  margin-top: 115px;
}
@media screen and (max-width:767px) {
  .contents-wrap + .contents-wrap {
    margin-top: 60px;
  }
}

/* ------------------------------------------------------------------------------
    qa
-------------------------------------------------------------------------------*/
.qa-list {
  margin-bottom: 20px;
}
@media screen and (max-width:767px) {
  .qa-list {
    margin-bottom: 10px;
  }
}
.qa-list dt,
.qa-list dd {
  padding: 10px 40px 10px 16px;
  border: 2px solid #000;
}
@media screen and (max-width:767px) {
  .qa-list dt {
    padding: 8px 30px 8px 12px;
    border: 1px solid #000;
  }
  .qa-list dd {
    padding: 8px 12px;
    border: 1px solid #000;
  }
}
.qa-list dt {
  position: relative;
  cursor: pointer;
}
.qa-list dt:hover {
  opacity: 0.7;
  transition: 0.5s;
}
.qa-list dt::before,
.qa-list dt::after {
  content: "";
  position: absolute;
  top: 0; bottom: 0;
  right: 20px;
  display: block;
  width: 16px;
  height: 3px;
  margin: auto;
  background: #1AD1E8;
}
@media screen and (max-width:767px) {
  .qa-list dt::before,
  .qa-list dt::after {
    right: 10px;
    width: 14px;
    height: 2px;
  }
}
.qa-list dt::after {
  transform: rotate(90deg);
  transition: 0.5s;
}
.qa-list dt.opened::after {
  transform: rotate(0deg);
}
.qa-list dd {
  display: none;
  margin-top: -2px;
}
@media screen and (max-width:767px) {
  .qa-list dd {
    margin-top: -1px;
  }
}
.qa-list dd + dt {
  margin-top: 20px;
}
.qa-list-q {
  margin-right: 10px;
  color: #1AD1E8;
  font-size: 18px;
}
@media screen and (max-width:767px) {
  .qa-list-q {
    margin-right: 6px;
    font-size: 14px;
  }
}
.qa-list-a {
  margin-right: 10px;
  color: #E8A11A;
  font-size: 18px;
}
@media screen and (max-width:767px) {
  .qa-list-a {
    margin-right: 6px;
    font-size: 14px;
  }
}

/* ------------------------------------------------------------------------------
     link-top
-------------------------------------------------------------------------------*/
.link-top {
  position: fixed;
  display: block;
  right: 30px;
  bottom: 30px;
  background: #F8FE54;
  border: 2px solid #000000;
  border-radius: 50%;
  width: 50px;
  height: 50px;
  box-sizing: border-box;
}
@media only screen and (max-width:767px) {
  .link-top {
    right: 20px;
    bottom: 20px;
    width: 40px;
    height: 40px;
  }
}
.link-top span {
  position: relative;
  display: block;
}
.link-top span::before {
  content: "";
  display: block;
  position: absolute;
  top: 20px;
  left: 0; right: 0;
  margin: auto;
  width: 10px;
  height: 10px;
  border-top: 2px solid #000000;
  border-left: 2px solid #000000;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
@media only screen and (max-width:767px) {
  .link-top span::before {
    top: 16px;
    width: 8px;
    height: 8px;
  }
}

/* ------------------------------------------------------------------------------
     footer
-------------------------------------------------------------------------------*/
.footer {
  padding: 80px 20px 50px;
  background: #FAFAFA;
}
@media only screen and (max-width:767px) {
  .footer {
    padding: 50px 20px 40px;
  }
}
@media only screen and (min-width:768px) {
  .footer-content {
    display: flex;
    justify-content: space-between;
    max-width: 1300px;
    margin: 0 auto;
  }
}

.copyright-txt {
  margin-top: 65px;
  text-align: center;
}
@media only screen and (max-width:767px) {
  .copyright-txt {
    margin-top: 25px;
    font-size: 10px;
  }
}
@media only screen and (min-width:768px) {
  .footer-logo {
    width: 193px;
  }
}
@media only screen and (max-width:767px) {
  .footer-logo {
    text-align: center;
  }
}
.footer-sitemap {
  margin-top: 30px;
  font-size: 20px;
  text-align: center;
}
@media only screen and (max-width:767px) {
  .footer-sitemap {
    width: 100%;
    font-size: 14px;
    padding-bottom: 30px;
    border-bottom: 1px solid #ccc;
  }
}
@media only screen and (max-width:767px) {
  .footer-sitemap > li + li {
    margin-top: 10px;
  }
}

.footer-sitemap a {
  text-decoration: underline;
}
@media only screen and (min-width:1001px) {
  .footer-main {
    width: calc(100% - 276px);
  }
}
@media only screen and (min-width:768px) {
  .footer-main {
    width: calc(100% - 276px);
  }
}
.footer-dl {
  font-size: 0;
}
@media only screen and (max-width:767px) {
  .footer-dl {
    margin-top: 32px;
    text-align: center;
  }
}
.footer-dl > dt {
  display: inline-block;
  width: 120px;
  padding: 4px 0;
  border: 1px solid #000000;
  font-size: 16px;
  text-align: center;
  vertical-align: top;
}
@media only screen and (max-width:1000px) {
  .footer-dl > dt {
    width: 100px;
    padding: 2px 0;
    font-size: 14px;
  }
}
@media only screen and (max-width:767px) {
  .footer-dl > dt {
    display: inline-block;
    width: auto;
    padding: 2px 20px;
    border: 1px solid #000000;
    font-size: 14px;
    text-align: center;
  }
}
.footer-dl > dd {
  display: inline-block;
  width: calc(100% - 120px);
  padding-left: 20px;
  font-size: 20px;
  vertical-align: top;
}
@media only screen and (max-width:1000px) {
  .footer-dl > dd {
    display: inline-block;
    width: calc(100% - 120px);
    padding-left: 10px;
    font-size: 16px;
    vertical-align: top;
  }
}
@media only screen and (max-width:767px) {
  .footer-dl > dd {
    display: block;
    width: 100%;
    margin-top: 5px;
    padding-left: 0;
    font-size: 14px;
    vertical-align: top;
  }
}
@media only screen and (min-width:768px) {
  .footer-dl > dd + dt,
  .footer-dl > dd + dt + dd {
    margin-top: 18px;
  }
}
@media only screen and (max-width:767px) {
  .footer-dl > dd + dt {
    margin-top: 18px;
  }
}
.footer-dl .icon-blank {
  display: inline-block;
  position: static;
  width: 14px;
  height: 14px;
  margin: 0 0 0 8px;
  vertical-align: middle;
  background: url(/images/icon_blank.png) no-repeat 50%;
  background-size: contain;
}
@media screen and (max-width: 767px) {
  .footer-dl .icon-blank {
    width: 10px;
    height: 10px;
  }
}

/* ------------------------------------------------------------------------------
     20220616 追加
-------------------------------------------------------------------------------*/
.merit-lead {
  margin-bottom: 20px;
  padding: 40px 34px 70px;
  border: 2px solid #00B4CB;
}
@media screen and (max-width: 767px) {
  .merit-lead {
    padding: 20px;
  }
}
.merit-lead-txt {
  text-align: center;
}
.merit-lead-ttl {
  margin-top: 30px;
  color: #00B4CB;
  font-size: 28px;
  font-weight: bold;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .merit-lead-ttl {
    margin-top: 20px;
    font-size: 16px;
  }
}
@media screen and (min-width: 768px) {
  .merit-list {
    display: flex;
    margin-top: 24px;
  }
}
@media screen and (max-width: 767px) {
  .merit-list {
    margin-top: 16px;
  }
}
.merit-list > li {
  width: 32.5%;
  padding: 20px 10px;
  border: 6px solid #00B4CB;
  border-radius: 20px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .merit-list > li {
    width: 100%;
  }
}
.merit-list > li + li {
  margin-left: 1.75%;
}
@media screen and (max-width: 767px) {
  .merit-list > li + li {
    margin-top: 22px;
    margin-left: 0;
  }
}
@media screen and (min-width: 768px) {
  .merit-list-img {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 180px;
  }
}
@media screen and (max-width: 767px) {
  .merit-list-img {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 28.8vw;
  }
}
@media screen and (max-width: 767px) {
  .merit-list > li .merit-list-img img {
    width: auto;
    max-width: 120px;
    max-height: 100%;
  }
}
.merit-list-txt {
  margin-top: 24px;
  color: #01b4cb;
  font-weight: bold;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .merit-list-txt {
    margin-top: 10px;
  }
}
.merit-list-txt-01 {
  font-size: 20px;
  line-height: 1.45;
}
@media screen and (max-width: 1230px) {
  .merit-list-txt-01 {
    font-size: 18px;
  }
}
@media screen and (max-width: 767px) {
  .merit-list-txt-01 {
    font-size: 14px;
    text-align: center;
  }
}
.merit-list-txt-02 {
  font-size: 14px;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .merit-list-txt-02 {
    font-size: 12px;
    text-align: center;
  }
}
.merit-txt-01 {
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .merit-txt-01 {
    margin-top: 20px;
    font-size: 14px;
  }
}
.merit-balloon-wrap {
  margin-top: 60px;
}
@media screen and (max-width: 767px) {
  .merit-balloon-wrap {
    margin-top: 30px;
  }
}
.merit-balloon-inner {
  display: flex;
  align-items: center;
}
.merit-balloon-img {
  width: 130px;
}
@media screen and (max-width: 767px) {
  .merit-balloon-img {
    width: 60px;
    padding-right: 20px;
  }
}
@media screen and (max-width: 767px) {
  .merit-balloon-inner:nth-child(2) .merit-balloon-img {
    width: 60px;
    padding-left: 20px;
    padding-right: 0;
  }
}
.merit-balloon {
  position: relative;
  width: calc(100% - 130px);
  padding: 20px 22px;
  background: #E9FAFD;
  border-radius: 10px;
}
@media screen and (max-width: 767px) {
  .merit-balloon {
    width: calc(100% - 40px);
    padding: 10px;
    font-size: 12px;
  }
}
.merit-balloon::before {
  content: "";
  position: absolute;
  top: 0; bottom: 0;
  left: -30px;
  display: block;
  width: 0;
  height: 0;
  margin: auto 0;
  border-style: solid;
  border-width: 10px 30px 10px 0;
  border-color: transparent #E9FAFD transparent transparent;
}
@media screen and (max-width: 767px) {
  .merit-balloon::before {
    left: -15px;
    border-width: 5px 15px 5px 0;
  }
}
.merit-balloon-inner:nth-child(2) .merit-balloon::before {
  content: "";
  position: absolute;
  top: 0; bottom: 0;
  left: auto; right: -30px;
  display: block;
  width: 0;
  height: 0;
  margin: auto 0;
  border-style: solid;
  border-width: 10px 0 10px 30px;
  border-color: transparent transparent transparent #E9FAFD;
}
@media screen and (max-width: 767px) {
  .merit-balloon-inner:nth-child(2) .merit-balloon::before {
    left: auto; right: -15px;
    border-width: 5px 0 5px 15px;
  }
}
.merit-balloon-inner + .merit-balloon-inner {
  margin-top: 48px;
}
@media screen and (max-width: 767px) {
  .merit-balloon-inner + .merit-balloon-inner {
    margin-top: 24px;
  }
}
.merit-balloon-inner:nth-child(2) .merit-balloon-img {
  text-align: right;
}

p + .merit-lead {
  margin-top: 30px;
}
.merit-dl {
  margin: 30px 0 0;
}
.merit-dl dt {
  font-weight: normal;
}
.merit-dl ul > li {
  margin-top: 20px;
}
.merit-dl ul > li a {
  text-decoration: underline;
}
.table-01 {
  word-wrap: break-word;
}
.button-03 {
  position: relative;
  display: block;
  width: 400px;
  margin: 0 auto;
  padding: 10px 20px;
  background: #00B4CB;
  border: 2px solid #00B4CB;
  border-radius: 100px;
  color: #fff;
  font-size: 18px;
  text-align: center;
}
@media screen and (max-width:767px) {
  .button-03 {
    width: 250px;
    font-size: 16px;
  }
}
.button-03:visited {
  color: #fff;
}
.button-03:hover {
  opacity: 1;
  background: #fff;
  color: #00B4CB;
  transition: .5s;
}
.button-03::after {
  content: "";
  position: absolute;
  top: 0; bottom: 0;
  right: 20px;
  display: block;
  border-top: solid 2px #fff;
  border-right: solid 2px #fff;
  width: 8px;
  height: 8px;
  margin: auto;
  transform: rotate(45deg);
}
.button-03:hover::after {
  border-top: solid 2px #00B4CB;
  border-right: solid 2px #00B4CB;
  transition: .5s;
}
.idea-ttl-01{
  margin-top: 50px;
  text-align: center;
  font-size: 22px;
}
.idea-ttl-02 {
  margin-top: 22px;
}
.details-merit-lead {
  padding: 20px;
  background: #00B4CB;
  color: #fff;
}
.details-merit-lead p + p {
  margin-top: 40px;
}
.button-04 {
  position: relative;
  display: block;
  width: 400px;
  margin: 0 auto;
  padding: 10px 20px;
  background: #fff;
  border: 2px solid #00B4CB;
  border-radius: 100px;
  color: #00B4CB;
  font-size: 18px;
  text-align: center;
}
@media screen and (max-width:767px) {
  .button-04 {
    width: 280px;
    font-size: 14px;
  }
}
.button-04:visited {
  color: #00B4CB;
}
.button-04::after {
  content: "";
  position: absolute;
  top: 0; bottom: 0;
  right: 20px;
  display: block;
  border-top: solid 2px #00B4CB;
  border-right: solid 2px #00B4CB;
  width: 8px;
  height: 8px;
  margin: auto;
  transform: rotate(45deg);
}
.idea-wrap + .idea-wrap {
  margin-top: 60px;
}
@media screen and (max-width:767px) {
  .idea-wrap + .idea-wrap {
    margin-top: 30px;
  }
}
.acd-wrap {
  display: none;
}
@media screen and (max-width:365px) {
  .idea-button > .button-02 {
    font-size: 12px!important;
  }
}
.idea-button .button-02::after {
  transform: rotate(135deg);
}
.idea-button .button-02.opened::after {
  transform: rotate(-45deg);
}

.download-note ul {
  list-style-type: disc;
  margin-bottom: 1em;
  margin-left: 2rem;
}
