@charset "UTF-8";
/* --------------------------------------------------
	bese	
-------------------------------------------------- */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
nav,
section,
summary {
  display: block;
}

[hidden] {
  display: none;
}

html {
  width: 100%;
  font-size: 100%;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  display: block;
  position: relative;
}

html,
button,
input,
select,
textarea {
  font-family: "Hiragino Kaku Gothic ProN", "Hiragino Sans", "ヒラギノ角ゴシック", -apple-system, BlinkMacSystemFont, "Segoe UI", "Noto Sans JP", "Yu Gothic", "YuGothic", "Meiryo", "メイリオ", "Helvetica Neue", Arial, sans-serif;
  _font-family: arial, sans-serif;
}

body {
  background-color: #F5F5F5;
  margin: 0;
  margin-left: auto;
  margin-right: auto;
  max-width: 1080px;
  width: 100%;
  display: block;
  position: relative;
  font-size: 16px;
  line-height: 1.8;
  color: #000000;
  letter-spacing: 0px;
  word-break: break-all;
  text-align: justify;
  box-shadow: 0px 0px 10px -8px #777777;
}

a {
  color: #F5721A;
  text-decoration: none;
  cursor: pointer;
}
a img {
  pointer-events: auto;
}

a:focus,
a:visited {
  outline: 0;
}

a:hover,
a:active {
  outline: 0;
  opacity: 0.7;
  transition: all 0.2s;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: normal;
  margin: 0;
}

p,
pre {
  display: block;
  position: relative;
  margin: 0;
}

abbr[title] {
  border-bottom: 1px dotted;
}

b,
strong {
  font-weight: normal;
}

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

dl,
dt,
dd,
ol,
ul,
li,
menu,
nav {
  margin: 0;
  padding: 0;
  list-style: none;
  list-style-image: none;
}

img {
  border: 0;
  vertical-align: text-bottom;
  display: block;
  -ms-interpolation-mode: bicubic;
  pointer-events: none;
}

svg:not(:root) {
  overflow: hidden;
}

form {
  margin: 0;
}

table.t-type01 {
  border-collapse: separate;
  border-spacing: 0px;
  width: 100%;
  border-top: 1px solid #0C3463;
  color: #0C3463;
}
table.t-type01 thead,
table.t-type01 tbody {
  width: 100%;
}
table.t-type01 thead tr,
table.t-type01 tbody tr {
  width: 100%;
}
table.t-type01 thead tr th,
table.t-type01 tbody tr th {
  padding: 10px;
  text-align: left;
  vertical-align: top;
  border-bottom: 1px solid #0C3463;
}
table.t-type01 thead tr td,
table.t-type01 tbody tr td {
  vertical-align: top;
  padding: 10px;
  border-bottom: 1px solid #0C3463;
}
table.t-type01 thead tr td p:last-of-type,
table.t-type01 tbody tr td p:last-of-type {
  margin-bottom: 0px;
}

table.calendar01 {
  border-collapse: separate;
  border-spacing: 0px;
  width: 100%;
  border: 1px solid #0C3463;
  color: #0C3463;
  font-size: 13px;
}
table.calendar01 thead,
table.calendar01 tbody {
  width: 100%;
}
table.calendar01 thead tr,
table.calendar01 tbody tr {
  width: 100%;
}
table.calendar01 thead tr > *,
table.calendar01 tbody tr > * {
  border-right: 1px solid #0C3463;
  border-bottom: 1px solid #0C3463;
}
table.calendar01 thead tr > *:last-child,
table.calendar01 tbody tr > *:last-child {
  border-right: 0px solid #0C3463;
  border-bottom: 1px solid #0C3463;
}
table.calendar01 thead tr:last-child td,
table.calendar01 tbody tr:last-child td {
  border-bottom: 0px;
}
table.calendar01 thead tr th:first-child,
table.calendar01 thead tr td:first-child,
table.calendar01 tbody tr th:first-child,
table.calendar01 tbody tr td:first-child {
  text-align: left;
}
table.calendar01 thead tr th,
table.calendar01 tbody tr th {
  padding: 5px;
  text-align: left;
  vertical-align: top;
  background-color: #0C3463;
  color: #FFFFFF;
  text-align: center;
  font-weight: 700;
}
table.calendar01 thead tr td,
table.calendar01 tbody tr td {
  vertical-align: top;
  padding: 5px;
  border-bottom: 1px solid #0C3463;
  background-color: #FFFFFF;
  text-align: center;
  font-weight: 700;
}
table.calendar01 thead tr td p:last-of-type,
table.calendar01 tbody tr td p:last-of-type {
  margin-bottom: 0px;
}

.is-style-outline a,
.wp-block-button a,
a.btn01 {
  display: inline-block;
  position: relative;
  background: linear-gradient(180deg, #1377BC 0%, #0C3463 100%);
  box-shadow: 0px 2px 0px rgba(12, 52, 99, 0.2);
  border-radius: 100px;
  font-size: 24px;
  line-height: 24px;
  padding: 25px;
  padding-left: 50px;
  padding-right: 50px;
  box-sizing: border-box;
  text-align: center;
  font-weight: 700;
  color: #FFFFFF;
}
.is-style-outline a:hover,
.wp-block-button a:hover,
a.btn01:hover {
  opacity: 1;
}
.is-style-outline a span.pop01,
.wp-block-button a span.pop01,
a.btn01 span.pop01 {
  width: 130px;
  display: block;
  position: absolute;
  color: #FFFFFF;
  text-align: center;
  font-size: 12px;
  line-height: 12px;
  background-color: #F5721A;
  box-sizing: border-box;
  padding: 10px;
  border-radius: 5px;
  left: 50%;
  margin-left: -65px;
  top: -35px;
  box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.25);
}
.is-style-outline a span.pop01:before,
.wp-block-button a span.pop01:before,
a.btn01 span.pop01:before {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -10px;
  border: 10px solid transparent;
  border-top: 10px solid #F5721A;
}
.is-style-outline a.min01,
.wp-block-button a.min01,
a.btn01.min01 {
  font-size: 16px;
  padding: 15px;
  padding-left: 20px;
  padding-right: 20px;
  width: 240px;
}
.is-style-outline a.min02,
.wp-block-button a.min02,
a.btn01.min02 {
  font-size: 12px;
  line-height: 12px;
  padding: 15px;
  padding-left: 30px;
  padding-right: 30px;
}

nav.btn-area01 {
  display: flex;
  position: relative;
  justify-content: center;
  align-items: center;
}

.gord {
  color: #FFCC00;
  font-style: normal;
}

.min03 {
  font-size: 12px;
}

.otherpostlist {
  padding: 30px;
}
.otherpostlist strong.title01 {
  color: #0C3463;
  font-size: 28px;
  font-weight: 700;
  display: block;
  position: relative;
  margin-bottom: 20px;
}

/* --------------------------------------------------
	sab	
-------------------------------------------------- */
.unselectable {
  -webkit-touch-callout: none;
  -webkit-user-drag: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  -o-user-select: none;
  user-select: none;
  touch-callout: none;
}

.hidden {
  display: none !important;
  visibility: hidden;
}

.invisible {
  visibility: hidden;
}

.no-scroll {
  overflow: hidden;
}

.underline {
  text-decoration: underline;
}

.block {
  position: relative;
  display: block !important;
}

.fc05 {
  color: #0C3463;
}

.f-weight {
  font-weight: 700;
}

.center {
  text-align: center !important;
  justify-content: center !important;
}

.pm00 {
  padding-bottom: 0px !important;
}

.bm00 {
  margin-bottom: 0px !important;
}

.bm01 {
  margin-bottom: 10px !important;
}

.bm02 {
  margin-bottom: 20px !important;
}

.bm03 {
  margin-bottom: 30px !important;
}

.bm04 {
  margin-bottom: 40px !important;
}

.bm05 {
  margin-bottom: 50px !important;
}

.bm06 {
  margin-bottom: 60px !important;
}

.bm08 {
  margin-bottom: 80px !important;
}

section.page {
  padding-top: 120px;
}

.p50 {
  padding: 50px;
}

.pt10 {
  padding-top: 10px;
}

.pt20 {
  padding-top: 20px;
}

.pt30 {
  padding-top: 30px;
}

.pt50 {
  padding-top: 60px;
}

.pt60 {
  padding-top: 60px;
}

.plr50 {
  padding-left: 50px;
  padding-right: 50px;
}

.plr100 {
  padding-left: 100px;
  padding-right: 100px;
}

h1.pagetitle {
  width: 100%;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #0C3463;
  background: linear-gradient(90deg, rgb(12, 52, 99) 0%, rgb(24, 106, 201) 100%);
  font-size: 28px;
  line-height: 40px;
  padding: 20px;
  height: 200px;
  box-sizing: border-box;
  color: #FFFFFF;
  font-weight: 700;
}
h2.sectiontitle {
  font-size: 28px;
  line-height: 1.4;
  display: block;
  position: relative;
  font-weight: 700;
  color: #0C3463;
  margin-bottom: 30px;
}
h2.sectiontitle.center {
  text-align: center;
}

dl.qa {
  display: block;
  position: relative;
  margin-bottom: 20px;
  line-height: 1.5;
}
dl.qa:last-child {
  margin-bottom: 0px;
}
dl.qa dt {
  display: block;
  position: relative;
  font-weight: 700;
  margin-bottom: 15px;
}
dl.qa dt::before {
  content: "Q";
  background-color: #1377BC;
  color: #FFFFFF;
}
dl.qa dd {
  display: block;
  position: relative;
}
dl.qa dd::before {
  content: "A";
  background-color: #0EADB3;
  color: #FFFFFF;
}
dl.qa dt,
dl.qa dd {
  padding-left: 40px;
}
dl.qa dt::before,
dl.qa dd::before {
  position: absolute;
  left: 0px;
  top: -1px;
  width: 30px;
  height: 30px;
  line-height: 30px;
  text-align: center;
  border-radius: 50%;
  font-weight: 700;
  font-size: 14px;
}

dl.p02-02-box01,
dl.p02-02-box02,
dl.p02-02-box03 {
  padding: 30px;
  border-radius: 5px;
  background-color: #FFFFFF;
  border: 1px solid #0EADB3;
  display: block;
  position: relative;
  margin-bottom: 20px;
}
dl.p02-02-box01 dt,
dl.p02-02-box02 dt,
dl.p02-02-box03 dt {
  font-size: 18px;
  font-weight: 700;
  display: block;
  margin-bottom: 10px;
  color: #0EADB3;
}
dl.p02-02-box01 dd ul.threeli,
dl.p02-02-box02 dd ul.threeli,
dl.p02-02-box03 dd ul.threeli {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: 1fr;
  grid-column-gap: 10px;
  grid-row-gap: 10px;
}
dl.p02-02-box01 dd ul li,
dl.p02-02-box02 dd ul li,
dl.p02-02-box03 dd ul li {
  position: relative;
  display: block;
  padding-left: 20px;
}
dl.p02-02-box01 dd ul li::before,
dl.p02-02-box02 dd ul li::before,
dl.p02-02-box03 dd ul li::before {
  position: absolute;
  left: 0px;
  content: "・";
  color: #0EADB3;
}

dl.p02-02-box02 {
  border: 1px solid #B30E11;
}
dl.p02-02-box02 dt {
  color: #B30E11;
}
dl.p02-02-box02 dd ul li::before {
  color: #B30E11;
}

dl.p02-02-box03 {
  border: 1px solid #FFFFFF;
}
dl.p02-02-box03 dd ul li::before {
  color: #333333;
}

dl.postlistdl dt {
  position: relative;
  display: block;
  background-color: #FFFFFF;
  margin-bottom: 17.5px;
  border-radius: 5px;
  overflow: hidden;
}
dl.postlistdl dt a {
  aspect-ratio: 16/9;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
dl.postlistdl dt a img {
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: 100%;
}
dl.postlistdl dd strong {
  display: block;
  font-weight: 700;
  font-size: 16px;
  line-height: 1.4;
  font-weight: 700;
  margin-bottom: 10px;
}
dl.postlistdl dd strong a {
  color: #0C3463;
}

div.postlistbox {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: 1fr;
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  margin-bottom: 30px;
}
div.postlistbox.three {
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: 1fr;
}

div.infobox {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  position: relative;
}
div.infobox time {
  padding-top: 5px;
  font-size: 12px;
  line-height: 12px;
  margin-left: 5px;
  padding-bottom: 5px;
}

ul.taglist {
  display: flex;
  position: relative;
  flex-wrap: wrap;
}
ul.taglist li {
  margin-top: 2.5px;
  margin-bottom: 2.5px;
  margin-right: 5px;
}
ul.taglist li a {
  display: block;
  font-size: 12px;
  line-height: 12px;
  white-space: nowrap;
  box-sizing: border-box;
  padding: 5px;
  padding-left: 10px;
  padding-right: 10px;
  border-radius: 5px;
  background-color: #FFFFFF;
  border: 1px solid #1377BC;
  color: #1377BC;
}

ul.catlist {
  border-top: 1px solid #CCCCCC;
}
ul.catlist li {
  display: block;
  position: relative;
  border-bottom: 1px solid #CCCCCC;
}
ul.catlist li a {
  display: block;
  position: relative;
  padding-top: 10px;
  padding-bottom: 10px;
  color: #1377BC;
}
ul.catlist li a i {
  margin-right: 10px;
}

nav.inpagenav {
  background-color: #FFFFFF;
}
nav.inpagenav ul {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  white-space: nowrap;
  overflow: auto;
}
nav.inpagenav ul li {
  font-weight: 700;
  font-size: 14px;
  display: block;
}
nav.inpagenav ul li a {
  position: relative;
  display: block;
  padding: 20px;
  color: #0C3463;
}

div.breadcrumbs {
  position: relative;
  display: block;
  font-size: 11px;
  padding: 10px;
  padding-left: 20px;
  padding-right: 20px;
  margin-left: auto;
  margin-right: auto;
  white-space: nowrap;
  overflow-x: auto;
  text-overflow: ellipsis;
  -webkit-overflow-scrolling: touch;
  color: #1377BC;
}
div.breadcrumbs span {
  color: #0C3463;
  margin-left: 0px;
  margin-right: 5px;
}
div.breadcrumbs span:last-of-type {
  margin-right: 0px;
}
div.breadcrumbs a {
  color: #333333;
}
div.breadcrumbs a:hover {
  color: #FFFFFF;
}

nav.pagenav {
  display: block;
  position: relative;
  padding-top: 10px;
}
nav.pagenav ul {
  display: flex;
  justify-content: center;
  align-items: center;
}
nav.pagenav ul li {
  font-size: 14px;
  line-height: 40px;
  text-align: center;
  margin-left: 5px;
  margin-right: 5px;
}
nav.pagenav ul li a.previouspostslink,
nav.pagenav ul li a.nextpostslink,
nav.pagenav ul li a.first,
nav.pagenav ul li a.last {
  font-size: 20px;
  color: #1377BC;
  padding-left: 5px;
  padding-right: 5px;
}
nav.pagenav ul li a.page {
  display: block;
  position: relative;
  color: #1377BC;
  box-sizing: border-box;
  min-width: 40px;
  background-color: #FFFFFF;
  border: 1px solid #1377BC;
  border-radius: 40px;
}
nav.pagenav ul li a.page:hover {
  color: #FFFFFF;
  background-color: #1377BC;
}
nav.pagenav ul li span.current {
  display: block;
  position: relative;
  background-color: #1377BC;
  color: #FFFFFF;
  box-sizing: border-box;
  min-width: 40px;
  border-radius: 40px;
}

header {
  position: absolute;
  display: block;
  padding: 30px;
  width: 100%;
  box-sizing: border-box;
}
header div.menubtn {
  display: none;
}
header div.head {
  display: flex;
  position: relative;
}
header div.head strong {
  position: relative;
  display: block;
  width: 300px;
  min-width: 300px;
}
header div.head strong img {
  width: 100%;
  height: auto;
}
header div.head span.infonav {
  text-align: right;
  display: flex;
  justify-content: flex-end;
  font-size: 40px;
  margin-top: 0px;
  padding-right: 0px;
  font-weight: 700;
  position: absolute;
  right: 0px;
  top: 1px;
  bottom: 0px;
}
header div.head span.infonav a {
  color: #1377BC;
  margin-left: 0px;
  display: flex;
  align-items: center;
}
header div.head span.infonav a b {
  display: none;
  font-weight: 700;
}
header div.head span.infonav a i {
  margin-right: 0px;
}
header div.head span.infonav a i::before {
  width: 38px;
  height: 38px;
  border-radius: 38px;
  box-shadow: 0px 2px 0px rgba(12, 52, 99, 0.2);
}
header div.head nav.gnav {
  display: flex;
  width: 100%;
}
header div.head nav.gnav strong.logo {
  display: none;
}
header div.head nav.gnav ul.tnav {
  width: 100%;
  height: 44px;
  display: flex;
  font-size: 14px;
  align-items: center;
  justify-content: flex-end;
}
header div.head nav.gnav ul.tnav li {
  position: relative;
  margin-left: 10px;
}
header div.head nav.gnav ul.tnav li a {
  color: #0C3463;
}
header div.head nav.gnav div.bnav {
  margin-left: 15px;
  padding-right: 50px;
}
header div.head nav.gnav div.bnav ul {
  display: flex;
}
header div.head nav.gnav div.bnav ul li a.btn01 {
  margin-left: 10px;
  white-space: nowrap;
}

footer {
  display: block;
  position: relative;
}
footer div.twobox {
  display: flex;
  position: relative;
}
footer div.twobox div.foot01 {
  display: block;
  position: relative;
  padding: 30px;
  padding-top: 50px;
  box-sizing: border-box;
  min-width: 400px;
}
footer div.twobox div.foot01 strong {
  display: block;
  width: 300px;
  margin-bottom: 30px;
}
footer div.twobox div.foot01 strong a img {
  width: 100%;
  height: auto;
}
footer div.twobox div.foot01 p {
  font-size: 10px;
}
footer div.twobox div.foot01 p b {
  display: block;
  font-size: 14px;
  font-weight: 700;
  color: #1377BC;
  margin-bottom: 5px;
}
footer div.twobox div.foot02 {
  position: relative;
  display: flex;
  padding: 50px;
  padding-right: 80px;
  background: #FFFFFF;
  box-sizing: border-box;
  width: 100%;
  border-radius: 20px 0px 0px 20px;
}
footer div.twobox div.foot02 dl {
  display: block;
  position: relative;
  width: 220px;
}
footer div.twobox div.foot02 dl:last-of-type {
  padding-left: 30px;
  width: 100%;
}
footer div.twobox div.foot02 dl dt {
  font-size: 16px;
  font-weight: 700;
  color: #0C3463;
  padding-bottom: 10px;
  margin-bottom: 20px;
  border-bottom: 2px solid #0C3463;
}
footer div.twobox div.foot02 dl dt a {
  color: #0C3463;
}
footer div.twobox div.foot02 dl dd {
  font-size: 12px;
}
footer div.twobox div.foot02 dl dd ul.foot-link01,
footer div.twobox div.foot02 dl dd ul.foot-link02 {
  padding-right: 0px;
}
footer div.twobox div.foot02 dl dd ul.foot-link01 li,
footer div.twobox div.foot02 dl dd ul.foot-link02 li {
  display: block;
  padding-top: 5px;
  padding-bottom: 5px;
  line-height: 18px;
}
footer div.twobox div.foot02 dl dd ul.foot-link01 li a,
footer div.twobox div.foot02 dl dd ul.foot-link02 li a {
  color: #1377BC;
}
footer div.twobox div.foot02 dl dd ul.foot-link02 {
  padding-right: 0px;
  display: flex;
  flex-wrap: wrap;
}
footer div.twobox div.foot02 dl dd ul.foot-link02 li {
  width: 50%;
}
footer div.twobox div.pagetop {
  position: absolute;
  right: 30px;
  top: -30px;
}
footer div.twobox div.pagetop a {
  top: 0%;
  background: #0C3463;
  box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25);
  border-radius: 30px;
  color: #FFFFFF;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 54px;
  height: 60px;
}
footer div.twobox div.pagetop a i {
  font-size: 30px;
}
footer small {
  display: block;
  position: relative;
  text-align: center;
  font-size: 12px;
  padding-top: 30px;
  padding-bottom: 120px;
  color: #0C3463;
}

div.foot-tracking {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 98%;
  padding: 10px;
  position: fixed;
  z-index: 100;
  bottom: 0px;
  background: #FFFFFF;
  box-shadow: 0px -3px 5px rgba(0, 0, 0, 0.1);
  border-radius: 10px 10px 0px 0px;
  left: 1%;
  box-sizing: border-box;
}
div.foot-tracking a.btn01 {
  display: block;
  margin-left: 5px;
  margin-right: 5px;
}

.top01 {
  height: 350px;
  background-color: #CCCCCC;
  width: 100%;
  display: flex;
  align-items: flex-end;
  background-image: url("../img/cmn/t01.jpg");
  background-size: contain;
  background-repeat: no-repeat;
}
.top01 h1 {
  padding: 50px;
  font-size: 28px;
  line-height: 38px;
  font-weight: 700;
  color: #0C3463;
}

.top02 {
  position: relative;
}
.top02 .top02-01 {
  width: 500px;
  position: absolute;
  display: block;
  right: 50px;
  top: 50px;
}
.top02 .top02-01 img {
  width: 100%;
  height: auto;
  margin-bottom: 20px;
}
.top02 .top02-01 p {
  font-size: 10px;
  line-height: 14px;
  text-align: center;
  display: none;
}
.top02 .top02-02 {
  display: block;
  padding: 50px;
  padding-bottom: 0px;
}
.top02 .top02-02 strong {
  padding: 10px;
  padding-left: 15px;
  padding-right: 15px;
  font-weight: 700;
  display: inline-block;
  color: #FFFFFF;
  background-color: #0EADB3;
  font-size: 20px;
  line-height: 20px;
  margin-bottom: 20px;
}
.top02 .top02-02 h2 {
  font-size: 40px;
  line-height: 50px;
  font-weight: 700;
  color: #0C3463;
  display: block;
  margin-bottom: 30px;
}
.top02 .top02-02 p {
  font-weight: 700;
}
.top02 .top02-03 {
  display: block;
  position: relative;
  padding: 50px;
}
.top02 .top02-03 ul {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: 1fr;
  grid-column-gap: 20px;
  grid-row-gap: 20px;
}
.top02 .top02-03 ul li {
  padding: 30px;
  padding-top: 40px;
  border-radius: 5px;
  background-color: #FFFFFF;
  display: block;
  position: relative;
}
.top02 .top02-03 ul li img {
  width: 30px;
  height: auto;
  margin-bottom: 30px;
}
.top02 .top02-03 ul li strong {
  display: block;
  position: relative;
  font-weight: 700;
  color: #0C3463;
  font-size: 18px;
  line-height: 20px;
  margin-bottom: 10px;
}
.top02 .top02-03 ul li p {
  font-size: 12px;
  line-height: 22px;
}
.top02 div.top02-04 {
  padding: 50px;
  padding-bottom: 60px;
  display: block;
  position: relative;
  border-radius: 20px;
  background-color: #FFFFFF;
}
.top02 div.top02-04 h2 {
  display: block;
  font-size: 40px;
  font-weight: 700;
  color: #0C3463;
}
.top02 div.top02-04 p {
  margin-bottom: 30px;
}
.top02 div.top02-04 div.dllist01 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: 1fr;
  grid-column-gap: 10px;
  grid-row-gap: 10px;
}
.top02 div.top02-04 div.dllist01 dl {
  padding-top: 30px;
  border-radius: 5px;
  border: 1px solid #0EADB3;
  box-shadow: 0px 3px 3px rgba(0, 0, 0, 0.05);
}
.top02 div.top02-04 div.dllist01 dl dt {
  display: block;
  font-weight: 700;
  padding-left: 30px;
  font-size: 20px;
  line-height: 28px;
  color: #0C3463;
  padding-top: 3px;
  padding-bottom: 3px;
  position: relative;
}
.top02 div.top02-04 div.dllist01 dl dt::before {
  content: "";
  display: block;
  position: absolute;
  height: 100%;
  top: 0px;
  left: 0px;
  width: 5px;
  border-top-right-radius: 3px;
  border-bottom-right-radius: 3px;
  background-color: #0EADB3;
}
.top02 div.top02-04 div.dllist01 dl dd {
  padding: 30px;
  padding-top: 10px;
}
.top02 div.top02-04 div.dllist01 dl dd ul li a {
  color: #1377BC;
  font-size: 16px;
}
.top02 div.top02-04 div.dllist01 dl dd ul li a i {
  margin-right: 10px;
}
.top02 .top02-05 {
  position: relative;
  padding: 50px;
}
.top02 .top02-05 h2 {
  font-size: 40px;
  line-height: 40px;
  display: block;
  position: relative;
  text-align: center;
  font-weight: 700;
  margin-bottom: 40px;
  color: #0C3463;
}
.top02 .top02-05 div.twobox {
  display: flex;
  justify-content: center;
  margin-bottom: 50px;
}
.top02 .top02-05 div.twobox dl {
  padding: 30px;
  padding-top: 50px;
  background-color: #FFFFFF;
  margin-left: 10px;
  margin-right: 10px;
  border-radius: 5px;
  display: block;
  position: relative;
  width: 100%;
  box-sizing: border-box;
}
.top02 .top02-05 div.twobox dl::before {
  width: 80%;
  left: 10%;
  content: "";
  height: 5px;
  border-radius: 0px 0px 3px 3px;
  background-color: #0EADB3;
  top: 0px;
  position: absolute;
}
.top02 .top02-05 div.twobox dl dt {
  display: block;
  font-size: 28px;
  text-align: center;
  font-weight: 700;
  color: #0C3463;
  padding-top: 0px;
  padding-bottom: 50px;
}
.top02 .top02-05 div.twobox dl dd {
  position: relative;
  display: block;
  padding: 30px;
  padding-top: 50px;
  border-radius: 5px;
  background-color: #F2FAFA;
}
.top02 .top02-05 div.twobox dl dd span.pop02 {
  width: 180px;
  display: block;
  position: absolute;
  color: #FFFFFF;
  text-align: center;
  font-size: 12px;
  line-height: 12px;
  background-color: #F5721A;
  box-sizing: border-box;
  padding: 10px;
  border-radius: 5px;
  left: 50%;
  margin-left: -90px;
  top: -15px;
  box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.25);
}
.top02 .top02-05 div.twobox dl dd span.pop02:before {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -10px;
  border: 10px solid transparent;
  border-top: 10px solid #F5721A;
}
.top02 .top02-05 div.twobox dl dd ul {
  display: block;
  position: relative;
  margin-bottom: 20px;
}
.top02 .top02-05 div.twobox dl dd ul li {
  display: block;
  position: relative;
  color: #0C3463;
  font-weight: 700;
  margin-bottom: 10px;
  line-height: 1.6;
  padding-left: 40px;
}
.top02 .top02-05 div.twobox dl dd ul li::before {
  content: "";
  display: block;
  position: absolute;
  width: 25px;
  height: 24px;
  left: 0px;
  top: 0px;
  background-image: url("../img/cmn/04.png");
  background-size: contain;
  background-repeat: no-repeat;
}
.top02 .top02-05 div.twobox dl dd p {
  display: block;
  font-size: 12px;
  line-height: 20px;
}

.p01 div.p01-01 p {
  display: block;
  text-align: center;
  font-weight: 700;
}
.p01 div.p01-02 div.twobox {
  display: flex;
  margin-bottom: 50px;
  position: relative;
}
.p01 div.p01-02 div.twobox img {
  border-radius: 5px;
  width: 440px;
  margin-top: 10px;
  margin-right: 50px;
}
.p01 div.p01-02 div.twobox div.p01-02-box h3 {
  font-size: 18px;
  font-weight: 700;
  color: #0C3463;
  display: block;
  padding-bottom: 15px;
  margin-bottom: 20px;
  border-bottom: 2px solid #0C3463;
}
.p01 div.p01-02 div.twobox div.p01-02-box ul {
  position: relative;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: 1fr;
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  margin-bottom: 20px;
}
.p01 div.p01-02 div.twobox div.p01-02-box ul li {
  border-radius: 20px;
  display: block;
  position: relative;
  background-color: #FFFFFF;
  border: 1px solid #0EADB3;
  font-size: 14px;
  line-height: 14px;
  font-weight: 700;
  padding: 10px;
  color: #0C3463;
  padding-left: 40px;
}
.p01 div.p01-02 div.twobox div.p01-02-box ul li::before {
  position: absolute;
  width: 22px;
  height: 20px;
  top: 8px;
  left: 10px;
  content: "";
  background-image: url("../img/cmn/i03.png");
  background-size: contain;
  background-repeat: no-repeat;
}
.p01 div.p01-02 div.twobox div.p01-02-box p {
  margin-bottom: 20px;
}
.p01 div.p01-03 dl {
  margin-bottom: 30px;
  display: block;
  position: relative;
}
.p01 div.p01-03 dl dt {
  margin-bottom: 30px;
}
.p01 div.p01-03 dl dt img {
  width: 100%;
  height: auto;
  border-radius: 5px;
}
.p01 div.p01-03 dl dd strong {
  display: block;
  font-weight: 700;
  margin-bottom: 5px;
}
.p01 div.p01-04 {
  display: flex;
  background-color: #FFFFFF;
  flex-direction: row-reverse;
}
.p01 div.p01-04 img {
  min-width: 480px;
  min-height: 320px;
}
.p01 div.p01-04 div.p01-04-box {
  padding: 50px;
  width: 100%;
}
.p02 div.p02-01 div.p02-01-box {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: 1fr;
  grid-column-gap: 20px;
  grid-row-gap: 20px;
}
.p02 div.p02-01 div.p02-01-box dl {
  display: block;
  position: relative;
  background-color: #FFFFFF;
  border-radius: 5px;
  padding: 20px;
}
.p02 div.p02-01 div.p02-01-box dl dt {
  margin-bottom: 20px;
}
.p02 div.p02-01 div.p02-01-box dl dt strong {
  display: block;
  color: #0C3463;
  font-weight: 700;
  font-size: 18px;
  line-height: 1.4;
}
.p02 div.p02-01 div.p02-01-box dl dt p {
  margin-top: 10px;
  font-size: 14px;
  line-height: 1.4;
  color: #333333;
}
.p02 div.p02-01 div.p02-01-box dl dd {
  color: #0EADB3;
  font-weight: 700;
  display: flex;
  flex-wrap: wrap;
}
.p02 div.p02-01 div.p02-01-box dl dd span {
  position: relative;
  display: flex;
  align-items: center;
  margin-right: 10px;
  margin-top: 5px;
  white-space: nowrap;
}
.p02 div.p02-01 div.p02-01-box dl dd span i {
  background-color: #F2FAFA;
  font-size: 10px;
  line-height: 10px;
  padding: 5px;
  display: inline-block;
  border-radius: 5px;
  font-weight: normal;
  font-style: normal;
  margin-right: 10px;
}
.p03 h2 {
  padding-top: 30px;
}
.p03 a.p03-01-link {
  display: block;
  position: relative;
  margin-bottom: 10px;
  background-color: #FFFFFF;
  border-radius: 5px;
  border: 1px solid #FFFFFF;
  box-sizing: border-box;
}
.p03 a.p03-01-link:hover {
  opacity: 1;
  border: 1px solid #0EADB3;
}
.p03 a.p03-01-link dl {
  padding: 30px;
  display: flex;
  padding-right: 90px;
  align-items: center;
  position: relative;
}
.p03 a.p03-01-link dl::before {
  content: "";
  display: block;
  position: absolute;
  height: 80%;
  top: 10%;
  left: 0px;
  width: 5px;
  border-top-right-radius: 3px;
  border-bottom-right-radius: 3px;
  background-color: #0EADB3;
}
.p03 a.p03-01-link dl::after {
  /* use !important to prevent issues with browser extensions that change fonts */
  font-family: "icomoon" !important;
  speak: never;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  content: "\e912";
  width: 40px;
  height: 40px;
  position: absolute;
  color: #FFFFFF;
  background-color: #1377BC;
  border-radius: 80px;
  right: 30px;
  top: 50%;
  margin-top: -20px;
  text-align: center;
  line-height: 40px;
  font-size: 20px;
}
.p03 a.p03-01-link dl dt {
  position: relative;
  color: #0C3463;
  font-weight: 700;
  min-width: 300px;
  font-size: 18px;
}
.p03 a.p03-01-link dl dd ul li {
  display: flex;
  align-items: center;
  margin-bottom: 10px;
}
.p03 a.p03-01-link dl dd ul li:last-child {
  margin-bottom: 0px;
}
.p03 a.p03-01-link dl dd ul li strong {
  display: block;
  position: relative;
  background-color: #0EADB3;
  padding: 5px;
  padding-left: 10px;
  padding-right: 10px;
  font-size: 11px;
  line-height: 11px;
  font-weight: 700;
  border-radius: 10px;
  color: #FFFFFF;
  margin-right: 10px;
}
.p03 a.p03-01-link dl dd ul li p {
  display: block;
  position: relative;
  margin-top: 4px;
  padding-left: 5px;
  color: #000000;
  font-size: 13px;
  line-height: 1.4;
}

.p04 div.twobox {
  display: flex;
}
.p04 div.twobox div.postlist {
  width: 100%;
  margin-right: 40px;
}
.p04 div.twobox div.postlist p.description {
  font-size: 14px;
  line-height: 1.5;
  display: block;
  margin-bottom: 30px;
}
.p04 div.twobox aside {
  position: relative;
  display: block;
  min-width: 300px;
  max-width: 300px;
}
.p04 div.twobox aside dl {
  display: block;
  position: relative;
  margin-bottom: 20px;
}
.p04 div.twobox aside dl dt {
  display: block;
  font-size: 18px;
  line-height: 18px;
  font-weight: 700;
  padding-top: 20px;
  padding-bottom: 30px;
  text-align: center;
  color: #0C3463;
}
.p05 div.postdatail {
  position: relative;
  display: block;
  width: 750px;
  margin-left: auto;
  margin-right: auto;
  padding-top: 50px;
  padding-bottom: 0px;
}
.p05 div.postdatail div.mainimg {
  margin-bottom: 40px;
}
.p05 div.postdatail div.mainimg img {
  width: 100%;
  height: auto;
  border-radius: 5px;
}
.p05 div.postdatail div.header {
  display: block;
  position: relative;
  width: 650px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 30px;
}
.p05 div.postdatail div.header h1 {
  display: block;
  position: relative;
  font-size: 28px;
  line-height: 1.4;
  font-weight: 700;
  margin-bottom: 10px;
}
.p05 div.postdatail div.postdatailbox {
  display: block;
  position: relative;
  width: 650px;
  margin-left: auto;
  margin-right: auto;
}

.p06-01 {
  display: block;
  position: relative;
  padding: 30px;
  background-color: #FFFFFF;
  border-radius: 5px;
}

ul.imglist01 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: 1fr;
  grid-column-gap: 20px;
  grid-row-gap: 20px;
}
ul.imglist01 li {
  width: 100%;
}
ul.imglist01 li strong {
  font-weight: 700;
  color: #0C3463;
  display: block;
  text-align: center;
}
ul.imglist01 li img {
  margin-bottom: 10px;
  width: 100%;
  border-radius: 5px;
}

ol.step01 {
  position: relative;
  display: block;
  padding: 40px;
  background-color: #FFFFFF;
  border-radius: 10px;
}
ol.step01 li {
  padding-left: 60px;
  margin-bottom: 20px;
  position: relative;
  display: block;
  counter-increment: li;
}
ol.step01 li::before {
  content: counter(li);
  position: absolute;
  left: 0px;
  top: -3px;
  width: 40px;
  height: 40px;
  line-height: 40px;
  text-align: center;
  border-radius: 50%;
  background-color: #1377BC;
  color: #FFFFFF;
  font-weight: 700;
}
ol.step01 li:last-child {
  margin-bottom: 0px;
}
ol.step01 li strong {
  display: block;
  position: relative;
  font-weight: 700;
  font-size: 18px;
  color: #0C3463;
  margin-bottom: 5px;
}

.googlemap {
  display: block;
  position: relative;
}
.googlemap iframe {
  width: 100%;
  height: 300px;
  position: relative;
  display: block;
  border: 0px;
  padding: 0px;
}

.p07-01 .p07-01-pt {
  margin-bottom: 50px;
}

@media screen and (max-width: 1024px) {
  /* --------------------------------------------------
  	bese	
  -------------------------------------------------- */
  article,
  aside,
  details,
  figcaption,
  figure,
  footer,
  header,
  hgroup,
  nav,
  section,
  summary {
    display: block;
  }
  [hidden] {
    display: none;
  }
  html {
    width: 100%;
    font-size: 100%;
    -webkit-text-size-adjust: 100%;
    -ms-text-size-adjust: 100%;
    display: block;
    position: relative;
  }
  html,
  button,
  input,
  select,
  textarea {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Sans", "ヒラギノ角ゴシック", -apple-system, BlinkMacSystemFont, "Segoe UI", "Noto Sans JP", "Yu Gothic", "YuGothic", "Meiryo", "メイリオ", "Helvetica Neue", Arial, sans-serif;
    _font-family: arial, sans-serif;
  }
  body {
    background-color: #F5F5F5;
    margin: 0;
    margin-left: auto;
    margin-right: auto;
    max-width: none;
    width: 100%;
    display: block;
    position: relative;
    font-size: 16px;
    line-height: 1.8;
    color: #000000;
    letter-spacing: 0px;
    word-break: break-all;
    text-align: justify;
    box-shadow: 0px 0px 10px -8px #777777;
  }
  a {
    color: #F5721A;
    text-decoration: none;
    cursor: pointer;
  }
  a img {
    pointer-events: auto;
  }
  a:focus,
  a:visited {
    outline: 0;
  }
  a:hover,
  a:active {
    outline: 0;
    opacity: 0.7;
    transition: all 0.2s;
  }
  h1,
  h2,
  h3,
  h4,
  h5,
  h6 {
    font-weight: normal;
    margin: 0;
  }
  p,
  pre {
    display: block;
    position: relative;
    margin: 0;
  }
  abbr[title] {
    border-bottom: 1px dotted;
  }
  b,
  strong {
    font-weight: normal;
  }
  sub,
  sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline;
  }
  dl,
  dt,
  dd,
  ol,
  ul,
  li,
  menu,
  nav {
    margin: 0;
    padding: 0;
    list-style: none;
    list-style-image: none;
  }
  img {
    border: 0;
    vertical-align: text-bottom;
    display: block;
    -ms-interpolation-mode: bicubic;
    pointer-events: none;
  }
  svg:not(:root) {
    overflow: hidden;
  }
  form {
    margin: 0;
  }
  table.t-type01 {
    border-collapse: separate;
    border-spacing: 0px;
    width: 100%;
    border-top: 1px solid #0C3463;
    color: #0C3463;
  }
  table.t-type01 thead,
  table.t-type01 tbody {
    width: 100%;
  }
  table.t-type01 thead tr,
  table.t-type01 tbody tr {
    width: 100%;
  }
  table.t-type01 thead tr th,
  table.t-type01 tbody tr th {
    padding: 10px;
    text-align: left;
    vertical-align: top;
    border-bottom: 1px solid #0C3463;
  }
  table.t-type01 thead tr td,
  table.t-type01 tbody tr td {
    vertical-align: top;
    padding: 10px;
    border-bottom: 1px solid #0C3463;
  }
  table.t-type01 thead tr td p:last-of-type,
  table.t-type01 tbody tr td p:last-of-type {
    margin-bottom: 0px;
  }
  table.calendar01 {
    border-collapse: separate;
    border-spacing: 0px;
    width: 100%;
    border: 1px solid #0C3463;
    color: #0C3463;
    font-size: 13px;
  }
  table.calendar01 thead,
  table.calendar01 tbody {
    width: 100%;
  }
  table.calendar01 thead tr,
  table.calendar01 tbody tr {
    width: 100%;
  }
  table.calendar01 thead tr > *,
  table.calendar01 tbody tr > * {
    border-right: 1px solid #0C3463;
    border-bottom: 1px solid #0C3463;
  }
  table.calendar01 thead tr > *:last-child,
  table.calendar01 tbody tr > *:last-child {
    border-right: 0px solid #0C3463;
    border-bottom: 1px solid #0C3463;
  }
  table.calendar01 thead tr:last-child td,
  table.calendar01 tbody tr:last-child td {
    border-bottom: 0px;
  }
  table.calendar01 thead tr th:first-child,
  table.calendar01 thead tr td:first-child,
  table.calendar01 tbody tr th:first-child,
  table.calendar01 tbody tr td:first-child {
    text-align: left;
  }
  table.calendar01 thead tr th,
  table.calendar01 tbody tr th {
    padding: 5px;
    text-align: left;
    vertical-align: top;
    background-color: #0C3463;
    color: #FFFFFF;
    text-align: center;
    font-weight: 700;
  }
  table.calendar01 thead tr td,
  table.calendar01 tbody tr td {
    vertical-align: top;
    padding: 5px;
    border-bottom: 1px solid #0C3463;
    background-color: #FFFFFF;
    text-align: center;
    font-weight: 700;
  }
  table.calendar01 thead tr td p:last-of-type,
  table.calendar01 tbody tr td p:last-of-type {
    margin-bottom: 0px;
  }
  .is-style-outline a,
  .wp-block-button a,
  a.btn01 {
    display: inline-block;
    position: relative;
    background: linear-gradient(180deg, #1377BC 0%, #0C3463 100%);
    box-shadow: 0px 2px 0px rgba(12, 52, 99, 0.2);
    border-radius: 100px;
    font-size: 20px;
    line-height: 20px;
    padding: 25px;
    padding-left: 50px;
    padding-right: 50px;
    box-sizing: border-box;
    text-align: center;
    font-weight: 700;
    color: #FFFFFF;
  }
  .is-style-outline a:hover,
  .wp-block-button a:hover,
  a.btn01:hover {
    opacity: 1;
  }
  .is-style-outline a span.pop01,
  .wp-block-button a span.pop01,
  a.btn01 span.pop01 {
    width: 130px;
    display: block;
    position: absolute;
    color: #FFFFFF;
    text-align: center;
    font-size: 12px;
    line-height: 12px;
    background-color: #F5721A;
    box-sizing: border-box;
    padding: 10px;
    border-radius: 5px;
    left: 50%;
    margin-left: -65px;
    top: -35px;
    box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.25);
  }
  .is-style-outline a span.pop01:before,
  .wp-block-button a span.pop01:before,
  a.btn01 span.pop01:before {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    margin-left: -10px;
    border: 10px solid transparent;
    border-top: 10px solid #F5721A;
  }
  .is-style-outline a.min01,
  .wp-block-button a.min01,
  a.btn01.min01 {
    font-size: 16px;
    padding: 15px;
    padding-left: 15px;
    padding-right: 15px;
    width: 240px;
  }
  .is-style-outline a.min02,
  .wp-block-button a.min02,
  a.btn01.min02 {
    font-size: 12px;
    line-height: 12px;
    padding: 15px;
    padding-left: 30px;
    padding-right: 30px;
  }
  nav.btn-area01 {
    display: flex;
    position: relative;
    justify-content: center;
    align-items: center;
  }
  .gord {
    color: #FFCC00;
    font-style: normal;
  }
  .min03 {
    font-size: 12px;
  }
  .otherpostlist {
    padding: 20px;
  }
  .otherpostlist strong.title01 {
    color: #0C3463;
    font-size: 28px;
    font-weight: 700;
    display: block;
    position: relative;
    margin-bottom: 20px;
  }
  /* --------------------------------------------------
  	sab	
  -------------------------------------------------- */
  .unselectable {
    -webkit-touch-callout: none;
    -webkit-user-drag: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    -o-user-select: none;
    user-select: none;
    touch-callout: none;
  }
  .hidden {
    display: none !important;
    visibility: hidden;
  }
  .invisible {
    visibility: hidden;
  }
  .no-scroll {
    overflow: hidden;
  }
  .underline {
    text-decoration: underline;
  }
  .block {
    position: relative;
    display: block !important;
  }
  .f-weight {
    font-weight: 700;
  }
  .center {
    text-align: center !important;
    justify-content: center !important;
  }
  .pm00 {
    padding-bottom: 0px !important;
  }
  .bm00 {
    margin-bottom: 0px !important;
  }
  .bm01 {
    margin-bottom: 10px !important;
  }
  .bm02 {
    margin-bottom: 20px !important;
  }
  .bm03 {
    margin-bottom: 30px !important;
  }
  .bm04 {
    margin-bottom: 40px !important;
  }
  .bm05 {
    margin-bottom: 50px !important;
  }
  .bm06 {
    margin-bottom: 60px !important;
  }
  .bm08 {
    margin-bottom: 80px !important;
  }
  section.page {
    padding-top: 80px;
  }
  .p50 {
    padding: 20px;
  }
  .pt30 {
    padding-top: 30px;
  }
  .pt50 {
    padding-top: 60px;
  }
  .pt60 {
    padding-top: 60px;
  }
  .plr50 {
    padding-left: 20px;
    padding-right: 20px;
  }
  .plr100 {
    padding-left: 20px;
    padding-right: 20px;
  }
  h1.pagetitle {
    width: 100%;
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: #0C3463;
    font-size: 26px;
    line-height: 38px;
    padding: 20px;
    height: 200px;
    box-sizing: border-box;
    color: #FFFFFF;
    font-weight: 700;
  }
  h2.sectiontitle {
    font-size: 24px;
    line-height: 1.4;
    display: block;
    position: relative;
    font-weight: 700;
    color: #0C3463;
    margin-bottom: 20px;
  }
  h2.sectiontitle.center {
    text-align: center;
  }
  dl.qa {
    display: block;
    position: relative;
    margin-bottom: 20px;
    line-height: 1.5;
  }
  dl.qa:last-child {
    margin-bottom: 0px;
  }
  dl.qa dt {
    display: block;
    position: relative;
    font-weight: 700;
    margin-bottom: 15px;
  }
  dl.qa dt::before {
    content: "Q";
    background-color: #1377BC;
    color: #FFFFFF;
  }
  dl.qa dd {
    display: block;
    position: relative;
  }
  dl.qa dd::before {
    content: "A";
    background-color: #0EADB3;
    color: #FFFFFF;
  }
  dl.qa dt,
  dl.qa dd {
    padding-left: 40px;
  }
  dl.qa dt::before,
  dl.qa dd::before {
    position: absolute;
    left: 0px;
    top: -1px;
    width: 30px;
    height: 30px;
    line-height: 30px;
    text-align: center;
    border-radius: 50%;
    font-weight: 700;
    font-size: 14px;
  }
  dl.p02-02-box01,
  dl.p02-02-box02,
  dl.p02-02-box03 {
    padding: 30px;
    border-radius: 5px;
    background-color: #FFFFFF;
    border: 1px solid #0EADB3;
    display: block;
    position: relative;
    margin-bottom: 20px;
  }
  dl.p02-02-box01 dt,
  dl.p02-02-box02 dt,
  dl.p02-02-box03 dt {
    font-size: 18px;
    font-weight: 700;
    display: block;
    margin-bottom: 10px;
    color: #0EADB3;
  }
  dl.p02-02-box01 dd ul.threeli,
  dl.p02-02-box02 dd ul.threeli,
  dl.p02-02-box03 dd ul.threeli {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    grid-template-rows: 1fr;
    grid-column-gap: 10px;
    grid-row-gap: 10px;
  }
  dl.p02-02-box01 dd ul li,
  dl.p02-02-box02 dd ul li,
  dl.p02-02-box03 dd ul li {
    position: relative;
    display: block;
    padding-left: 20px;
  }
  dl.p02-02-box01 dd ul li::before,
  dl.p02-02-box02 dd ul li::before,
  dl.p02-02-box03 dd ul li::before {
    position: absolute;
    left: 0px;
    content: "・";
    color: #0EADB3;
  }
  dl.p02-02-box02 {
    border: 1px solid #B30E11;
  }
  dl.p02-02-box02 dt {
    color: #B30E11;
  }
  dl.p02-02-box02 dd ul li::before {
    color: #B30E11;
  }
  dl.p02-02-box03 {
    border: 1px solid #FFFFFF;
  }
  dl.p02-02-box03 dd ul li::before {
    color: #333333;
  }
  dl.postlistdl dt {
    position: relative;
    display: block;
    background-color: #FFFFFF;
    margin-bottom: 17.5px;
    border-radius: 5px;
    overflow: hidden;
  }
  dl.postlistdl dt a {
    aspect-ratio: 16/9;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
  }
  dl.postlistdl dt a img {
    max-width: 100%;
    max-height: 100%;
    width: auto;
    height: 100%;
  }
  dl.postlistdl dd strong {
    display: block;
    font-weight: 700;
    font-size: 16px;
    line-height: 1.4;
    font-weight: 700;
    margin-bottom: 10px;
  }
  dl.postlistdl dd strong a {
    color: #0C3463;
  }
  div.postlistbox {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    grid-template-rows: 1fr;
    grid-column-gap: 20px;
    grid-row-gap: 20px;
    margin-bottom: 30px;
  }
  div.postlistbox.three {
    grid-template-columns: repeat(1, 1fr);
    grid-template-rows: 1fr;
  }
  div.infobox {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    position: relative;
  }
  div.infobox time {
    padding-top: 5px;
    font-size: 12px;
    line-height: 12px;
    margin-left: 5px;
    padding-bottom: 5px;
  }
  ul.taglist {
    display: flex;
    position: relative;
    flex-wrap: wrap;
  }
  ul.taglist li {
    margin-top: 2.5px;
    margin-bottom: 2.5px;
    margin-right: 5px;
  }
  ul.taglist li a {
    display: block;
    font-size: 12px;
    line-height: 12px;
    white-space: nowrap;
    box-sizing: border-box;
    padding: 5px;
    padding-left: 10px;
    padding-right: 10px;
    border-radius: 5px;
    background-color: #FFFFFF;
    border: 1px solid #1377BC;
    color: #1377BC;
  }
  ul.catlist {
    border-top: 1px solid #CCCCCC;
  }
  ul.catlist li {
    display: block;
    position: relative;
    border-bottom: 1px solid #CCCCCC;
  }
  ul.catlist li a {
    display: block;
    position: relative;
    padding-top: 10px;
    padding-bottom: 10px;
    color: #1377BC;
  }
  ul.catlist li a i {
    margin-right: 10px;
  }
  nav.inpagenav {
    background-color: #FFFFFF;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  nav.inpagenav ul {
    position: relative;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    text-overflow: ellipsis;
    -webkit-overflow-scrolling: touch;
  }
  nav.inpagenav ul li {
    display: inline-block;
    font-weight: 700;
    font-size: 14px;
  }
  nav.inpagenav ul li a {
    position: relative;
    display: block;
    padding: 10px;
    color: #0C3463;
  }
  div.breadcrumbs {
    position: relative;
    display: block;
    font-size: 11px;
    padding: 10px;
    padding-left: 20px;
    padding-right: 20px;
    margin-left: auto;
    margin-right: auto;
    white-space: nowrap;
    overflow-x: auto;
    text-overflow: ellipsis;
    -webkit-overflow-scrolling: touch;
    color: #1377BC;
  }
  div.breadcrumbs span {
    color: #0C3463;
    margin-left: 0px;
    margin-right: 5px;
  }
  div.breadcrumbs span:last-of-type {
    margin-right: 0px;
  }
  div.breadcrumbs a {
    color: #333333;
  }
  div.breadcrumbs a:hover {
    color: #FFFFFF;
  }
  nav.pagenav {
    display: block;
    position: relative;
    padding-top: 10px;
  }
  nav.pagenav ul {
    display: flex;
    justify-content: center;
    align-items: center;
  }
  nav.pagenav ul li {
    font-size: 14px;
    line-height: 40px;
    text-align: center;
    margin-left: 5px;
    margin-right: 5px;
  }
  nav.pagenav ul li a.previouspostslink,
  nav.pagenav ul li a.nextpostslink,
  nav.pagenav ul li a.first,
  nav.pagenav ul li a.last {
    font-size: 20px;
    color: #1377BC;
    padding-left: 5px;
    padding-right: 5px;
  }
  nav.pagenav ul li a.page {
    display: block;
    position: relative;
    color: #1377BC;
    box-sizing: border-box;
    min-width: 40px;
    background-color: #FFFFFF;
    border: 1px solid #1377BC;
    border-radius: 40px;
  }
  nav.pagenav ul li a.page:hover {
    color: #FFFFFF;
    background-color: #1377BC;
  }
  nav.pagenav ul li span.current {
    display: block;
    position: relative;
    background-color: #1377BC;
    color: #FFFFFF;
    box-sizing: border-box;
    min-width: 40px;
    border-radius: 40px;
  }
  header {
    position: absolute;
    display: block;
    padding: 20px;
    width: 100%;
    box-sizing: border-box;
    z-index: 101;
  }
  header div.menubtn {
    display: flex;
    width: 35px;
    height: 35px;
    position: fixed;
    border-radius: 40px;
    justify-content: center;
    align-items: center;
    color: #FFFFFF;
    cursor: pointer;
    z-index: 100;
    background: linear-gradient(180deg, #1377BC 0%, #0C3463 100%);
    box-shadow: 0px 2px 0px rgba(12, 52, 99, 0.2);
    right: 65px;
    top: 20px;
  }
  header div.head {
    display: flex;
    position: relative;
  }
  header div.head strong {
    position: relative;
    display: block;
    width: 240px;
    min-width: 240px;
  }
  header div.head strong img {
    width: 100%;
    height: auto;
  }
  header div.head span.infonav {
    text-align: right;
    display: flex;
    justify-content: flex-end;
    font-size: 30px;
    margin-top: 0px;
    padding-right: 0px;
    font-weight: 700;
    position: fixed;
    right: 20px;
    top: 20px;
    bottom: auto;
    z-index: 100;
  }
  header div.head span.infonav a {
    color: #1377BC;
    margin-left: 0px;
    display: flex;
    align-items: center;
  }
  header div.head span.infonav a b {
    display: none;
    font-weight: 700;
  }
  header div.head span.infonav a i {
    margin-right: 0px;
  }
  header div.head span.infonav a i::before {
    width: 33px;
    height: 33px;
    border-radius: 33px;
    box-shadow: 0px 2px 0px rgba(12, 52, 99, 0.2);
  }
  header div.head nav.gnav {
    display: none;
    justify-content: center;
    align-items: center;
    width: 100%;
    position: fixed;
    flex-wrap: wrap;
    height: 100%;
    background-color: #F5F5F5;
    top: 0px;
    left: 0px;
  }
  header div.head nav.gnav.open {
    display: block;
  }
  header div.head nav.gnav strong.logo {
    max-width: 280px;
    width: 60%;
    display: block;
    margin-left: auto;
    margin-right: auto;
    padding-top: 80px;
    margin-bottom: 20px;
  }
  header div.head nav.gnav strong.logo img {
    width: 100%;
    height: auto;
  }
  header div.head nav.gnav ul.tnav {
    padding-top: 0px;
    width: auto;
    height: auto;
    display: block;
    font-size: 16px;
    align-items: center;
    justify-content: flex-end;
    margin-left: 40px;
    margin-right: 40px;
    box-sizing: border-box;
    border-bottom: 1px solid #CCCCCC;
    margin-bottom: 20px;
  }
  header div.head nav.gnav ul.tnav li {
    border-top: 1px solid #CCCCCC;
    position: relative;
    margin-left: 0px;
  }
  header div.head nav.gnav ul.tnav li a {
    padding: 10px;
    color: #0C3463;
    display: block;
  }
  header div.head nav.gnav div.bnav {
    margin-left: 0px;
    display: block;
    width: 100%;
  }
  header div.head nav.gnav div.bnav ul {
    display: block;
    margin-left: 20px;
    margin-right: 20px;
  }
  header div.head nav.gnav div.bnav ul li {
    margin-top: 10px;
  }
  header div.head nav.gnav div.bnav ul li a.btn01 {
    display: block;
    width: 100%;
    max-width: 375px;
    margin-left: auto;
    margin-right: auto;
    box-sizing: border-box;
    white-space: nowrap;
    font-size: 16px;
    line-height: 16px;
    padding: 20px;
  }
  footer {
    display: block;
    position: relative;
  }
  footer div.twobox {
    display: block;
    position: relative;
  }
  footer div.twobox div.foot01 {
    display: block;
    position: relative;
    padding: 30px;
    padding-top: 50px;
    box-sizing: border-box;
    min-width: auto;
  }
  footer div.twobox div.foot01 strong {
    display: block;
    width: 300px;
    margin-bottom: 20px;
    margin-left: auto;
    margin-right: auto;
  }
  footer div.twobox div.foot01 strong a img {
    width: 100%;
    height: auto;
  }
  footer div.twobox div.foot01 p {
    font-size: 12px;
    display: block;
    text-align: center;
  }
  footer div.twobox div.foot01 p b {
    display: block;
    font-size: 14px;
    font-weight: 700;
    color: #1377BC;
    margin-bottom: 5px;
  }
  footer div.twobox div.foot02 {
    position: relative;
    display: block;
    padding: 30px;
    padding-top: 0px;
    padding-right: 30px;
    background: #FFFFFF;
    box-sizing: border-box;
    width: 100%;
    border-radius: 0px 0px 0px 0px;
  }
  footer div.twobox div.foot02 div.pagetop {
    position: absolute;
    right: 20px;
    top: -20px;
  }
  footer div.twobox div.foot02 div.pagetop a {
    top: 0%;
    background: #0C3463;
    box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25);
    border-radius: 30px;
    color: #FFFFFF;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 50px;
  }
  footer div.twobox div.foot02 div.pagetop a i {
    font-size: 30px;
  }
  footer div.twobox div.foot02 dl {
    display: block;
    position: relative;
    width: 100%;
  }
  footer div.twobox div.foot02 dl:last-of-type {
    padding-left: 0px;
    width: 100%;
  }
  footer div.twobox div.foot02 dl dt {
    font-size: 16px;
    font-weight: 700;
    color: #0C3463;
    padding-bottom: 10px;
    margin-bottom: 20px;
    border-bottom: 2px solid #0C3463;
    padding-top: 30px;
  }
  footer div.twobox div.foot02 dl dd {
    font-size: 12px;
  }
  footer div.twobox div.foot02 dl dd ul.foot-link01,
  footer div.twobox div.foot02 dl dd ul.foot-link02 {
    display: flex;
    flex-wrap: wrap;
    padding-right: 0px;
  }
  footer div.twobox div.foot02 dl dd ul.foot-link01 li,
  footer div.twobox div.foot02 dl dd ul.foot-link02 li {
    width: 50%;
    display: block;
    padding-top: 3px;
    padding-bottom: 3px;
  }
  footer div.twobox div.foot02 dl dd ul.foot-link01 li a,
  footer div.twobox div.foot02 dl dd ul.foot-link02 li a {
    color: #1377BC;
  }
  footer div.twobox div.foot02 dl dd ul.foot-link02 {
    display: flex;
    flex-wrap: wrap;
  }
  footer div.twobox div.foot02 dl dd ul.foot-link02 li {
    width: 50%;
  }
  footer small {
    display: block;
    position: relative;
    text-align: center;
    font-size: 12px;
    padding-top: 30px;
    padding-bottom: 120px;
    color: #0C3463;
  }
  div.foot-tracking {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 98%;
    padding: 10px;
    position: fixed;
    z-index: 100;
    bottom: 0px;
    background: #FFFFFF;
    box-shadow: 0px -3px 5px rgba(0, 0, 0, 0.1);
    border-radius: 10px 10px 0px 0px;
    left: 1%;
    box-sizing: border-box;
  }
  div.foot-tracking a.btn01 {
    display: block;
    margin-left: 5px;
    margin-right: 5px;
  }
  .top01 {
    height: 220px;
    background-color: #CCCCCC;
    width: 100%;
    display: flex;
    align-items: flex-end;
    background-size: cover;
    background-repeat: no-repeat;
  }
  .top01 h1 {
    padding: 30px;
    font-size: 24px;
    line-height: 36px;
    font-weight: 700;
    color: #0C3463;
  }
  .top02 {
    position: relative;
    padding-top: 30px;
  }
  .top02 .top02-01 {
    width: 90%;
    position: relative;
    display: block;
    right: auto;
    top: auto;
    margin-left: auto;
    margin-right: auto;
  }
  .top02 .top02-01 img {
    width: 100%;
    height: auto;
    margin-bottom: 20px;
  }
  .top02 .top02-01 p {
    font-size: 10px;
    line-height: 14px;
    text-align: center;
  }
  .top02 .top02-02 {
    display: block;
    padding: 30px;
    padding-bottom: 0px;
    padding-top: 0px;
  }
  .top02 .top02-02 strong {
    padding: 10px;
    padding-left: 15px;
    padding-right: 15px;
    font-weight: 700;
    display: inline-block;
    color: #FFFFFF;
    background-color: #0EADB3;
    font-size: 18px;
    line-height: 18px;
    margin-bottom: 20px;
  }
  .top02 .top02-02 h2 {
    font-size: 30px;
    line-height: 40px;
    font-weight: 700;
    color: #0C3463;
    display: block;
    margin-bottom: 20px;
  }
  .top02 .top02-02 p {
    font-weight: 700;
    font-size: 14px;
    line-height: 1.6;
    margin-bottom: 30px;
  }
  .top02 .top02-03 {
    display: block;
    position: relative;
    padding: 10px;
    padding-bottom: 30px;
  }
  .top02 .top02-03 ul {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: 1fr;
    grid-column-gap: 10px;
    grid-row-gap: 10px;
  }
  .top02 .top02-03 ul li {
    padding: 20px;
    padding-top: 30px;
    border-radius: 5px;
    background-color: #FFFFFF;
    display: block;
    position: relative;
  }
  .top02 .top02-03 ul li img {
    width: 30px;
    height: auto;
    margin-bottom: 30px;
  }
  .top02 .top02-03 ul li strong {
    display: block;
    position: relative;
    font-weight: 700;
    color: #0C3463;
    font-size: 18px;
    line-height: 22px;
    margin-bottom: 10px;
  }
  .top02 .top02-03 ul li p {
    font-size: 12px;
    line-height: 20px;
  }
  .top02 div.top02-04 {
    padding: 30px;
    padding-bottom: 60px;
    display: block;
    position: relative;
    border-radius: 20px;
    background-color: #FFFFFF;
  }
  .top02 div.top02-04 h2 {
    display: block;
    font-size: 32px;
    line-height: 1.4;
    font-weight: 700;
    color: #0C3463;
    margin-bottom: 20px;
    font-feature-settings: "abvf";
  }
  .top02 div.top02-04 p {
    margin-bottom: 30px;
  }
  .top02 div.top02-04 div.dllist01 {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    grid-template-rows: 1fr;
    grid-column-gap: 10px;
    grid-row-gap: 10px;
  }
  .top02 div.top02-04 div.dllist01 dl {
    padding-top: 30px;
    border-radius: 5px;
    border: 1px solid #0EADB3;
    box-shadow: 0px 3px 3px rgba(0, 0, 0, 0.05);
  }
  .top02 div.top02-04 div.dllist01 dl dt {
    display: block;
    font-weight: 700;
    padding-left: 30px;
    font-size: 20px;
    line-height: 28px;
    color: #0C3463;
    padding-top: 3px;
    padding-bottom: 3px;
    position: relative;
  }
  .top02 div.top02-04 div.dllist01 dl dt::before {
    content: "";
    display: block;
    position: absolute;
    height: 100%;
    top: 0px;
    left: 0px;
    width: 5px;
    border-top-right-radius: 3px;
    border-bottom-right-radius: 3px;
    background-color: #0EADB3;
  }
  .top02 div.top02-04 div.dllist01 dl dd {
    padding: 30px;
    padding-top: 10px;
  }
  .top02 div.top02-04 div.dllist01 dl dd ul li a {
    color: #1377BC;
    font-size: 14px;
  }
  .top02 div.top02-04 div.dllist01 dl dd ul li a i {
    margin-right: 10px;
  }
  .top02 .top02-05 {
    position: relative;
    padding: 10px;
  }
  .top02 .top02-05 h2 {
    font-size: 30px;
    line-height: 30px;
    display: block;
    position: relative;
    text-align: center;
    font-weight: 700;
    margin-bottom: 40px;
    color: #0C3463;
    padding-top: 50px;
  }
  .top02 .top02-05 div.twobox {
    display: block;
    justify-content: center;
    align-items: center;
    margin-bottom: 30px;
  }
  .top02 .top02-05 div.twobox dl {
    padding: 20px;
    padding-top: 30px;
    background-color: #FFFFFF;
    margin-left: 0px;
    margin-right: 0px;
    border-radius: 5px;
    display: block;
    position: relative;
    margin-bottom: 20px;
  }
  .top02 .top02-05 div.twobox dl::before {
    width: 80%;
    left: 10%;
    content: "";
    height: 5px;
    border-radius: 0px 0px 3px 3px;
    background-color: #0EADB3;
    top: 0px;
    position: absolute;
  }
  .top02 .top02-05 div.twobox dl dt {
    display: block;
    font-size: 24px;
    text-align: center;
    font-weight: 700;
    color: #0C3463;
    padding-top: 0px;
    padding-bottom: 30px;
  }
  .top02 .top02-05 div.twobox dl dd {
    position: relative;
    display: block;
    padding: 20px;
    padding-top: 50px;
    border-radius: 5px;
    background-color: #F2FAFA;
  }
  .top02 .top02-05 div.twobox dl dd span.pop02 {
    width: 180px;
    display: block;
    position: absolute;
    color: #FFFFFF;
    text-align: center;
    font-size: 12px;
    line-height: 12px;
    background-color: #F5721A;
    box-sizing: border-box;
    padding: 10px;
    border-radius: 5px;
    left: 50%;
    margin-left: -90px;
    top: -15px;
    box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.25);
  }
  .top02 .top02-05 div.twobox dl dd span.pop02:before {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    margin-left: -10px;
    border: 10px solid transparent;
    border-top: 10px solid #F5721A;
  }
  .top02 .top02-05 div.twobox dl dd ul {
    display: block;
    position: relative;
    margin-bottom: 20px;
  }
  .top02 .top02-05 div.twobox dl dd ul li {
    display: block;
    position: relative;
    color: #0C3463;
    font-weight: 700;
    margin-bottom: 10px;
    line-height: 1.6;
    padding-left: 40px;
  }
  .top02 .top02-05 div.twobox dl dd ul li::before {
    content: "";
    display: block;
    position: absolute;
    width: 25px;
    height: 24px;
    left: 0px;
    top: 0px;
    background-image: url("../img/cmn/04.png");
    background-size: contain;
    background-repeat: no-repeat;
  }
  .top02 .top02-05 div.twobox dl dd p {
    display: block;
    font-size: 12px;
    line-height: 20px;
  }
  .p01 div.p01-01 p {
    display: block;
    text-align: center;
    font-weight: 700;
  }
  .p01 div.p01-02 div.twobox {
    display: block;
    margin-bottom: 30px;
    position: relative;
  }
  .p01 div.p01-02 div.twobox img {
    border-radius: 5px;
    width: 100%;
    margin-top: 0px;
    margin-right: 0px;
    margin-bottom: 30px;
  }
  .p01 div.p01-02 div.twobox div.p01-02-box h3 {
    font-size: 18px;
    font-weight: 700;
    color: #0C3463;
    display: block;
    padding-bottom: 15px;
    margin-bottom: 20px;
    border-bottom: 2px solid #0C3463;
  }
  .p01 div.p01-02 div.twobox div.p01-02-box ul {
    position: relative;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: 1fr;
    grid-column-gap: 10px;
    grid-row-gap: 10px;
    margin-bottom: 20px;
  }
  .p01 div.p01-02 div.twobox div.p01-02-box ul li {
    border-radius: 20px;
    display: block;
    position: relative;
    background-color: #FFFFFF;
    border: 1px solid #0EADB3;
    font-size: 13px;
    line-height: 13px;
    font-weight: 700;
    padding: 10px;
    color: #0C3463;
    padding-left: 40px;
  }
  .p01 div.p01-02 div.twobox div.p01-02-box ul li::before {
    position: absolute;
    width: 22px;
    height: 20px;
    top: 8px;
    left: 10px;
    content: "";
    background-image: url("../img/cmn/i03.png");
    background-size: contain;
    background-repeat: no-repeat;
  }
  .p01 div.p01-02 div.twobox div.p01-02-box p {
    margin-bottom: 20px;
  }
  .p01 div.p01-03 {
    padding-top: 30px;
  }
  .p01 div.p01-03 dl {
    margin-bottom: 30px;
    display: block;
    position: relative;
  }
  .p01 div.p01-03 dl dt {
    margin-bottom: 20px;
  }
  .p01 div.p01-03 dl dt img {
    width: 100%;
  }
  .p01 div.p01-03 dl dd strong {
    display: block;
    font-weight: 700;
    margin-bottom: 5px;
  }
  .p01 div.p01-04 {
    display: block;
    background-color: #FFFFFF;
    flex-direction: row-reverse;
  }
  .p01 div.p01-04 img {
    width: 100%;
    height: auto;
    min-width: auto;
    min-height: auto;
  }
  .p01 div.p01-04 div.p01-04-box {
    padding: 30px;
    width: 100%;
    box-sizing: border-box;
  }
  .p02 div.p02-01 div.p02-01-box {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    grid-template-rows: 1fr;
    grid-column-gap: 10px;
    grid-row-gap: 10px;
  }
  .p02 div.p02-01 div.p02-01-box dl {
    display: block;
    position: relative;
    background-color: #FFFFFF;
    border-radius: 5px;
    padding: 20px;
  }
  .p02 div.p02-01 div.p02-01-box dl dt {
    margin-bottom: 20px;
  }
  .p02 div.p02-01 div.p02-01-box dl dt strong {
    display: block;
    color: #0C3463;
    font-weight: 700;
    font-size: 18px;
    line-height: 1.4;
  }
  .p02 div.p02-01 div.p02-01-box dl dt p {
    margin-top: 10px;
    font-size: 14px;
    line-height: 1.4;
    color: #333333;
  }
  .p02 div.p02-01 div.p02-01-box dl dd {
    color: #0EADB3;
    font-weight: 700;
    display: flex;
    flex-wrap: wrap;
  }
  .p02 div.p02-01 div.p02-01-box dl dd span {
    position: relative;
    display: flex;
    align-items: center;
    margin-right: 10px;
    margin-top: 5px;
    white-space: nowrap;
  }
  .p02 div.p02-01 div.p02-01-box dl dd span i {
    background-color: #F2FAFA;
    font-size: 10px;
    line-height: 10px;
    padding: 5px;
    display: inline-block;
    border-radius: 5px;
    font-weight: normal;
    font-style: normal;
    margin-right: 10px;
  }
  .p03 h2 {
    padding-top: 30px;
  }
  .p03 a.p03-01-link {
    display: block;
    position: relative;
    margin-bottom: 10px;
    background-color: #FFFFFF;
    border-radius: 5px;
    border: 1px solid #FFFFFF;
    box-sizing: border-box;
  }
  .p03 a.p03-01-link:hover {
    opacity: 1;
    border: 1px solid #0EADB3;
  }
  .p03 a.p03-01-link dl {
    padding: 30px;
    display: block;
    padding-right: 80px;
    align-items: center;
    position: relative;
  }
  .p03 a.p03-01-link dl::before {
    content: "";
    display: block;
    position: absolute;
    height: 80%;
    top: 10%;
    left: 0px;
    width: 5px;
    border-top-right-radius: 3px;
    border-bottom-right-radius: 3px;
    background-color: #0EADB3;
  }
  .p03 a.p03-01-link dl::after {
    /* use !important to prevent issues with browser extensions that change fonts */
    font-family: "icomoon" !important;
    speak: never;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    /* Better Font Rendering =========== */
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    content: "\e912";
    width: 30px;
    height: 30px;
    position: absolute;
    color: #FFFFFF;
    background-color: #1377BC;
    border-radius: 80px;
    right: 20px;
    top: 50%;
    margin-top: -20px;
    text-align: center;
    line-height: 30px;
    font-size: 20px;
  }
  .p03 a.p03-01-link dl dt {
    position: relative;
    color: #0C3463;
    font-weight: 700;
    min-width: auto;
    font-size: 20px;
    margin-bottom: 10px;
  }
  .p03 a.p03-01-link dl dd ul li {
    display: block;
    align-items: center;
    margin-bottom: 10px;
  }
  .p03 a.p03-01-link dl dd ul li:last-child {
    margin-bottom: 0px;
  }
  .p03 a.p03-01-link dl dd ul li strong {
    display: inline-block;
    position: relative;
    background-color: #0EADB3;
    padding: 5px;
    padding-left: 10px;
    padding-right: 10px;
    font-size: 11px;
    line-height: 11px;
    font-weight: 700;
    border-radius: 10px;
    color: #FFFFFF;
    margin-right: 10px;
  }
  .p03 a.p03-01-link dl dd ul li p {
    color: #000000;
    display: block;
    font-size: 13px;
  }
  .p04 div.twobox {
    display: block;
  }
  .p04 div.twobox div.postlist {
    width: 100%;
    margin-right: 40px;
  }
  .p04 div.twobox div.postlist p.description {
    font-size: 14px;
    line-height: 1.5;
    display: block;
    margin-bottom: 30px;
  }
  .p04 div.twobox aside {
    position: relative;
    display: block;
    min-width: auto;
    max-width: none;
  }
  .p04 div.twobox aside dl {
    display: block;
    position: relative;
    margin-bottom: 20px;
  }
  .p04 div.twobox aside dl dt {
    display: block;
    font-size: 18px;
    line-height: 18px;
    font-weight: 700;
    padding-top: 50px;
    padding-bottom: 30px;
    text-align: center;
    color: #0C3463;
  }
  .p05 div.postdatail {
    position: relative;
    display: block;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
    padding-top: 50px;
    padding-bottom: 0px;
  }
  .p05 div.postdatail div.mainimg {
    margin-bottom: 40px;
  }
  .p05 div.postdatail div.mainimg img {
    width: 100%;
    height: auto;
    border-radius: 5px;
  }
  .p05 div.postdatail div.header {
    display: block;
    position: relative;
    width: auto;
    margin-left: 20px;
    margin-right: 20px;
    margin-bottom: 30px;
  }
  .p05 div.postdatail div.header h1 {
    display: block;
    position: relative;
    font-size: 24px;
    line-height: 1.4;
    font-weight: 700;
    margin-bottom: 10px;
  }
  .p05 div.postdatail div.postdatailbox {
    display: block;
    position: relative;
    width: auto;
    margin-left: 20px;
    margin-right: 20px;
  }
  .p06-01 {
    display: block;
    position: relative;
    padding: 20px;
    background-color: #FFFFFF;
    border-radius: 5px;
  }
  ul.imglist01 {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: 1fr;
    grid-column-gap: 20px;
    grid-row-gap: 20px;
  }
  ul.imglist01 li {
    width: 100%;
  }
  ul.imglist01 li strong {
    font-weight: 700;
    color: #0C3463;
    font-size: 12px;
    display: block;
    text-align: center;
  }
  ul.imglist01 li img {
    margin-bottom: 10px;
    width: 100%;
    border-radius: 5px;
  }
  ol.step01 {
    position: relative;
    display: block;
    padding: 30px;
    background-color: #FFFFFF;
    border-radius: 10px;
  }
  ol.step01 li {
    padding-left: 60px;
    margin-bottom: 20px;
    position: relative;
    display: block;
    counter-increment: li;
  }
  ol.step01 li::before {
    content: counter(li);
    position: absolute;
    left: 0px;
    top: -3px;
    width: 40px;
    height: 40px;
    line-height: 40px;
    text-align: center;
    border-radius: 50%;
    background-color: #1377BC;
    color: #FFFFFF;
    font-weight: 700;
  }
  ol.step01 li:last-child {
    margin-bottom: 0px;
  }
  ol.step01 li strong {
    display: block;
    position: relative;
    font-weight: 700;
    font-size: 18px;
    color: #0C3463;
    margin-bottom: 5px;
  }
  div.no_bullets {
    padding: 20px !important;
  }
  .spbr {
    display: none;
  }
  .p07-01 .p07-01-pt {
    margin-bottom: 20px;
  }
}
@font-face {
  font-family: "icomoon";
  src: url("../img/fonts/icomoon.eot?w60to1");
  src: url("../img/fonts/icomoon.eot?w60to1#iefix") format("embedded-opentype"), url("../img/fonts/icomoon.ttf?w60to1") format("truetype"), url("../img/fonts/icomoon.woff?w60to1") format("woff"), url("../img/fonts/icomoon.svg?w60to1#icomoon") format("svg");
  font-weight: normal;
  font-style: normal;
  font-display: block;
}
[class^=icon-],
[class*=" icon-"] {
  /* use !important to prevent issues with browser extensions that change fonts */
  font-family: "icomoon" !important;
  speak: never;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.icon-facebook:before {
  content: "\e900";
}

.icon-instagram:before {
  content: "\e901";
}

.icon-line:before {
  content: "\e927";
}

.icon-tiktok:before {
  content: "\e902";
}

.icon-x:before {
  content: "\e903";
}

.icon-youtube:before {
  content: "\e904";
}

.icon-library_add:before {
  content: "\e905";
}

.icon-call_end:before {
  content: "\e906";
}

.icon-email:before {
  content: "\e909";
}

.icon-add:before {
  content: "\e90a";
}

.icon-block:before {
  content: "\e90b";
}

.icon-remove:before {
  content: "\e90d";
}

.icon-keyboard_arrow_down:before {
  content: "\e90e";
}

.icon-keyboard_arrow_left:before {
  content: "\e90f";
}

.icon-keyboard_arrow_right:before {
  content: "\e910";
}

.icon-keyboard_arrow_up:before {
  content: "\e911";
}

.icon-arrow_forward:before {
  content: "\e912";
}

.icon-menu:before {
  content: "\e913";
}

.icon-clear:before {
  content: "\e90c";
}

.icon-check_box:before {
  content: "\e914";
}

.icon-check_box_outline_blank:before {
  content: "\e915";
}

.icon-done:before {
  content: "\e916";
}

.icon-favorite:before {
  content: "\e917";
}

.icon-favorite_outline:before {
  content: "\e918";
}

.icon-launch:before {
  content: "\e919";
}

.icon-search:before {
  content: "\e91a";
}

.icon-thumb_down:before {
  content: "\e91b";
}

.icon-thumb_up:before {
  content: "\e91c";
}

.icon-verified_user:before {
  content: "\e91d";
}

.icon-zoom_in:before {
  content: "\e91e";
}

.icon-north:before {
  content: "\e91f";
}

.icon-south:before {
  content: "\e922";
}

.icon-star_outline:before {
  content: "\e925";
}

.icon-star_rate:before {
  content: "\e926";
}

.icon-english::before {
  content: "";
  width: 12px;
  height: 12px;
  background-image: url("../img/cmn/uk01.png");
  background-size: contain;
  background-repeat: no-repeat;
  border-radius: 12px;
  display: inline-block;
}

.icon-crown::before {
  content: "";
  width: 53px;
  height: 47px;
  background-image: url("../img/cmn/i02.png");
  background-size: contain;
  background-repeat: no-repeat;
  display: inline-block;
}

.icon-kome::before {
  content: "※";
  width: 12px;
  height: 12px;
  background-color: #1377BC;
  border-radius: 12px;
  font-size: 10px;
  color: #FFFFFF;
  text-align: center;
  line-height: 12px;
  display: inline-block;
}

.postdatailbox h2 span,
.postdatailbox h3 span {
  display: block;
  position: relative;
  padding-top: 15px;
}
.postdatailbox a {
  color: #F5721A;
}
.postdatailbox strong {
  font-weight: 700;
}
.postdatailbox h2 {
  display: block;
  position: relative;
  font-size: 24px;
  line-height: 1.4;
  padding-bottom: 15px;
  border-bottom: 2px solid #0EADB3;
  font-weight: 700;
  margin-bottom: 25px;
}
.postdatailbox h3 {
  display: block;
  position: relative;
  font-size: 20px;
  line-height: 1.4;
  margin-bottom: 15px;
  font-weight: 700;
  margin-bottom: 20px;
}
.postdatailbox h4 {
  padding: 10px;
  font-weight: 700;
  line-height: 1.4;
  background-color: #F2FAFA;
  color: #0EADB3;
  display: block;
  position: relative;
  margin-bottom: 10px;
}
.postdatailbox h5 {
  font-weight: 700;
  line-height: 1.4;
  display: block;
  position: relative;
  color: #0C3463;
  margin-bottom: 5px;
}
.postdatailbox img {
  display: block;
  position: relative;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
  height: auto;
}
.postdatailbox p {
  display: block;
  position: relative;
  margin-bottom: 25px;
}
.postdatailbox em {
  font-style: italic;
}
.postdatailbox ul,
.postdatailbox ol {
  display: block;
  position: relative;
  list-style: disc;
  padding-left: 30px;
  margin-bottom: 25px;
}
.postdatailbox ul li,
.postdatailbox ol li {
  margin-left: 15px;
  display: list-item;
  list-style: disc;
}
.postdatailbox ol {
  list-style-type: decimal;
}
.postdatailbox ol li {
  list-style-type: decimal;
}
.postdatailbox figure {
  margin: 0px;
}
.postdatailbox figure.wp-block-table {
  margin-bottom: 25px;
}
.postdatailbox .wp-block-image {
  margin-bottom: 25px;
}
.postdatailbox blockquote {
  border-radius: 5px;
  position: relative;
  padding: 20px;
  margin-left: 20px;
  margin-right: 20px;
  background-color: #CCCCCC;
  color: #333333;
}
.postdatailbox blockquote p:last-of-type {
  margin-bottom: 0px;
}
.postdatailbox figcaption {
  text-align: center;
  display: block;
  padding-top: 10px;
  color: #333333;
  font-size: 16px;
}
.postdatailbox .is-type-video {
  display: block;
  margin-bottom: 25px;
}
.postdatailbox .is-type-video .wp-block-embed__wrapper {
  position: relative;
  width: 100%;
  margin-bottom: 20px;
}
.postdatailbox .is-type-video .wp-block-embed__wrapper::before {
  content: "";
  display: block;
  padding-top: 56.25%;
}
.postdatailbox .is-type-video .wp-block-embed__wrapper iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.postdatailbox .has-black-background-color {
  background-color: #000000;
}
.postdatailbox .has-black-background-color th,
.postdatailbox .has-black-background-color td {
  background-color: #000000;
}
.postdatailbox .has-cyan-bluish-gray-background-color {
  background-color: #abb8c3;
}
.postdatailbox .has-cyan-bluish-gray-background-color th,
.postdatailbox .has-cyan-bluish-gray-background-color td {
  background-color: #abb8c3;
}
.postdatailbox .has-white-background-color {
  background-color: #ffffff;
}
.postdatailbox .has-white-background-color th,
.postdatailbox .has-white-background-color td {
  background-color: #ffffff;
}
.postdatailbox .has-pale-pink-background-color {
  background-color: #f78da7;
}
.postdatailbox .has-pale-pink-background-color th,
.postdatailbox .has-pale-pink-background-color td {
  background-color: #f78da7;
}
.postdatailbox .has-vivid-red-background-color {
  background-color: #cf2e2e;
}
.postdatailbox .has-vivid-red-background-color th,
.postdatailbox .has-vivid-red-background-color td {
  background-color: #cf2e2e;
}
.postdatailbox .has-luminous-vivid-orange-background-color {
  background-color: #ff6900;
}
.postdatailbox .has-luminous-vivid-orange-background-color th,
.postdatailbox .has-luminous-vivid-orange-background-color td {
  background-color: #ff6900;
}
.postdatailbox .has-luminous-vivid-amber-background-color {
  background-color: #FCB900;
}
.postdatailbox .has-luminous-vivid-amber-background-color th,
.postdatailbox .has-luminous-vivid-amber-background-color td {
  background-color: #FCB900;
}
.postdatailbox .has-light-green-cyan-background-color {
  background-color: #7bdcb5;
}
.postdatailbox .has-light-green-cyan-background-color th,
.postdatailbox .has-light-green-cyan-background-color td {
  background-color: #7bdcb5;
}
.postdatailbox .has-vivid-green-cyan-background-color {
  background-color: #00d084;
}
.postdatailbox .has-vivid-green-cyan-background-color th,
.postdatailbox .has-vivid-green-cyan-background-color td {
  background-color: #00d084;
}
.postdatailbox .has-pale-cyan-blue-background-color {
  background-color: #8ed1fc;
}
.postdatailbox .has-pale-cyan-blue-background-color th,
.postdatailbox .has-pale-cyan-blue-background-color td {
  background-color: #8ed1fc;
}
.postdatailbox .has-vivid-cyan-blue-background-color {
  background-color: #0693E3;
}
.postdatailbox .has-vivid-cyan-blue-background-color th,
.postdatailbox .has-vivid-cyan-blue-background-color td {
  background-color: #0693E3;
}
.postdatailbox .has-vivid-purple-background-color {
  background-color: #9b51e0;
}
.postdatailbox .has-vivid-purple-background-color th,
.postdatailbox .has-vivid-purple-background-color td {
  background-color: #9b51e0;
}
.postdatailbox .has-black-color {
  color: #000000;
}
.postdatailbox .has-cyan-bluish-gray-color {
  color: #abb8c3;
}
.postdatailbox .has-white-color {
  color: #ffffff;
}
.postdatailbox .has-pale-pink-color {
  color: #f78da7;
}
.postdatailbox .has-vivid-red-color {
  color: #cf2e2e;
}
.postdatailbox .has-luminous-vivid-orange-color {
  color: #ff6900;
}
.postdatailbox .has-luminous-vivid-amber-color {
  color: #FCB900;
}
.postdatailbox .has-light-green-cyan-color {
  color: #7bdcb5;
}
.postdatailbox .has-vivid-green-cyan-color {
  color: #00d084;
}
.postdatailbox .has-pale-cyan-blue-color {
  color: #8ed1fc;
}
.postdatailbox .has-vivid-cyan-blue-color {
  color: #0693e3;
}
.postdatailbox .has-vivid-purple-color {
  color: #9b51e0;
}
.postdatailbox table.has-black-color {
  background-color: #000000;
}
.postdatailbox table.has-cyan-bluish-gray-color {
  background-color: #abb8c3;
}
.postdatailbox table.has-white-color {
  background-color: #ffffff;
}
.postdatailbox table.has-pale-pink-color {
  background-color: #f78da7;
}
.postdatailbox table.has-vivid-red-color {
  background-color: #cf2e2e;
}
.postdatailbox table.has-luminous-vivid-orange-color {
  background-color: #ff6900;
}
.postdatailbox table.has-luminous-vivid-amber-color {
  background-color: #FCB900;
}
.postdatailbox table.has-light-green-cyan-color {
  background-color: #7bdcb5;
}
.postdatailbox table.has-vivid-green-cyan-color {
  background-color: #00d084;
}
.postdatailbox table.has-pale-cyan-blue-color {
  background-color: #8ed1fc;
}
.postdatailbox table.has-vivid-cyan-blue-color {
  background-color: #0693e3;
}
.postdatailbox table.has-vivid-purple-color {
  background-color: #9b51e0;
}
.postdatailbox .has-small-font-size {
  font-size: 12px;
}
.postdatailbox .has-small-font-size table {
  font-size: 12px;
}
.postdatailbox .has-medium-font-size {
  font-size: 20px;
}
.postdatailbox .has-medium-font-size table {
  font-size: 20px;
}
.postdatailbox .has-large-font-size {
  font-size: 36px;
}
.postdatailbox .has-large-font-size table {
  font-size: 36px;
}
.postdatailbox .has-x-large-font-size {
  font-size: 42px;
}
.postdatailbox .has-x-large-font-size table {
  font-size: 42px;
}
.postdatailbox .has-text-align-left {
  text-align: left;
}
.postdatailbox .has-text-align-center {
  text-align: center;
}
.postdatailbox .has-text-align-right {
  text-align: right;
}
.postdatailbox .has-background {
  padding: 15px;
  display: block;
}
.postdatailbox table.has-background {
  padding: 0px;
  border-radius: 0px;
  display: table;
}
.postdatailbox .wp-block-group {
  display: block;
  position: relative;
  padding: 15px;
  margin-bottom: 25px;
}
.postdatailbox .wp-block-group p:last-of-type,
.postdatailbox .wp-block-group pre:last-of-type,
.postdatailbox .wp-block-group table:last-of-type,
.postdatailbox .wp-block-group ul:last-of-type,
.postdatailbox .wp-block-group ol:last-of-type,
.postdatailbox .wp-block-group h2:last-of-type,
.postdatailbox .wp-block-group h3:last-of-type,
.postdatailbox .wp-block-group h4:last-of-type,
.postdatailbox .wp-block-group h5:last-of-type,
.postdatailbox .wp-block-group dl:last-of-type {
  margin-bottom: 0px;
}
.postdatailbox .wp-block-group ul,
.postdatailbox .wp-block-group ol {
  padding-left: 0px;
}
.postdatailbox .wp-block-group ul ul,
.postdatailbox .wp-block-group ul ol,
.postdatailbox .wp-block-group ol ul,
.postdatailbox .wp-block-group ol ol {
  padding-left: 20px;
}
.postdatailbox .wp-block-group {
  background-color: #F5F5F5;
  border: 1px solid #CCCCCC;
}
.postdatailbox figure.is-style-stripes {
  position: relative;
  display: block;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}
.postdatailbox table {
  font-size: 16px;
  margin-bottom: 0px;
  width: 100%;
  border-top: 1px solid #0C3463;
  border-spacing: 0;
}
.postdatailbox table tbody tr td,
.postdatailbox table tbody tr th,
.postdatailbox table thead tr td,
.postdatailbox table thead tr th {
  padding: 10px;
  border-bottom: 1px solid #0C3463;
}
.postdatailbox table thead tr td,
.postdatailbox table thead tr th {
  color: #0C3463;
}

div.no_bullets {
  background-color: #FFFFFF;
  padding: 30px;
  margin-bottom: 40px;
  border-radius: 5px;
}
div.no_bullets p.toc_title {
  display: block;
  text-align: center;
  font-size: 16px;
  font-weight: 700;
  margin-bottom: 10px;
}
div.no_bullets ul.toc_list {
  padding-left: 0px;
  margin-bottom: 0px;
}
div.no_bullets ul.toc_list li {
  position: relative;
  list-style: none;
  margin-bottom: 0px;
  line-height: 1.4;
  margin-left: 0px;
  padding-top: 8px;
  padding-bottom: 8px;
  padding-left: 25px;
}
div.no_bullets ul.toc_list li::before {
  position: absolute;
  content: "⚫︎";
  left: 0px;
  color: #0EADB3;
}
div.no_bullets ul.toc_list li:first-of-type {
  padding-top: 6px;
}
div.no_bullets ul.toc_list li a {
  width: 100%;
  color: #333333;
}
div.no_bullets ul.toc_list li ul {
  padding-top: 10px;
  margin-bottom: 0px;
  padding-left: 0px;
  counter-reset: listnum;
  /* カウンターをリセット */
}
div.no_bullets ul.toc_list li ul li {
  font-weight: 300;
  display: flex;
  margin-left: 0px;
  padding-top: 5px;
  padding-bottom: 5px;
}
div.no_bullets ul.toc_list li ul li::before {
  display: block;
  counter-increment: listnum;
  content: counter(listnum) ".";
  margin-right: 10px;
}