@charset "utf-8";
@import url(http://fonts.googleapis.com/earlyaccess/notosansjp.css);
body {
    font-size: 15px;
    color: #333;
    line-height: 1.7;
}

* {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    -o-box-sizing: border-box;
    -ms-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-backface-visibility: hidden -webkit-font-smoothing: antialiased
}

img {
    max-width: 100%;
    height: auto;
    width: auto;
    vertical-align: middle;
    line-height: 1;
    /*IE8のみ適用*/
}

p,div,li,span {
    overflow-wrap: break-word;
    word-wrap: break-word;
}

a {
    text-decoration: none;
    transition: 0.5s;
    color: #001d2e;
}

a:hover {
    text-decoration: none;
    color: #001d2e;
}



.bold { font-weight: 700;}
.small {
  font-size: 80%;
  font-weight: 400 !important;
}
.strong {
  font-size: 105%;
  font-weight: 700;
}

.center { text-align: center;}

.font_big {
    font-size: 150%;
    font-weight: 700;
}

.wrapper {
    width: 100%;
    max-width: 1000px;
    margin: 0 auto;
    padding: 0 10px;
    box-sizing: border-box;
}

.flexBlock {
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-flex-direction: row;
    -ms-flex-direction: row;
    flex-direction: row;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-align-items: stretch;
    -ms-flex-align: stretch;
    -webkit-align-content: flex-start;
    -ms-flex-line-pack: start;
    align-content: flex-start;
    align-items: stretch;
}
.flexBlock2 {
    display: flex;
    flex-wrap: wrap;
    justify-content: start;
}
.flexBlock3 {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}


.fixed { z-index: 2;}

.sd {
    -webkit-overflow-scrolling: touch;
    align-content: center;
    align-items: center;
    display: flex;
    flex: none;
    flex-direction: column;
    flex-wrap: nowrap;
    max-width: 100%;
    pointer-events: all;
    position: relative;
    z-index: 0;
}

.sd.icon, .sd.text {
    align-content: center;
    align-items: center;
    display: flex;
    flex-direction: row;
    justify-content: center;
    overflow: visible;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.button, .link { cursor: pointer;}

/**************************************

header

***************************************/
header.sd {
    align-content: flex-start;
    align-items: flex-start;
    background: rgba(0,0,0,0.0);
    display: flex;
    flex: none;
    flex-direction: row;
    flex-wrap: nowrap;
    height: auto;
    justify-content: space-between;
    left: 0;
    margin: 0 0 0 0;
    opacity: 1;
    overflow-x: visible;
    overflow-y: visible;
    padding: 0px 0px 0px;
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 2;
    max-width: 100%;
}
header.sd a {
    align-content: center;
    align-items: center;
    background: #4052BC;
    flex: none;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: center;
    margin: 0px 0px 0px 0px;
    padding: 10px 20px;
    width: fit-content;
    max-width: 100%;
    z-index: 9999;
}
header.sd a > div > img {
    flex: none;
    height: auto;
    width: 65px;
    max-width: 100%;
}
header.sd a > div > h1 {
    color: #FFFFFF;
    font-size: 20px;
    font-style: italic;
    font-weight: 900;
    height: auto;
    line-height: 1.4;
    text-align: center;
    text-indent: 0.8em;
    width: auto;
    max-width: 100%;
    justify-content: center;
    padding-top: 2px;
}
header.sd a > div > h1 span {
    display: inline-block;
    font-size: 90%;
    font-style: italic;
    text-indent: 0.65em;
}

header.sd a > div.flexBlock.sd.appear {
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-flex-direction: row;
    -ms-flex-direction: row;
    flex-direction: row;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-align-items: stretch;
    -ms-flex-align: stretch;
    -webkit-align-content: flex-start;
    -ms-flex-line-pack: start;
    align-content: flex-start;
    align-items: stretch;
}

header.sd > .mBtn {
    align-content: center;
    align-items: center;
    background: rgba(0,0,0,0.0);
    flex: none;
    flex-direction: row;
    flex-wrap: wrap;
    height: calc(100% - 14px);
    justify-content: center;
    margin: 14px 0px 0px 0px;
    padding: 0px 25px 0px 0px;
    width: auto;
    max-width: 100%;
    z-index: 9999;
}
header.sd > .mBtn button {
    align-content: center;
    align-items: center;
    background: #000000;
    border-radius: 50%;
    box-shadow: none;
    display: flex;
    flex: none;
    flex-direction: column;
    flex-wrap: nowrap;
    gap: 7px;
    height: 55px;
    justify-content: center;
    margin: 0px 0px 0px 20px;
    padding: 0px;
    transition-duration: 300ms;
    width: 55px;
    max-width: calc(100% - 20px);
}
header.sd > .mBtn button > span {
    flex: none;
    max-width: 100%;
}

.menu-trigger { position: relative;}
.menu-trigger span {
    display: block;
    transition: all .4s;
}
.menu-trigger span {
    position: absolute;
    left: 0;
    right: 0;
    height: 2px;
    background: #fff;
    width: 30px;
    margin: auto;
}
.menu-trigger.active span { background: #fff; }

.menu-trigger span:nth-of-type(1) { top: 15px;}
.menu-trigger span:nth-of-type(2) { top: 26px;}
.menu-trigger span:nth-of-type(3) { bottom: 15px;}

.menu-trigger.active span:nth-of-type(1) {
    -webkit-transform: translateY(13px) rotate(-45deg);
    transform: translateY(13px) rotate(-45deg);
}
.menu-trigger.active span:nth-of-type(2) { opacity: 0;}
.menu-trigger.active span:nth-of-type(3) {
    -webkit-transform: translateY(-10px) rotate(45deg);
    transform: translateY(-10px) rotate(45deg);
}

header nav {
    display: block;
    top: 0;
    left: 0;
    background: rgba(250,241,230,.65);
    position: fixed;
    width: 100%;
    height: 100vh;
    -webkit-transform: translate3d(-100%,0,0);
    transform: translate3d(-100%,0,0);
    transition: opacity 1s,z-index 1s,-webkit-transform .3s;
    transition: transform .3s,opacity 1s,z-index 1s;
    transition: transform .3s,opacity 1s,z-index 1s,-webkit-transform .3s;
    z-index: 9994;
}
header nav.is_active {
    opacity: 1;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
    transition: opacity .3s,-webkit-transform .3s;
    transition: transform .3s,opacity .3s;
    transition: transform .3s,opacity .3s,-webkit-transform .3s;
}

.navBox {
    display: block;
    margin: 0 0 0;
    -webkit-overflow-scrolling: touch;
    overflow-y: scroll;
    padding: 3rem 2rem 8rem;
    position: absolute;
    top: 0;
    right: 9rem;
    bottom: 0;
    left: 0;
    background: rgba(250,241,230,0.9);
    padding: 12rem 2rem 8rem;
    position: absolute;
    height: 100%;
}
.navBox ul li {
    text-align: center;
    font-size: 1.5rem;
}
.navBox ul li a {
    display: block;
    color: #fff;
    padding: 15px 0;
    letter-spacing: 2px;
}
.navBox ul li a:hover { background: rgba(255,255,255,0.2);}

.navBox ul.contactUl { margin-bottom: 30px; }
.navBox ul.contactUl li { width: 33.3%;}


.gNavi {
    align-content: center;
    align-items: center;
    background: rgba(0,0,0,0.0);
    bottom: auto;
    display: flex;
    flex: none;
    flex-direction: row;
    flex-wrap: nowrap;
    gap: 5px;
    height: auto;
    justify-content: center;
    left: auto;
    margin: 0 0 0 0;
    position: absolute;
    right: 105px;
    top: 19px;
    transition-delay: 1500ms;
    transition-duration: 800ms;
    width: auto;
    z-index: 998;
    max-width: 100%;
}
.gNavi a {
    color: #fff;
    font-size: 18px;
    font-weight: 800;
    height: auto;
    line-height: 1.4;
    padding: 10px;
    text-align: center;
    transition-duration: 600ms;
    width: auto;
    max-width: 100%;
    justify-content: center;
}
.gNavi a:hover { color: #ec632f;}

.navBoxIn01 {
    display: flex;
    margin-bottom: 50px;
    align-content: center;
    align-items: center;
    flex: none;
    flex-direction: row;
    flex-wrap: nowrap;
    gap: 30px;
    justify-content: center;
    padding: 0px;
    width: calc(100% - 0px);
    max-width: calc(100% - 0px);
}
.navBoxIn01 ul {
    align-content: center;
    align-items: center;
    flex: none;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: center;
    padding: 0px 0px;
    width: calc(48% - 0px);
}
.navBoxIn01 ul li a {
    display: flex;
    background: #faf1e6;
    border-radius: 0;
    height: auto;
    margin-bottom: 5px;
    align-content: center;
    align-items: center;
    flex: none;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: space-between;
    padding: 10px 20px;
    width: 100%;
    max-width: 100%;
}
.navBoxIn01 ul li a:hover { opacity: 1;}

.navBoxIn01 ul li a p {
    color: #000000;
    font-size: 38px;
    font-weight: 900;
    height: auto;
    letter-spacing: NaNem;
    line-height: 1.2;
    text-align: left;
    width: auto;
    max-width: 100%;
    justify-content: center;
}
.navBoxIn01 ul li a:hover p {
    color: #4052a2;
    transition-duration: 600ms;
}

.navBoxIn01 ul li a p span {
    display: block;
    font-size: 50%;
}

.navBoxIn01 ul li a > i {
    background: #4052a2;
    border-radius: 50%;
    color: #faf1e6;
    flex: none;
    font-size: 24px;
    height: 36px;
    width: 36px;
    max-width: 100%;
}
.navBoxIn01 ul li a:hover > i {
    transform: translate(10px, 0px);
    transition-duration: 400ms;
}
.navBoxIn01 ul li a > i:before {
    content: "";
    display: inline-block;
    width: 10px;
    height: 10px;
    margin: 0 3px 0 0;
    border-top: 2px solid #fff;
    border-left: 2px solid #fff;
    transform: rotate(135deg);
    -webkit-transform: rotate(135deg);
}

/**************************************

footer

***************************************/
footer {
    align-content: center;
    align-items: center;
    background: #000000;
    display: flex;
    flex: none;
    flex-direction: column;
    flex-wrap: nowrap;
    height: auto;
    justify-content: center;
    padding: 80px 0px 30px;
    width: 100%;
    z-index: 5;
    max-width: 100%;
}
.footerIn {
    align-content: flex-start;
    align-items: flex-start;
    flex: none;
    flex-direction: row;
    flex-wrap: wrap;
    height: auto;
    justify-content: space-between;
    margin: 0px 80px 0px;
    padding: 0px 0px 0px;
    width: 1300px;
    max-width: calc(100% - 160px);
}

.footerInT {
    align-content: flex-start;
    align-items: flex-start;
    flex: none;
    flex-direction: row;
    flex-wrap: nowrap;
    gap: 40px;
    justify-content: space-between;
    margin: 0px 0px 80px 0px;
    padding: 0px;
    width: 100%;
    max-width: 100%;
}
.footerInT > a {
    align-content: flex-start;
    align-items: flex-start;
    background: rgba(0,0,0,0.0);
    flex: 1;
    flex-direction: column;
    flex-wrap: nowrap;
    height: auto;
    justify-content: flex-start;
    padding: 0px;
    width: auto;
    max-width: 100%;
}
.footerInT > a > div {
    align-content: center;
    align-items: center;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: center;
    margin: 0px 0px 10px 0px;
    padding: 0px;
    max-width: 100%;
}
.footerInT > a > div img {
    flex: none;
    height: auto;
    width: 294px;
    max-width: 100%;
}
.footerInT > a > p.text {
    color: #FFFFFF;
    font-size: 12px;
    font-weight: 400;
    height: auto;
    line-height: 2;
    margin: 27px 0px 0px 0px;
    text-align: left;
    width: auto;
    max-width: 100%;
    justify-content: flex-start;
}

.footerInL {
    align-content: center;
    align-items: center;
    flex-direction: row;
    flex-wrap: nowrap;
    gap: 120px;
    justify-content: flex-start;
    padding: 0px;
}
.footerInL > div {
    align-content: flex-start;
    align-items: flex-start;
    background: rgba(0,0,0,0.0);
    display: flex;
    flex: none;
    flex-direction: column;
    flex-wrap: nowrap;
    gap: 5px;
    height: auto;
    justify-content: center;
    margin: 0 0 0 0;
    position: relative;
    width: auto;
    max-width: 100%;
}
.footerInL > div a {
    color: #FFFFFF;
    font-size: 28px;
    font-weight: 800;
    height: auto;
    line-height: 1.4;
    padding: 10px;
    text-align: center;
    width: auto;
    max-width: 100%;
    justify-content: center;
}
.footerInL > div a:hover {
    color: #ec632f;
    transition-duration: 600ms;
}

.footerInU {
    align-content: center;
    align-items: center;
    border-bottom: 0px solid #6a6a6a;
    border-left: 0px solid #6a6a6a;
    border-right: 0px solid #6a6a6a;
    border-top: 2px solid #6a6a6a;
    flex: none;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: space-between;
    margin: 0px 0px 0px 0px;
    padding: 10px 0px 0px 0px;
    width: 100%;
    max-width: 100%;
}

.footerInUicon {
    align-content: center;
    align-items: center;
    flex-direction: row;
    flex-wrap: nowrap;
    gap: 6px;
    justify-content: flex-start;
    padding: 0px;
}
.footerInUicon > a {
    align-content: center;
    align-items: center;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: center;
    margin: 0px 0px 0px 0px;
    padding: 10px;
    max-width: 100%;
}
.footerInUicon a.fa-twitter {
    color: #FFFFFF;
    font-size: 24px;
    margin: 0px;
    padding: 10px;
    max-width: 100%;
}
.footerInUicon a.fa-instagram {
    color: #FFFFFF;
    font-size: 24px;
    margin: 0px 0px 0px 0px;
    padding: 10px;
    max-width: 100%;
}
.footerInUicon > a:hover { color: #eb612a;}

.footerInUcopy {
    align-content: center;
    align-items: center;
    background: rgba(0,0,0,0.0);
    flex: none;
    flex-direction: row;
    flex-wrap: nowrap;
    height: auto;
    justify-content: center;
    margin: 0px 0px 0px 0px;
    width: auto;
    max-width: 100%;
}
.footerInUcopy > p {
    color: #FFFFFF;
    font-size: 14px;
    font-weight: 400;
    height: auto;
    line-height: 1.4;
    text-align: left;
    width: auto;
    max-width: 100%;
    justify-content: flex-start;
}

/**************************************

common

***************************************/
.border {
  position: relative;
  z-index: 1;
}
.border:before {
  content: '';
  background: #ffff00;
  left: 0;
  right: 0;
  top: 40%;
  bottom: 20%;
  position: absolute;
  z-index: -1;
}

.secEN {
    align-content: center;
    align-items: center;
    background: rgba(0,0,0,0.0);
    flex: none;
    flex-direction: column;
    flex-wrap: nowrap;
    height: auto;
    justify-content: center;
    padding: 60px 30px;
    width: calc(100% - 0px);
    max-width: 100%;
}
.secEN .secIn {
    padding: 60px 0;
    width: calc(100% - 30px);
    height: auto;
    flex-direction: column;
    flex-wrap: nowrap;
    align-content: center;
    align-items: center;
    justify-content: center;
    max-width: 100%;
}
.secEN .secIn .secIner {
    align-content: flex-start;
    align-items: flex-start;
    background: #4052a2;
    border-radius: 15px;
    flex: none;
    flex-direction: column;
    flex-wrap: nowrap;
    gap: 0px;
    height: auto;
    justify-content: center;
    margin: 0px 0px 0px 0px;
    padding: 70px 70px;
    width: calc(100% - 50px);
}

.secEN .secIn .secIner dl {
    align-content: flex-start;
    align-items: flex-start;
    flex-direction: row;
    flex-wrap: nowrap;
    gap: 120px;
    height: auto;
    justify-content: space-between;
    padding: 0px;
    max-width: 100%;
}
.secEN .secIn .secIner dl dt {
    align-content: center;
    align-items: center;
    flex-direction: row;
    flex-wrap: nowrap;
    gap: 30px;
    justify-content: center;
    margin: 0px 0px 0px 0px;
    padding: 0px;
    max-width: 100%;
}
.secEN .secIn .secIner dl dt img {
    flex: none;
    height: auto;
    width: 150px;
    max-width: 100%;
}
.secEN .secIn .secIner dl dt > div {
    align-content: start;
    align-items: start;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: start;
    padding: 0px;
}
.secEN .secIn .secIner dl dt > div > p {
    color: #faf1e6;
    font-size: 68px;
    font-weight: 900;
    height: auto;
    line-height: 1;
    margin: 0px 0px 0px 0px;
    text-align: left;
    width: auto;
    max-width: 100%;
    justify-content: flex-start;
}
.secEN .secIn .secIner dl dt > div > p:last-child { line-height:0.75; font-size: 48px;}
.secEN .secIn .secIner dl dt > div > p.text > span.small {
    display: contents;
    font-size: 75%;
}

.secEN .secIn .secIner dl dd {
    align-content: flex-start;
    align-items: flex-start;
    flex: 1;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: center;
    padding: 0px;
    width: auto;
    max-width: 100%;
}
.secEN .secIn .secIner dl dd > p {
    color: #faf1e6;
    font-size: 44px;
    font-weight: 900;
    height: auto;
    line-height: 1.2;
    margin: 0px 0px 20px 0px;
    text-align: left;
    width: auto;
    max-width: 100%;
    justify-content: flex-start;
}
.secEN .secIn .secIner dl dd > p:last-child {
    color: #faf1e6;
    flex: none;
    font-size: 16px;
    font-weight: 400;
    height: auto;
    line-height: 1.6;
    margin: 0px 0px 0px 0px;
    padding: 0px 0px 0px 0px;
    text-align: left;
    width: auto;
    max-width: 100%;
    justify-content: flex-start;
}


.secEN .secIn .secIner > .entryBdL {
    background: #faf1e6;
    flex: none;
    height: 8px;
    margin: 50px 0px;
    width: calc(100% - 0px);
    max-width: calc(100% - 0px);
}

div.entryBtn {
    align-content: center;
    align-items: center;
    flex: none;
    flex-direction: row;
    flex-wrap: nowrap;
    gap: 30px;
    justify-content: space-between;
    padding: 0px;
    width: calc(95% - 0px);
    max-width: calc(95% - 0px);
    margin: 0 auto;
}
div.entryBtn > a {
    align-content: center;
    align-items: center;
    background: #faf1e6;
    border-radius: 15px;
    flex: none;
    flex-direction: row;
    flex-wrap: nowrap;
    height: 100px;
    justify-content: center;
    padding: 0px 20px;
    width: calc(33% - 50px * 0.5);
    max-width: calc(33% - 50px * 0.67);
}
div.entryBtn > a:hover { opacity: 1;}
div.entryBtn > a > div {
    align-content: center;
    align-items: center;
    flex: none;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: space-between;
    padding: 0px 0px 0px 0px;
    width: 100%;
    max-width: 100%;
}
div.entryBtn > a > div > div {
    align-content: center;
    align-items: center;
    flex-direction: row;
    flex-wrap: nowrap;
    gap: 9px;
    justify-content: center;
    padding: 0px;
}
div.entryBtn > a > div > div > p {
    color: #4052a2;
    font-size: 32px;
    font-weight: 900;
    height: auto;
    letter-spacing: -0.03em;
    line-height: 1.4;
    text-align: center;
    width: auto;
    max-width: 100%;
    justify-content: center;
}
div.entryBtn > a > div > i {
    background: #4052a2;
    border-radius: 50%;
    color: #faf1e6;
    flex: none;
    font-size: 28px;
    height: 36px;
    width: 36px;
    max-width: 100%;
}
div.entryBtn > a:hover > div > i {
    transform: translate(10px, 0px);
    transition-duration: 400ms;
}
div.entryBtn > a > div > i:before {
    content: "";
    display: inline-block;
    width: 10px;
    height: 10px;
    margin: 0 3px 0 0;
    border-top: 2px solid #fff;
    border-left: 2px solid #fff;
    transform: rotate(135deg);
    -webkit-transform: rotate(135deg);
}

.image { position: relative;}
.image:before {
    background-position: 50%;
    background-size: cover;
    border-radius: inherit;
    content: "";
    height: 100%;
    left: 0;
    pointer-events: none;
    position: absolute;
    top: 0;
    transition: inherit;
    width: 100%;
    z-index: -2;
}

.navBoxIn02 div.entryBtn > a { background: #4052a2;}
.navBoxIn02 div.entryBtn > a > div > div > p { color: #faf1e6;}
.navBoxIn02 div.entryBtn > a > div > i { background: #faf1e6;}
.navBoxIn02 div.entryBtn > a > div > i:before {
    border-top: 2px solid #4052a2;
    border-left: 2px solid #4052a2;
}


/**************************************

Toppage

***************************************/

#mainImg {
    align-content: center;
    align-items: center;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: center;
    width: 100%;
    max-width: 100%;
    display: flex;
    height: auto;
    min-height: 100vh;
    position: relative;
}
#mainImg h2 {
    color: #fff;
    font-size: 100px;
    font-style: italic;
    font-weight: 900;
    height: auto;
    line-height: 1.0;
    letter-spacing: 2px;
    text-align: center;
    text-shadow: 0 0 10px BLACK;
    width: 100%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(0%) translateX(-50%);
    -webkit- transform: translateY(-50%) translateX(0%);
    margin: 0 auto;
}
#mainImg:before {
    content: "";
    background: url(../img/mainImg.png) 0 0 no-repeat;
    background-size: cover;
    width: 100%;
    height: 100vh;
    display: block;
    z-index: -1;
}

.srl {
    align-content: center;
    align-items: center;
    bottom: 20px;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: center;
    left: 0px;
    margin: 0 0 0 0;
    padding: 0px;
    position: absolute;
    right: 0px;
    top: auto;
    width: auto;
    max-width: 100%;
}

.srl > .text.sd {
    color: #FFFFFF;
    font-size: 18px;
    font-weight: 900;
    height: auto;
    line-height: 1.4;
    text-align: center;
    width: auto;
    max-width: 100%;
    justify-content: center;
}
.srl > .icon.sd {
    color: #FFFFFF;
    flex: none;
    font-size: 22px;
    height: 20px;
    width: 20px;
    max-width: 100%;
  display: inline-block;
  vertical-align: middle;
  line-height: 1;
  border: 0.15em solid currentColor;
  border-left: 0;
  border-bottom: 0;
  box-sizing: border-box;
  transform: translateY(-25%) rotate(135deg);
}

#topSec01,#topSec05 {
    align-content: flex-start;
    align-items: flex-start;
    background: #4052a2;
    flex: none;
    flex-direction: column;
    flex-wrap: nowrap;
    height: auto;
    justify-content: space-between;
    padding: 80px 0px 90px 120px;
    width: 100%;
    max-width: 100%;
}
.topMesg,.topCarp {
    align-content: flex-start;
    align-items: flex-start;
    flex: none;
    flex-direction: row;
    flex-wrap: nowrap;
    gap: 20px;
    height: auto;
    justify-content: center;
    margin: 0px 0px 0px 0px;
    padding: 0px;
    width: 100%;
    max-width: 100%;
}
.topMesgDl,.topCarpDl {
    align-content: flex-start;
    align-items: flex-start;
    flex: 1;
    flex-direction: column;
    flex-wrap: nowrap;
    gap: 40px;
    justify-content: center;
    margin: 0px 0px;
    padding: 0px;
    width: auto;
    max-width: 100%;
}
.topMesgDl dt,.topCarpDl dt {
    align-content: center;
    align-items: center;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: center;
    margin: 0px 0px 0px 0px;
    padding: 0px;
    transition-delay: 1000ms;
    transition-duration: 0ms;
    max-width: 100%;
}
.topMesgDl dt h3,.topCarpDl dt h3 {
    color: #faf1e6;
    font-size: 54px;
    font-style: italic;
    font-weight: 900;
    height: auto;
    line-height: 1.1;
    letter-spacing: 2px;
    margin: 0px 0px 0px 3px;
    text-align: left;
    width: auto;
    max-width: calc(100% - 3px);
    justify-content: flex-start;
}
.topMesgDl dd,.topCarpDl dd {
    align-content: flex-end;
    align-items: flex-end;
    flex-direction: column;
    flex-wrap: nowrap;
    gap: 0px;
    justify-content: center;
    padding: 0px;
    transition-delay: 200ms;
    transition-duration: 800ms;
    transition-timing-function: ease-in-out;
}
.topMesgDl dd p,.topCarpDl dd p {
    color: #faf1e6;
    flex: none;
    font-size: 25px;
    font-style: normal;
    font-weight: 900;
    height: auto;
    letter-spacing: -0.04em;
    line-height: 1.6;
    margin: 0px 0px 0px 0px;
    padding: 0px 0px 0px 0px;
    text-align: left;
    transition-delay: 1000ms;
    transition-duration: 0ms;
    width: auto;
    max-width: 100%;
    justify-content: flex-start;
}

.topMesgImg,.topCarpImg {
    align-content: center;
    align-items: center;
    border-radius: 10px 0px 0px 10px;
    box-shadow: none;
    flex: none;
    flex-direction: row-reverse;
    flex-wrap: nowrap;
    height: 700px;
    justify-content: center;
    margin: 0px 0px 0px 0px;
    overflow-x: hidden;
    overflow-y: hidden;
    padding: 0px;
    width: calc(52% - 0px);
    max-width: calc(52% - 0px);
    background: #fff;
}

.topMesgImg.sd > .image {
    width: 100%;
    height: 100%;
}
.topMesgImg.sd > .image:before {
    content: "";
    background: url(../img/topImg01.png) center center no-repeat;
    background-size: cover;
}

#topSec02,#topSec03,
#topSec04,#topSec06 { background: #faf1e6; }

.topAbout,.topCult,.topStaff,.topCalng {
    padding: 120px 0px 120px 0px;
    width: 100%;
    height: auto;
    flex-direction: column;
    flex-wrap: nowrap;
    align-content: center;
    align-items: center;
    justify-content: space-between;
    max-width: 100%;
}
dl.topAboutDl,dl.topStaffDl,
dl.topCalngDl {
    align-content: flex-start;
    align-items: flex-start;
    flex: none;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: center;
    margin: 0px 0px 72px 0px;
    padding: 0px 40px 0px 120px;
    width: 100%;
    max-width: 100%;
}
dl.topAboutDl dt,dl.topStaffDl dt,
dl.topCalngDl dt {
    align-content: flex-start;
    align-items: flex-start;
    flex: none;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: center;
    margin: 0px 0px 30px 0px;
    padding: 0px 0px 0px 0px;
    width: auto;
    max-width: 100%;
}
dl.topAboutDl dt h3,dl.topCultDl dt h3,
dl.topStaffDl dt h3,dl.topCalngDl dt h3 {
    color: #4052a2;
    font-size: 60px;
    font-weight: 900;
    font-style: italic;
    height: auto;
    line-height: 1;
    margin: 0px 0px 25px;
    text-align: left;
    transition-delay: 1000ms;
    transition-duration: 0ms;
    width: auto;
    max-width: 100%;
    justify-content: flex-start;
}
dl.topAboutDl dt .richText,dl.topCultDl dt .richText,
dl.topStaffDl dt .richText,dl.topCarpDl dt .richText,
dl.topCalngDl dt .richText {
    color: #000000;
    flex: none;
    font-size: 88px;
    font-weight: 900;
    font-style: italic;
    height: auto;
    letter-spacing: 0;
    padding: 0px 0px 0px;
    text-align: left;
    transition-delay: 1000ms;
    transition-duration: 0ms;
    width: calc(100% - 0px);
    max-width: 100%;
}

.richText p {
    display: block;
    margin: 10px 0;
}
.richText > p {
    margin: 0px 0px 0px 0px;
    line-height: 1.0;
    width: 100%;
}

dl.topAboutDl dt .richText > p,
dl.topCultDl dt .richText > p,
dl.topStaffDl dt .richText > p,
dl.topCarpDl dt .richText > p,
dl.topCalngDl dt .richText > p {
    margin: 0px 0px 0px 0px;
    line-height: 1.0;
    width: 100%;
    font-style: italic;
}
dl.topAboutDl dt .richText > p > .strong,
dl.topCultDl dt .richText > p > .strong,
dl.topStaffDl dt .richText > p > .strong,
dl.topCalngDl dt .richText > p > .strong  { color: #4052a2;}

dl.topAboutDl dd.topAboutDd,
dl.topCultDl dd.topCultDd,
dl.topCalngDl dd.topCultDd {
    align-content: flex-start;
    align-items: flex-start;
    flex: none;
    flex-direction: row;
    flex-wrap: nowrap;
    gap: 80px;
    justify-content: space-between;
    margin: 35px 0px 0px 0px;
    padding: 0px;
    width: 90%;
    max-width: 90%;
}
dl.topAboutDl dd.topAboutDd p,
dl.topCultDl dd.topCultDd p,
dl.topCalngDl dd.topCalngDd p {
    align-content: center;
    align-items: center;
    flex: 1;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: center;
    margin: 0px 0px 0px 0px;
    opacity: 1;
    padding: 0px;
    transform: translate(0px, 0px);
    transition-delay: 200ms;
    transition-duration: 800ms;
    transition-timing-function: ease-in-out;
    width: auto;
    max-width: 100%;
    color: #000000;
    font-size: 20px;
    font-weight: 400;
    height: auto;
    line-height: 2;
    text-align: left;
    width: auto;
    max-width: 100%;
    justify-content: flex-start;
}
dl.topAboutDl dd.topAboutDd a.link,
dl.topCultDl dd.topCultDd a.link,
dl.topStaffDl dd.topStaffDd a.link,
dl.topCarpDl dd.topCarpDd a.link,
dl.topCalngDl dd.topCalngDd a.link {
    align-content: center;
    align-items: center;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: center;
    padding: 0px;
    transition-delay: 200ms;
    transition-duration: 800ms;
}
dl.topAboutDl dd.topAboutDd a.link > div,
dl.topCultDl dd.topCultDd a.link > div,
dl.topStaffDl dd.topStaffDd a.link > div,
dl.topCarpDl dd.topCarpDd a.link > div,
dl.topCalngDl dd.topCalngDd a.link > div {
    align-content: center;
    align-items: center;
    background: #000000;
    border-radius: 40px;
    flex: none;
    flex-direction: row;
    flex-wrap: nowrap;
    height: 80px;
    justify-content: center;
    width: 300px;
    max-width: 100%;
}
dl.topAboutDl dd.topAboutDd a.link > div > div,
dl.topCultDl dd.topCultDd a.link > div > div,
dl.topStaffDl dd.topStaffDd a.link > div > div,
dl.topCarpDl dd.topCarpDd a.link > div > div,
dl.topCalngDl dd.topCalngDd a.link > div > div {
    align-content: center;
    align-items: center;
    flex: none;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: space-between;
    padding: 0px 30px 0px 30px;
    width: 100%;
    max-width: 100%;
}
dl.topAboutDl dd.topAboutDd a.link > div > div > p,
dl.topCultDl dd.topCultDd a.link > div > div > p,
dl.topStaffDl dd.topStaffDd a.link > div > div > p,
dl.topCarpDl dd.topCarpDd a.link > div > div > p,
dl.topCalngDl dd.topCalngDd a.link > div > div > p {
    color: #FFFFFF;
    font-size: 24px;
    font-weight: 900;
    height: auto;
    line-height: 1.4;
    text-align: center;
    width: auto;
    max-width: 100%;
    justify-content: center;
}
dl.topAboutDl dd.topAboutDd a.link > div > div > i,
dl.topCultDl dd.topCultDd a.link > div > div > i,
dl.topStaffDl dd.topStaffDd a.link > div > div > i,
dl.topCarpDl dd.topCarpDd a.link > div > div > i,
dl.topCalngDl dd.topCalngDd a.link > div > div > i {
    background: #FFFFFF;
    border-radius: 50%;
    color: #000000;
    flex: none;
    font-size: 28px;
    height: 36px;
    width: 36px;
    max-width: 100%;
}
dl.topAboutDl dd.topAboutDd a.link > div:hover,
dl.topCultDl dd.topCultDd a.link > div:hover,
dl.topStaffDl dd.topStaffDd a.link > div:hover,
dl.topCarpDl dd.topCarpDd a.link > div:hover,
dl.topCalngDl dd.topCalngDd a.link > div:hover {
    opacity: 1;
    transform: ;
}
dl.topAboutDl dd.topAboutDd a.link > div:hover > div > i,
dl.topCultDl dd.topCultDd a.link > div:hover > div > i,
dl.topStaffDl dd.topStaffDd a.link > div:hover > div > i,
dl.topCarpDl dd.topCarpDd a.link > div:hover > div > i,
dl.topCalngDl dd.topCalngDd a.link > div:hover > div > i {
    transform: translate(10px, 0px);
    transition-duration: 400ms;
}
dl.topAboutDl dd.topAboutDd a.link > div > div > i:before,
dl.topCultDl dd.topCultDd a.link > div > div > i:before,
dl.topStaffDl dd.topStaffDd a.link > div > div > i:before,
dl.topCarpDl dd.topCarpDd a.link > div > div > i:before,
dl.topCalngDl dd.topCalngDd a.link > div > div > i:before {
    content: "";
    display: inline-block;
    width: 10px;
    height: 10px;
    margin: 0 3px 0 0;
    border-top: 2px solid #000;
    border-left: 2px solid #000;
    transform: rotate(135deg);
    -webkit-transform: rotate(135deg);
}

.topCult {
    padding: 120px 40px 120px 120px;
    width: calc(100% - 0px);
    height: auto;
    flex-direction: row;
    flex-wrap: nowrap;
    align-content: flex-start;
    align-items: flex-start;
    justify-content: space-between;
    gap: 50px;
    max-width: calc(100% - 0px);
}
dl.topCultDl {
    align-content: flex-start;
    align-items: flex-start;
    flex: 1;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: center;
    margin: 0px 0px 0px 0px;
    padding: 0px 0px 0px 0px;
    width: calc(60% - 0px);
    z-index: 1;
    max-width: 100%;
}
dl.topCultDl dt {
    align-content: flex-start;
    align-items: flex-start;
    flex: none;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: center;
    margin: 0px 0px 30px 0px;
    padding: 0px 0px 0px 0px;
    width: auto;
    max-width: 100%;
}
dl.topCultDl dd,dl.topCultDl dd > p,dl.topCultDl dd > a,
dl.topCarpDl dd > a { display:block; }

dl.topCultDl dd.topCultDd { margin-top: 10px;}
dl.topCultDl dd.topCultDd a.link,
dl.topCarpDl dd.topCarpDd a.link { margin-top: 60px;}

.topCultImg {
    align-content: center;
    align-items: center;
    border-radius: 30px;
    box-shadow: none;
    flex: none;
    flex-direction: row-reverse;
    flex-wrap: nowrap;
    height: 700px;
    justify-content: center;
    margin: 0px 0px 0px 0px;
    overflow-x: hidden;
    overflow-y: hidden;
    padding: 0px;
    width: calc(38% - 0px);
    max-width: calc(45% - 0px);
    background: #fff;
}
.topCultImgIn {
    flex: none;
    height: 100%;
    margin: 0px 0px 0px 0px;
    transition-delay: 300ms;
    transition-duration: 3000ms;
    transition-timing-function: ease-in-out;
    width: 100%;
    max-width: 100%;
}
.topCultImgIn:before {
    background: url(../img/topImg02.png) center center no-repeat;
    background-size: cover;
}

dl.topStaffDl dd.topStaffDd p {
    margin: 0px 0px 0px 0px;
    opacity: 1;
    padding: 0px;
    transform: translate(0px, 0px);
    transition-delay: 200ms;
    transition-duration: 800ms;
    transition-timing-function: ease-in-out;
    width: auto;
    max-width: 100%;
    color: #000000;
    font-size: 20px;
    font-weight: 400;
    height: auto;
    line-height: 2;
    text-align: left;
    width: auto;
    max-width: 100%;
}

.topCarpDl {
    width: calc(50% - 0px);
    max-width: calc(50% - 0px);
}
.topCarpDl dt {
    display: block;
    width: 100%;
    text-align: left;
}
.topCarpDl dt h3.text.sd.appear {
    display: block;
    margin-bottom: 30px;
}

l.topCarpDl dt .richText {
    width: auto;
    display: block;
}
dl.topCarpDl dt .richText > p.subTitle {
    background: #faf1e6;
    color: #4052a2;
    font-size: 28px;
    font-weight: 900;
    height: auto;
    width: fit-content;
    padding: 5px 10px;
    margin: 0;
}
dl.topCarpDl dt .richText > p > .strong {
    color: #fff;
    font-size: 78px;
}
dl.topCarpDl dt .richText,.topCarpDl dd { display: block;}

.topCarpDl dd {
    width: calc(85% - 0px);
    max-width: calc(85% - 0px);
}
.topCarpImg {
    height: 550px;
    width: calc(45% - 0px);
    max-width: calc(45% - 0px);
    border-radius: 30px;
}
.topCarpImg > .image { width:100%; height:100%; }
.topCarpImg > .image:before {
    background: url(../img/topImg03.png) center center no-repeat;
    background-size: cover;
}

.topCalng { padding-bottom: 0;}

dd.topCalngDd.sd.appear.flexBlock {
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-flex-direction: row;
    -ms-flex-direction: row;
    flex-direction: row;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-align-items: stretch;
    -ms-flex-align: stretch;
    -webkit-align-content: flex-start;
    -ms-flex-line-pack: start;
    align-content: flex-start;
    align-items: stretch;
}
dl.topCalngDl dd.topCalngDd p {
    width: calc(100% - 0px);
    max-width: calc(100% - 0px);
}
dl.topCalngDl dd.topCalngDd a.link {
    width: calc(30% - 0px);
    max-width: calc(30% - 0px);
}

.blogBlock {
    padding: 50px 0 0;
    margin-bottom: 40px;
}

ul.blogList li {
    width: calc(25% - 20px);
}

.newsImg {
    overflow: hidden;
    max-width: 395px;
    max-height: 280px;
    margin-bottom: 8px;
}
span.cate {
    display: inline-block;
    background: #eb612a;
    line-height: 1.0;
    padding: 0.5rem 1rem;
    border-radius: 15px;
    color: #fff;
}
dl.topCalngDl dd.topCalngDd ul li p.ttl {
    font-size: 95%;
    line-height: 1.5;
    letter-spacing: 0.3px;
}


/**************************************

Underpage

***************************************/

/******
 ABOUT
******/
#about section#underSec01 {
    background: #4052a2;
    padding: 8% 0 0;
    margin-bottom: 100px;
}
#about section#underSec01 h2 {
    color: #fff;
    font-size: 700%;
    letter-spacing: 2px;
    line-height: 1.0;
}

p.logoTxt {
    text-align: center;
    font-size: 42px;
    font-weight: 700;
    font-style: italic;
    color: #fff;
    margin-bottom: 20px;
}
p.logoTxt span {
    display: block;
    font-style: italic;
}

p.abTxtW {
    color: #fff;
    font-weight: 700;
    font-size: 140%;
    text-align: center;
    letter-spacing: 1px;
    margin-bottom: 100px;
}

section#underSec02 > div,
section#underSec03 > div,
section#underSec04 > div,
section#underSec05 > div {
    width: calc(85% - 0px);
    margin: 0 auto;
}

p.subTtl {
    font-size: 35px;
    font-weight: 700;
    letter-spacing: 1px;
    line-height: 1.25;
    text-align: left;
    position: relative;
    display: inline-block;
    height: 60px;
    margin: 0 0 20px 30px;
    padding: 1rem 2rem 1rem 3rem;
    color: #fff;
    background: #fa4141;
}
p.subTtl:before {
    position: absolute;
    top: 0;
    left: -30px;
    content: '';
    border-width: 30px 30px 30px 0;
    border-style: solid;
    border-color: transparent #fa4141 transparent transparent;
}
p.subTtl:after {
    position: absolute;
    top: calc(50% - 7px);
    left: -10px;
    width: 14px;
    height: 14px;
    content: '';
    border-radius: 50%;
    background: #fff;
}

h3.uNrchiTxt {
    color: #000000;
    font-size: 80px;
    font-weight: 700;
    font-style: italic;
    padding: 0px 0px 0px;
    text-align: left;
    line-height: 1.1;
    letter-spacing: 1px;
    margin-bottom: 30px;
}
h3.uNrchiTxt span {color: #4052a2;}

p.pageTxt,p.dDtxt {
    font-size: 18px;
    letter-spacing: 1px;
}

p.subDTtl {
    position: relative;
    padding: 1rem 1rem 0;
    width: fit-content;
    font-size: 24px;
}
p.subDTtl:before {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 8px;
    content: '';
    background-image: -webkit-repeating-linear-gradient(135deg, #4052a2, #4052a2 1px, transparent 2px, transparent 5px);
    background-image: repeating-linear-gradient(-45deg, #4052a2, #4052a2 1px, transparent 2px, transparent 5px);
    background-size: 7px 7px;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
}
p.subDTtl span {
    font-size: 130%;
    color: #4052a2;
    text-indent: 0.25em;
    display: inline-block;
    letter-spacing: 0px;
}

dl.waysDl dd h4 {
    font-size: 35px;
    line-height: 1.2;
    margin-bottom: 20px;
}
dl.waysDl dd h4 span {
    font-size: 110%;
    color: #4052a2;
}

dl.waysDl { margin-bottom:60px; }
.ways dl.waysDl:last-child { margin-bottom:0px; }
dl.waysDl dt { width: calc(40% - 0px);}
dl.waysDl dd { width: calc(60% - 50px);}

dl.waysDl dt .image {
    align-content: center;
    align-items: center;
    border-radius: 20px;
    box-shadow: none;
    flex: none;
    flex-direction: row-reverse;
    flex-wrap: nowrap;
    height: 360px;
    justify-content: center;
    margin: 0px 0px 0px 0px;
    overflow-x: hidden;
    overflow-y: hidden;
    padding: 0px;
    width: calc(100% - 0px);
}
dl.waysDl.wyDl01 dt .image:before {
    background: url(../img/aboutImg01.png) center center no-repeat;
    background-size: cover; 
}
dl.waysDl.wyDl02 dt .image:before {
    background: url(../img/aboutImg02.png) center center no-repeat;
    background-size: cover; 
}
dl.waysDl.wyDl03 dt .image:before {
    background: url(../img/aboutImg03.png) center center no-repeat;
    background-size: cover; 
}
dl.waysDl.wyDl04 dt .image:before {
    background: url(../img/aboutImg04.png) center center no-repeat;
    background-size: cover; 
}
dl.waysDl.wyDl05 dt .image:before {
    background: url(../img/aboutImg05.png) center center no-repeat;
    background-size: cover; 
}
dl.waysDl.wyDl06 dt .image:before {
    background: url(../img/aboutImg06.png) center center no-repeat;
    background-size: cover; 
}
dl.waysDl.wyDl07 dt .image:before {
    background: url(../img/aboutImg09.png) center center no-repeat;
    background-size: cover; 
}
dl.waysDl.wyDl08 dt .image:before {
    background: url(../img/aboutImg08.png) center center no-repeat;
    background-size: cover; 
}


/******
 CULTURE
******/
#culture,#workstyle,#flow,#career,#blog,#blogSgl { background: #d9ffe9;}

#culture section#underSec01,
#workstyle section#underSec01,
#flow section#underSec01,
#career section#underSec01,
#blog section#underSec01,
#blogSgl section#underSec01 {
    padding: 10% 0 0;
    margin-bottom: 100px;
}
#culture section#underSec01 > div,
#workstyle section#underSec01 > div,
#career section#underSec01 > div,
#blog section#underSec01 > div,
#blogSgl section#underSec01 > div {
    width: calc(85% - 0px);
    margin: 0 auto;
}
#culture #underSec01 p.pageTxt,
#workstyle #underSec01 p.pageTxt {
    font-weight: 700;
    font-size: 140%;
    text-align: center;
    letter-spacing: 1px;
    margin-bottom: 100px;
}

h2.unH2 {
    color: #000000;
    flex: none;
    font-size: 80px;
    font-weight: 700;
    letter-spacing: 1px;
    padding: 0px 0px 0px;
    text-align: left;
    line-height: 1.2;
    margin-bottom: 30px;
}
h2.unH2 span { color: #4052a2;}

p.pageSTtl {
    text-align: center;
    font-size: 50px;
    font-weight: 700;
    font-style: italic;
    color: #4052BC;
    margin-bottom: 20px;
    position: relative;
}
p.pageSTtl:before {
    position: absolute;
    bottom: 10px;
    left: 0;
    right: 0;
    width: 45%;
    height: 8px;
    content: '';
    background: #8ca1ca;
    margin: 0 auto;
}

.cultListIn h3.uNrchiTxt {
    font-size: 50px;
    position: relative;
    padding: 1rem 1.5rem;
    border-bottom: 8px solid #4052BC;
}
.cultListIn h3.uNrchiTxt:before {
    position: absolute;
    bottom: -8px;
    left: 0;
    width: 18%;
    height: 8px;
    content: '';
    background: #8ca1ca;
}
.cultListIn dl.waysDl dt .image { height:380px }
.cultListIn dl.waysDl dt .image:before { z-index:0; }

.cultListIn dl.waysDl.wD01 .image:before {
    background: url(../img/cultureImg01.png) center center no-repeat;
    background-size: cover; 
}
.cultListIn dl.waysDl.wD02 .image:before {
    background: url(../img/cultureImg02.png) center center no-repeat;
    background-size: cover; 
}
.cultListIn dl.waysDl.wD03 .image:before {
    background: url(../img/cultureImg03.png) center center no-repeat;
    background-size: cover; 
}
.cultListIn dl.waysDl.wD04 .image:before {
    background: url(../img/cultureImg04.png) center center no-repeat;
    background-size: cover; 
}
.cultListIn dl.waysDl.wD05 .image:before {
    background: url(../img/cultureImg05.png) center center no-repeat;
    background-size: cover; 
}

.nxtPage {
    position: relative;
    width: calc(60% - 0px);
    padding: 10% 0;
    display: block;
    margin: 0 auto;
}
.nxtPage a { display: block;}
.nxtPage a:hover { opacity: 1;}
.nxtPageIn {
    position: relative;
    width: 100%;
    height: 100%;
    padding: 10% 0;
    border-radius: 20px;
    display: block;
    overflow: hidden;
}
.nxtPageIn:before {
    background: url(../img/topImg03.png) center center no-repeat;
    background-size: cover; 
}
.nxtPage a:hover .nxtPageIn:before {
  transform: scale(1.05, 1.05);
  transition-duration: 600ms;
}

p.btnSttl {
    color: #fff;
    background: #000000;
    margin: 0px 0px 15px 0px;
    padding: 5px 10px;
    width: fit-content;
    font-size: 36px;
    font-weight: 700;
    font-style: italic;
    letter-spacing: 1px;
}

p.btnTtl {
    color: #000000;
    flex: none;
    font-size: 65px;
    font-weight: 700;
    letter-spacing: 1px;
    padding: 15px 15px 10px;
    text-align: left;
    line-height: 1.1;
    background: #fff;
    width: fit-content;
}
p.btnTtl span { color: #4052a2;}

p.linkBtn {
    position: absolute;
    right: 0;
    bottom: 0;
    background: #FFFFFF;
    border-radius: 15px 0px 15px 0px;
    width: 200px;
    max-width: 100%;
    font-size: 22px;
    font-weight: 700;
    padding: 0 20px;
    line-height: 2.5;
}
p.linkBtn i {
    background: #4052a2;
    border-radius: 50%;
    color: #fff;
    display: block;
    font-size: 28px;
    height: 34px;
    width: 34px;
    max-width: 100%;
    transform: translateY(30%) translateX(0%);
    -webkit- transform: translateY(30%) translateX(0%);
}
p.linkBtn i:before {
    content: "";
    width: 10px;
    height: 10px;
    border-top: 2px solid #fff;
    border-left: 2px solid #fff;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-70%) rotate(135deg);
    -webkit- transform: translateY(-50%) translateX(-70%) rotate(135deg);
    margin: auto;
}


/******
 WORKSTYLE
******/
.wlbBox {
    background: #fff;
    padding: 3% 5%;
}

dl.wlbDl {
    display: block;
    width: calc(33% - 30px);
}
dl.wlbDl dt {
    margin-bottom: 10px;
}
dl.wlbDl dd h4 {
    font-size: 22px;
    border-bottom: 1px solid #ccc;
    margin-bottom: 10px;
}
dl.wlbDl dd p {
    font-size: 18px;
}

.wlbBox dl dt {
    background: #4052BC;
    position: relative;
    height: 200px;
    width: 100%;
}
.wlB01 dl dt img,.wlB02 dl dt img {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    -webkit- transform: translateY(-50%) translateX(-50%);
    margin: auto;
    text-align: center;
    width: 40%;
    height: auto;
}
.wlB03 dl dt p.img {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    -webkit- transform: translateY(-50%) translateX(-50%);
    margin: auto;
    text-align: center;
}
.wlB03 dl dt p img {
    width: 50%;
    height: auto;
}
.wlB03 dl dt p span {
    display: block;
    color: #fff;
    font-size: 15px;
    font-weight: 700;
    line-height: 1.0;
    margin-top: 10px;
}


/******
 FLOW
******/
#flow section#underSec01 > div {
    width: calc(85% - 0px);
    margin: 0 auto;
}

#flow h3 {
    border-bottom: 8px solid #4052a2;
    margin: 0px 0px 30px;
    padding: 0px;
    line-height: 1.0;
    color: #4052a2;
    font-size: 80px;
}

.flowBox > div > div { width: calc(50% - 30px);}

.flowList ul li {
    background: #4052BC;
    border-radius: 10px;
    padding: 15px 24px;
    color: #fff;
    font-size: 20px;
    font-weight: 700;
    letter-spacing: 1px;
    line-height: 1.2;
    position: relative;
    margin-bottom: 25px;
}
.flowList ul li:after {
    content: "";
    display: inline-block;
    vertical-align: middle;
    color: #4052BC;
    line-height: 1;
    width: 0;
    height: 0;
    border-style: solid;
    border-color: transparent;
    border-width: 0.9em 3em;
    border-top-color: currentColor;
    border-bottom: 0;
    position: absolute;
    bottom: -40%;
    left: 50%;
    transform: translateY(0%) translateX(-50%);
    -webkit- transform: translateY(0%) translateX(-50%);
    margin: auto;
}
.flowList ul li:last-child { margin-bottom: 0;}
.flowList ul li:last-child:after { display: none;}

.flowBoxIn h4 {
    color: #4052BC;
    font-size: 35px;
    border-bottom: 1px solid #ddd;
    margin-bottom: 15px;
}
.flowBoxIn p {
    font-size: 18px;
    margin-bottom: 30px;
}

.flowBox > div > div .entryBtn.sd.appear {
    width: calc(85% - 0px);
}
.flowBox > div > div .entryBtn.sd.appear a {
    width: 100%;
    max-width: 100%;
    background: #fff;
}
.flowBox > div > div .entryBtn.sd.appear a p {
    margin-bottom: 0;
    line-height: 1.0;
}


/******
 CAREER PLAN
******/
#career section#underSec01 {
    border-bottom: 3px solid #4052BC;
    padding-bottom: 8%;
    margin-bottom: 0;
}
#career section#topSec07 {
    border-top: 3px solid #4052BC;
}

p.subH2 {
    font-size: 36px;
    font-weight: 700;
    color: #4052a2;
    margin-bottom: 10px;
}
#career h2.center { text-align:center; }
#career section#underSec01 .pageTxt { width:calc(62% - 0px); }

#career section#underSec02 {
    background: url(../img/topImg04.png) center center no-repeat;
    background-size: cover;
    background-attachment: fixed;
    position: relative;
    z-index: 0;
}
#career section#underSec02:before {
    content: "";
    width: 100%;
    height: 100%;
    background: rgba(255,255,255,0.75);
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
}

#career section#underSec02 > div.cpBox {
    width: calc(60% - 0px);
    max-width: 1000px;
    padding: 100px 0;
    border-right: 3px solid #4052BC;
    border-left: 3px solid #4052BC;
    background: #d9ffe9;
}

dl.cpBoxIn { margin-bottom: 50px;}
dl.cpBoxIn dt {
    position: relative;
    font-size: 30px;
    line-height: 1.3;
    letter-spacing: 1px;
    z-index: 0;
    width: fit-content;
    margin: 0 auto 30px;
    padding: 10% 10% 15%;
}
dl.cpBoxIn dt:before {
    content: "";
    display: block;
    background: url(../img/carImgBk.png) center center no-repeat;
    background-size: contain;
    width: 98%;
    height: 95%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    -webkit- transform: translateY(-50%) translateX(-50%);
    margin: auto;
    z-index: -1;
}

p.cpTxt01 {
    font-size: 24px;
    letter-spacing: 2px;
    line-height: 1.3;
}
p.cpTxt02 {
    font-size: 40px;
    color: blue;
    line-height: 1.5;
    letter-spacing: 1px;
    position: relative;
    width: fit-content;
    margin: 0 auto;
    padding: 0 5px;
    z-index: 0;
}
p.cpTxt02:before,p.cpTxt02:after {
    content: "";
    display: block;
    height: 12px;
    background: #ff0;
    position: absolute;
    left: 0;
    z-index: -1;
}
p.cpTxt02:before {
    width: calc(100% - 0px);
    top: 40px;
}
/*p.cpTxt02:after {
    width: calc(85% - 0px);
    bottom: 8px;
    right: 0;
    margin: 0 auto;
}*/
p.cpTxt03 {
    font-size: 30px;
    letter-spacing: 2px;
    line-height: 1.4;
}

.sptList {
    width: calc(90% - 0px);
    margin: 0 auto 50px;
}
dl.sptDl {
    width: calc(50% - 20px);
    margin-bottom: 40px;
    background: #fff;
    border: 3px solid #8ca1ca;
    border-radius: 15px;
    padding: 2% 3%;
}
dl.sptDl dt {
    font-size: 22px;
    font-weight: 700;
    letter-spacing: 1px;
    color: #4052BC;
    border-bottom: 4px solid #8ca1ca;
    margin-bottom: 10px;
}
dl.sptDl dd {
    font-size: 16px;
    letter-spacing: 1px;
}

.styTtl,.sklTtl {
    background: #4052BC;
    padding: 3% 5%;
}
.styTtl dt, .styTtl dd {
    width: calc(35% - 0px);
    text-align: center;
}
.styTtl dt { height:150px; }
.styTtl dd p {
    color: #4052BC;
    font-size: 20px;
    font-weight: 700;
    line-height: 1.0;
    background: #fcf0c1;
    display: inline-block;
    padding: 12px 25px 10px;
    border-radius: 30px;
    border: 3px solid #fff;
    margin: 15px 0 15px;
}
.styTtl dd h3.styH3 {
    font-size: 26px;
    color: #fff;
    letter-spacing: 1px;
    line-height: 1.3;
}

.styBoxIn,.sklBoxIn {
    width: calc(90% - 0px);
    margin: 0 auto;
    padding: 8% 0 5%;
    position: relative;
}

.styBoxIn:before {
    content: "";
    display: block;
    width: 10px;
    height: 85%;
    background: #4052BC;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateY(10%) translateX(-50%);
    -webkit- transform: translateY(10%) translateX(-50%);
    margin: auto;
    z-index: 0;
}

.styBoxIn dl {
    width: calc(95% - 0px);
    margin: 0 auto 7%;
    border: 5px solid #4052BC;
    border-radius: 20px;
    box-shadow: 3px 3px #4052BC;
    position: relative;
}
.styBoxIn dl dt {
    background: #4052BC;
    color: #fff;
    font-size: 30px;
    font-weight: 700;
    letter-spacing: 1px;
    text-indent: 3em;
    position: relative;
}
.styBoxIn dl dt span {
    font-size: 225%;
    position: absolute;
    bottom: -25px;
    left: -62px;
    text-shadow: -4px -4px #4052BC;
}
.styBoxIn dl dd {
    padding: 5% 6.5%;
    font-size: 18px;
    letter-spacing: 1px;
    background: #e7f9ff;
    border-radius: 0 0 20px 20px;
}
.styBoxIn dl:last-child { margin-bottom: 0;}
.styBoxIn dl:last-child dt {
    text-indent: 7em;
    font-size: 40px;
}
.styBoxIn dl:last-child dt span {
    font-size: 215%;
    left: -28%;
    bottom: -60%;
}

.styBoxIn dl dd ul {
    width: calc(90% - 0px);
    margin: 0 auto;
}
.styBoxIn dl dd ul li {
    background: #fff;
    border-radius: 20px;
    padding: 3% 1%;
    margin: 0 auto 15px;
    position: relative;
    width: calc(78% - 0px);
}
.styBoxIn dl dd ul li p {
    color: #4052BC;
    font-size: 20px;
    font-weight: 700;
    letter-spacing: 1px;
    line-height: 1.3;
    padding-left: 4em;
}
.styBoxIn dl dd ul li p span {
    display: block;
    color: #f3d96e;
    font-size: 160%;
    text-shadow: 2px 2px 1px rgba(96,96,96,0.8);
}
.styBoxIn dl dd ul li:first-child:before { content: "01";}
.styBoxIn dl dd ul li:last-child:before { content: "02";}
.styBoxIn dl dd ul li:before {
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    transform: translateY(10%) translateX(0%);
    -webkit- transform: translateY(-50%) translateX(-50%);
    color: #4052BC;
    font-size: 50px;
    font-weight: 700;
    letter-spacing: -2px;
}

.comBoxIn {
    background: url(../img/fukidashi.png) center center no-repeat;
    background-size: 100% 100%;
    width: fit-content;
    margin: 0 auto 50px;
    padding: 8% 12% 12%;
}
.comBoxIn p {
    text-align: center;
    color: #ff0;
    font-size: 36px;
    font-weight: 700;
    line-height: 1.3;
    letter-spacing: 1px;
    padding: 5% 1%;
    width: max-content;
}

h3.sklH3 {
    font-size: 50px;
    color: #ff0;
    line-height: 1.0;
    letter-spacing: 1px;
    padding: 20px 0 10px;
}
h3.sklH3 span {
    display: block;
    color: #fff;
    font-size: 65%;
    margin: 0 auto 30px;
    position: relative;
    padding: 0 15px 0.5rem;
    border-bottom: 3px solid #fff;
    background-color: 4052BC;
    width: fit-content;
}
h3.sklH3 span:before {
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%) skew(-25deg);
    height: 25px;
    width: 10px;
    border-right: 3px solid #fff;
    background-color: #4052BC;
    content: "";
}

.sklBoxIn dl {
    margin: 0 auto 10px;
    border-radius: 20px;
    background: #fff;
    padding: 20px 30px;
}
.sklBoxIn dl dt {
    font-size: 30px;
    font-weight: 700;
    letter-spacing: 1px;
    line-height: 1.8;
    margin-bottom: 15px;
    border-bottom: 3px solid #4052BC;
}
.sklBoxIn dl dd {
    padding: 0 5px;
    font-size: 22px;
    font-weight: 700;
    line-height: 1.0;
}
.sklBoxIn dl dd span {
    display: inline-block;
    margin: 0 5px 8px;
    background: #e7f9ff;
    padding: 13px 20px 10px;
    border-radius: 15px;
}
.sklBoxIn > p {
    color: #4052BC;
    font-size: 60px;
}

.crgTtl {
    background: url(../img/fukidashiImg02.png) center center no-repeat;
    background-size: 100% 100%;
    width: fit-content;
    margin: 0 auto 50px;
    padding: 13% 18% 8% 14%;  
    position: relative;
}
p.crgTtlSub {
    position: absolute;
    top: -10px;
    left: -25px;
    color: #fff;
    font-size: 25px;
    font-weight: 700;
    line-height: 1.3;
    letter-spacing: 1px;
    background: url(../img/fukidashiImg03.png) center center no-repeat;
    background-size: 100% 100%;
    padding: 5% 5%;
    transform: rotate(-10deg);
    -moz-transform: rotate(-10deg);
    -webkit-transform: rotate(-10deg);
}
p.crgTtlTxt {
    color: #4052bc;
    font-size: 40px;
    font-weight: 700;
    line-height: 1.3;
    letter-spacing: 1px;
}


/******
 BLOG archive
******/
#blog .secIn {
    background: #fff;
    padding: 3%;
}

.post.first {
    border-bottom: 2px solid #ddd;
    padding-bottom: 15px;
    margin-bottom: 15px;
    width: 100%;
}
.post.first a > div > div {
    width: calc(50% - 15px);
    position: relative;
}

.post.first a > div > div.thumbnail {
    width: calc(40% - 20px);
    height: 200px;
    overflow: hidden;
    position: relative;
}
.post.second a > div.thumbnail {
    overflow:hidden;
    margin-bottom: 5px;
}
.post.first a > div > div.thumbnail img,
.post.second a > div.thumbnail img {
    width: 100%;
    height: 100%;
    pointer-events: none;
    position: relative;
    top: 0;
    left: 0;
    margin: auto;
    transition: 1s all;
}
.post.first a:hover > div > div.thumbnail img,
.post.second a:hover > div.thumbnail img {
    transform: scale(1.1,1.1);
    transition: 1s all;
}
.post.first a > div > div.conBox { width: calc(60% - 20px);}
.post.first a > div > div.conBox .title h3 {
    font-size: 20px;
    letter-spacing: 1.5px;
}

ol.cdOl.flexBlock {
    -webkit-justify-content: flex-start;
    justify-content: flex-start;
    margin-bottom: 5px
}
ol.cdOl.flexBlock li {
    width: fit-content;
    font-size: 13px;
}

li.ctgr {
    background: #eb612a;
    border-radius: 20px;
    color: #FFFFFF;
    font-size: 20px;
    font-weight: 900;
    line-height: 1.0;
    margin: 0px 10px 0px 0px;
    padding: 8px 20px;
}
li.date {
    color: #eb612a;
    font-size: 16px;
    font-weight: 900;
    line-height: 2.0;
}
.title h3 {
    font-size: 28px;
    line-height: 1.3;
    letter-spacing: 1px;
}

p.lead {
    position: absolute;
    right: 20px;
    bottom: 10px;
    font-size: 18px;
    font-weight: 700;
}
p.lead > i {
    display: inline-block;
    vertical-align: middle;
    color: #333;
    line-height: 1.0;
    position: relative;
    width: 0.1em;
    height: 0.9em;
    background: currentColor;
    transform: rotate(30deg);
    -moz-transform: rotate(30deg);
    -webkit-transform: rotate(30deg);
    margin-left: 10px;
}
p.lead > i:before {
    content: '';
    width: 0.65em;
    height: 0.65em;
    border: 0.15em solid currentColor;
    border-left: 0;
    border-bottom: 0;
    transform: rotate(-45deg);
    transform-origin: top right;
    position: absolute;
    top: -0.1em;
    right: 50%;
    box-sizing: border-box;
}

.post.second {
    position: relative;
    width: calc(33% - 30px);
    margin-bottom: 30px;
}
.post.second .title h3 {
    font-size: 16px;
    margin-bottom: 0;
}



/*ローディングが表示されるエリアの設定*/
#infscr-loading {
width:100%;
text-align:center;
margin:20px auto;
}

#infscr-loading img{
    width:30px;/*ローディング画像のサイズ*/
}



/******
 BLOG single
******/
.wp-block-group { display: none;}

.nav-links {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin: 0 auto;
    width: auto;
    max-width: 300px;
}
.nav-links > div {
    width: calc(50% - 0px);
    text-align: center;
}

h2.unH2 { font-size: 60px;}

div#sideR {
    display: block;
    padding: 0 0 100px;
    width: 100%;
}

.sideIn {
    width: 90%;
    margin: 0 auto 100px;
    padding-top: 50px;
}

section.blogPost div p {
    font-size: 18px;
    letter-spacing: 1px;
}
section.blogPost > div > p { margin-bottom: 40px;}

ul.snglUl { width: 300px;}
ul.snglUl > li {
    width: calc(50% - 10px);
    text-align: center;
    font-size: 100%;
}

ul.post-categories li a {
    display: inline-block;
    background: #eb612a;
    line-height: 1.0;
    padding: 0.5rem 1rem;
    border-radius: 15px;
    color: #fff;
}

.diBlock { margin-bottom: 80px;}

.blogPost h3 {
  position: relative;
  padding: 1.2rem 2rem calc(1.2rem + 8px);
  background: #c4d3f0;
  font-size: 140%;
  margin-bottom: 30px;
  width: 100%;
}
.blogPost h3:before {
  position: absolute;
  top: -7px;
  left: -7px;
  width: 100%;
  height: 100%;
  content: '';
  border: 4px solid #000;
}

.blogPost h4 {
  position: relative;
  padding: 1.5rem 1rem 1.3rem;
  font-size: 130%;
  margin-bottom: 20px;
  width: 100%;
}
.blogPost h4:before {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 8px;
    content: '';
    background-image: -webkit-repeating-linear-gradient(135deg, #000, #000 1px, transparent 2px, transparent 5px);
    background-image: repeating-linear-gradient(-45deg, #000, #000 1px, transparent 2px, transparent 5px);
    background-size: 7px 7px;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
}

.blogPost h5 {
    padding: 0.5rem 1.5rem;
    border-left: 8px double #000;
    font-size: 140%;
    margin-bottom: 25px;
    line-height: 1.0;
}

.diBlock > p { margin-bottom: 1em;}

dl.blgDl01 { margin-bottom: 50px;}
dl.blgDl01 dt {
    font-size: 130%;
    letter-spacing: 1px;
    font-weight: 700;
    margin-bottom: 10px;
    position: relative;
    padding: 1rem 2rem calc(1rem + 8px);
    background: #fff;
}
dl.blgDl01 dt:before {
    position: absolute;
    top: -5px;
    left: -5px;
    width: 100%;
    height: 100%;
    content: '';
    border: 3px solid #000;
}


dl.blgDl02 { margin-bottom: 30px;}
dl.blgDl02 dt {
    position: relative;
    padding: 1.5rem 1.5rem calc(1.5rem + 5px);
    border: 2px solid #000;
    background: #fff;
    font-size: 120%;
    font-weight: 700;
    line-height: 1.0;
    width: fit-content;
    letter-spacing: 1px;
    border-radius: 8px;
    margin-bottom: 10px;
}
dl.blgDl02 dt:before {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 10px;
    content: '';
    border-top: 2px solid #000;
    background-image: -webkit-repeating-linear-gradient(135deg, #000, #000 1px, transparent 2px, transparent 5px);
    background-image: repeating-linear-gradient(-45deg, #000, #000 1px, transparent 2px, transparent 5px);
    background-size: 7px 7px;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
}

dl.blgDl03 { padding: 10px 20px 25px;}
dl.blgDl03:nth-child(even) { background: #fcfcfc;}

.diBlock table th {
    font-size: 120%;
    padding: 5px 8px;
}
.diBlock table td {
    font-size: 110%;
    letter-spacing: 1px;
    line-height: 1.4;
    padding: 5px 8px;
}
.diBlock table tr:nth-child(even) { background:#fcfcfc; }


/******
 BLOG sidebar
******/
.sideIn {
    width: 100%;
    max-width: 1000px;
    margin: 0 auto;
}

.rpwe-block ul.rpwe-ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;    
}
.rpwe-block ul.rpwe-ul li.rpwe-li {
    width: calc(25% - 20px);
}

ul.rpwe-ul li h3:before { display: none;}