@charset "UTF-8";
@import url(https://use.typekit.net/bzf3wrs.css);

/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
html {
    line-height: 1.15;
    -webkit-text-size-adjust: 100%
}

body {
     margin: -11px 0px 0px 0px;
}

main {
    display: block
}

h1 {
    font-size: 2em;
    margin: .67em 0
}

hr {
    -webkit-box-sizing: content-box;
    box-sizing: content-box;
    height: 0;
    overflow: visible
}

pre {
    font-family: monospace, monospace;
    font-size: 1em
}

a {
    background-color: transparent
}

abbr[title] {
    border-bottom: none;
    text-decoration: underline;
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted
}

b,
strong {
    font-weight: bolder
}

code,
kbd,
samp {
    font-family: monospace, monospace;
    font-size: 1em
}

small {
    font-size: 80%
}

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

sub {
    bottom: -.25em
}

sup {
    top: -.5em
}

img {
    border-style: none
}

button,
input,
optgroup,
select,
textarea {
    font-family: inherit;
    font-size: 100%;
    line-height: 1.15;
    margin: 0
}

button,
input {
    overflow: visible
}

button,
select {
    text-transform: none
}

[type=button],
[type=reset],
[type=submit],
button {
    -webkit-appearance: button
}

[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner,
button::-moz-focus-inner {
    border-style: none;
    padding: 0
}

[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring,
button:-moz-focusring {
    outline: 1px dotted ButtonText
}

fieldset {
    padding: .35em .75em .625em
}

legend {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    color: inherit;
    display: table;
    max-width: 100%;
    padding: 0;
    white-space: normal
}

progress {
    vertical-align: baseline
}

textarea {
    overflow: auto
}

[type=checkbox],
[type=radio] {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    padding: 0
}

[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
    height: auto
}

[type=search] {
    -webkit-appearance: textfield;
    outline-offset: -2px
}

[type=search]::-webkit-search-decoration {
    -webkit-appearance: none
}

::-webkit-file-upload-button {
    -webkit-appearance: button;
    font: inherit
}

details {
    display: block
}

summary {
    display: list-item
}

template {
    display: none
}

[hidden] {
    display: none
}

/*! locomotive-scroll v3.5.4 | MIT License | https://github.com/locomotivemtl/locomotive-scroll */
html.has-scroll-smooth {
    overflow: hidden
}

html.has-scroll-dragging {
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none
}

.has-scroll-smooth body {
    overflow: hidden
}

.has-scroll-smooth [data-scroll-container] {
    min-height: 100vh
}

.c-scrollbar {
    position: absolute;
    right: 0;
    top: 0;
    width: 11px;
    height: 100vh;
    -webkit-transform-origin: center right;
    transform-origin: center right;
    -webkit-transition: opacity .3s, -webkit-transform .3s;
    transition: opacity .3s, -webkit-transform .3s;
    transition: transform .3s, opacity .3s;
    transition: transform .3s, opacity .3s, -webkit-transform .3s;
    opacity: 0
}

.c-scrollbar:hover {
    -webkit-transform: scaleX(1.45);
    transform: scaleX(1.45)
}

.c-scrollbar:hover,
.has-scroll-dragging .c-scrollbar,
.has-scroll-scrolling .c-scrollbar {
    opacity: 1
}

.c-scrollbar_thumb {
    position: absolute;
    top: 0;
    right: 0;
    background-color: #000;
    opacity: .5;
    width: 7px;
    border-radius: 10px;
    margin: 2px;
    cursor: -webkit-grab;
    cursor: grab
}

.has-scroll-dragging .c-scrollbar_thumb {
    cursor: -webkit-grabbing;
    cursor: grabbing
}

.slideup {
    overflow: hidden
}

.slideup .txthidden {
    will-change: transform;
    -webkit-transform: translateY(100%);
    transform: translateY(100%);
    display: inline-block;
    -webkit-transition: transform .64s cubic-bezier(.7, .21, .35, .88);
    -webkit-transition: -webkit-transform .64s cubic-bezier(.7, .21, .35, .88);
    transition: -webkit-transform .64s cubic-bezier(.7, .21, .35, .88);
    transition: transform .64s cubic-bezier(.7, .21, .35, .88);
    transition: transform .64s cubic-bezier(.7, .21, .35, .88), -webkit-transform .64s cubic-bezier(.7, .21, .35, .88)
}

.slideup.on .txthidden {
    -webkit-transform: translateY(0);
    transform: translateY(0);
    padding-bottom: 0.15em;
}

.fadein {
    opacity: 0;
    -webkit-transform: translateY(25px);
    transform: translateY(25px);
    will-change: transform;
    -webkit-transition: .64s cubic-bezier(.7, .21, .35, .88);
    transition: .64s cubic-bezier(.7, .21, .35, .88)
}

.fadein.on {
    opacity: 1;
    -webkit-transform: translateY(0);
    transform: translateY(0)
}

.fadein2 {
    opacity: 0;
    -webkit-transform: translateY(-40%) !important;
    transform: translateY(-40%) !important;
    will-change: transform;
    -webkit-transition: .9s cubic-bezier(.7, .21, .35, .88);
    transition: .9s cubic-bezier(.7, .21, .35, .88);
    -webkit-transition-delay: .1s;
    transition-delay: .1s
}

.fadein2.on {
    opacity: 1;
    -webkit-transform: translateY(-50%) !important;
    transform: translateY(-50%) !important
}

.fadein3 {
    opacity: 0;
    -webkit-transform: translateY(0px);
    transform: translateY(0px);
    will-change: transform;
    -webkit-transition: .64s cubic-bezier(.7, .21, .35, .88);
    transition: .64s cubic-bezier(.7, .21, .35, .88)
}

.fadein3.on {
    opacity: 1;
    -webkit-transform: translateY(0);
    transform: translateY(0)
}

html {
    visibility: hidden;
    font-size: 62.5%
}

html.wf-active {
    visibility: visible
}

body {
    font-family: dnp-shuei-mgothic-std, "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", sans-serif;
    font-size: 1rem;
    font-weight: 500;
    letter-spacing: 0;
    -webkit-font-feature-settings: "palt";
    font-feature-settings: "palt";
    width: 100%;
    color: #fff
}

.font-dnp {
    font-family: dnp-shuei-mgothic-std, sans-serif;
    font-style: normal
}

.font-en {
    font-family: mic-32-new-web, sans-serif;
    font-style: normal
}

.font-en2 {
    font-family: mic-32-new-web, sans-serif;
    font-style: normal;
    color: #161616;
    letter-spacing: 0.04em;
    font-size: 15px;
}

.font-avn {
    font-family: Lato, sans-serif
}

.font-yugo {
    font-family: "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", sans-serif
}

.pc-hide {
    display: none
}

.sp-hide {
    display: block;
}

::-moz-selection {
    background: #1d94b7;
    color: #fff
}

::selection {
    background: #1d94b7;
    color: #fff
}

a {
    color: #000;
    text-decoration: none;
    cursor: pointer
}

a:active,
a:link,
a:visited {
    color: #000
}

:focus,
a:focus {
    outline: 0
}

*,
:after,
:before {
    -webkit-box-sizing: border-box;
    box-sizing: border-box
}

dd,
div,
dl,
dt,
h1,
h2,
h3,
h4,
h5,
h6,
p {
    margin: 0;
    padding: 0
}

li,
ol,
ul {
    padding: 0;
    margin: 0
}

li {
    list-style: none
}

img {
    vertical-align: bottom
}

figure {
    margin: 0;
    padding: 0
}

input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0
}

input[type=number] {
    -moz-appearance: textfield
}

.l-main {
    line-height: 1.2
}

.l-footer {
    width: 100%;
    position: relative;
    padding: 50px 114px 62px;
}

.l-footer .inner {
    position: relative
}

.l-footer:after {
    content: "";
    background: #044b60;
    background: -webkit-gradient(linear, right top, left bottom, from(#38c0e9), to(#044b60));
    background: linear-gradient(to bottom left, #38c0e9 0, #044b60 100%);
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0
}

.l-footer .footer-menu {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    position: relative;
    z-index: 1
}

.l-footer .footer-menu li {
    margin-right: 29px
}

.l-footer .footer-menu li a {
    color: #fff;
    font-size: 20px;
    -webkit-transition: .33s ease;
    transition: .33s ease;
    position: relative;
    display: block
}

.l-footer .footer-menu li a:before {
    content: "";
    display: block;
    position: absolute;
    bottom: -2px;
    left: 0;
    -webkit-transition: all .33s ease-in-out;
    transition: all .33s ease-in-out;
    width: 100%;
    height: 2px;
    background-color: #fff;
    -webkit-transform: scaleX(0);
    transform: scaleX(0);
    -webkit-transform-origin: left top;
    transform-origin: left top
}

.l-footer .footer-menu li a:hover:before {
    -webkit-transform: scaleX(1);
    transform: scaleX(1)
}

.l-footer ul.subfooter {
    position: relative;
    z-index: 1;
    margin-top: 30px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

.l-footer ul.subfooter li {
    margin-right: 38px
}

.l-footer ul.subfooter li a {
    color: #fff;
    -webkit-transition: .5s ease;
    transition: .5s ease;
    position: relative;
    display: block
}

.l-footer ul.subfooter li a:before {
    content: "";
    display: none
}

.l-footer ul.subfooter li a path {
    -webkit-transition: .5s ease;
    transition: .5s ease
}

.l-footer ul.subfooter li a:hover path.a {
    fill: #1d94b7
}

.l-footer ul.subfooter li svg {
    width: 22px;
    height: 23px
}

.l-footer ul.subfooter li .rec-btn {
    background-color: #1d94b7;
    width: 171px;
    height: 45px;
    display: block;
    border-radius: 60px;
    opacity: .87;
    text-align: center;
    padding-top: 14px;
    font-size: 16px
}

.l-footer ul.subfooter li .rec-btn:hover {
    background-color: #fff;
    color: #1d94b7
}

.l-footer ul.subfooter2 {
    position: absolute;
    right: 0;
    top: 0;
    z-index: 1;
    text-align: right
}

.l-footer ul.subfooter2 li {
    font-size: 13px;
    margin-bottom: 11px;
    letter-spacing: 1px
}

.l-footer ul.subfooter2 li a {
    color: #fff;
    -webkit-transition: .5s ease;
    transition: .5s ease
}

.l-footer ul.subfooter2 li a:hover {
    opacity: .6
}

.l-footer .copyright {
    position: absolute;
    bottom: -20px;
    right: 0;
    z-index: 1;
    font-size: 13px;
    letter-spacing: 1px
}

.l-footer .vr {
  transition: opacity .5s ease;
  width: 150px;
}

.l-footer .vr:hover {
  opacity: .4;
}

.l-footer .vr img {
  width: 100%;
}


.l-footer ul.subfooter li.docs {
  font-size: 14px;
  margin-left: auto;
  margin-right: 0;
  position: relative;
}

.l-footer ul.subfooter li.docs::before {
  background-color: #fff;
  bottom: 0;
  content: "";
  display: block;
  height: 1px;
  left: 0;
  position: absolute;
  width: 100%;
}

.bg-is-white .l-header .g-nav li a {
    color: #184557
}

.bg-is-white .l-header .g-nav li.recruit a {
    color: #fff
}

div#loading {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    background: #fff;
    z-index: 99999
}

div#loading .logowrap {
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    margin: auto;
    width: 139px;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%)
}

div#loading .logowrap img {
    opacity: 0;
    width: 100%
}

.l-header {
    width: 100%;
    position: fixed;
    height: 94px;
    z-index: 999
}

.l-header:before {
    content: "";
    height: 94px;
    background-color: #fff;
    -webkit-transition: .5s ease;
    transition: .5s ease;
    -webkit-transform: scaleX(0);
    transform: scaleX(0);
    -webkit-transform-origin: top left;
    transform-origin: top left
}

.l-header.white.hide:before {
    opacity: 0
}

.l-header.white .menu-trigger span {
    background-color: #184557
}

.l-header.white:before {
    background-color: #fff;
    width: 100%;
    display: block;
    -webkit-transform: scaleX(1);
    transform: scaleX(1);
    -webkit-transform-origin: top left;
    transform-origin: top left
}

.l-header.white .g-nav li a {
    color: #147b9a
}

.l-header.white .g-nav li a:before {
    background-color: #147b9a
}

.l-header.white .g-nav li.recruit a {
    color: #fff
}

.l-header.white .g-nav li a.wpml-ls-link {
    border: 1px solid #184557;
    color: #184557;
    border-radius: 100%;
    width: 31px;
    height: 31px;
    display: block;
    padding-top: 7px;
    text-align: center;
    font-size: 14px;
    padding: 5px
}

.l-header.white .g-nav li a.wpml-ls-link:hover {
    background-color: #184557;
    color: #fff;
    text-shadow: 0 0 0 #fff;
    border: 1px solid #fff
}

.l-header.headerwhite {
    background-color: #fff
}

.l-header.headerwhite .menu-trigger span {
    background-color: #184557
}

.l-header.headerwhite .g-nav li a {
    color: #147b9a;
    -webkit-transition: .3s;
    transition: .3s
}

.l-header.headerwhite .g-nav li a:before {
    background-color: #147b9a
}

.l-header.headerwhite .g-nav li.recruit a {
    color: #fff
}

.l-header.headerwhite .g-nav li a.wpml-ls-link {
    border: 1px solid;
    border-radius: 100%;
    width: 31px;
    height: 31px;
    display: block;
    padding-top: 7px;
    text-align: center;
    font-size: 14px;
    padding: 5px;
    color: #184557;
    border-color: #184557
}

.l-header.headerwhite .g-nav li a.wpml-ls-link:hover {
    background-color: #184557;
    color: #fff;
    text-shadow: 0 0 0 #fff;
    border: 1px solid #fff
}

.l-header h1 {
    position: absolute;
    width: 139px;
    top: 15px;
    left: 0
}

.l-header h1 img {
    width: 94%;
    margin-left: 1.4vw;
    margin-top: 0.3em;
}

.l-header .g-nav {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    position: absolute;
    right: 20px;
    top: 33px
}

.l-header .g-nav li {
    font-size: 18px;
    font-weight: 500;
    margin-right: 35px;
    letter-spacing: 0
}

.l-header .g-nav li a {
    color: #fff;
    display: block;
    position: relative
}

.l-header .g-nav li a.current:before {
    -webkit-transform: scaleX(1);
    transform: scaleX(1)
}

.l-header .g-nav li a:before {
    content: "";
    display: block;
    position: absolute;
    bottom: -5px;
    left: 0;
    -webkit-transition: all .33s ease-in-out;
    transition: all .33s ease-in-out;
    width: 100%;
    height: 2px;
    background-color: #fff;
    -webkit-transform: scaleX(0);
    transform: scaleX(0);
    -webkit-transform-origin: left top;
    transform-origin: left top
}

.l-header .g-nav li a:hover:before {
    -webkit-transform: scaleX(1);
    transform: scaleX(1)
}

.l-header .g-nav li.recruit a {
    background: #147b9a 0 0 no-repeat padding-box;
    border: 1px solid #147b9a;
    border-radius: 15px;
    font-size: 17px;
    padding: 5px 16px;
    text-align: center;
    display: block;
    -webkit-transition: .5s ease;
    transition: .5s ease
}

.l-header .g-nav li.recruit a:before {
    display: none !important
}

.l-header .g-nav li.recruit a:hover {
    background-color: #fff;
    color: #147b9a;
    text-shadow: 0 0 0 #147b9a
}

.l-header .g-nav li.vr a {
  transition: opacity .5s ease;
  width: 147px;
}

.l-header .g-nav li.vr a img {
  width: 100%;
}

.l-header .g-nav li.vr a:before {
    display: none !important
}

.l-header .g-nav li.vr a:hover {
  opacity: .6;
}

.l-header .g-nav li.vr a .-light {
  display: none;
}

.l-header.white .g-nav li.vr a .-light,
.l-header.headerwhite .g-nav li.vr a .-light {
  display: block;
}

.l-header.white .g-nav li.vr a .-dark,
.l-header.headerwhite .g-nav li.vr a .-dark {
  display: none;
}

.l-header .g-nav li a.wpml-ls-link {
    border: 1px solid #fff;
    color: #fff;
    border-radius: 100%;
    width: 31px;
    height: 31px;
    display: block;
    padding-top: 7px;
    text-align: center;
    font-size: 14px;
    padding: 5px;
    -webkit-transition: .5s ease;
    transition: .5s ease
}

.l-header .g-nav li a.wpml-ls-link:before {
    display: none
}

.l-header .g-nav li a.wpml-ls-link:hover {
    background-color: #fff;
    color: #184557;
    text-shadow: 0 0 0 #184557;
    border: 1px solid #184557
}

.l-header .g-nav li ul.lang {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-left: -0.8em;
}

.l-header .menu-trigger,
.l-header .menu-trigger span {
    display: inline-block;
    -webkit-transition: all .4s;
    transition: all .4s;
    -webkit-box-sizing: border-box;
    box-sizing: border-box
}

.l-header .menu-trigger {
    position: fixed;
    width: 25px;
    height: 13px;
    top: 24px;
    right: 18px
}

.l-header .menu-trigger.active span {
    background-color: #147b9a
}

.l-header .menu-trigger span {
    position: absolute;
    left: 0;
    width: 100%;
    height: 1px;
    background-color: #fff;
    border-radius: 4px
}

.l-header .menu-trigger span:nth-of-type(1) {
    top: 0
}

.l-header .menu-trigger span:nth-of-type(2) {
    top: 6px
}

.l-header .menu-trigger span:nth-of-type(3) {
    bottom: 0
}

.l-header .menu-trigger span:nth-of-type(1) {
    -webkit-animation: menu-bar01 .5s forwards;
    animation: menu-bar01 .5s forwards
}

@-webkit-keyframes menu-bar01 {
    0% {
        -webkit-transform: translateY(6px) rotate(45deg)
    }

    50% {
        -webkit-transform: translateY(6px) rotate(0)
    }

    100% {
        -webkit-transform: translateY(0) rotate(0)
    }
}

@keyframes menu-bar01 {
    0% {
        -webkit-transform: translateY(6px) rotate(45deg);
        transform: translateY(6px) rotate(45deg)
    }

    50% {
        -webkit-transform: translateY(6px) rotate(0);
        transform: translateY(6px) rotate(0)
    }

    100% {
        -webkit-transform: translateY(0) rotate(0);
        transform: translateY(0) rotate(0)
    }
}

.l-header .menu-trigger span:nth-of-type(2) {
    -webkit-transition: all .3s .3s;
    transition: all .3s .3s;
    opacity: 1
}

.l-header .menu-trigger span:nth-of-type(3) {
    -webkit-animation: menu-bar02 .5s forwards;
    animation: menu-bar02 .5s forwards
}

@-webkit-keyframes menu-bar02 {
    0% {
        -webkit-transform: translateY(-6px) rotate(-45deg)
    }

    50% {
        -webkit-transform: translateY(-6px) rotate(0)
    }

    100% {
        -webkit-transform: translateY(0) rotate(0)
    }
}

@keyframes menu-bar02 {
    0% {
        -webkit-transform: translateY(-6px) rotate(-45deg);
        transform: translateY(-6px) rotate(-45deg)
    }

    50% {
        -webkit-transform: translateY(-6px) rotate(0);
        transform: translateY(-6px) rotate(0)
    }

    100% {
        -webkit-transform: translateY(0) rotate(0);
        transform: translateY(0) rotate(0)
    }
}

.l-header .menu-trigger.active span:nth-of-type(1) {
    -webkit-animation: active-menu-bar01 .5s forwards;
    animation: active-menu-bar01 .5s forwards
}

@-webkit-keyframes active-menu-bar01 {
    0% {
        -webkit-transform: translateY(0) rotate(0)
    }

    50% {
        -webkit-transform: translateY(6px) rotate(0)
    }

    100% {
        -webkit-transform: translateY(6px) rotate(45deg)
    }
}

@keyframes active-menu-bar01 {
    0% {
        -webkit-transform: translateY(0) rotate(0);
        transform: translateY(0) rotate(0)
    }

    50% {
        -webkit-transform: translateY(6px) rotate(0);
        transform: translateY(6px) rotate(0)
    }

    100% {
        -webkit-transform: translateY(6px) rotate(45deg);
        transform: translateY(6px) rotate(45deg)
    }
}

.l-header .menu-trigger.active span:nth-of-type(2) {
    opacity: 0
}

.l-header .menu-trigger.active span:nth-of-type(3) {
    -webkit-animation: active-menu-bar03 .5s forwards;
    animation: active-menu-bar03 .5s forwards
}

@-webkit-keyframes active-menu-bar03 {
    0% {
        -webkit-transform: translateY(0) rotate(0)
    }

    50% {
        -webkit-transform: translateY(-6px) rotate(0)
    }

    100% {
        -webkit-transform: translateY(-6px) rotate(-45deg)
    }
}

@keyframes active-menu-bar03 {
    0% {
        -webkit-transform: translateY(0) rotate(0);
        transform: translateY(0) rotate(0)
    }

    50% {
        -webkit-transform: translateY(-6px) rotate(0);
        transform: translateY(-6px) rotate(0)
    }

    100% {
        -webkit-transform: translateY(-6px) rotate(-45deg);
        transform: translateY(-6px) rotate(-45deg)
    }
}

.splang {
    display: none
}

.splogo {
    display: none;
    opacity: 0
}

div.langsp {
    display: none;
    opacity: 0
}

#nav {
    width: 100%;
    height: 100vh;
    position: fixed;
    background-color: #c3f4ff;
    top: 0;
    left: 0;
    z-index: 99;
    display: none;
    opacity: 0;
    -webkit-transform: scale(.8);
    transform: scale(.8);
    -webkit-overflow-scrolling: touch
}

#nav:after {
    content: "";
    width: 100%;
    height: 100%;
    background-image: url(../images/top/navbg.png);
    background-position: center;
    position: absolute;
    top: 0;
    left: 0
}

#nav .inner {
    width: 100%;
    padding: 0 18px;
    height: 100%;
    z-index: 1;
    position: relative
}

#nav .inner ul.menu {
    text-align: center;
    position: absolute;
    top: 50.5%;
    left: 0;
    right: 0;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%)
}


#nav .inner div.langsp span.wpml-ls-native {
    font-size: 26px;
}

#nav .inner ul.menu li {
    font-size: 32px;
    margin-bottom: 4px;
    line-height: 43px
}

#nav .inner ul.menu li a {
    letter-spacing: 0;
    color: #147b9a
}

#nav .inner ul.menu li.recruit {
    background: #1d94b7 0 0 no-repeat padding-box;
    border-radius: 110px;
    width: 21rem;
    height: 6.5rem;
    padding: 1rem 0;
    font-size: 25px;
    text-align: center;
    margin: 24px auto 16px;
    letter-spacing: 1.64px
}

#nav .inner ul.menu li.recruit a {
    color: #fff;
    letter-spacing: 1.64px
}

#nav .inner ul.menu li.vr {
  margin: 38px auto 0;
  width: 331px;
}

#nav .inner ul.menu li.vr img {
  width: 100%;
}

#nav .inner .info {
  align-items: center;
  display: flex;
  justify-content: space-between;
  line-height: 1;
  margin: 47px auto 0;
  width: 330px;
}

#nav .inner .info .policy {
  font-size: 0;
  line-height: 1;
}

#nav .inner .info .policy a {
  color: #147b9a;
  font-size: 17px;
  font-weight: bold;
  text-decoration: underline;
}

#nav .inner .info .sns {
  font-size: 0;
  line-height: 1;
}

#nav .inner .info .sns svg .a {
  fill: #147b9a
}

#nav .inner ul.menu li.sns {
    margin-top: 20px
}

div.langsp a {
    align-items: center;
    border: 1px solid;
    border-radius: 100%;
    display: flex;
    line-height: 1;
    justify-content: center;
    font-size: 13px;
    background: transparent;
    color: #147b9a;
    height: 100%;
    width: 100%;
}

#nav .inner ul.submenu {
    position: absolute;
    bottom: 32px;
    left: 18px
}

#nav .inner ul.submenu li {
    margin-bottom: 10px
}

#nav .inner ul.submenu li a {
    color: #147b9a;
    font-size: 14px
}

section#recruit {
    padding-top: 146px;
    padding-bottom: 180px
}

section#recruit .inner {
    width: 85%;
    margin: 0 auto
}

section#recruit .inner .contwrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

section#recruit .inner .contwrap .left {
    width: 42%;
    margin-right: 8%
}

section#recruit .inner .contwrap .left .txt.enver .cloum {
    margin-bottom: 50px
}

section#recruit .inner .contwrap .left .txt.enver .cloum h3 {
    font-size: 27px;
    font-weight: 700;
    color: #343434;
    margin-bottom: 22px
}

section#recruit .inner .contwrap .left .txt.enver .cloum h5 {
    font-size: 14px;
    font-weight: 700;
    color: #343434;
    margin-top: 50px
}

section#recruit .inner .contwrap .left .txt.enver p {
    margin-bottom: 0
}

section#recruit .inner .contwrap .left .txt h4 {
    letter-spacing: 0;
    color: #343434;
    font-size: 27px;
    margin-bottom: 24px;
    line-height: 1.55;
}

section#recruit .inner .contwrap .left .txt p {
    letter-spacing: 0;
    font-size: 16px;
    color: #343434;
    margin-bottom: 55px;
    line-height: 30px
}

section#recruit .inner .contwrap .left .txt .readmore {
    width: 269px;
    height: 80px;
    border-radius: 40px;
    padding: 30px 0 0 0;
    color: #fff
}

section#recruit .inner .contwrap .left .txt .readmore:hover {
    color: #147b9a
}

section#recruit .inner .contwrap .right {
    width: 40%;
    padding-left: 4%
}

section#recruit .inner .contwrap .right .img {
    background-size: cover;
    width: 100%;
    height: 0;
    padding-top: calc(1062 / 1148 * 100%);
    background-position: center
}

.fuctxt .cloum {
    margin-bottom: 50px
}

.fuctxt .cloum h3 {
    font-size: 27px;
    font-weight: 700;
    color: #343434;
    margin-bottom: 22px
}

.fuctxt .cloum h5 {
    font-size: 14px;
    font-weight: 700;
    color: #343434;
    margin-top: 50px
}

.fuctxt p {
    letter-spacing: 0;
    font-size: 16px;
    color: #343434;
    margin-bottom: 15px;
    line-height: 25px
}

.l-main {
    width: 100%
}

.l-main.pt100 {
    padding-top: 139px;
}

div#js-scroll {
    width: 100%;
    overflow: hidden
}

section#companytop {
    position: relative
}

section#companytop:before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: block;
    background: #5FB0D5;
    background: -webkit-gradient(linear, left top, right bottom, from(#5FB0D5), to(#003A4B));
    background: linear-gradient(to bottom right, #5FB0D5 0, #003A4B 100%)
}

section#companytop .inner {
    padding: 166px 114px 107px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

section#companytop .inner .ttl-wrap {
    padding-bottom: 0
}

section#companytop .inner .ttl-wrap h2,
section#companytop .inner .ttl-wrap h3 {
    color: #fff
}

section#companytop .inner .ttl-wrap h2 {
    margin-bottom: 25px
}

section#companytop .inner .ttl-wrap h3 {
    margin-bottom: 120px
}

section#companytop .inner .txtwrap {
    position: relative;
    z-index: 1
}

section#companytop .inner .txtwrap h4 {
    font-size: 42px;
    letter-spacing: 1.68px;
    line-height: 54px;
    margin-bottom: 49px
}

section#companytop .inner .txtwrap p {
    font-size: 20px;
    line-height: 40px;
    letter-spacing: 0.5px;
    margin-bottom: 24px
}

section#companytop .inner .img {
    width: 50%;
    height: 0;
    padding-top: calc(742 / 778 * 50%);
    background-size: cover;
    background-position: center;
    position: absolute;
    right: -6%;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%)
}

section.loop #carousel .slick-slide img {
    width: 100%;
    height: auto
}

section.companycont .inner {
    padding: 0 114px;
    max-width: 1134px;
    margin: 0 auto
}

section.companycont .inner .ttl-wrap {
    margin-top: 54px
}

section.companycont .inner .ttl-wrap h2 {
    font-size: 62px;
    font-weight: 400;
    line-height: 72px;
    letter-spacing: 0;
    margin-bottom: 0.1em;
}

section.companycont .inner .ttl-wrap h3 {
    font-size: 20px
}

section.companycont .inner .info1 dl {
    margin-bottom: 35px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: top;
    -ms-flex-align: top;
    align-items: top
}

section.companycont .inner .info1 dl dt {
    width: 12px;
    height: 12px;
    margin-right: 11px;
    border-radius: 100%;
    background-color: #1d94b7;
    margin-top: 1.2em;
}

section.companycont .inner .info1 dl dd {
    color: #191919;
    font-size: 20px;
    width: calc(100% - 23px);
    line-height: 30px;
    letter-spacing: .68px
}

section.companycont .inner .info2 {
    margin-bottom: 61px
}

section.companycont .inner .info2 p {
    font-size: 14.9px;
    letter-spacing: .48px;
    line-height: 1.9;
    font-weight: 400;
    color: #191919;
    margin-bottom: 0.6em;
}

section.companycont .inner .info2 p span {
    display: block;
    margin-left: 10px
}

section.companycont .inner .studio {
    margin-top: 120px
}

section.companycont .inner .studio .studio-wrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-bottom: 65px
}

section.companycont .inner .studio .studio-wrap .left {
    width: 46%;
    color: #343434;
    margin-right: 18px;
}

section.companycont .inner .studio .studio-wrap .left h3 {
    font-size: 27px;
    font-weight: 700;
    margin-bottom: 10px
}

section.companycont .inner .studio .studio-wrap .left h4 {
    font-size: 20px;
    font-weight: 700;
    margin-bottom: 10px
}

section.companycont .inner .studio .studio-wrap .left p {
    font-size: 16px;
    line-height: 1.8;
    margin-bottom: 25px
}

section.companycont .inner .studio .studio-wrap .right {
    width: 50%
}

section.companycont .inner .studio .studio-wrap .right img {
    width: 100%;
    margin-top: 1.2em;
}

section.companycont .investors .txt .date {
    font-size: 14px;
    letter-spacing: .48px;
    line-height: 30px;
    color: #191919
}

section.companycont .investors .txt h3 {
    font-size: 20px;
    line-height: 30px;
    letter-spacing: .68px;
    color: #191919;
    margin-bottom: 0.2em;
}

section.companycont .ir-content-dnp p {
    font-size: 13px;
    line-height: 1.8;
    margin-bottom: 11px;
    color: #191919;
}

section.companycont .investors .txt a {
    font-size: 17px;
    letter-spacing: .58px;
    line-height: 30px;
    color: #147b9a;
    border-bottom: 1px solid #147b9a
}

section.companycont .investors .txt .readmore {
    background-color: transparent;
    color: #147b9a;
    margin-top: 35px;
    height: auto;
    padding-top: 14px;
    padding-bottom: 15px;
    -webkit-transition: .3s ease;
    transition: .3s ease
}

section.companycont .investors .txt .readmore:hover {
    color: #fff;
    background-color: #147b9a
}

.contact .l-main {
    line-height: 1.2;
    color: #222;
    font-size: 1.5em
}

.contact .ttlbg {
    width: 578px
}

.contact section#contact {
    position: relative
}

.contact section#contact:before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: block;
    background: #044b60;
    background: -webkit-gradient(linear, left top, right bottom, from(#1d94b7), to(#044b60));
    background: linear-gradient(to bottom right, #1d94b7 0, #044b60 100%)
}

.contact section#contact .ttl-wrap {
    position: relative;
    padding-bottom: 34px;
    font-weight: 400;
    display: inline-block;
    top: -40px;
    line-height: 1;
    padding-right: 0;
    z-index: 1;
    padding-left: 106px
}

.contact section#contact .ttl-wrap h2 {
    font-size: 82px
}

.contact section#contact .contacttop .inner {
    padding: 0 0 8em 7em;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

.contact section#contact .contacttop .inner h2 {
    font-size: 20px;
    width: 62%;
    margin-top: 4vw;
    line-height: 31px;
    color: #fff
}

.contact section#contact .contacttop .inner .img {
    height: 0;
    width: 38%;
    position: relative;
    right: -6%;
    padding-top: calc(341 / 428 * 38%);
    background-size: cover;
    background-position: center;
    z-index: 1;
    mix-blend-mode: multiply;
}

.contact section#contact .contactcont {
    background-color: #fff;
    padding: 65px 0 85px
}

.contact section#contact .contactcont .inner {
    width: 750px;
    margin: 0 auto
}

.contact section#contact .contactcont .inner img {
    width: 100%
}

.contact section#contact .contactcont .inner #wpcf7-f121-o1 span.en_cap,
.contact section#contact .contactcont .inner div#wpcf7-f5-o1 span.en_cap {
    line-height: 0px;
    display: block;
    color: #147b9a;
    font-size: 11px;
    margin-bottom: -0.5em;
}

.contact section#contact .contactcont .inner #wpcf7-f121-o1 h3,
.contact section#contact .contactcont .inner div#wpcf7-f5-o1 h3 {
    font-size: 24px;
    color: #191919;
    line-height: 1.5;
    margin-bottom: 12px;
    font-family: dnp-shuei-mgothic-std, sans-serif
}

.contact section#contact .contactcont .inner #wpcf7-f121-o1 h3 span,
.contact section#contact .contactcont .inner div#wpcf7-f5-o1 h3 span {
    font-size: 11px;
    line-height: 24px;
    color: #147b9a
}

.contact section#contact .contactcont .inner #wpcf7-f121-o1 input,
.contact section#contact .contactcont .inner div#wpcf7-f5-o1 input {
    background-color: #147B9A2E;
    border: none;
    border-radius: 8px;
    width: 100%;
    padding: 14px 24px;
    color: #909090;
    margin-bottom: 33px;
    margin-top: 0.3em;
    font-size: 15px;
    font-family: dnp-shuei-mgothic-std, sans-serif
}

.contact section#contact .contactcont .inner #wpcf7-f121-o1 select,
.contact section#contact .contactcont .inner div#wpcf7-f5-o1 select {
    background-color: #147B9A2E;
    border: none;
    border-radius: 8px;
    width: 100%;
    padding: 14px 24px;
    color: #909090;
    margin-bottom: 39px;
    font-size: 15px;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none
}

.contact section#contact .contactcont .inner span.wpcf7-form-control-wrap.menu-328 {
    display: block;
    position: relative
}

.contact section#contact .contactcont .inner span.wpcf7-form-control-wrap.menu-328:after {
    content: "";
    width: 12px;
    height: 12px;
    border: 0;
    border-top: solid 2px #147b9a;
    border-right: solid 2px #147b9a;
    -webkit-transform: rotate(135deg);
    transform: rotate(135deg);
    position: absolute;
    top: 16px;
    right: 24px;
    margin-top: -4px
}

.contact section#contact .contactcont .inner #wpcf7-f121-o1 textarea.wpcf7-form-control.wpcf7-textarea.wpcf7-validates-as-required,
.contact section#contact .contactcont .inner div#wpcf7-f5-o1 textarea.wpcf7-form-control.wpcf7-textarea.wpcf7-validates-as-required {
    background-color: #147B9A2E;
    border: none;
    border-radius: 8px;
    width: 100%;
    padding: 14px 24px;
    color: #909090;
    margin-bottom: 52px;
    font-size: 15px;
    resize: none
}

.contact section#contact .contactcont .inner #wpcf7-f121-o1 input.wpcf7-form-control.wpcf7-submit,
.contact section#contact .contactcont .inner div#wpcf7-f5-o1 input.wpcf7-form-control.wpcf7-submit {
    width: 269px;
    height: 80px;
    font-size: 18px;
    border: 1px solid #147b9a;
    border-radius: 40px;
    color: #fff;
    font-family: dnp-shuei-mgothic-std, sans-serif;
    background-color: #147b9a;
    display: block;
    margin: 40px auto 0;
    -webkit-transition: .3s cubic-bezier(.45, 0, .55, 1);
    transition: .3s cubic-bezier(.45, 0, .55, 1)
}

.contact section#contact .contactcont .inner #wpcf7-f121-o1 input.wpcf7-form-control.wpcf7-submit:hover,
.contact section#contact .contactcont .inner div#wpcf7-f5-o1 input.wpcf7-form-control.wpcf7-submit:hover {
    background-color: transparent;
    color: #147b9a
}

.contact section#contact .contactcont .inner #wpcf7-f121-o1 .wpcf7-acceptance .wpcf7-list-item,
.contact section#contact .contactcont .inner #wpcf7-f5-o1 .wpcf7-acceptance .wpcf7-list-item {
  margin-left: 0;
}

.contact section#contact .contactcont .inner #wpcf7-f121-o1 .wpcf7-acceptance label input,
.contact section#contact .contactcont .inner #wpcf7-f5-o1 .wpcf7-acceptance label input {
  display: none;
}

.contact section#contact .contactcont .inner #wpcf7-f121-o1 .wpcf7-acceptance label .wpcf7-list-item-label,
.contact section#contact .contactcont .inner #wpcf7-f5-o1 .wpcf7-acceptance label .wpcf7-list-item-label {
  align-items: center;
  color: #000;
  display: flex;
  font-size: 15px;
  font-weight: bold;
  position: relative;
}

.contact section#contact .contactcont .inner #wpcf7-f121-o1 .wpcf7-acceptance label .wpcf7-list-item-label::before,
.contact section#contact .contactcont .inner #wpcf7-f5-o1 .wpcf7-acceptance label .wpcf7-list-item-label::before {
  border: solid 2px #147b9a;
  border-radius: 8px;
  content: "";
  display: block;
  height: 29px;
  margin-right: 16px;
  opacity: 0.82;
  width: 29px;
}

.contact section#contact .contactcont .inner #wpcf7-f121-o1 .wpcf7-acceptance label input:checked + .wpcf7-list-item-label::after,
.contact section#contact .contactcont .inner #wpcf7-f5-o1 .wpcf7-acceptance label input:checked + .wpcf7-list-item-label::after {
  border-bottom: solid 2px #147b9a;
  border-right: solid 2px #147b9a;
  content: "";
  display: block;
  height: 12px;
  left: 12px;
  opacity: 0.82;
  position: absolute;
  top: 8px;
  transform: rotate(45deg);
  width: 6px;
}

.contact section#contact .contactcont .inner #wpcf7-f121-o1 .wpcf7-acceptance label .wpcf7-list-item-label .policy,
.contact section#contact .contactcont .inner #wpcf7-f5-o1 .wpcf7-acceptance label .wpcf7-list-item-label .policy {
  display: inline-block;
  position: relative;
}

.contact section#contact .contactcont .inner #wpcf7-f121-o1 .wpcf7-acceptance label .wpcf7-list-item-label .policy::before,
.contact section#contact .contactcont .inner #wpcf7-f5-o1 .wpcf7-acceptance label .wpcf7-list-item-label .policy::before {
  background-color: #707070;
  bottom: -2px;
  content: "";
  display: block;
  height: 2px;
  left: 0;
  position: absolute;
  width: 100%;
}

section#ircont .ttl-wrap2 {
    width: 100%;
    height: 422px;
    background: #044b60;
    background: -webkit-gradient(linear, left top, right bottom, from(#1d94b7), to(#044b60));
    background: linear-gradient(to bottom right, #1d94b7 0, #044b60 100%)
}

section#ircont .ttl-wrap2 .ttl {
    padding-top: 160px;
    padding-left: 114px
}

section#ircont .ttl-wrap2 .ttl h2 {
    font-size: 110px;
    font-weight: 400
}

section#ircont .ttl-wrap2 .ttl h3 {
    font-size: 20px;
    font-weight: 400
}

section#ircont .inner {
    padding: 120px 114px
}

section#ircont .inner ul.irlist {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

section#ircont .inner ul.irlist li {
    width: 30%;
    margin-bottom: 80px;
    margin-right: 5%
}

section#ircont .inner ul.irlist li:nth-child(3n) {
    margin-right: 0
}

section#ircont .inner ul.irlist li .date {
    font-size: 14px;
    letter-spacing: .48px;
    margin-bottom: 8px;
    color: #191919
}

section#ircont .inner ul.irlist li h3 {
    font-size: 20px;
    letter-spacing: .68px;
    margin-bottom: 5px;
    color: #191919;
}

section#ircont .ir-content-dnp p {
    font-size: 13px;
    line-height: 1.8;
    margin-bottom: 13px;
    color: #191919;
}

section#ircont .inner ul.irlist li a {
    font-size: 16px;
    letter-spacing: .58px;
    -webkit-text-decoration: var(--unnamed-decoration-underline);
    text-decoration: var(--unnamed-decoration-underline);
    color: #147b9a;
    border-bottom: 1px solid #147b9a;
    -webkit-transition: .3s ease;
    transition: .3s ease
}

section#ircont .inner ul.irlist li a:hover {
    opacity: .6;
}

section#newscont {
    position: relative
}

section#newscont:before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: block;
    background: #044b60;
    background: -webkit-gradient(linear, left top, right bottom, from(#1d94b7), to(#044b60));
    background: linear-gradient(to bottom right, #1d94b7 0, #044b60 100%)
}

section#newscont .ttl-wrap {
    position: relative;
    padding-bottom: 34px;
    font-weight: 400;
    display: inline-block;
    top: -40px;
    line-height: 1;
    padding-right: 0;
    z-index: 1;
    padding-left: 106px
}

section#newscont .ttl-wrap h2 {
    font-size: 82px
}

section#newscont .ttl-wrap:before {
    top: -70px
}

section#newscont .inner {
    width: 100%;
    padding: 120px 106px 77px
}

section#newscont .inner ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

section#newscont .inner ul li {
    width: calc(33.33% - 13.33px);
    margin-right: 20px;
    margin-bottom: 77px
}

section#newscont .inner ul li:nth-child(3n) {
    margin-right: 0
}

section#newscont .inner ul li a:hover .imghidden .img {
    -webkit-transform: scale(1.05);
    transform: scale(1.05)
}

section#newscont .inner ul li .imghidden {
    overflow: hidden;
    border-radius: 8px
}

section#newscont .inner ul li .imghidden .img {
    width: 100%;
    height: 0;
    padding-top: calc(175 / 319 * 100%);
    background-size: cover;
    background-position: center;
    -webkit-transition: transform .35s cubic-bezier(.45, 0, .55, 1);
    -webkit-transition: -webkit-transform .35s cubic-bezier(.45, 0, .55, 1);
    transition: -webkit-transform .35s cubic-bezier(.45, 0, .55, 1);
    transition: transform .35s cubic-bezier(.45, 0, .55, 1);
    transition: transform .35s cubic-bezier(.45, 0, .55, 1), -webkit-transform .35s cubic-bezier(.45, 0, .55, 1)
}

section#newscont .inner ul li p.date {
    font-size: 13px;
    margin-top: 20px;
    color: #fff
}

section#newscont .inner ul li h3 {
    margin-top: 9px;
    font-size: 16px;
    line-height: 1.6;
    color: #fff;
    letter-spacing: 0.12em;
    font-weight: 400;
}

section#newscont .pagerwrap {
    width: 100%;
    background-color: #fff;
    position: relative;
    bottom: 0;
    margin-top: 90px
}

section#newscont .pagerwrap .more-wrap {
    width: 389px;
    border-radius: 87px;
    margin: 0 auto;
    background: #fff;
    padding: 37px;
    position: relative;
    top: -30px;
    text-align: center
}

section#newscont .pagerwrap .more-wrap .wp-pagenavi {
    text-align: center;
    font-size: 24px
}

section#newscont .pagerwrap .more-wrap .wp-pagenavi span.current {
    color: #147b9a
}

section#newscont .pagerwrap .more-wrap .wp-pagenavi a {
    color: #1d94B784
}

section#newscont .pagerwrap .more-wrap .wp-pagenavi a,
section#newscont .pagerwrap .more-wrap .wp-pagenavi span {
    margin: 0 9px
}


section#boardgamecont {
    position: relative
}

section#boardgamecont:before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: block;
    background: #044b60;
    background: -webkit-gradient(linear, left top, right bottom, from(#1d94b7), to(#044b60));
    background: linear-gradient(to bottom right, #1d94b7 0, #044b60 100%)
}

section#boardgamecont .ttl-wrap {
    position: relative;
    padding-bottom: 34px;
    font-weight: 400;
    display: inline-block;
    top: -40px;
    line-height: 1;
    padding-right: 0;
    z-index: 1;
    padding-left: 106px
}

section#boardgamecont .ttl-wrap h2 {
    font-size: 82px
}

section#boardgamecont .ttl-wrap:before {
    top: -70px
}

section#boardgamecont .inner {
    width: 100%;
    padding: 60px 106px 77px
}

section#boardgamecont .inner ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

section#boardgamecont .inner ul li {
    width: auto;
    margin-right: 36px;
    margin-bottom: 77px
}

section#boardgamecont .inner ul li:nth-child(3n) {
    margin-right: 36px;
}

@media screen and (max-width: 812px) {
  .contact section#contact .contactcont .inner #wpcf7-f121-o1 .wpcf7-acceptance label .wpcf7-list-item-label,
  .contact section#contact .contactcont .inner #wpcf7-f5-o1 .wpcf7-acceptance label .wpcf7-list-item-label {
    font-size: 14px;
  }

  .contact section#contact .contactcont .inner #wpcf7-f121-o1 .wpcf7-acceptance label .wpcf7-list-item-label::before,
  .contact section#contact .contactcont .inner #wpcf7-f5-o1 .wpcf7-acceptance label .wpcf7-list-item-label::before {
    border-radius: 4px;
    height: 18px;
    margin-right: 8px;
    width: 18px;
  }

  .contact section#contact .contactcont .inner #wpcf7-f121-o1 .wpcf7-acceptance label input:checked + .wpcf7-list-item-label::after,
  .contact section#contact .contactcont .inner #wpcf7-f5-o1 .wpcf7-acceptance label input:checked + .wpcf7-list-item-label::after {
    height: 10px;
    left: 7px;
    top: 3px;
    width: 5px;
  }

  section#boardgamecont .inner ul li:nth-child(3n) {
      margin-right: 36px;
  }
}


section#boardgamecont .inner ul li a:hover .imghidden .img {
    -webkit-transform: scale(1.05);
    transform: scale(1.05)
}

section#boardgamecont .inner ul li .imghidden {
    overflow: hidden;
    border-radius: 22px
}

section#boardgamecont .inner ul li .imghidden .img {
    width: 100%;
    height: 0;
    padding-top: calc(175 / 319 * 100%);
    background-size: cover;
    background-position: center;
    -webkit-transition: transform .35s cubic-bezier(.45, 0, .55, 1);
    -webkit-transition: -webkit-transform .35s cubic-bezier(.45, 0, .55, 1);
    transition: -webkit-transform .35s cubic-bezier(.45, 0, .55, 1);
    transition: transform .35s cubic-bezier(.45, 0, .55, 1);
    transition: transform .35s cubic-bezier(.45, 0, .55, 1), -webkit-transform .35s cubic-bezier(.45, 0, .55, 1)
}

section#boardgamecont .inner ul li p.cate {
    width: 91%;
    font-family: 'dnp-shuei-mgothic-std';
    font-size: 16px;
    margin-top: 8px;
    line-height: 1.5em;
    color: #c3f4ff;
}

section#boardgamecont .inner ul li p.date {
    font-family: 'dnp-shuei-mgothic-std';
    font-size: 13px;
    margin-top: 9px;
    color: #c3f4ff;
}

section#boardgamecont .inner ul li h3 {
    margin-top: 9px;
    font-size: 24px;
    line-height: 1.6;
    color: #fff;
    letter-spacing: 0.12em;
    font-weight: 400;
}

section#boardgamecont .pagerwrap {
    width: 100%;
    background-color: #fff;
    position: relative;
    bottom: 0;
    margin-top: 90px
}

section#boardgamecont .pagerwrap .more-wrap {
    width: 389px;
    border-radius: 87px;
    margin: 0 auto;
    background: #fff;
    padding: 37px;
    position: relative;
    top: -30px;
    text-align: center
}

section#boardgamecont .pagerwrap .more-wrap .wp-pagenavi {
    text-align: center;
    font-size: 24px
}

section#boardgamecont .pagerwrap .more-wrap .wp-pagenavi span.current {
    color: #147b9a
}

section#boardgamecont .pagerwrap .more-wrap .wp-pagenavi a {
    color: #1d94B784
}

section#boardgamecont .pagerwrap .more-wrap .wp-pagenavi a,
section#boardgamecont .pagerwrap .more-wrap .wp-pagenavi span {
    margin: 0 9px
}

.newsdetail .ttlbg {
    width: 694px
}

.newsdetail section#newsdetail {
    position: relative
}

.newsdetail section#newsdetail:before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: block;
    background: #044b60;
    background: -webkit-gradient(linear, left top, right top, from(#1d94b7), to(#044b60));
    background: linear-gradient(to right, #1d94b7 0, #044b60 100%)
}

.newsdetail section#newsdetail .ttl-wrap {
    padding-left: 106px;
    position: relative;
    z-index: 1;
    top: -40px
}

.newsdetail section#newsdetail .ttl-wrap h2 {
    font-size: 82px;
    line-height: 1
}

.newsdetail section#newsdetail .ttl-wrap h3 {
    font-size: 20px;
    margin-top: 10px
}

.newsdetail section#newsdetail .singletop {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    padding: 0 106px 77px;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    max-width: 1280px;
    margin: 0 auto
}

.newsdetail section#newsdetail .singletop .left {
    width: calc(50% - 30px);
    margin-right: 30px
}

.newsdetail section#newsdetail .singletop .left p.date {
    font-size: 21px;
    color: #fff;
    margin-bottom: 17px
}

.newsdetail section#newsdetail .singletop .left .txt {
    color: #fff;
    font-size: 28px;
    letter-spacing: .95px;
    line-height: 41px
}

.newsdetail section#newsdetail .singletop .right {
    width: 50%
}

.newsdetail section#newsdetail .singletop .right .img {
    border-radius: 9px;
    width: 100%;
    height: 0;
    padding-top: calc(175 / 319 * 100%);
    background-size: cover;
    background-position: center;
    -webkit-transition: transform .35s cubic-bezier(.45, 0, .55, 1);
    -webkit-transition: -webkit-transform .35s cubic-bezier(.45, 0, .55, 1);
    transition: -webkit-transform .35s cubic-bezier(.45, 0, .55, 1);
    transition: transform .35s cubic-bezier(.45, 0, .55, 1);
    transition: transform .35s cubic-bezier(.45, 0, .55, 1), -webkit-transform .35s cubic-bezier(.45, 0, .55, 1)
}

.newsdetail section#newsdetail .singlecont {
    background-color: #fff;
    padding-bottom: 142px
}

.newsdetail section#newsdetail .singlecont .txtinner {
    width: 69%;
    margin: 0 auto;
    padding-top: 50px;
    line-height: 30px
}

.newsdetail section#newsdetail .singlecont .txtinner .txt-wrap {
    margin-bottom: 60px
}

.newsdetail section#newsdetail .singlecont .txtinner p,
.newsdetail section#newsdetail .singlecont .txtinner ul,
.newsdetail section#newsdetail .singlecont .txtinner ol {
    color: #191919;
    font-size: 17px;
    letter-spacing: .68px;
    margin-bottom: 34px;
    line-height: 1.75;
}

.newsdetail section#newsdetail .singlecont .txtinner a {
    color: #147b9a;
    font-size: 17px;
    letter-spacing: .68px;
    margin-bottom: 34px;
    line-height: 1.75;
    border-bottom: solid 0px #147b9a;
}

.newsdetail section#newsdetail .singlecont .txtinner a:hover {
    color: #005a87;
    border-bottom: solid 1px #005a87;
    transition: color .1s, border-bottom .1s ease;
}

.newsdetail section#newsdetail .singlecont .txtinner .link-wrap a:nth-child(2n) {
    background-color: #147b9a;
    border: 1px solid #147b9a;
}

.newsdetail section#newsdetail .singlecont .txtinner .link-wrap a:nth-child(2n):hover {
    color: #147b9a;
    background-color: transparent;
    border-color: #147b9a;
}

.newsdetail section#newsdetail .singlecont .txtinner .readmore {
	color: #ffffff;
    margin: 0 auto 16px;
    width: 41rem;
    height: auto;
    font-size: 16px;
    line-height: 1.35;
    padding: 22px 28px 22px 28px;
}

.newsdetail section#newsdetail .singlecont .txtinner .readmore:hover {
    color: #1d94b7;
    transition-delay: color 2s;
}

.newsdetail section#newsdetail .singlecont .txtinner ul {
  padding-left: 1em;
}

.newsdetail section#newsdetail .singlecont .txtinner ul > li {
  list-style: disc;
}

.newsdetail section#newsdetail .singlecont .txtinner ol {
  padding-left: 1em;
}

.newsdetail section#newsdetail .singlecont .txtinner ol > li {
  list-style: decimal;
}

.newsdetail section#other {
    position: relative
}

.newsdetail section#other:before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: block;
    background: #044b60;
    background: -webkit-gradient(linear, left top, right top, from(#1d94b7), to(#044b60));
    background: linear-gradient(to right, #1d94b7 0, #044b60 100%)
}

.newsdetail section#other .ttl-wrap {
    border-radius: 0 0 138px 0;
    background-color: #fff;
    padding-right: 148px;
    top: -63px;
    padding-left: 106px
}

.newsdetail section#other .ttl-wrap h2 {
    font-size: 82px
}

.newsdetail section#other .ttl-wrap h3 {
    font-size: 20px
}

.newsdetail section#other .slider2 {
    position: relative;
    top: 20px;
    left: 7%;
    overflow: hidden;
    padding-bottom: 127px
}

.newsdetail section#other .slider2 li.swiper-slide a:hover .imghidden .img {
    -webkit-transform: scale(1.05);
    transform: scale(1.05)
}

.newsdetail section#other .slider2 li.swiper-slide .imghidden {
    overflow: hidden;
    border-radius: 8px
}

.newsdetail section#other .slider2 li.swiper-slide .imghidden .img {
    width: 100%;
    height: 0;
    padding-top: calc(175 / 319 * 100%);
    background-size: cover;
    background-position: center;
    -webkit-transition: transform .35s cubic-bezier(.45, 0, .55, 1);
    -webkit-transition: -webkit-transform .35s cubic-bezier(.45, 0, .55, 1);
    transition: -webkit-transform .35s cubic-bezier(.45, 0, .55, 1);
    transition: transform .35s cubic-bezier(.45, 0, .55, 1);
    transition: transform .35s cubic-bezier(.45, 0, .55, 1), -webkit-transform .35s cubic-bezier(.45, 0, .55, 1)
}

.newsdetail section#other .slider2 li.swiper-slide .date {
    font-size: 13px;
    color: #fff;
    margin-top: 15px
}

.newsdetail section#other .slider2 li.swiper-slide h3 {
    font-size: 16px;
    color: #fff;
    margin-top: 8px;
    font-weight: 400;
    line-height: 1.8;
    letter-spacing: .9px
}

.newsdetail section#other .newsmore {
    width: 100%;
    background-color: #fff;
    position: relative;
    bottom: 0
}

.newsdetail section#other .newsmore .more-wrap {
    width: 389px;
    border-radius: 87px;
    margin: 0 auto;
    background: #fff;
    padding: 37px;
    position: relative;
    top: -50px
}

.newsdetail section#other .newsmore .more-wrap .readmore {
    border-radius: 40px;
    width: 232px;
    margin: 0 auto;
    background-color: transparent;
    color: #147b9a
}

.newsdetail section#other .newsmore .more-wrap .readmore:hover {
    background-color: #147b9a;
    color: #fff;
    font-size: 16px
}

.slick-loading .slick-list {
    background: #fff url(ajax-loader.gif) center center no-repeat
}

@font-face {
    font-family: slick;
    src: url(fonts/slick.eot);
    src: url(fonts/slick.eot?#iefix) format("embedded-opentype"), url(fonts/slick.woff) format("woff"), url(fonts/slick.ttf) format("truetype"), url(fonts/slick.svg#slick) format("svg");
    font-weight: 400;
    font-style: normal
}

.slick-next,
.slick-prev {
    position: absolute;
    display: block;
    height: 20px;
    width: 20px;
    line-height: 0;
    font-size: 0;
    cursor: pointer;
    background: 0 0;
    color: transparent;
    top: 50%;
    -webkit-transform: translate(0, -50%);
    transform: translate(0, -50%);
    padding: 0;
    border: none;
    outline: 0
}

.slick-next:focus,
.slick-next:hover,
.slick-prev:focus,
.slick-prev:hover {
    outline: 0;
    background: 0 0;
    color: transparent
}

.slick-next:focus:before,
.slick-next:hover:before,
.slick-prev:focus:before,
.slick-prev:hover:before {
    opacity: 1
}

.slick-next.slick-disabled:before,
.slick-prev.slick-disabled:before {
    opacity: .25
}

.slick-next:before,
.slick-prev:before {
    font-family: slick;
    font-size: 20px;
    line-height: 1;
    color: #fff;
    opacity: .75;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale
}

.slick-prev {
    left: -25px
}

[dir=rtl] .slick-prev {
    left: auto;
    right: -25px
}

.slick-prev:before {
    content: "←"
}

[dir=rtl] .slick-prev:before {
    content: "→"
}

.slick-next {
    right: -25px
}

[dir=rtl] .slick-next {
    left: -25px;
    right: auto
}

.slick-next:before {
    content: "→"
}

[dir=rtl] .slick-next:before {
    content: "←"
}

.slick-dotted.slick-slider {
    margin-bottom: 30px
}

.slick-dots {
    position: absolute;
    bottom: -25px;
    list-style: none;
    display: block;
    text-align: center;
    padding: 0;
    margin: 0;
    width: 100%
}

.slick-dots li {
    position: relative;
    display: inline-block;
    height: 20px;
    width: 20px;
    margin: 0 5px;
    padding: 0;
    cursor: pointer
}

.slick-dots li button {
    border: 0;
    background: 0 0;
    display: block;
    height: 20px;
    width: 20px;
    outline: 0;
    line-height: 0;
    font-size: 0;
    color: transparent;
    padding: 5px;
    cursor: pointer
}

.slick-dots li button:focus,
.slick-dots li button:hover {
    outline: 0
}

.slick-dots li button:focus:before,
.slick-dots li button:hover:before {
    opacity: 1
}

.slick-dots li button:before {
    position: absolute;
    top: 0;
    left: 0;
    content: "•";
    width: 20px;
    height: 20px;
    font-family: slick;
    font-size: 6px;
    line-height: 20px;
    text-align: center;
    color: #000;
    opacity: .25;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale
}

.slick-dots li.slick-active button:before {
    color: #000;
    opacity: .75
}

.slick-slider {
    position: relative;
    display: block;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    -ms-touch-action: pan-y;
    touch-action: pan-y;
    -webkit-tap-highlight-color: transparent
}

.slick-list {
    position: relative;
    overflow: hidden;
    display: block;
    margin: 0;
    padding: 0
}

.slick-list:focus {
    outline: 0
}

.slick-list.dragging {
    cursor: pointer;
    cursor: hand
}

.slick-slider .slick-list,
.slick-slider .slick-track {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0)
}

.slick-track {
    position: relative;
    left: 0;
    top: 0;
    display: block;
    margin-left: auto;
    margin-right: auto
}

.slick-track:after,
.slick-track:before {
    content: "";
    display: table
}

.slick-track:after {
    clear: both
}

.slick-loading .slick-track {
    visibility: hidden
}

.slick-slide {
    float: left;
    height: 100%;
    min-height: 1px;
    display: none
}

[dir=rtl] .slick-slide {
    float: right
}

.slick-slide img {
    display: block
}

.slick-slide.slick-loading img {
    display: none
}

.slick-slide.dragging img {
    pointer-events: none
}

.slick-initialized .slick-slide {
    display: block
}

.slick-loading .slick-slide {
    visibility: hidden
}

.slick-vertical .slick-slide {
    display: block;
    height: auto;
    border: 1px solid transparent
}

.slick-arrow.slick-hidden {
    display: none
}

section#stafftop {
    position: relative;
    padding-bottom: 60px
}

section#stafftop:before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: block;
    background: #044b60;
    background: -webkit-gradient(linear, left top, right bottom, from(#1d94b7), to(#044b60));
    background: linear-gradient(to bottom right, #1d94b7 0, #044b60 100%)
}

section#stafftop .ttl-wrap {
    position: relative;
    padding-bottom: 34px;
    font-weight: 400;
    display: inline-block;
    top: -40px;
    line-height: 1;
    padding-right: 0;
    z-index: 1;
    padding-left: 106px
}

section#stafftop .ttl-wrap h2 {
    font-size: 82px
}

section#stafftop .topinner {
    padding: 0 114px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    position: relative;
    top: -40px;
    max-width: 1280px;
    margin: 32px auto 0px auto;
}

section#stafftop .topinner .txtwrap {
    width: 60%;
    position: relative;
    z-index: 1;
    white-space: pre
}

section#stafftop .topinner .txtwrap h2 {
    font-size: 74px;
    font-weight: 400;
    margin-bottom: 7px
}

section#stafftop .topinner .txtwrap p {
    font-size: 20px;
    line-height: 31px
}

section#stafftop .topinner .img {
    width: 40%;
    height: 0;
    padding-top: calc(414 / 459 * 40%);
    background-size: cover;
    background-position: center
}

section.staffcont {
    padding-top: 60px
}

section.staffcont .inner {
    padding: 0 114px;
    margin: 0 auto
}

section.staffcont .inner .ttl-wrap h2 {
    font-size: 62px;
    color: #147b9a;
    line-height: 72px
}

section.staffcont .inner .ttl-wrap h3 {
    font-size: 20px;
    color: #147b9a
}

section.staffcont .inner .ceo {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

section.staffcont .inner .ceo .left {
    width: calc(50% - 35px);
    margin-right: 35px
}

section.staffcont .inner .ceo .left .img {
    width: 100%;
    height: 0;
    background-size: cover;
    background-position: center;
    padding-top: calc(480 / 540 * 100%)
}

section.staffcont .inner .ceo .right {
    width: 50%
}

section.staffcont .inner .ceo .right .position {
    font-size: 24px;
    color: #147b9a;
    line-height: 10px;
    margin-bottom: 20px
}

section.staffcont .inner .ceo .right h4 {
    font-size: 43px;
    line-height: 65px;
    color: #4a4a4a;
    margin-bottom: 24px
}

section.staffcont .inner .ceo .right h4 span {
    display: block;
    line-height: 18px;
    font-size: 15px;
    font-weight: 400
}

section.staffcont .inner .ceo .right p.txt {
    font-variant: JIS90;
    color: #191919;
    font-size: 18px;
    letter-spacing: .68px;
    margin-bottom: 24px;
    line-height: 1.9
}

section.staffcont .inner .ceo .right a {
    font-size: 24px;
    line-height: 53px;
    letter-spacing: .82px;
    color: #147b9a;
    font-weight: 700;
    display: inline-block;
    position: relative
}

section.staffcont .inner .ceo .right a:before {
    content: "";
    width: 100%;
    height: 2px;
    position: absolute;
    top: 1.8em;
    left: 0;
    bottom: 0;
    -webkit-transition: .5s ease;
    transition: .5s ease;
    background-color: #147b9a;
    -webkit-transform: scaleX(1);
    transform: scaleX(1)
}

section.staffcont .inner .ceo .right a:hover:before {
    -webkit-animation: border .6s forwards;
    animation: border .6s forwards
}

section.staffcont .inner ul.stafflist {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-top: 34px
}

section.staffcont .inner ul.stafflist li {
    width: calc(33% - 8px);
    margin-right: 12px
}

section.staffcont .inner ul.stafflist li:last-child {
    margin-right: 0
}

section.staffcont .inner ul.stafflist li .img {
    width: 100%;
    height: 0;
    background-size: cover;
    background-position: center;
    padding-top: calc(352 / 352 * 100%)
}

section.staffcont .inner ul.stafflist li .position {
    font-size: 16px;
    color: #147b9a;
    line-height: 20px;
    margin-top: 5px
}

section.staffcont .inner ul.stafflist li h4 {
    font-size: 32px;
    line-height: 51px;
    color: #4a4a4a;
    margin-bottom: 11px
}

section.staffcont .inner ul.stafflist li h4 span {
    display: block;
    line-height: 18px;
    font-size: 15px;
    font-weight: 400
}

section.staffcont .inner ul.stafflist li p.txt {
    color: #191919;
    font-size: 20px;
    letter-spacing: .68px;
    margin-bottom: 30px
}

section.staffcont .inner ul.stafflist li a {
    font-size: 17px;
    line-height: 31px;
    letter-spacing: .68px;
    color: #147b9a;
    font-weight: 700;
    display: inline-block;
    position: relative
}

section.staffcont .inner ul.stafflist li a:before {
    content: "";
    width: 100%;
    height: 2px;
    position: absolute;
    top: 1.8em;
    left: 0;
    bottom: 0;
    -webkit-transition: .5s ease;
    transition: .5s ease;
    background-color: #147b9a;
    -webkit-transform: scaleX(1);
    transform: scaleX(1)
}

section.staffcont .inner ul.stafflist li a:hover:before {
    -webkit-animation: border .6s forwards;
    animation: border .6s forwards
}

section#othermember {
    margin-top: 100px;
}

section#othermembererror {
    margin-top: 10em;
}

section#othermember .inner {
    padding: 0 114px;
    margin: 0 auto
}

section#othermember .inner .ttl-wrap h2 {
    font-size: 62px;
    color: #147b9a;
    line-height: 72px
}

section#othermember .inner .ttl-wrap h3 {
    font-size: 20px;
    color: #147b9a
}

section#othermember .inner ul.otherlist {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

section#othermember .inner ul.otherlist li {
    width: calc(33% - 10.66px);
    margin-right: 16px
}

section#othermember .inner ul.otherlist li:last-child {
    margin-right: 0
}

section#othermember .inner ul.otherlist li .img {
    width: 100%;
    height: 0;
    background-size: cover;
    background-position: center;
    padding-top: calc(246 / 368 * 100%)
}

section#othermember .inner ul.otherlist li .position {
    font-size: 16px;
    color: #147b9a;
    line-height: 20px;
    margin-top: 22px
}

section#othermember .inner ul.otherlist li h4 {
    font-size: 30px;
    line-height: 40px;
    color: #4a4a4a;
    margin-bottom: 12px;
    margin-top: 6px
}

section#othermember .inner ul.otherlist li h4 span {
    display: block;
    line-height: 18px;
    font-size: 15px;
    font-weight: 400
}

section#othermember .inner ul.otherlist li p.txt {
    color: #191919;
    font-size: 20px;
    letter-spacing: .68px;
    margin-bottom: 10px
}

section#othermember .inner ul.otherlist li a {
    font-size: 17px;
    line-height: 31px;
    letter-spacing: .68px;
    color: #147b9a;
    font-weight: 700;
    display: inline-block;
    position: relative
}

section#othermember .inner ul.otherlist li a:before {
    content: "";
    width: 100%;
    height: 2px;
    position: absolute;
    top: 1.8em;
    left: 0;
    bottom: 0;
    -webkit-transition: .5s ease;
    transition: .5s ease;
    background-color: #147b9a;
    -webkit-transform: scaleX(1);
    transform: scaleX(1)
}

section#othermember .inner ul.otherlist li a:hover:before {
    -webkit-animation: border .6s forwards;
    animation: border .6s forwards
}

@-webkit-keyframes border {
    0% {
        -webkit-transform: scaleX(1);
        transform: scaleX(1);
        -webkit-transform-origin: right top;
        transform-origin: right top
    }

    49% {
        -webkit-transform: scaleX(0);
        transform: scaleX(0);
        -webkit-transform-origin: right top;
        transform-origin: right top
    }

    50% {
        -webkit-transform: scaleX(0);
        transform: scaleX(0);
        -webkit-transform-origin: left top;
        transform-origin: left top
    }

    100% {
        -webkit-transform: scaleX(1);
        transform: scaleX(1);
        -webkit-transform-origin: left top;
        transform-origin: left top
    }
}

@keyframes border {
    0% {
        -webkit-transform: scaleX(1);
        transform: scaleX(1);
        -webkit-transform-origin: right top;
        transform-origin: right top
    }

    49% {
        -webkit-transform: scaleX(0);
        transform: scaleX(0);
        -webkit-transform-origin: right top;
        transform-origin: right top
    }

    50% {
        -webkit-transform: scaleX(0);
        transform: scaleX(0);
        -webkit-transform-origin: left top;
        transform-origin: left top
    }

    100% {
        -webkit-transform: scaleX(1);
        transform: scaleX(1);
        -webkit-transform-origin: left top;
        transform-origin: left top
    }
}

.staffdetail .l-main.pt100 {
    padding-top: 85px
}

section#staffdetailtop .ttl-wrap {
    padding-left: 106px;
    padding-bottom: 0
}

section#staffdetailtop .ttl-wrap h2 {
    font-weight: 110px
}

section#staffdetailtop .topinner {
    position: relative;
    width: 70%;
    margin: 0 auto;
    height: 70vh;
    min-height: 489px;
    max-width: 960px
}

section#staffdetailtop .topinner .txtwrap {
    width: 50%;
    position: absolute;
    top: 50%;
    left: 0;
    z-index: 1;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%)
}

section#staffdetailtop .topinner .txtwrap .img {
    width: 120%;
    height: 0;
    background-size: cover;
    background-position: center;
    padding-top: calc(480 / 540 * 120%);
    position: relative;
    top: 0;
    right: -6%;
    -webkit-transform: translateY(0);
    transform: translateY(0)
}

section#staffdetailtop .topinner .txtwrap .position {
    letter-spacing: 0;
    color: #147b9a;
    text-transform: uppercase;
    line-height: 40px;
    font-size: 25px
}

section#staffdetailtop .topinner .txtwrap h4 {
    font-size: 67px;
    letter-spacing: 0;
    color: #4a4a4a;
    line-height: 92px;
    font-weight: 700;
    margin-top: -0.1em;
}

section#staffdetailtop .topinner .txtwrap h4 span {
    display: block;
    font-size: 23px;
    line-height: 26px;
    margin-top: -0.15em;
}

section#staffdetailtop .topinner .img {
    width: 77%;
    height: 0;
    background-size: cover;
    background-position: center;
    padding-top: calc(480 / 540 * 77%);
    position: absolute;
    top: 50%;
    right: -12%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%)
}

section#staffdetailtop .topinner .img.othekv {
    width: 65%;
    padding-top: calc(457 / 684 * 68%);
    border-radius: 24px
}

section.staffdetailcont .inner {
    width: 70%;
    max-width: 960px;
    margin: 0 auto
}

section.staffdetailcont .inner .contents {
    padding-bottom: 38px
}

section.staffdetailcont .inner .contents h4 {
    font-size: 25px;
    line-height: 1.7;
    letter-spacing: 0;
    color: #343434;
    margin-bottom: 0.5em;
}

section.staffdetailcont .inner .contents p {
    font-size: 16px;
    line-height: 30px;
    letter-spacing: 0;
    color: #3f2e32;
    font-weight: 400
}

section.staffdetailcont .inner .contents .txtwrap1 {
    margin-bottom: 50px
}

section.staffdetailcont .inner .contents .txtwrap2,
section.staffdetailcont .inner .contents .txtwrap3 {
    margin-bottom: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

section.staffdetailcont .inner .contents .txtwrap2 .img,
section.staffdetailcont .inner .contents .txtwrap3 .img {
    width: 100%;
    height: 0;
    background-size: cover;
    background-position: center;
    padding-top: calc(289 / 432 * 100%);
    position: relative
}

section.staffdetailcont .inner .contents .txtwrap2 .left {
    width: 50%
}

section.staffdetailcont .inner .contents .txtwrap2 .right {
    width: calc(50% - 48px);
    margin-left: 48px
}

section.staffdetailcont .inner .contents .txtwrap3 {
    margin-bottom: 53px
}

section.staffdetailcont .inner .contents .txtwrap3 .left {
    width: calc(50% - 48px);
    margin-right: 48px
}

section.staffdetailcont .inner .contents .txtwrap3 .right {
    width: 50%
}

section.staffdetailcont .inner .contents .txtwrap3 .right .img {
    width: 100%;
    height: 0;
    background-size: cover;
    background-position: center;
    padding-top: calc(289 / 432 * 100%);
    position: relative;
    margin-top: 4em;
    margin-bottom: 5em;
}

section#endroll {
    position: relative
}

section#endroll:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: block;
    background: #044b60;
    z-index: -1;
    background: -webkit-gradient(linear, left top, right bottom, from(#1d94b7), to(#044b60));
    background: linear-gradient(to bottom right, #1d94b7 0, #044b60 100%)
}

section#endroll .inner {
    width: 70%;
    max-width: 960px;
    margin: 0 auto;
    padding: 65px 0 109px
}

section#endroll .inner h4 {
    font-size: 25px;
    line-height: 59px;
    letter-spacing: 0;
    color: #fff;
    margin-bottom: 0.3em;
}

section#endroll .inner p {
    font-size: 16px;
    line-height: 30px;
    letter-spacing: .99px;
    color: #fff;
    font-weight: 400
}

section#endroll .steffmore {
    width: 100%;
    background-color: #fff;
    position: relative;
    bottom: 0
}

section#endroll .steffmore .more-wrap {
    width: 389px;
    border-radius: 87px;
    margin: 0 auto;
    background: #fff;
    padding: 37px;
    position: relative;
    top: -50px
}

section#endroll .steffmore .more-wrap .readmore {
    border-radius: 40px;
    width: 232px;
    margin: 0 auto;
    background-color: transparent;
    color: #147b9a
}

section#endroll .steffmore .more-wrap .readmore:hover {
    background-color: #147b9a;
    color: #fff
}

.topkv {
    position: relative;
    width: 100%;
    height: 100vh
}

.topkv:after {
    content: "";
    background: #32788f;
    width: 100%;
    height: 110vh;
    position: absolute;
    top: 0;
    left: 0
}

@media screen and (max-width: 812px) {
.topkv:after {
    content: "";
    background: #327087;
    width: 100%;
    height: 110vh;
    position: absolute;
    top: 0;
    left: 0;
}
}

.topkv .bg-img {
    position: absolute;
    left: 0;
    top: 0;
    height: 100%;
    height: 100vh;
    width: 100%;
    text-align: center;
    z-index: 1
}

.topkv .bg-img video {
    position: absolute;
    top: 0
}

.topkv .swiper-container {
    width: 100%;
    height: calc(100vh + 74px)
}

.topkv .swiper-container .swiper-slide.swiper-slide-active {
    opacity: 1 !important
}

.topkv .swiper-container .swiper-slide-prev {
    opacity: 0
}

.topkv .swiper-container .swiper-pagination-bullet {
    width: 56px;
    height: 8px;
    border-radius: 12px;
    opacity: .41;
    background: #fff 0 0 no-repeat padding-box
}

.topkv .swiper-container .swiper-pagination-bullet-active {
    opacity: 1;
    background: #1d94b7 0 0 no-repeat padding-box
}

.topkv .swiper-container .swiper-pagination {
    bottom: 180px
}

.topkv .swiper-container .swiper-slide {
    position: relative;
    opacity: 0 !important;
    -webkit-transition-delay: .3s;
    transition-delay: .3s
}

.topkv .swiper-container .swiper-slide div.txt-wrap {
    text-align: center;
    position: absolute;
    top: calc(50% - 30px);
    left: 0;
    right: 0;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%)
}

.topkv .swiper-container .swiper-slide div.txt-wrap h2 {
    font-size: 7vw;
    color: #fff;
    letter-spacing: 1.5px;
}

.topkv .swiper-container .swiper-slide div.txt-wrap h2 span {
    color: transparent;
    -webkit-text-stroke: 2px #fff;
    text-stroke: 1.5px #fff
}

.topkv .swiper-container .swiper-slide div.txt-wrap h3 {
    font-size: 21px;
    color: #fff;
    letter-spacing: 3.8px;
    margin-top: 1.35em;
}

.topkv .swiper-container .swiper-slide .slide-inner {
    position: absolute;
    top: calc(50% - 30px);
    left: 0;
    right: 0;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    width: 80%;
    margin: auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

.topkv .swiper-container .swiper-slide .slide-inner .left {
    width: 45%;
    position: relative;
    z-index: 1;
    word-break: break-all
}

.topkv .swiper-container .swiper-slide .slide-inner .left p.cate {
    letter-spacing: 0;
    color: #147b9a;
    text-transform: uppercase;
    font-size: 16px;
    font-weight: 700;
    margin-bottom: 21px
}

.topkv .swiper-container .swiper-slide .slide-inner .left h3 {
    font-size: 40px;
    line-height: 1.4;
    color: #fff;
    margin-bottom: 10px
}

.topkv .swiper-container .swiper-slide .slide-inner .left span {
    font-size: 22px;
    display: block;
    font-weight: bold;
    line-height: 1.5;
    margin-bottom: 4px;
}

.topkv .swiper-container .swiper-slide .slide-inner .left p.cap {
    font-size: 20px;
    color: #fff;
    margin-bottom: 30px;
    line-height: 1.8
}

.topkv .swiper-container .swiper-slide .slide-inner .readmore {
    color: #fff;
    padding-top: 19px
}

.topkv .swiper-container .swiper-slide .slide-inner .right {
    width: 55%;
    margin-left: 2%
}

.topkv .swiper-container .swiper-slide .slide-inner .right .img {
    width: 100%;
    height: 0;
    padding-top: calc(383 / 680 * 100%);
    background-size: cover;
    background-position: center;
    border-radius: 24px;
}

section#about {
    background-color: #fff;
    padding-top: 114px;
    padding-bottom: 137px;
    position: relative;
    top: -30px;
    z-index: 1;
    border-radius: 0 140px 0 0/0 120px 0 0
}

section#about .inner {
    text-align: center
}

section#about .inner .txt p {
    font-size: 20px;
    letter-spacing: -.14px;
    color: #147b9a;
    margin-bottom: 8px;
    line-height: 2.2
}

section#news {
    width: 100%;
    position: relative
}

section#news .inner {
    padding-bottom: 5vw;
}

section#news:after {
    content: "";
    background: #044b60;
    background: -webkit-gradient(linear, left top, right bottom, from(#38c0e9), to(#044b60));
    background: linear-gradient(to bottom right, #38c0e9 0, #044b60 100%);
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1
}

section#news .ttl-wrap {
    max-width: 632px;
    top: -90px;
    padding-left: 6.2%;
    padding-right: 155px;
    border-radius: 0 0 138px 0;
    background-color: #fff;
    z-index: 1
}

section#news .slider2 {
    position: relative;
    top: -30px;
    left: 6.6%;
    overflow: hidden
}

section#news .slider2 li.swiper-slide a:hover .imghidden .img {
    -webkit-transform: scale(1.05);
    transform: scale(1.05)
}

section#news .slider2 li.swiper-slide .imghidden {
    overflow: hidden;
    border-radius: 8px
}

section#news .slider2 li.swiper-slide .imghidden .img {
    width: 100%;
    height: 0;
    padding-top: calc(175 / 319 * 100%);
    background-size: cover;
    background-position: center;
    -webkit-transition: transform .35s cubic-bezier(.45, 0, .55, 1);
    -webkit-transition: -webkit-transform .35s cubic-bezier(.45, 0, .55, 1);
    transition: -webkit-transform .35s cubic-bezier(.45, 0, .55, 1);
    transition: transform .35s cubic-bezier(.45, 0, .55, 1);
    transition: transform .35s cubic-bezier(.45, 0, .55, 1), -webkit-transform .35s cubic-bezier(.45, 0, .55, 1)
}

section#news .slider2 li.swiper-slide .date {
    font-size: 13px;
    color: #fff;
    margin-top: 13px;
}

section#news .slider2 li.swiper-slide h3 {
    font-size: 16px;
    color: #fff;
    margin-top: 7px;
    font-weight: 400;
    line-height: 1.6;
    letter-spacing: .9px
}

section#news .newsmore {
    width: 100%;
    background-color: #fff;
    position: relative;
    bottom: -1px;
}

section#news .newsmore .more-wrap {
    width: 389px;
    border-radius: 87px;
    margin: 0 auto;
    background: #fff;
    padding: 37px;
    position: relative;
    top: -30px
}

section#news .newsmore .more-wrap .readmore {
    margin: 0 auto;
    background-color: transparent;
    color: #147b9a
}

section#news .newsmore .more-wrap .readmore:hover {
    background-color: #147b9a;
    color: #fff
}

section#works {
    padding-top: 193px;
    margin-top: 160px;
    position: relative
}

section#works:after {
    content: "";
    background: #044b60;
    background: -webkit-gradient(linear, left top, right bottom, from(#38c0e9), to(#044b60));
    background: linear-gradient(to bottom right, #38c0e9 0, #044b60 100%);
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1
}

section#works .ttl-wrap {
    right: 0;
    position: absolute;
    top: -90px;
    padding-left: 149px;
    padding-right: 6%;
    border-radius: 23px 0 0 168px !important;
    background-color: #fff
}

section#works .ttl-wrap:before {
    content: "";
    background-color: #fff;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    border-radius: 138px 0 0 138px !important
}

section#works .inner {
    padding-bottom: 47px
}

section#works #masonry {
    position: relative;
    width: 86%;
    margin: 0 auto
}

section#works #masonry .item {
    margin-bottom: 60px;
    display: inline-block;
    width: calc(50% - 30px)
}

section#works #masonry .item .imghidden {
    overflow: hidden;
    border-radius: 13px;
}

section#works #masonry .item .imghidden img {
    -webkit-transition: transform .35s cubic-bezier(.45, 0, .55, 1);
    -webkit-transition: -webkit-transform .35s cubic-bezier(.45, 0, .55, 1);
    transition: -webkit-transform .35s cubic-bezier(.45, 0, .55, 1);
    transition: transform .35s cubic-bezier(.45, 0, .55, 1);
    transition: transform .35s cubic-bezier(.45, 0, .55, 1), -webkit-transform .35s cubic-bezier(.45, 0, .55, 1)
}

section#works #masonry .item a:hover .imghidden img {
    -webkit-transform: scale(1.05);
    transform: scale(1.05)
}

section#works #masonry .item img {
    width: 100%;
    height: auto
}

section#works #masonry .item h3 {
	font-family: 'dnp-shuei-mgothic-std';
    font-size: 23px;
    font-weight: 400;
    margin-top: 10px;
    margin-bottom: 10px;
    color: #fff;
    letter-spacing: 0;
    line-height: 1.6
}

section#works #masonry .item p {
	font-family: 'dnp-shuei-mgothic-std';
    margin-top: 14px;
    font-size: 17px;
    letter-spacing: .34px;
    color: #c3f4ff;
}

section#works .worksmore {
    width: 100%;
    background-color: #fff;
    position: relative;
    bottom: 0
}

section#works .worksmore .more-wrap {
    width: 389px;
    border-radius: 87px;
    margin: 0 auto;
    background: #fff;
    padding: 37px;
    position: relative;
    top: -30px
}

section#works .worksmore .more-wrap .readmore {
    margin: 0 auto;
    background-color: transparent;
    color: #147b9a;
    letter-spacing: .96px;
}

section#works .worksmore .more-wrap .readmore:hover {
    background-color: #147b9a;
    color: #ffffff;
    letter-spacing: .96px;
}

section#vr {
  margin: 36px 0 43px;
}

section#vr .container {
  align-items: center;
  background-color: #e2e5e9;
  border-radius: 107px;
  display: flex;
  justify-content: center;
  overflow: hidden;
  padding: 72px 0 69px;
  position: relative;
}

section#vr .bg {
  left: 50%;
  position: absolute;
  top: 0;
  transform: translateX(-50%);
  width: 98.0966325vw;
}

section#vr .bg img {
  width: 100%;
}

section#vr .wrap {
  color: #111;
  position: relative;
  text-align: center;
  width: 100%;
}

section#vr .ttl {
  color: #1d94b7;
  font-size: 50px;
  font-weight: bold;
}

section#vr .ttl::before {
  background: no-repeat url(../images/top/vr.png) 0 0;
  background-size: contain;
  content: "";
  display: block;
  height: 212px;
  margin: 0 auto 29px;
  width: 208px;
}

section#vr .txt {
  color: #1d94b7;
  font-size: 16px;
  line-height: 1.9;
  margin-top: 24px;
}

section#vr .txt .-en {
  font-size: 18px;
}

section#vr .vrmore {
  margin-top: 46px;
}

section#vr .vrmore .readmore {
  color: #fff;
  display: inline-block;
}

section#vr .vrmore .readmore:hover {
  color: #147b9a;
}

@media screen and (max-width: 812px) {
  section#vr {
    margin: 44px 0 100px;
  }

  section#vr .container {
    border-radius: 39px;
    padding: 36px 0;
  }

  section#vr .bg {
    width: 108.26666667vw;
  }

  section#vr .ttl {
    font-size: 25px;
    line-height: 1.4;
  }

  section#vr .ttl::before {
    height: 130px;
    width: 128px;
  }

  section#vr .txt {
    font-size: 14px;
    line-height: 1.4;
    margin-top: 16px;
    padding: 0 30px;
  }

  section#vr .txt .-en {
    font-size: 16px;
  }

  section#vr .vrmore {
    margin-top: 32px;
  }
}

section#shop {
    padding-bottom: 60px
}

section#shop .ttl-wrap {
    text-align: center;
    width: 48.8%;
    margin: 0 auto;
    background-color: #fff;
    border-radius: 116px;
    display: block;
    border-radius: 138px;
    top: 60px;
    z-index: 1
}

section#shop .inner ul.shopwrap li {
    width: 100%;
    text-align: center
}

section#shop .inner ul.shopwrap li .img {
    background-size: cover;
    width: 100%;
    height: 0;
    padding-top: calc(562 / 1366 * 100%);
    background-position: center
}

section#shop .inner ul.shopwrap li.grounding .shopmore .more-wrap .readmore {
    padding: 30px 2%
}

section#shop .inner ul.shopwrap li .shopmore {
    width: 455px;
    height: 80px;
    background: #fff;
    border-radius: 95px;
    margin: -35px auto 0
}

section#shop .inner ul.shopwrap li .shopmore .more-wrap {
    width: 100%;
    padding: 30px 45px;
    text-align: center
}

section#shop .inner ul.shopwrap li .shopmore .more-wrap .readmore {
    height: 80px;
    border-radius: 40px;
    background: #ffffff 0 0 no-repeat padding-box;
    border: 1px solid #147b9a;
    width: 100%;
    padding: 30px 18px 0;
    color: #147b9a;
}

section#shop .inner ul.shopwrap li .shopmore .more-wrap .readmore:hover {
    background-color: #147b9a;
    color: #ffffff;
}

section#shop .inner ul.shopwrap li .shopmore .more-wrap span.en a.readmore {
    height: 80px;
    border-radius: 40px;
    background: #E8E8E8 0 0 no-repeat padding-box;
    border: 1px solid #E8E8E8;
    width: 100%;
    padding: 30px 18px 0;
    color: #777777;
}

section#shop .inner ul.shopwrap li .shopmore .more-wrap span.en a.readmore:hover {
    background-color: #E8E8E8;
    color: #777777;
}

section#workscont {
    position: relative
}

section#workscont:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: block;
    background: #044b60;
    background: -webkit-gradient(linear, left top, right bottom, from(#1d94b7), to(#044b60));
    background: linear-gradient(to bottom right, #1d94b7 0, #044b60 100%)
}

section#workscont .ttl-wrap {
    position: relative;
    padding-bottom: 34px;
    font-weight: 400;
    display: inline-block;
    top: -64px;
    line-height: 1;
    padding-right: 0;
    z-index: 1;
    padding-left: 106px
}

section#workscont .ttl-wrap h2 {
    font-size: 82px
}

section#workscont .ttl-wrap:before {
    top: -70px
}

section#workscont .worksfv {
    max-width: 1280px;
    margin: 0 auto
}

section#workscont .worksfv a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    padding: 0 114px;
    margin: 0 auto
}

section#workscont .worksfv a:hover .img {
    -webkit-transform: scale(1.05);
    transform: scale(1.05)
}

section#workscont .worksfv .left {
    width: 48%;
    position: relative;
    z-index: 1
}

section#workscont .worksfv .left p.cate {
    color: #c3f4ff;
    text-transform: uppercase;
    font-size: 17px;
    letter-spacing: .34px;
    margin-bottom: 7px
}

section#workscont .worksfv .left p.date {
    color: #c3f4ff;
    font-size: 17px;
    letter-spacing: .34px
}

section#workscont .worksfv .left h3 {
    font-size: 42px;
    color: #fff;
    margin-top: 3.2vw;
    margin-bottom: 1.2vw;
    line-height: 1.4;
}

section#workscont .worksfv .left h3 span {
    font-size: 22px
}

section#workscont .worksfv .left p.cap {
    font-size: 21px;
    color: #fff;
    margin-bottom: 20px;
    line-height: 1.8
}

@media screen and (max-width: 812px) {
section#workscont .worksfv .left p.cap {
    font-size: 15px;
    color: #fff;
    margin-bottom: 20px;
    line-height: 1.6;
}
}

section#workscont .worksfv .right {
    width: 65%;
    margin-left: 6%;
    border-radius: 20px;
}

section#workscont .worksfv .right .imghidden {
    overflow: hidden;
    border-radius: 20px;
}

section#workscont .worksfv .right .imghidden .img {
    width: 100%;
    height: 0;
    padding-top: calc(383 / 680 * 100%);
    background-size: cover;
    background-position: center;
    position: relative;
    -webkit-transition: transform .35s cubic-bezier(.45, 0, .55, 1);
    -webkit-transition: -webkit-transform .35s cubic-bezier(.45, 0, .55, 1);
    transition: -webkit-transform .35s cubic-bezier(.45, 0, .55, 1);
    transition: transform .35s cubic-bezier(.45, 0, .55, 1);
    transition: transform .35s cubic-bezier(.45, 0, .55, 1), -webkit-transform .35s cubic-bezier(.45, 0, .55, 1);
    border-radius: 20px;
}

section#workscont #masonry {
    position: relative;
    width: 83%;
    margin: 110px auto 86px
}

section#workscont #masonry .item {
    margin-bottom: 60px;
    display: inline-block;
    width: calc(48.5% - 30px)
}

section#workscont #masonry .item .imghidden {
    overflow: hidden;
    border-radius: 20px
}

section#workscont #masonry .item .imghidden img {
    -webkit-transition: transform .35s cubic-bezier(.45, 0, .55, 1);
    -webkit-transition: -webkit-transform .35s cubic-bezier(.45, 0, .55, 1);
    transition: -webkit-transform .35s cubic-bezier(.45, 0, .55, 1);
    transition: transform .35s cubic-bezier(.45, 0, .55, 1);
    transition: transform .35s cubic-bezier(.45, 0, .55, 1), -webkit-transform .35s cubic-bezier(.45, 0, .55, 1)
}

section#workscont #masonry .item a:hover .imghidden img {
    -webkit-transform: scale(1.05);
    transform: scale(1.05)
}

section#workscont #masonry .item img {
    width: 100%;
    height: auto
}

section#workscont #masonry .item h3 {
    font-size: 23px;
    font-weight: 400;
    margin-top: 10px;
    margin-bottom: 10px;
    color: #fff;
    letter-spacing: 0;
    line-height: 1.65
}

section#workscont #masonry .item p.cate {
    font-size: 17px;
    letter-spacing: .34px;
    color: #c3f4ff
}

section#workscont #masonry .item p.date {
    margin-top: 7px;
    font-size: 15px;
    letter-spacing: .34px;
    color: #c3f4ff;
    line-height: 1.4;
}

section#workscont .whitearea {
    height: 82px;
    width: 100%;
    background-color: #fff;
    position: relative
}

section#boardgamecont {
    position: relative
}

section#boardgamecont:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: block;
    background: #044b60;
    background: -webkit-gradient(linear, left top, right bottom, from(#1d94b7), to(#044b60));
    background: linear-gradient(to bottom right, #1d94b7 0, #044b60 100%)
}

section#boardgamecont .ttl-wrap {
    position: relative;
    padding-bottom: 34px;
    font-weight: 400;
    display: inline-block;
    top: -47px;
    line-height: 1;
    padding-right: 0;
    z-index: 1;
    padding-left: 106px
}

section#boardgamecont .ttl-wrap h2 {
    font-size: 82px
}

section#boardgamecont .ttl-wrap:before {
    top: -70px
}

section#boardgamecont .worksfv {
    max-width: 1280px;
    margin: 0 auto
}

section#boardgamecont .worksfv a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    padding: 0 114px;
    margin: 0 auto
}

section#boardgamecont .worksfv a:hover .img {
    -webkit-transform: scale(1.05);
    transform: scale(1.05)
}

section#boardgamecont .worksfv .left {
    width: 48%;
    position: relative;
    z-index: 1
}

section#boardgamecont .worksfv .left p.cate {
    color: #c3f4ff;
    text-transform: uppercase;
    font-size: 17px;
    letter-spacing: .34px;
    margin-bottom: 7px
}

section#boardgamecont .worksfv .left p.date {
    color: #c3f4ff;
    text-transform: uppercase;
    font-size: 17px;
    letter-spacing: .34px
}

section#boardgamecont .worksfv .left h3 {
    font-size: 42px;
    color: #fff;
    margin-top: 3.2vw;
    margin-bottom: 1.2vw;
    line-height: 1.4;
}

section#boardgamecont .worksfv .left h3 span {
    font-size: 22px
}

section#boardgamecont .worksfv .left p.cap {
    font-size: 21px;
    color: #fff;
    margin-bottom: 20px;
    line-height: 1.8
}

@media screen and (max-width: 812px) {
section#boardgamecont .worksfv .left p.cap {
    font-size: 15px;
    color: #fff;
    margin-bottom: 20px;
    line-height: 1.6;
}

section#boardgamecont .inner {
    width: 100%;
    padding: 34px 35px 77px;
    margin-left: 4vw;
}
}

section#boardgamecont .worksfv .right {
    width: 65%;
    margin-left: 6%;
    border-radius: 20px;
}

section#boardgamecont .worksfv .right .imghidden {
    overflow: hidden;
    border-radius: 20px;
}

section#boardgamecont .worksfv .right .imghidden .img {
    width: 100%;
    height: 0;
    padding-top: calc(383 / 680 * 100%);
    background-size: cover;
    background-position: center;
    position: relative;
    -webkit-transition: transform .35s cubic-bezier(.45, 0, .55, 1);
    -webkit-transition: -webkit-transform .35s cubic-bezier(.45, 0, .55, 1);
    transition: -webkit-transform .35s cubic-bezier(.45, 0, .55, 1);
    transition: transform .35s cubic-bezier(.45, 0, .55, 1);
    transition: transform .35s cubic-bezier(.45, 0, .55, 1), -webkit-transform .35s cubic-bezier(.45, 0, .55, 1);
    border-radius: 20px;
}

section#boardgamecont #masonry {
    position: relative;
    width: 83%;
    margin: 110px auto 86px
}

section#boardgamecont #masonry .item {
    margin-bottom: 60px;
    display: inline-block;
    width: calc(48.5% - 30px)
}

section#boardgamecont #masonry .item .imghidden {
    overflow: hidden;
    border-radius: 20px
}

section#boardgamecont #masonry .item .imghidden img {
    -webkit-transition: transform .35s cubic-bezier(.45, 0, .55, 1);
    -webkit-transition: -webkit-transform .35s cubic-bezier(.45, 0, .55, 1);
    transition: -webkit-transform .35s cubic-bezier(.45, 0, .55, 1);
    transition: transform .35s cubic-bezier(.45, 0, .55, 1);
    transition: transform .35s cubic-bezier(.45, 0, .55, 1), -webkit-transform .35s cubic-bezier(.45, 0, .55, 1)
}

section#boardgamecont #masonry .item a:hover .imghidden img {
    -webkit-transform: scale(1.05);
    transform: scale(1.05)
}

section#boardgamecont #masonry .item img {
    width: 100%;
    height: auto
}

section#boardgamecont #masonry .item h3 {
    font-size: 23px;
    font-weight: 400;
    margin-top: 10px;
    margin-bottom: 10px;
    color: #fff;
    letter-spacing: 0;
    line-height: 1.65
}

section#boardgamecont #masonry .item p.cate {
    font-size: 17px;
    letter-spacing: .34px;
    color: #c3f4ff
}

section#boardgamecont #masonry .item p.date {
    margin-top: 7px;
    font-size: 15px;
    letter-spacing: .34px;
    color: #c3f4ff;
    line-height: 1.4;
}

section#boardgamecont .whitearea {
    height: 82px;
    width: 100%;
    background-color: #fff;
    position: relative
}


section#worksdetail {
    position: relative
}

section#worksdetail:before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: block;
    background: #044b60;
    background: -webkit-gradient(linear, left top, right bottom, from(#1d94b7), to(#044b60));
    background: linear-gradient(to bottom right, #1d94b7 0, #044b60 100%)
}

section#worksdetail .ttlbg {
    width: 674px
}

section#worksdetail .ttl-wrap {
    position: relative;
    padding-bottom: 34px;
    font-weight: 400;
    display: inline-block;
    top: -40px;
    line-height: 1;
    padding-right: 0;
    z-index: 1;
    padding-left: 106px
}

section#worksdetail .ttl-wrap h2 {
    font-size: 80px
}

section#worksdetail .singletop {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    padding: 0 106px 90px;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    max-width: 1280px;
    margin: 70px auto 0
}

section#worksdetail .singletop .left {
    width: calc(40% - 30px);
    margin-right: 30px
}

section#worksdetail .singletop .left p {
    font-size: 17px;
    color: #c3f4ff;
    line-height: 31px;
    letter-spacing: .34px
}

section#worksdetail .singletop .left h3 {
    font-size: 40px;
    margin-bottom: 20px;
    letter-spacing: 1.68px;
    line-height: 1.45;
}

section#worksdetail .singletop .left h3 span {
    font-size: 22px
}

section#worksdetail .singletop .left h4 {
    font-size: 24px;
    margin-bottom: 20px;
    letter-spacing: .96px;
    line-height: 1.5;
}

section#worksdetail .singletop .left .txt {
    color: #fff;
    font-size: 28px;
    letter-spacing: .95px;
    line-height: 41px
}

section#worksdetail .singletop .right {
    width: 60%
}


section#worksdetail .singletop2 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    padding: 0 106px 90px;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    max-width: 1280px;
    margin: 70px auto 0
}

section#worksdetail .singletop2 .left {
    width: calc(49% - 23px);
    margin-right: 48px
}

section#worksdetail .singletop2 .left p {
    font-size: 17px;
    color: #c3f4ff;
    line-height: 31px;
    letter-spacing: .34px
}

section#worksdetail .singletop2 .left h3 {
    font-size: 40px;
    margin-bottom: 20px;
    letter-spacing: 1.68px;
    line-height: 1.45;
}

section#worksdetail .singletop2 .left h3 span {
    font-size: 22px
}

section#worksdetail .singletop2 .left h4 {
    font-size: 24px;
    margin-bottom: 20px;
    letter-spacing: .96px;
    line-height: 1.5;
}

section#worksdetail .singletop2 .left .txt {
    color: #fff;
    font-size: 28px;
    letter-spacing: .95px;
    line-height: 41px
}

section#worksdetail .singletop2 .right {
    width: 42%
}

section#boardgamedetail {
    position: relative
}

section#boardgamedetail:before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: block;
    background: #044b60;
    background: -webkit-gradient(linear, left top, right bottom, from(#1d94b7), to(#044b60));
    background: linear-gradient(to bottom right, #1d94b7 0, #044b60 100%)
}

section#boardgamedetail .ttlbg {
    width: 674px
}

section#boardgamedetail .ttl-wrap {
    position: relative;
    padding-bottom: 34px;
    font-weight: 400;
    display: inline-block;
    top: -40px;
    line-height: 1;
    padding-right: 0;
    z-index: 1;
    padding-left: 106px
}

section#boardgamedetail .ttl-wrap h2 {
    font-size: 80px
}

section#boardgamedetail .singletop {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    padding: 0 64px 96px;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    max-width: 1280px;
    margin: 3em 0em 5em 14em;
}

section#boardgamedetail .singletop .left {
    width: calc(45% - 30px);
    margin-right: 46px
}

section#boardgamedetail .singletop .left p {
    font-size: 17px;
    color: #c3f4ff;
    line-height: 31px;
    letter-spacing: .34px
}

section#boardgamedetail .singletop .left h3 {
    font-size: 40px;
    margin-bottom: 20px;
    letter-spacing: 1.68px;
    line-height: 1.45;
}

section#boardgamedetail .singletop .left h3 span {
    font-size: 22px
}

section#boardgamedetail .singletop .left h4 {
    font-size: 24px;
    margin-bottom: 20px;
    letter-spacing: .96px;
    line-height: 1.5;
}

section#boardgamedetail .singletop .left .txt {
    color: #fff;
    font-size: 28px;
    letter-spacing: .95px;
    line-height: 41px
}

section#boardgamedetail .singletop .right {
}

section#boardgamedetail .singletop2 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    padding: 0 106px 90px;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    max-width: 1280px;
    margin: 70px auto 0
}

section#boardgamedetail .singletop2 .left {
    width: calc(49% - 23px);
    margin-right: 48px
}

section#boardgamedetail .singletop2 .left p {
    font-size: 17px;
    color: #c3f4ff;
    line-height: 31px;
    letter-spacing: .34px
}

section#boardgamedetail .singletop2 .left h3 {
    font-size: 40px;
    margin-bottom: 20px;
    letter-spacing: 1.68px;
    line-height: 1.45;
}

section#boardgamedetail .singletop2 .left h3 span {
    font-size: 22px
}

section#boardgamedetail .singletop2 .left h4 {
    font-size: 24px;
    margin-bottom: 20px;
    letter-spacing: .96px;
    line-height: 1.5;
}

section#boardgamedetail .singletop2 .left .txt {
    color: #fff;
    font-size: 28px;
    letter-spacing: .95px;
    line-height: 41px
}

section#boardgamedetail .singletop2 .right {
    width: 42%
}

section#workscontent {
    background-color: #fff;
    padding: 114px 114px 200px
}

section#workscontent .inner {
    max-width: 1134px;
    margin: 0 auto
}

section#workscontent .inner .content {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    margin-bottom: 40px
}

section#workscontent .inner .content .left {
    width: calc(80% - 0px);
    margin-right: 62px
}

section#workscontent .inner .content .left2 {
    width: calc(100% - 0px);
    margin-right: 22px
}

section#workscontent .inner .content .left h3 {
    color: #191919;
    letter-spacing: .99px;
    font-size: 26px;
    font-weight: 400;
    line-height: 41px;
    margin-bottom: 36px;
    font-weight: 700
}

section#workscontent .inner .content .left p {
    color: #191919;
    line-height: 1.8;
    margin-bottom: 48px;
    font-size: 18px;
    font-weight: 400
}

section#workscontent .inner .content .left a {
    color: #147b9a;
    font-size: 17px;
    letter-spacing: .68px;
    margin-bottom: 34px;
    line-height: 1.75;
    border-bottom: solid 0px #147b9a;
}

section#workscontent .inner .content .left a:hover {
    color: #005a87;
    border-bottom: solid 1px #005a87;
    transition: color .1s, border-bottom .1s ease;
}

section#workscontent .inner .content ul,
section#workscontent .inner .content ol {
    color: #191919;
    line-height: 1.8;
    margin-bottom: 0px;
    font-size: 18px;
    font-weight: 400
}

section#workscontent .inner .content .left ul {
    padding-left: 1em;
    /* margin-bottom: 40px; */
}

section#workscontent .inner .content .left ul > li {
  list-style: disc;
}

section#workscontent .inner .content .left ol {
  padding-left: 1em;
  /* margin-bottom: 40px; */
}

section#workscontent .inner .content .left ol > li {
  list-style: decimal;
}


blockquote{
    position:relative;
    border-left:3px solid #C3C3C3;
    padding-left:10px;
}

blockquote p{
    position:relative;
    padding-left:30px;
}
blockquote cite{
    display: block;
    font-size:0.8rem;
    color:#F8C8B2;
    text-align:right;
}


span.copyright {
    color: #808080;
    font-size: 14px;
    letter-spacing: .68px;
    line-height: 1.75;
    display: block;
}

span.underline1 {
    border-bottom: solid 2px #50bed8;
}

span.underline2 {
    border-bottom: double 5px #50bed8;
}

span.underline3 {
    background: linear-gradient(transparent 50%, #50bed8 30%);
}
}

section#workscontent .inner .content .right {
    width: 45%
}

section#workscontent .inner .content .right img {
    width: 100%;
    height: auto
}

section#workscontent .inner .movie {
    margin-top: 100px;
    background-color: #1d94b7;
    padding: 80px 86px;
    border-radius: 20px
}

section#workscontent .inner .movie iframe {
    width: 100%;
    height: 584px;
    border-radius: 20px
}

section#workscontent .inner .info {
    margin-top: 78px
}

section#workscontent .inner .info h3 {
    font-size: 29px;
    font-weight: 400;
    color: #191919;
    letter-spacing: .99px;
    line-height: 41px;
    margin-bottom: 17px
}

section#workscontent .inner .info dl {
    font-size: 16px;
    color: #191919;
    letter-spacing: .48px;
    line-height: 30px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    font-weight: 400
}

section#workscontent .inner .info a {
    color: #147b9a;
    border-bottom: solid 0px #147b9a;
    word-break: break-all;
}

section#workscontent .inner .info a:hover  {
    color: #005a87;
    border-bottom: solid 1px #005a87;
    transition: color 1.5s border-bottom 1.5s ease;
    word-break: break-all;
}


section#workscontent .inner .info a.linkbtn {
    padding: 29px 50px;
    background-color: #147b9a;
    border: 1px solid #147b9a;
    color: #fff;
    text-align: center;
    border-radius: 40px;
    display: inline-block;
    font-size: 18px;
    margin-top: 36px;
    -webkit-transition: .3s cubic-bezier(.45, 0, .55, 1);
    transition: .3s cubic-bezier(.45, 0, .55, 1)
}

section#workscontent .inner .info a.linkbtn:hover {
    background-color: #fff;
    color: #147b9a
}

section#otherworks {
    position: relative
}

section#otherworks:before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: block;
    background: #044b60;
    background: -webkit-gradient(linear, left top, right top, from(#1d94b7), to(#044b60));
    background: linear-gradient(to right, #1d94b7 0, #044b60 100%)
}

section#otherworks .ttl-wrap {
    border-radius: 0 0 138px 0;
    background-color: #fff;
    padding-right: 148px;
    top: -63px;
    padding-left: 106px
}

section#otherworks .ttl-wrap h2 {
    font-size: 80px
}

section#otherworks .ttl-wrap h3 {
    font-size: 20px
}

section#otherworks #masonry {
    position: relative;
    width: 83%;
    margin: 110px auto 205px
}

section#otherworks #masonry .item {
    margin-bottom: 60px;
    width: calc(48.5% - 30px)
}

section#otherworks #masonry .item .imghidden {
    overflow: hidden;
    border-radius: 14px
}

section#otherworks #masonry .item .imghidden img {
    -webkit-transition: transform .35s cubic-bezier(.45, 0, .55, 1);
    -webkit-transition: -webkit-transform .35s cubic-bezier(.45, 0, .55, 1);
    transition: -webkit-transform .35s cubic-bezier(.45, 0, .55, 1);
    transition: transform .35s cubic-bezier(.45, 0, .55, 1);
    transition: transform .35s cubic-bezier(.45, 0, .55, 1), -webkit-transform .35s cubic-bezier(.45, 0, .55, 1)
}

section#otherworks #masonry .item a:hover .imghidden img {
    -webkit-transform: scale(1.05);
    transform: scale(1.05)
}

section#otherworks #masonry .item img {
    width: 100%;
    height: auto
}

section#otherworks #masonry .item h3 {
	font-family: 'dnp-shuei-mgothic-std';
    font-size: 23px;
    font-weight: 400;
    margin-top: 13px;
    margin-bottom: 10px;
    color: #fff;
    letter-spacing: 0;
    line-height: 1.4
}

section#otherworks #masonry .item p {
	font-family: 'dnp-shuei-mgothic-std';
    font-size: 17px;
    line-height: 31px;
    letter-spacing: .34px;
    color: #c3f4ff
}

section#otherworks #masonry .item .cate {
    margin-top: 10px
}

section#otherworks .worksmore {
    width: 100%;
    background-color: #fff;
    position: relative;
    bottom: 0
}

section#otherworks .worksmore .more-wrap {
    width: 389px;
    border-radius: 87px;
    margin: 0 auto;
    background: #fff;
    padding: 37px;
    position: relative;
    top: -50px
}

section#otherworks .worksmore .more-wrap .readmore {
    border-radius: 40px;
    width: 232px;
    margin: 0 auto;
    background-color: transparent;
    color: #147b9a
}

section#otherworks .worksmore .more-wrap .readmore:hover {
    background-color: #147b9a;
    color: #fff
}

section#policytop .inner {
  padding: 166px 114px 107px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center
}

section#policytop .ttl {
  color: #147b9a;
}

section#policytop .ttl .-main {
  display: block;
  font-size: 94px;
  font-weight: 500;
}

section#policytop .ttl .-sub {
  display: block;
  font-size: 20px;
  font-weight: 400;
  margin-top: -8px;
}

section#policytop .container {
  margin-top: 104px;
}

section#policytop .wrap:not(:first-child) {
  margin-top: 104px;
}

section#policytop .head {
  color: #000;
  font-size: 17px;
  letter-spacing: .04em;
  line-height: 1.8;
  margin-top: 170px;
}

section#policytop .heading {
  color: #191919;
  font-size: 20px;
  margin-bottom: 32px;
}

section#policytop ul,
section#policytop li {
  list-style: none;
  margin: 0;
  padding: 0;
}

section#policytop .num-indent {
  padding-left: 2.6em;
  text-indent: -2.6em;
}

section#policytop .item-indent {
  padding-left: 1.6em;
  text-indent: -1.6em;
}

section#policytop .kana-indent {
  padding-left: 3.8em;
  text-indent: -3.8em;
}

section#policytop .text {
  color: #000;
  font-size: 15px;
  letter-spacing: .04em;
  line-height: 1.8;
}

section#policytop .link {
  color: #3578cd;
}

section#policytop .comment {
  color: #000;
  font-size: 20px;
  font-weight: bold;
  letter-spacing: .04em;
  margin-top: 80px;
  text-align: right;
  width: 100%;
}

section#policytop .break-contents {
  margin-top: 46px;
}

section#policytop .break-wrap {
  margin-top: 38px;
}

section#policytop .break-item {
  margin-top: 18px;
}

section#policytop .break-box {
  margin-top: 14px;
}

section#policytop .info {
  margin-top: 40px;
  width: 100%;
}

section#policytop .info + .info {
  margin-top: 60px;
}

section#policytop .info > dt {
  font-weight: bold;
}

section#policytop .info > dd:first-of-type {
  margin-top: 32px;
}

@media screen and (max-width: 812px) {
  section#policytop .inner {
    display: block;
    padding: 85px 18px 75px
  }

  section#policytop .ttl .-main {
    font-size: 50px;
  }

  section#policytop .ttl .-sub {
    font-size: 14px;
    margin-top: 7.5px;
  }

  section#policytop .container {
    margin-top: 48px;
  }

  section#policytop .wrap:not(:first-child) {
    margin-top: 48px;
  }

  section#policytop .head {
    margin-top: 52px;
  }

  section#policytop .heading {
    font-size: 17px;
    margin-bottom: 20px;
  }

  section#policytop ul,
  section#policytop li {
    list-style: none;
    margin: 0;
    padding: 0;
  }

  section#policytop .num-indent {
    padding-left: 2em;
    text-indent: -2em;
  }

  section#policytop .item-indent {
    padding-left: 1.1em;
    text-indent: -1.1em;
  }

  section#policytop .kana-indent {
    padding-left: 3.8em;
    text-indent: -3.8em;
  }

  section#policytop .comment {
    font-size: 15px;
    margin-top: 52px;
  }

  section#policytop .break-contents {
    margin-top: 24px;
  }

  section#policytop .break-wrap {
    margin-top: 24px;
  }

  section#policytop .break-item {
    margin-top: 14px;
  }

  section#policytop .break-box {
    margin-top: 14px;
  }

  section#policytop .info+.info {
    margin-top: 40px;
  }

  section#policytop .info>dd:first-of-type {
    margin-top: 20px;
  }
}

.readmore {
    width: 203px;
    height: auto;
    background: #147b9a 0 0 no-repeat padding-box;
    border: 1px solid #147b9a;
    border-radius: 87px;
    display: block;
    text-align: center;
    color: #fff;
    font-size: 17px;
    padding-top: 22px;
    padding-bottom: 22px;
    -webkit-transition: .3s cubic-bezier(.45, 0, .55, 1);
    transition: .3s cubic-bezier(.45, 0, .55, 1)
}

.readmore:hover {
    background-color: transparent;
    color: #fff;
    font-size: 16px
}

h1 {
    font-size: 20px
}

h2 {
    font-size: 18px
}

.ttlbg {
    width: 482px;
    height: 250px;
    background-color: #fff;
    position: absolute;
    left: 0;
    top: 0;
    z-index: 1;
    border-radius: 0 0 138px 0;
    min-height: 270px;
    min-width: 482px
}

.ttlbg2 {
    width: 482px;
    height: 280px;
    background-color: #fff;
    position: absolute;
    left: 0;
    top: 0;
    z-index: 1;
    border-radius: 0 0 138px 0;
    min-height: 250px;
    min-width: 578px
}

.ttl-wrap {
    position: relative;
    padding-bottom: 27px;
    font-weight: 400;
    display: inline-block
}

.ttl-wrap:before {
    content: "";
    top: 0;
    display: none
}

.ttl-wrap h2 {
    font-size: 109px;
    font-weight: 400;
    line-height: 93px;
    letter-spacing: 0;
    color: #147b9a;
    letter-spacing: 0;
    position: relative;
    margin-top: 0.18em;
}

.ttl-wrap h3 {
    font-size: 20px;
    font-weight: 400;
    letter-spacing: 0;
    color: #147b9a;
    letter-spacing: 0;
    margin-top: 0.3vw;
}

section#error .topinner .txtwrap h2 {
    font-size: 74px;
    font-weight: 400;
    margin-bottom: 7px;
    font-family: 'dnp-shuei-mgothic-std';
}

section#error {
    position: relative;
    padding-bottom: 60px
}

section#error:before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: block;
    background: #044b60;
    background: -webkit-gradient(linear, left top, right bottom, from(#1d94b7), to(#044b60));
    background: linear-gradient(to bottom right, #1d94b7 0, #044b60 100%)
}

section#error .ttl-wrap {
    position: relative;
    padding-bottom: 34px;
    font-weight: 400;
    display: inline-block;
    top: -40px;
    line-height: 1;
    padding-right: 0;
    z-index: 1;
    padding-left: 106px
}

section#error .ttl-wrap h2 {
    font-size: 82px
}

section#error .topinner {
    padding: 0 114px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    position: relative;
    top: -40px;
    max-width: 1280px;
    margin: 32px auto 0px auto;
}

section#error .topinner .txtwrap {
    width: 60%;
    position: relative;
    z-index: 1;
    white-space: pre
}

section#error .topinner .txtwrap h2 {
    font-size: 63px;
    font-weight: 400;
    margin-bottom: 7px
}

section#error .topinner .txtwrap p {
    font-size: 20px;
    line-height: 31px
}

section#error .topinner .img {
    width: 40%;
    height: 0;
    padding-top: calc(414 / 459 * 40%);
    background-size: cover;
    background-position: center
}

.clearfix:after {
    content: "";
    clear: both;
    display: block
}

.recaptcha_policy {
  padding: 0;
  margin: 0;
  text-align: center;
  font-size: 12px !important;
  color: #147b9a !important;
  line-height: 1.4;
}

.recaptcha_policy a {
  border-bottom: solid 1px;
  color: #147b9a !important;
  font-size: 12px !important;
  font-weight: bold;
}

.grecaptcha-badge {
  visibility: hidden;
}

@media (min-width:813px) {
    .ex-link {
        opacity: 1;
        -webkit-transition: opacity .2s linear;
        transition: opacity .2s linear
    }

    .ex-link:hover {
        opacity: .5
    }

    .l-footer ul.subfooter2.pc-hide {
        display: none
    }

    .l-header .menu-trigger,
    .l-header .menu-trigger span {
        display: none
    }
}

@media screen and (min-width: 812px) {
    .br_sp { display: none;
    }
 }
@media screen and (max-width: 812px) {
    .br_sp { display: block;
    }
}

@media (max-width:812px) {
    .pc-hide {
        display: block;
    }

    .sp-hide {
        display: none;
    }



    body,
    html {
        width: 100%;
        height: 100%
    }

    dd,
    div,
    dl,
    dt,
    h1,
    h2,
    h3,
    h4,
    h5,
    h6,
    p {
        margin: 0;
        padding: 0
    }

    img {
        height: auto;
        max-height: 100%;
        max-width: 100%;
        width: auto
    }

    .l-footer {
        padding: 70px 18px 20px
    }

    .l-footer .footer-menu {
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        padding-left: 15%
    }

    .l-footer .footer-menu li {
        /* margin-right: 0; */
        margin-bottom: 22px;
        /* width: 43% */
    }

    .l-footer ul.subfooter {
        display: block;
        margin-top: 15px
    }

    .l-footer ul.subfooter li {
        margin-right: 0
    }

    .l-footer ul.subfooter li .rec-btn {
        margin: 0 auto
    }

    .l-footer ul.subfooter2.sp-hide {
        display: none
    }

    .l-footer ul.subfooter2 {
        position: relative;
        left: 0;
        text-align: center;
        display: block;
        margin-top: 31px
    }

    .l-footer ul.subfooter2>li:first-child {
        margin-right: 7px;
        margin-bottom: 0;
        margin-top: -8px
    }

    .l-footer ul.subfooter2>li:first-child svg {
        width: 30px;
        height: 30px
    }

    .l-footer ul.subfooter2 li {
        margin-bottom: 0
    }

    .l-footer ul.subfooter2 li ul li {
        margin-bottom: 10px
    }

    .l-footer .copyright {
        position: relative;
        font-size: 12px;
        line-height: 16px;
        bottom: 0;
        margin-top: 17px;
        text-align: center;
    }

    .l-footer .vr {
      margin: 10px auto 0;
      width: 190px;
    }

    .l-footer ul.subfooter2 li.docs {
      display: inline-block;
      font-size: 14px;
      margin-left: auto;
      margin-right: 0;
      position: relative;
    }

    .l-footer ul.subfooter2 li.docs::before {
      background-color: #fff;
      bottom: 0;
      content: "";
      display: block;
      height: 1px;
      left: 0;
      position: absolute;
      width: 100%;
    }

    .l-header {
        height: 75px
    }

    .l-header:before {
        height: 75px
    }

    .l-header h1 {
        width: 93px
    }

    .l-header .g-nav {
        display: none
    }

    .splang {
        position: fixed;
        top: 24px;
        left: 17px;
        z-index: 999;
        padding: 7px;
        width: 30px;
        opacity: 0;
        display: none;
        height: 30px;
        border: 2px solid #184557;
        border: 2px solid #184557;
        border-radius: 63px;
        color: #184557
    }

    .splang a {
        color: #184557;
        padding: 0 !important
    }

    .splogo {
        width: 104px;
        height: 102px;
        margin: 13px auto 0;
        position: fixed;
        left: 0;
        right: 0;
        margin: 0.8vw auto -8vw auto;
        top: 10px;
        z-index: 9998
    }

    div.langsp {
        position: fixed;
        left: 22px;
        margin: 0.8vw auto -8vw auto;
        top: 14px;
        z-index: 9998;
        width: 28.5px;
        height: 28.5px;
    }

    section#recruit {
        padding-top: 0;
        padding-bottom: 65px
    }

    section#recruit .inner {
        width: 100%;
        padding: 0 18px
    }

    section#recruit .inner .contwrap {
        display: block
    }

    section#recruit .inner .contwrap .left {
        width: 100%;
        margin-right: 0
    }

    section#recruit .inner .contwrap .left .img {
        background-size: cover;
        width: 90%;
        height: 0;
        padding-top: calc(1062 / 1148 * 90%);
        background-position: center;
        margin: 0 auto 25px
    }

    section#recruit .inner .contwrap .left .txt h4 {
        font-size: 25px;
        margin-bottom: 15px
    }

    section#recruit .inner .contwrap .left .txt p {
        font-size: 16px;
        margin-bottom: 34px
    }

    section#recruit .inner .contwrap .left .txt .readmore {
        height: auto;
        padding: 23px 0 24px 0;
        margin: 0 auto;
        letter-spacing: .96px;
    }

    section#recruit .inner .contwrap .right {
        width: 100%
    }

    .fuctxt p {
        font-size: 14px;
        margin-bottom: 30px
    }

    section#companytop .inner {
        display: block;
        padding: 150px 18px 45px
    }

    section#companytop .inner .ttl-wrap h2 {
        font-size: 68px
    }

    section#companytop .inner .ttl-wrap h3 {
        font-size: 14px;
        margin-bottom: 60px
    }

    section#companytop .inner .txtwrap h4 {
        font-size: 21px;
        line-height: 34px
    }

    section#companytop .inner .txtwrap p {
        font-size: 17px;
        line-height: 1.9;
    }

    section#companytop .inner .img {
        width: 100%;
        padding-top: calc(742 / 778 * 100%);
        top: 68px;
        right: -14%;
        -webkit-transform: translateY(0);
        transform: translateY(0)
    }

    section.companycont .inner {
        padding: 0 18px
    }

    section.companycont .inner .ttl-wrap {
        margin-top: 19px
    }

    section.companycont .inner .ttl-wrap h2 {
        font-size: 40px;
        line-height: 50px;
        margin-bottom: 3px
    }

    section.companycont .inner .ttl-wrap h3 {
        font-size: 14px
    }

    section.companycont .inner .info1 dl dt {
        width: 10px;
        height: 10px
    }

    section.companycont .inner .info1 dl dd {
        font-size: 17px;
        line-height: 1.9;
    }

    section.companycont .inner .info2 {
        margin-bottom: 10px
    }

    section.companycont .inner .info2 p {
        line-height: 1.7;
    }

    section.companycont .inner .studio {
        margin-top: 60px
    }

    section.companycont .inner .studio .studio-wrap {
        display: block;
        margin-bottom: 60px
    }

    section.companycont .inner .studio .studio-wrap .left {
        width: 100%
    }

    section.companycont .inner .studio .studio-wrap .left h3 {
        font-size: 18px;
        margin-bottom: 7px
    }

    section.companycont .inner .studio .studio-wrap .left h4 {
        font-size: 16px;
        margin-bottom: 7px
    }

    section.companycont .inner .studio .studio-wrap .left p {
        font-size: 14px;
        margin-bottom: 16px;
        line-height: 1.8;
    }

    section.companycont .inner .studio .studio-wrap .right {
        width: 100%;
        margin-top: 15px
    }

    section.companycont .investors {
        margin-bottom: 100px
    }

    section.companycont .investors .ttl-wrap {
        margin-bottom: 5px
    }

    section.companycont .investors .txt .date {
        line-height: 20px
    }

    section.companycont .investors .txt h3 {
        font-size: 17px;
        margin-bottom: 2px
    }

    section.companycont .ir-content-dnp p {
    font-size: 13px;
    line-height: 1.8;
    margin-bottom: 14px;
    color: #191919
    }

    section.companycont .investors .txt a {
        font-size: 15px
    }

    .contact .ttlbg {
        width: 60%;
        min-height: 203px
    }

    .contact section#contact .ttl-wrap {
        padding-left: 18px;
        top: -53px;
        padding-bottom: 0
    }

    .contact section#contact .ttl-wrap h2 {
        font-size: 50px;
        line-height: 58px
    }

    .contact section#contact .contacttop .inner {
        display: block;
        padding: 0 18px 45px 18px
    }

    .contact section#contact .contacttop .inner h2 {
        margin-top: 9vw;
        font-size: 17px;
        width: 100%;
        text-align: center
    }

    .contact section#contact .contacttop .inner .img {
        width: 100%;
        padding-top: calc(341 / 428 * 100%);
        right: 2%;
        z-index: -1;
        margin-top: -16em;
    }

    .contact section#contact .contactcont .inner {
        width: 100%;
        padding: 0 18px
    }

    section#ircont .ttl-wrap2 {
        height: auto
    }

    section#ircont .ttl-wrap2 .ttl {
        display: block;
        padding: 100px 18px 45px
    }

    section#ircont .ttl-wrap2 .ttl h2 {
        font-size: 64px;
        line-height: 1;
        margin-bottom: 20px
    }

    section#ircont .ttl-wrap2 .ttl h3 {
        font-size: 14px
    }

    section#ircont .inner {
        padding: 60px 18px
    }

    section#ircont .inner ul.irlist {
        display: block
    }

    section#ircont .inner ul.irlist li {
        width: 100%;
        margin-right: 0;
        margin-bottom: 40px
    }

    section#ircont .inner ul.irlist li h3 {
        font-size: 16px
    }

    section#ircont .inner ul.irlist li a {
        font-size: 14px
    }

    section#newscont .ttl-wrap {
        padding-left: 18px;
        top: -47px;
    }

    section#newscont .ttl-wrap h2 {
        font-size: 50px;
        line-height: 58px
    }

    section#newscont .inner {
        padding: 0 18px
    }

    section#newscont .inner ul {
        display: block
    }

    section#newscont .inner ul li {
        width: 100%;
        margin-bottom: 52px
    }

    section#newscont .inner ul li p.date {
        margin-top: 15px
    }

    section#newscont .inner ul li h3 {
        margin-top: 6px
    }

    section#newscont .pagerwrap .more-wrap {
        width: calc(100% - 36px);
        padding: 35px 0
    }

    .newsdetail .ttlbg {
        width: calc(100% - 18px)
    }

    section#boardgamedetail .ttlbg {
        width: calc(100% - 55px)
    }

    .newsdetail section#newsdetail {
        margin-top: 0
    }

    .newsdetail section#newsdetail .ttl-wrap {
        padding-left: 18px;
        top: -55px
    }

    .newsdetail section#newsdetail .ttl-wrap h2 {
        font-size: 50px
    }

    .newsdetail section#newsdetail .ttl-wrap h3 {
        font-size: 14px
    }

    .newsdetail section#newsdetail .singletop {
        display: block;
        padding: 0 18px 40px
    }

    .newsdetail section#newsdetail .singletop .left {
        width: 100%;
        margin-right: 0
    }

    .newsdetail section#newsdetail .singletop .left .img {
        border-radius: 9px;
        width: 100%;
        height: 0;
        padding-top: calc(175 / 319 * 100%);
        background-size: cover;
        background-position: center;
        -webkit-transition: transform .35s cubic-bezier(.45, 0, .55, 1);
        -webkit-transition: -webkit-transform .35s cubic-bezier(.45, 0, .55, 1);
        transition: -webkit-transform .35s cubic-bezier(.45, 0, .55, 1);
        transition: transform .35s cubic-bezier(.45, 0, .55, 1);
        transition: transform .35s cubic-bezier(.45, 0, .55, 1), -webkit-transform .35s cubic-bezier(.45, 0, .55, 1)
    }

    .newsdetail section#newsdetail .singletop .left p.date {
        font-size: 14px;
        margin-bottom: 5px;
        margin-top: 15px
    }

    .newsdetail section#newsdetail .singletop .left .txt {
        font-size: 17px;
        line-height: 1.58
    }

    .newsdetail section#newsdetail .singlecont {
        padding-bottom: 60px
    }

    .newsdetail section#newsdetail .singlecont .txtinner {
        width: 100%;
        padding: 45px 18px
    }

    .newsdetail section#newsdetail .singlecont .txtinner p {
        font-size: 17px;
        margin-bottom: 30px
    }

    .newsdetail section#newsdetail .singlecont .txtinner .readmore {
    	color: #ffffff;
        width: 100%;
        font-size: 15px;
        height: auto;
        border-radius: 61px
    }

    .newsdetail section#other .ttl-wrap {
        padding-left: 18px;
        padding-right: 0;
        width: 90%;
        top: -50px;
        border-radius: 0 0 70px 0
    }

    .newsdetail section#other .ttl-wrap h2 {
        font-size: 50px
    }

    .newsdetail section#other .ttl-wrap h3 {
        font-size: 14px
    }

    .newsdetail section#other .slider2 {
        padding-bottom: 100px
    }

    .newsdetail section#other .newsmore .more-wrap {
        width: calc(100% - 38px);
        padding: 30px;
        top: -40px
    }

    .newsdetail section#other .newsmore .more-wrap .readmore {
        border-radius: 61px;
        font-size: 16px
    }

    section#stafftop {
        padding-bottom: 3vw;
    }

    section#stafftop .ttl-wrap {
        padding-left: 18px;
        top: -47px;
    }

    section#stafftop .ttl-wrap h2 {
        font-size: 50px;
        line-height: 58px
    }

    section#stafftop .topinner {
        padding: 0 18px;
        display: block;
        top: -30px
    }

    section#stafftop .topinner .txtwrap {
        width: 100%;
        white-space: break-spaces
    }

    section#stafftop {
        padding-bottom: 3vw;
    }

    section#stafftop .ttl-wrap {
        padding-left: 18px;
        top: -47px;
    }

    section#stafftop .ttl-wrap h2 {
        font-size: 50px;
        line-height: 58px
    }

    section#stafftop .topinner {
        padding: 0 18px;
        display: block;
        top: -30px
    }

    section#stafftop .topinner .txtwrap {
        width: 100%;
        white-space: break-spaces
    }

    section#stafftop .topinner .txtwrap br {
        display: none
    }

    section#stafftop .topinner .txtwrap h2 {
        font-size: 43px;
        margin-bottom: 0
    }

    section#stafftop .topinner .txtwrap p {
        font-size: 17px
    }

    section#stafftop .topinner .img {
        width: 80%;
        margin: -225px auto 0;
        padding-top: calc(414 / 459 * 80%)
    }

    section.staffcont .inner {
        padding: 0 18px
    }

    section.staffcont .inner .ttl-wrap {
        padding-bottom: 0
    }

    section.staffcont .inner .ttl-wrap h2 {
        font-size: 43px;
        line-height: 50px
    }

    section.staffcont .inner .ttl-wrap h3 {
        font-size: 14px
    }

    section.staffcont .inner .ceo {
        display: block;
        margin-top: -10px
    }

    section.staffcont .inner .ceo .left {
        width: 100%
    }

    section.staffcont .inner .ceo .right {
        width: 100%;
        position: relative;
        top: -20px
    }

    section.staffcont .inner .ceo .right .position {
        font-size: 14px;
        font-weight: 400;
        margin-bottom: 15px
    }

    section.staffcont .inner .ceo .right h4 {
        font-size: 33px;
        line-height: 40px;
        margin-bottom: 20px
    }

    section.staffcont .inner .ceo .right h4 span {
        font-size: 12px
    }

    section.staffcont .inner .ceo .right p.txt {
        font-size: 16px;
        font-weight: 400;
        line-height: 1.8;
        margin-bottom: 20px
    }

    section.staffcont .inner .ceo .right a {
        font-size: 17px;
        line-height: 22px
    }

    section.staffcont .inner ul.stafflist {
        display: block;
        margin-top: 20px
    }

    section.staffcont .inner ul.stafflist li {
        width: 100%
    }

    section.staffcont .inner ul.stafflist li:last-child .img {
        position: relative;
        left: -31px
    }

    section.staffcont .inner ul.stafflist li:last-child .txt-wrap {
        /* left: 33%; */
        position: relative
    }

    section.staffcont .inner ul.stafflist li:first-child .img {
        position: relative;
        right: -16%
    }

    section.staffcont .inner ul.stafflist li .position {
        font-size: 14px;
        line-height: 14px;
        margin-bottom: 5px
    }

    section.staffcont .inner ul.stafflist li h4 {
        font-size: 33px;
        line-height: 50px;
        margin-bottom: 21px
    }

    section.staffcont .inner ul.stafflist li h4 span {
        font-size: 12px;
        margin-top: -0.3rem;
    }

    section.staffcont .inner ul.stafflist li p.txt {
        margin-bottom: 20px
    }

    section.staffcont .inner ul.stafflist li a {
        font-size: 15px;
        line-height: 22px
    }

    section#othermember .inner {
        padding: 0 18px 50px
    }

    section#othermember .inner .ttl-wrap h2 {
        font-size: 43px;
        line-height: 50px;
        margin-bottom: 4px
    }

    section#othermember .inner .ttl-wrap h3 {
        font-size: 14px
    }

    section#othermember .inner ul.otherlist {
        display: block
    }

    section#othermember .inner ul.otherlist li {
        width: 100%;
        margin-bottom: 50px
    }

    section#othermember .inner ul.otherlist li .position {
        font-size: 14px;
        margin-top: 15px;
        margin-bottom: 0.4em;
    }

    section#othermember .inner ul.otherlist li h4 {
        margin-bottom: 15px;
        margin-top: 0
    }

    section#othermember .inner ul.otherlist li h4 span {
        font-size: 12px
    }

    section#othermember .inner ul.otherlist li p.txt {
        font-size: 14px
    }

    section#othermember .inner ul.otherlist li a {
        font-size: 15px;
        line-height: 22px
    }

    section#staffdetailtop .ttl-wrap {
        padding-left: 18px;
        width: 100%;
        margin-bottom: 16px
    }

    section#staffdetailtop .ttl-wrap h2 {
        font-size: 50px
    }

    section#staffdetailtop .ttl-wrap h3 {
        font-size: 14px
    }

    section#staffdetailtop .topinner {
        height: auto;
        width: 100%;
        padding: 0 18px;
        min-height: auto
    }

    section#staffdetailtop .topinner .txtwrap {
        width: 100%;
        position: relative;
        top: 0;
        -webkit-transform: translateY(0);
        transform: translateY(0)
    }

    section#staffdetailtop .topinner .txtwrap .wrapinner {
        position: relative;
        top: -40px
    }

    section#staffdetailtop .topinner .txtwrap .position {
        font-size: 14px;
        line-height: 22px;
        margin-bottom: -1px;
        margin-top: 4.5em;
    }

    section#staffdetailtop .topinner .txtwrap h4 {
        font-size: 33px;
        line-height: 55px;
        margin-left: -0.1em;
        margin-bottom: -0.1em;
    }

    section#staffdetailtop .topinner .txtwrap h4 span {
        font-size: 13px;
        line-height: 13px
    }

    section#staffdetailtop .topinner .img.othekv {
        width: 100%;
        padding-top: calc(457 / 684 * 100%);
        right: 0;
        margin-bottom: 5.5em;
        margin-top: 1em;
    }

    section.staffdetailcont .inner {
        width: 100%;
        padding: 0 18px
    }

    section.staffdetailcont .inner .contents {
        padding-bottom: 0
    }

    section.staffdetailcont .inner .contents h4 {
        font-size: 18px;
        line-height: 1.7;
        margin-bottom: 14px
    }

    section.staffdetailcont .inner .contents p {
        font-size: 16px;
        line-height: 1.8
    }

    section.staffdetailcont .inner .contents .txtwrap1 {
        margin-bottom: 70px
    }

    section.staffdetailcont .inner .contents .txtwrap2,
    section.staffdetailcont .inner .contents .txtwrap3 {
        display: block
    }

    section.staffdetailcont .inner .contents .txtwrap2 {
        margin-bottom: 30px
    }

    section.staffdetailcont .inner .contents .txtwrap2 .left {
        width: 100%;
        margin-bottom: 30px
    }

    section.staffdetailcont .inner .contents .txtwrap2 .right {
        width: 100%;
        margin-left: 0
    }

    section.staffdetailcont .inner .contents .txtwrap3 {
        margin-bottom: 30px
    }

    section.staffdetailcont .inner .contents .txtwrap3 .left {
        width: 100%;
        margin-left: 0;
        margin-bottom: 30px
    }

    section.staffdetailcont .inner .contents .txtwrap3 .right {
        width: 100%
    }

    section#endroll .inner {
        width: 100%;
        padding: 66px 18px 92px;
    }

    section#endroll .inner h4 {
        font-size: 17px;
        line-height: 26px;
        margin-bottom: 0.85em;
    }

    section#endroll .inner p {
        font-size: 15px;
        line-height: 1.8;
    }

    section#endroll .steffmore {
        margin-bottom: 40px
    }

    section#endroll .steffmore .more-wrap {
        width: calc(100% - 36px);
        padding: 30px;
        top: -40px
    }

    section#error {
        padding-bottom: 3vw;
    }

    section#error .ttl-wrap {
        padding-left: 18px;
        top: -47px;
    }

    section#error .ttl-wrap h2 {
        font-size: 50px;
        line-height: 58px
    }

    section#error .topinner {
        padding: 0 18px;
        display: block;
        top: -30px
    }

    section#error .topinner .txtwrap {
        width: 100%;
        white-space: break-spaces
    }

    section#error {
        padding-bottom: 3vw;
    }

    section#error .ttl-wrap {
        padding-left: 18px;
        top: -47px;
    }

    section#error .ttl-wrap h2 {
        font-size: 50px;
        line-height: 58px
    }

    section#error .topinner {
        padding: 0 18px;
        display: block;
        top: -30px
    }

    section#error .topinner .txtwrap {
        width: 100%;
        white-space: break-spaces
    }

    section#error .topinner .txtwrap br {
        display: none
    }

    section#error .topinner .txtwrap h2 {
        font-size: 45px;
        margin-bottom: 0
    }

    section#error .topinner .txtwrap p {
        font-size: 17px
    }

    section#error .topinner .img {
        width: 80%;
        margin: -225px auto 0;
        padding-top: calc(414 / 459 * 80%)
    }

    .topkv {
        height: 100vh
    }

    .topkv .bg-img video {
        width: 90%;
        height: auto
    }

    .topkv .swiper-container {
        height: 100%;
        position: relative
    }

    .topkv .swiper-container .swiper-pagination {
        bottom: 10vw
    }

    .topkv .swiper-container .swiper-slide div.txt-wrap h2 {
        font-size: 15vw
    }

    .topkv .swiper-container .swiper-slide div.txt-wrap h3 {
        font-size: 19px
    }

    .topkv .swiper-container .swiper-slide .slide-inner {
        width: 100%;
        padding: 0 18px;
        margin-top: 22.5vw;
        position: relative;
        top: 0;
        -webkit-transform: translateY(0);
        transform: translateY(0)
    }

    .topkv .swiper-container .swiper-slide .slide-inner .left {
        width: 100%
    }

    .topkv .swiper-container .swiper-slide .slide-inner .left .img {
        width: 100%;
        height: 0;
        padding-top: calc(383 / 680 * 100%);
        background-size: cover;
        background-position: center;
        border-radius: 10px;
    }

    .topkv .swiper-container .swiper-slide .slide-inner .left p.cate {
        margin-bottom: 1.8rem;
    }

    .topkv .swiper-container .swiper-slide .slide-inner .left h3 {
        font-size: 21px;
        line-height: 1.55;
        margin-top: 10px;
        margin-bottom: 6px;
    }

    .topkv .swiper-container .swiper-slide .slide-inner .left span {
    font-size: 17px;
    display: block;
    font-weight: bold;
    line-height: 1.5;
    margin-bottom: 10px;
    }

    .topkv .swiper-container .swiper-slide .slide-inner .left p.cap {
        font-size: 15px;
        margin-bottom: 3px;
    }

    .topkv .swiper-container .swiper-slide .slide-inner .readmore {
        margin: 15px auto 0
    }

    section#about {
        width: 100%;
        padding-top: 80px;
        top: -15px;
        padding-bottom: 90px;
        border-radius: 0 109px 0 0/0 70px 0 0;
    }

    section#about .inner {
        width: 100%;
        padding: 50px 18px 0px 18px;
    }

    section#about .inner .txt p {
        font-size: 16px
    }

    section#news .inner {
        padding-bottom: 19vw
    }

    section#news .ttl-wrap {
        padding-right: 77px;
        top: -60px;
        padding-left: 18px
    }

    section#news .slider2 {
        top: 0;
        left: 18px
    }

    section#news .newsmore {
        padding: 0 18px
    }

    section#news .newsmore .more-wrap {
        width: 100%;
        padding: 30px
    }

    section#news .newsmore .more-wrap .readmore {
        font-size: 16px
    }

    section#works {
        margin-top: 90px;
        padding-top: 100px
    }

    section#works .ttl-wrap {
        top: -60px;
        padding-right: 18px;
        padding-left: 76px
    }

    section#works #masonry {
        width: 100%;
        padding: 0 18px
    }

    section#works #masonry .item {
        width: 100%;
        margin-bottom: 52px
    }

    section#works #masonry .item:nth-child(odd) {
        padding-right: 0
    }

    section#works #masonry .item:nth-child(even) {
        padding-left: 0
    }

    section#works #masonry .item h3 {
        font-size: 18px;
        margin-top: 3.2vw;
    }

    section#works #masonry .item p {
        font-size: 14px
    }

    section#works .worksmore {
        padding: 0 18px
    }

    section#works .worksmore .more-wrap {
        width: 100%;
        padding: 30px
    }

    section#shop {
        padding-bottom: 0
    }

    section#shop .ttl-wrap {
        width: calc(100% - 36px)
    }

    section#shop .inner ul.shopwrap {
        display: block
    }

    section#shop .inner ul.shopwrap li {
        width: 100%;
        margin-bottom: 100px
    }

    section#shop .inner ul.shopwrap li .img {
        padding-top: calc(624 / 750 * 100%)
    }

    section#shop .inner ul.shopwrap li.grounding .shopmore .more-wrap .readmore {
        padding: 21px 0
    }

    section#shop .inner ul.shopwrap li .shopmore {
        width: calc(100% - 36px);
        height: auto;
        margin: -40px auto 0;
        border-radius: 126px
    }

    section#shop .inner ul.shopwrap li .shopmore .more-wrap .readmore {
        height: 61px;
        padding: 20px 18px 0;
        font-size: 16px;
        letter-spacing: .96px;
    }

    section#shop .inner ul.shopwrap li .shopmore .more-wrap span.en a.readmore {
        height: 61px;
        padding: 12px 18px 0;
        font-size: 16px;
        letter-spacing: .96px;
    }

    section#workscont .ttl-wrap {
        padding-left: 18px
    }

    section#workscont .ttl-wrap h2 {
        font-size: 50px;
        line-height: 58px
    }

    section#workscont .worksfv a {
        display: block;
        padding: 0 18px
    }

    section#workscont .worksfv .left {
        width: 100%;
        margin-bottom: 15vw;
    }

    section#workscont .worksfv .left .img {
        width: 100%;
        height: 0;
        padding-top: calc(383 / 680 * 100%);
        background-size: cover;
        background-position: center;
        position: relative;
        border-radius: 13px;
    }

    section#workscont .worksfv .left p.cate {
        font-size: 14px;
        margin-top: 3vw;
        margin-bottom: 13vw;
        color: #c3f4ff;
    }

    section#workscont .worksfv .left p.date {
        font-size: 14px
    }

    section#workscont .worksfv .left h3 span {
        font-size: 13px;
        line-height: 1.2
    }

    section#workscont .worksfv .left h3 {
        font-size: 21px;
        line-height: 1.54;
    }

    section#workscont #masonry {
        margin: 0 auto 50px;
        width: 100%;
        padding: 0 18px
    }

    section#workscont #masonry .item {
        width: 100%;
        margin-bottom: 13vw;
    }

    section#workscont #masonry .item:nth-child(odd) {
        padding-right: 0
    }

    section#workscont #masonry .item:nth-child(even) {
        padding-left: 0
    }

    section#workscont #masonry .item h3 {
        font-size: 18px;
        margin-top: 2.5vw;
    }

    section#workscont #masonry .item p.cate {
        font-size: 14px
    }

    section#workscont #masonry .item p.date {
        font-size: 13px
    }



    section#boardgamecont .ttl-wrap {
        padding-left: 18px
    }

    section#boardgamecont .ttl-wrap h2 {
        font-size: 50px;
        line-height: 58px
    }

    section#boardgamecont .worksfv a {
        display: block;
        padding: 0 18px
    }

    section#boardgamecont .worksfv .left {
        width: 100%
    }

    section#boardgamecont .worksfv .left .img {
        width: 100%;
        height: 0;
        padding-top: calc(383 / 680 * 100%);
        background-size: cover;
        background-position: center;
        position: relative;
        border-radius: 13px;
    }

    section#boardgamecont .worksfv .left p.cate {
        font-size: 14px;
        margin-top: 3vw;
        margin-bottom: 13vw;
        color: #c3f4ff;
    }

    section#boardgamecont .worksfv .left p.date {
        font-size: 14px
    }

    section#boardgamecont .worksfv .left h3 span {
        font-size: 13px;
        line-height: 1.2
    }

    section#boardgamecont .worksfv .left h3 {
        font-size: 21px;
        line-height: 1.54;
    }

    section#boardgamecont #masonry {
        margin: 0 auto 50px;
        width: 100%;
        padding: 0 18px
    }

    section#boardgamecont #masonry .item {
        width: 100%;
        margin-bottom: 13vw;
    }

    section#boardgamecont #masonry .item:nth-child(odd) {
        padding-right: 0
    }

    section#boardgamecont #masonry .item:nth-child(even) {
        padding-left: 0
    }

    section#boardgamecont #masonry .item h3 {
        font-size: 18px;
        margin-top: 2.5vw;
    }

    section#boardgamecont #masonry .item p.cate {
        font-size: 14px
    }

    section#boardgamecont #masonry .item p.date {
        font-size: 13px
    }

    section#worksdetail .ttlbg {
        width: 93%
    }

    section#worksdetail .ttl-wrap {
        padding-left: 18px;
        top: -55px
    }

    section#worksdetail .ttl-wrap h2 {
        font-size: 50px
    }

    section#worksdetail .ttl-wrap h3 {
        font-size: 14px
    }

    section#worksdetail .singletop {
        display: block;
        padding: 0 18px 60px;
        margin-top: 0
    }

    section#worksdetail .singletop .left {
        width: 100%;
        margin-right: 0
    }

    section#worksdetail .singletop .left .img {
        border-radius: 14px;
        overflow: hidden;
        margin-bottom: 19px
    }

    section#worksdetail .singletop .left p {
        font-size: 14px;
        line-height: 1.65;
    }

    section#worksdetail .singletop .left h3 span {
        font-size: 17px;
        line-height: 1.2
    }

    section#worksdetail .singletop .left h3 {
        font-size: 24px;
        line-height: 1.5;
        margin-bottom: 15px
    }

    section#worksdetail .singletop .left h4 {
        font-size: 15px;
        margin-bottom: 26px
    }


    section#boardgamedetail .ttlbg {
        width: 93%
    }

    section#boardgamedetail .ttl-wrap {
        padding-left: 18px;
        top: -61px
    }

    section#boardgamedetail .ttl-wrap h2 {
        font-size: 50px
    }

    section#boardgamedetail .ttl-wrap h3 {
        font-size: 14px
    }

    section#boardgamedetail .singletop {
        display: block;
        padding: 0 9vw 9vw;
        margin-top: 0;
        margin: 0px 0px 0px 0px;
    }

    section#boardgamedetail .singletop .left {
        width: 100%;
        margin-right: 0
    }

    section#boardgamedetail .singletop .left .img {
        border-radius: 14px;
        overflow: hidden;
        margin-bottom: 19px
    }

    section#boardgamedetail .singletop .left p {
        font-size: 14px;
        line-height: 1.65;
    }

    section#boardgamedetail .singletop .left h3 span {
        font-size: 17px;
        line-height: 1.2
    }

    section#boardgamedetail .singletop .left h3 {
        font-size: 24px;
        line-height: 1.5;
        margin-bottom: 15px
    }

    section#boardgamedetail .singletop .left h4 {
        font-size: 15px;
        margin-bottom: 26px
    }



    section#workscontent {
        padding: 45px 18px 120px
    }

    section#workscontent .inner {
        width: 100%;
        padding: 0 0
    }

    section#workscontent .inner .content {
        display: block;
        padding: 0 0 0
    }

    section#workscontent .inner .content .left {
        width: 100%
    }

    section#workscontent .inner .content .left img {
        width: 100%;
        margin: 0 auto 30px
    }

    section#workscontent .inner .content .left h3 {
        font-size: 20px;
        line-height: 1.5;
        margin-bottom: 19px
    }

    section#workscontent .inner .content .left p {
    	font-size: 17px;
        line-height: 1.8;
        margin-bottom: 43px;
    }

    section#workscontent .inner .content .right {
        width: 100%
    }

    section#workscontent .inner .movie {
        margin-top: 47px;
        padding: 24px 25px
    }

    section#workscontent .inner .movie iframe {
        height: auto
    }

    section#workscontent .inner .info {
        margin-top: 47px
    }

    section#workscontent .inner .info h3 {
        font-size: 19px;
        font-weight: 700;
        line-height: 1.65;
    }

    section#workscontent .inner .info dl {
        line-height: 1.75;
    }

    section#workscontent .inner .info a.linkbtn {
        width: 100%;
        padding: 22px 0;
        font-size: 16px;
        margin-top: 30px
    }

    section#otherworks .ttl-wrap {
        padding-left: 18px;
        padding-right: 0;
        width: 90%;
        border-radius: 0 0 70px 0
    }

    section#otherworks .ttl-wrap h2 {
        font-size: 50px
    }

    section#otherworks .ttl-wrap h3 {
        font-size: 14px
    }

    section#otherworks #masonry {
        width: calc(100% - 84px);
        margin: 0px auto;
        padding-bottom: 8vw;
    }

    section#otherworks #masonry .item {
        width: 100%;
        margin-bottom: 48px
    }

    section#otherworks #masonry .item:nth-child(odd) {
        padding-right: 0
    }

    section#otherworks #masonry .item:nth-child(even) {
        padding-left: 0
    }

    section#otherworks #masonry .item h3 {
        font-size: 17px;
        margin-bottom: 0
    }

    section#otherworks #masonry .item p {
        font-size: 14px;
        line-height: 18px
    }

    section#otherworks #masonry .item .cate {
        margin-top: 8px
    }

    section#otherworks .worksmore {
        margin: 0 auto
    }

    section#otherworks .worksmore .more-wrap {
        width: calc(100% - 38px);
        padding: 30px;
        top: -40px
    }

    .readmore {
        font-size: 16px
    }

    .ttlbg {
        width: 64%;
        min-width: 240px;
        min-height: 199px;
        height: auto;
        border-radius: 0 0 102px 0
    }

    .ttlbg2 {
        width: 64%;
        min-width: 311px;
        min-height: 207px;
        height: auto;
        border-radius: 0 0 105px 0
    }

    section#boardgamedetail .ttlbg {
        width: 64%;
        min-width: 240px;
        min-height: 201px;
        height: auto;
        border-radius: 0 0 70px 0
    }

    .ttl-wrap {
        padding-bottom: 25px
    }

    .ttl-wrap h2 {
        font-size: 60px;
        line-height: 69px
    }

    .ttl-wrap h3 {
        font-size: 14px
    }
}

@media (max-width:812px) and (--mobile) {
    .l-footer ul.subfooter2>li:first-child {
        margin: -8px auto 0;
        display: block
    }
}

.wpcf7-quiz-label{
        font-size: 17px;
        margin-bottom: 0.3em;
    }
/*# sourceMappingURL=../../_sourcemaps/styles.css.map */