@charset "utf-8";

/* common.css
----------------------------------------- */
html {
	font-size: 62.5%;
}
body {
	/* /* font-family: YakuHanMPs_Noto, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", 'Noto Serif JP', serif; */ */
	font-family: 'Kosugi','Roboto';
	font-size: 1.4rem;
	color: #111;
	line-height: 1.8;
	letter-spacing: 0.06em;
	text-align: left;
	font-weight: 400;
	-webkit-text-size-adjust: 100%;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
a {
	color: black;
	text-decoration: none;
}
a:hover {
	/* color: #fff; */
	text-decoration: line;
}
a:focus {
}
.pc {
	display: none !important;
}
/* .sp {
	display: block !important;
} */
input:focus,
select:focus,
textarea:focus {
}
img {
	width: 100%;
	height: auto;
	image-rendering: -webkit-optimize-contrast;
}
* {
	box-sizing: border-box;
}


/* common
----------------------------------------- */
/* loading */
#contents-wrap {
	opacity: 1;
	transition: all 1.0s;
}
#contents-wrap.fade-in {
	opacity: 1;
}
.loading-img {
	display: none;
	position: fixed;
	top: 50%;
	left: 50%;
	width: 140px;
	height: 140px;
	margin-top: -70px;
	margin-left: -70px;
	text-align: center;
	color: #fff;
	z-index: 2;
	text-align: center;
}
.loading-img img {
	width: 100%;
	height: auto;
}

/* breadcrumbs-area */
.breadcrumbs-area {
	
}

/* page-nation */
.page-nation {
	padding: 0 20px;
	text-align: center;
}
.page-nation a,
.page-nation .current {
	margin: 0 2px 0;
	padding: 0 8px;
	font-family: 'Libre Baskerville', serif;
	letter-spacing: 0.01em;
	font-size: 1.2rem;
	color: #999;
}
.page-nation a {
}
.page-nation.white a {
	color: #999;
}
.page-nation .current {
	text-decoration: underline;
	color: #111;
}
.page-nation.white .current {
	color: #fff;
}

/* category-link-list-area */
.category-link-list-area {
	position: relative;
	padding: 40px 8% 37px;
}
.category-link-list-area::before {
	content: "";
	position: absolute;
	left: 8%;
	top: 0;
	width: calc(100% - 16%);
	height: 1px;
	background-color: #B2B2B2;
}
.category-link-list-area::after {
	content: "";
	position: absolute;
	left: 8%;
	bottom: 0;
	width: calc(100% - 16%);
	height: 1px;
	background-color: #B2B2B2;
}
.category-link-list-area-ttl {
	position: absolute;
	top: -5px;
	left: 50%;
	width: 120px;
	margin-left: -60px;
	font-family: 'Libre Baskerville', serif;
	letter-spacing: 0.01em;
	font-size: 1.2rem;
	text-align: center;
	background-color: #fff;
	line-height: 1;
}
.category-link-list {
	display: flex;
	flex-wrap: wrap;
}
.category-link-list a {
	margin: 0 6px 6px 0;
	padding: 2px 5px 2px;
	border: 1px solid #111;
	font-size: 1.0rem;
	letter-spacing: 0.01em;
	line-height: 1;
	vertical-align: top;
}

/* ttl */
.sec-ttl {
}

/* link */
.sec-btn {
	position: relative;
	display: inline-block;
	padding: 1px 24px 0 25px;
	border: 1px solid #111;
	border-radius: 21px;
	font-family: 'Libre Baskerville', serif;
	font-size: 1.1rem;
	line-height: 40px;
	letter-spacing: 0.06em;
}
.sec-btn.white {
	border: 1px solid #fff;
	color: #fff;
}
.sec-btn span {
	position: relative;
	display: inline-block;
	padding-right: 40px;
}
.sec-btn span::after {
	content: "";
	position: absolute;
	right: 0;
	top: 50%;
	width: 17px;
	height: 5px;
	margin-top: -4px;
	background: url(../images/common/sec-btn-arrow-black.svg) 0 0 no-repeat;
	background-size: 17px 5px;
}
.sec-btn.white span::after {
	background: url(../images/common/sec-btn-arrow-white.svg) 0 0 no-repeat;
}


/* header
----------------------------------------- */
#header {
}
.header-logo {
	position: absolute;
	top: 25px;
	left: 25px;
	width: 220px;
	height: auto;
	z-index: 100;
}

/* page-visual-area */
.page-visual-area {
}
.page-ttl {
	opacity: 0;
	transition: all 1.6s;
}
.page-ttl-tagline {
	opacity: 0;
	transition: all 1.6s;
}
.page-ttl-jpn {
	opacity: 0;
	transition: all 1.6s;
	transition-delay: .3s;
}
.page-ttl-sec.fade-in .page-ttl {
	opacity: 1;
}
.page-ttl-sec.fade-in .page-ttl-tagline {
	opacity: 1;
}
.page-ttl-sec.fade-in .page-ttl-jpn {
	opacity: 1;
}


/* slide-menu-btn */
.slide-menu-btn {
	position: fixed;
	top: 10px;
	right: 10px;
	z-index: 10000;
}
.slide-menu-nav {
	box-sizing: border-box;
	position: fixed;
	display: flex;
	align-items: center;
	left: 0;
	top: 0;
	width: calc(100% - 10px);
	height: 100vh;
	height: calc(var(--vh, 1vh) * 100 - 10px);
	margin-left: 10px;
	padding: 0;
	background-color: rgba(245,245,245,1.0);
	overflow: scroll;
	-webkit-overflow-scrolling: touch;
	z-index: 9000;
	opacity: 0;
	visibility: hidden;
	transition: all .6s;
}
.slide-menu-nav.open {
	visibility: visible;
	opacity: 1;
}

/* slide-menu-nav */
.slide-menu-nav .gnav-sp {
	width: 100%;
	margin-top: -20px;
	text-align: center;
}
.slide-menu-nav .gnav-sp li {
	position: relative;
	margin-bottom: 6.5%;
}
.slide-menu-nav li:last-child {
	margin-bottom: 0;
}
.slide-menu-nav .gnav-sp a {
	position: relative;
	display: inline-block;
	font-family: 'Roboto', serif;
	font-size: 1.3rem;
	line-height: 1.4;
	letter-spacing: 0.06em;
}
.slide-menu-nav .gnav-sp a.jpn {
	position: relative;
	display: inline-block;
	font-family: YakuHanMPs_Noto, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", 'Noto Serif JP', serif;
	font-size: 1.25rem;
	line-height: 1.4;
	letter-spacing: 0.06em;
}
.slide-menu-nav .gnav01 {
	opacity: 0;
	transition: all .6s;
}
.slide-menu-nav .gnav02 {
	opacity: 0;
	transition: all .6s;
	transition-delay: .1s;
}
.slide-menu-nav .gnav03 {
	opacity: 0;
	transition: all .6s;
	transition-delay: .16s;
}
.slide-menu-nav .gnav04 {
	opacity: 0;
	transition: all .6s;
	transition-delay: .22s;
}
.slide-menu-nav .gnav05 {
	opacity: 0;
	transition: all .6s;
	transition-delay: .28s;
}
.slide-menu-nav .gnav06 {
	opacity: 0;
	transition: all .6s;
	transition-delay: .34s;
}
.slide-menu-nav.open .gnav01,
.slide-menu-nav.open .gnav02,
.slide-menu-nav.open .gnav03,
.slide-menu-nav.open .gnav04,
.slide-menu-nav.open .gnav05,
.slide-menu-nav.open .gnav06 {
	opacity: 1;
}
#top .slide-menu-nav .gnav01 a,
#story .slide-menu-nav .gnav02 a,
#intermission .slide-menu-nav .gnav03 a,
#sikou .slide-menu-nav .gnav04 a,
#our-firm .slide-menu-nav .gnav05 a,
#access .slide-menu-nav .gnav06 a {
	color: #B9B9B9;
}
#top .slide-menu-nav .gnav01 a::after,
#story .slide-menu-nav .gnav02 a::after,
#intermission .slide-menu-nav .gnav03 a::after,
#sikou .slide-menu-nav .gnav04 a::after,
#our-firm .slide-menu-nav .gnav05 a::after,
#access .slide-menu-nav .gnav06 a::after {
	content: '';
	display: block;
	position: absolute;
	top: 50%;
	left: -3px;
	width: calc(100% + 6px);
	height: 1px;
	background-color: #B9B9B9;
}

/* menu-trigger */
.menu-trigger,
.menu-trigger span {
	display: inline-block;
	transition: all .4s;
	box-sizing: border-box;
}
.menu-trigger {
	position: relative;
	width: 50px;
	height: 50px;
	background-color: #fff;
	opacity: 0.9;
  	margin-top: 15px;
}
.menu-trigger span {
	position: absolute;
	left: 0;
	width: 24px;
	height: 1px;
	background-color: #0b2a4a;
}
#top .menu-trigger span {
	background-color:  #0b2a4a;
}
#top .menu-trigger.menu-color-black span {
	background-color: #0b2a4a;
}
#top .menu-trigger.active span {
	background-color: #0b2a4a;
}
.menu-trigger.active span {
	background-color: #0b2a4a;
}
.menu-trigger span:nth-of-type(1) {
	top: 21px;
	left: 13px;
}
.menu-trigger span:nth-of-type(2) {
	bottom: 22px;
	left: 13px;
}
.menu-trigger.active span:nth-of-type(1) {
	-webkit-transform: translateY(3px) rotate(-45deg);
	transform: translateY(3px) rotate(-45deg);
}
.menu-trigger.active span:nth-of-type(2) {
	-webkit-transform: translateY(-3px) rotate(45deg);
	transform: translateY(-3px) rotate(45deg);
}


/* contents
----------------------------------------- */
/* cta-sec */

.page_top_background{
	background-color: #0b2a4a;
	width:100%;
}
.cta-sec {
	margin: 100px 0 100px;
	padding: 0 6.6%;
}
#top .cta-sec {
	margin-top: 70px;
}
.cta-btn {
	position: relative;
	display: block;
}
.cta-btn::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 1px;
	height: calc(100% - 26px);
	margin-top: 13px;
	background-color: #B2B2B2;
}
.cta-btn::after {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	width: 1px;
	height: calc(100% - 26px);
	margin-top: 13px;
	background-color: #B2B2B2;
}
.cta-btn-inner {
	position: relative;
	padding: 50px 0 50px 40px;
}
.cta-btn-inner::before {
	content: "";
	position: absolute;
	top: 0;
	left: 10px;
	width: calc(100% - 20px);
	height: 1px;
	background-color: #B2B2B2;
}
.cta-btn-inner::after {
	content: "";
	position: absolute;
	bottom: 0;
	left: 10px;
	width: calc(100% - 20px);
	height: 1px;
	background-color: #B2B2B2;
}
.cta-btn-inner p {
}
.cta-btn-inner p::after {
	content: "";
	position: absolute;
	right: 40px;
	top: 50%;
	width: 42px;
	height: 6px;
	margin-top: -3px;
	background: url(../images/common/cta-btn-arrow_sp.svg) 0 0 no-repeat;
	background-size: 42px 6px;
}
.cta-btn .eng {
	position: relative;
	display: inline-block;
	margin-bottom: 5px;
	font-family: 'Libre Baskerville', serif;
	letter-spacing: 0.01em;
	font-size: 2.4rem;
	line-height: 1.0;
}
.cta-btn .jpn {
	display: block;
	padding-left: 3px;
	font-size: 1.0rem;
}
.cta-ourfirm-btn {
	margin-bottom: 20px;
	transform: translateY(20px);
	opacity: 0;
	transition: all 1.0s;
}
.cta-sec.scrollin .cta-ourfirm-btn {
	transform: translateY(0);
	opacity: 1;
}
.cta-access-btn {
	transform: translateY(20px);
	opacity: 0;
	transition: all 1.0s;
	transition-delay: .25s;
}
.cta-sec.scrollin .cta-access-btn {
	transform: translateY(0);
	opacity: 1;
}
.cta-btn.cta-access-btn .jpn {
	padding-left: 0;
}
#our-firm .cta-ourfirm-btn .cta-label,
#access .cta-access-btn .cta-label {
	opacity: .4;
}
#our-firm .cta-ourfirm-btn .cta-label .eng::after,
#access .cta-access-btn .cta-label .eng::after {
	content: "";
	position: absolute;
	left: -2px;
	top: 50%;
	width: calc(100% + 4px);
	height: 1px;
	background-color: #111;
}

/* form-input-tbl */
.form-input-tbl {
	width: 100%;
}
.form-input-tbl th,
.form-input-tbl td {
	display: block;
	width: 100%;
}
.form-input-tbl th {
	margin-bottom: 10px;
	font-size: 1.2rem;
	color: #111;
	letter-spacing: 0.07em;
}
.form-input-tbl td {
	margin-bottom: 20px;
	font-size: 1.2rem;
	color: #111;
}

/* form */
.input-text {
	font-family: YakuHanJP_Noto, 'Noto Sans JP', sans-serif;
	width: 100%;
	height: 46px;
	box-sizing: border-box;
	padding: 2px 8px;
	border: none;
	background-color: #F0F1F3;
	color: #111;
	vertical-align: middle;
	font-size: 1.2rem;
}
.textarea {
	font-family: YakuHanJP_Noto, 'Noto Sans JP', sans-serif;
	box-sizing: border-box;
	width: 	100%;
	padding: 8px 8px;
	border: none;
	background-color: #F0F1F3;
	font-size: 1.2rem;
}
.input-select {
	font-family: YakuHanJP_Noto, 'Noto Sans JP', sans-serif;
	width: 16em;
	height: 40px;
	margin-right: 5px;
	padding: 6px 8px;
	border: none;
	background-color: #F0F1F3;
	color: #111;
	font-size: 1.2rem;
	line-height: 1.6;
	vertical-align: middle;
}
.submit-btn {
	font-family: YakuHanJP_Noto, 'Noto Sans JP', sans-serif;
	display: block;
	width: 220px;
	margin: 20px auto 0;
	padding: 20px 0;
	background-color: #111;
	text-align: center;
	font-size: 1.2rem;
	color: #fff;
	letter-spacing: 0.1em;
	border-style: none;
}
.submit-btn:hover {
}
input[type="button"],input[type="submit"] {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}
input[type="text"],
input[type="button"],
input[type="email"],
input[type="submit"],
textarea {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
	border-radius: 0;
}

input[type="email"]:focus, input[type="number"]:focus, input[type="search"]:focus, input[type="text"]:focus, input[type="tel"]:focus, input[type="url"]:focus, textarea:focus, select:focus {
	border: 1px solid #AFB2B9;
	outline: 0;
}
input[type="submit"]:focus,
button[type="submit"]:focus {
	background-color: #AFB2B9;
	color: #fff;
	outline: 0;
}

.required-input-mark {
	color: #ff0000;
	font-size: 1.2rem;
}
.form-alert-text {
	margin-bottom: 30px;
	font-size: 1.2rem;
	line-height: 2.0;
}


/* footer
----------------------------------------- */
#footer {
	/* padding-bottom: 30px; */
	background:#0b2a4a;
}
.page-top {
	display: block;
	width: 22px;
	height: 11px;
	margin: 0 auto 60px;
	background: url(../images/common/page-top-arrow.svg) 0 0 no-repeat;
	background-size: cover;
}
.footer-gnav {
	margin-bottom: 70px;
	text-align: center;
}
.footer-gnav li {
	position: relative;
	margin-bottom: 5.0%;
}
.footer-gnav li:last-child {
	margin-bottom: 0;
}
.footer-gnav li a {
	position: relative;
	display: inline-block;
	font-family: 'Roboto';
	font-size: 1.3rem;
	line-height: 1.4;
	letter-spacing: 0.06em;
	color: #fff;
}
.footer-gnav li a.jpn {
	position: relative;
	display: inline-block;
	font-family:  'Roboto';
	font-size: 1.25rem;
	line-height: 1.4;
	letter-spacing: 0.06em;
}
#top .footer-gnav .fnav01 a,
#story .footer-gnav .fnav02 a,
#intermission .footer-gnav .fnav03 a,
#sikou .footer-gnav .fnav04 a,
#our-firm .footer-gnav .fnav05 a,
#access .footer-gnav .fnav06 a {
	color: #B9B9B9;
}
#top .footer-gnav .fnav01 a::after,
#story .footer-gnav .fnav02 a::after,
#intermission .footer-gnav .fnav03 a::after,
#sikou .footer-gnav .fnav04 a::after,
#our-firm .footer-gnav .fnav05 a::after,
#access .footer-gnav .fnav06 a::after {
	content: '';
	display: block;
	position: absolute;
	top: 50%;
	left: -3px;
	width: calc(100% + 6px);
	height: 1px;
	background-color: #B9B9B9;
}
.footer-logo {
	width: 100px;
	margin: 0 auto 40px;
}
.footer-instagram {
	width: 22px;
	margin: 0 auto 40px;
}
.footer-info {
	color: #999;
	font-size: 1.0rem;
	text-align: center;
	letter-spacing: 0.01em;
}
.footer-address {
	padding: 0 8%;
}
.footer-tel-fax {
	margin-bottom: 15px;
}
.footer-tel-fax span:first-child {
	margin-right: 10px;
}
.footer-privacy {
	margin-bottom: 60px;
}
.footer-privacy a {
	font-family: 'Libre Baskerville', serif;
	color: #999;
}
.footer-copyright {
	font-size: 1.0rem;
	transform: scale(0.9);
	transform-origin: center center;
}

/* trace-nav */
/* .trace-nav-wrap { */
/* 	display: none; */
/* } */
#top .trace-nav-wrap {
	display: block;
}
.trace-nav {
	position: fixed;
	top: -10px;
	right: 0;
	width: 100%;
	padding: 30px 78px 0 0;
	z-index: 100000;
	text-align: right;
	opacity: 0;
	transition: all .3s;
}
.trace-nav.fixed {
	top: 0;
	opacity: 0.9;
	background: #fff;
}
.trace-nav li {
	display: inline-block;
	width: auto;
}
.trace-nav li:not(:last-child) {
	/* margin-right: 3.4%; */
}
.trace-nav a {
	position: relative;
	display: inline-block;
	font-family: 'Roboto';
	font-weight:500;
	font-size: 1.2rem;
	line-height: 1.4;
	letter-spacing: 0.06em;
	transition: color .3s;
	padding: 20px;
}
.trace-nav a:hover {
	color: #B9B9B9;
}
.trace-nav a.jpn {
	position: relative;
	display: inline-block;
	font-family: 'Roboto','Kosugi';
	font-size: 1.25rem;
	line-height: 1.4;
	letter-spacing: 0.06em;
}
#top .trace-nav .gnav01 a,
#story .trace-nav .gnav02 a,
#intermission .trace-nav .gnav03 a,
#sikou .trace-nav .gnav04 a,
#our-firm .trace-nav .gnav05 a,
#access .trace-nav .gnav06 a {
	color: #B9B9B9;
}
#top .trace-nav .gnav01 a::after,
#story .trace-nav .gnav02 a::after,
#intermission .trace-nav .gnav03 a::after,
#sikou .trace-nav .gnav04 a::after,
#our-firm .trace-nav .gnav05 a::after,
#access .trace-nav .gnav06 a::after {
	content: '';
	display: block;
	position: absolute;
	top: 50%;
	left: -3px;
	width: calc(100% + 6px);
	height: 1px;
	background-color: #B9B9B9;
}






















































/* tablet 560px - 959px */
@media only screen and (min-width: 560px) {

/* common
----------------------------------------- */
/* loading */
#contents-wrap {
	opacity: 1;
	transition: all 2.0s;
}
#contents-wrap.fade-in {
	opacity: 1;
}
.loading-img {
	display: none;
	position: fixed;
	top: 50%;
	left: 50%;
	width: 160px;
	height: 160px;
	margin-top: -90px;
	margin-left: -80px;
	text-align: center;
	color: #fff;
	z-index: 2;
	text-align: center;
}
.loading-img img {
	width: 100%;
	height: auto;
}

/* breadcrumbs-area */
.breadcrumbs-area {
	display: none;
}

/* page-nation */
.page-nation {
	padding: 0 20px;
	text-align: center;
}
.page-nation a,
.page-nation .current {
	margin: 0 2px 0;
	padding: 0 12px;
	font-family: 'Libre Baskerville', serif;
	letter-spacing: 0.01em;
	font-size: 1.2rem;
	color: #999;
}
.page-nation a {
}
.page-nation.white a {
	color: #999;
}
.page-nation .current {
	text-decoration: underline;
	color: #111;
}
.page-nation.white .current {
	color: #fff;
}

/* category-link-list-area */
.category-link-list-area {
	position: relative;
	padding: 60px 8% 57px;
}
.category-link-list-area::before {
	content: "";
	position: absolute;
	left: 8%;
	top: 0;
	width: calc(100% - 16%);
	height: 1px;
	background-color: #B2B2B2;
}
.category-link-list-area::after {
	content: "";
	position: absolute;
	left: 8%;
	bottom: 0;
	width: calc(100% - 16%);
	height: 1px;
	background-color: #B2B2B2;
}
.category-link-list-area-ttl {
	position: absolute;
	top: -5px;
	left: 50%;
	width: 120px;
	margin-left: -60px;
	font-family: 'Libre Baskerville', serif;
	letter-spacing: 0.01em;
	font-size: 1.2rem;
	text-align: center;
	background-color: #fff;
	line-height: 1;
}
.category-link-list {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}
.category-link-list a {
	margin: 0 8px 8px 0;
	padding: 2px 5px 2px;
	border: 1px solid #111;
	font-size: 1.1rem;
	letter-spacing: 0.01em;
	line-height: 1;
	vertical-align: top;
}

/* ttl */
.sec-ttl {
}

/* link */
.sec-btn {
	position: relative;
	display: inline-block;
	padding: 1px 24px 0 25px;
	border: 1px solid #111;
	border-radius: 21px;
	font-family: 'Libre Baskerville', serif;
	font-size: 1.1rem;
	line-height: 40px;
	letter-spacing: 0.06em;
}
.sec-btn.white {
	border: 1px solid #fff;
	color: #fff;
}
.sec-btn span {
	position: relative;
	display: inline-block;
	padding-right: 40px;
}
.sec-btn span::after {
	content: "";
	position: absolute;
	right: 0;
	top: 50%;
	width: 17px;
	height: 5px;
	margin-top: -4px;
	background: url(../images/common/sec-btn-arrow-black.svg) 0 0 no-repeat;
	background-size: 17px 5px;
}
.sec-btn.white span::after {
	background: url(../images/common/sec-btn-arrow-white.svg) 0 0 no-repeat;
}

/* header
----------------------------------------- */
#header {
}
.header-logo {
	position: absolute;
	top: 40px;
	left: 40px;
	width: 280px;
	height: auto;
	z-index: 100;
}

/* page-visual-area */
.page-visual-area {
}
.page-ttl {
	opacity: 0;
	transition: all 1.6s;
}
.page-ttl-tagline {
	opacity: 0;
	transition: all 1.6s;
}
.page-ttl-jpn {
	opacity: 0;
	transition: all 1.6s;
	transition-delay: .3s;
}
.page-ttl-sec.fade-in .page-ttl {
	opacity: 1;
}
.page-ttl-sec.fade-in .page-ttl-tagline {
	opacity: 1;
}
.page-ttl-sec.fade-in .page-ttl-jpn {
	opacity: 1;
}

/* slide-menu-btn */
.slide-menu-btn {
	position: fixed;
	top: 30px;
	right: 30px;
	z-index: 10000;
}
.slide-menu-nav {
	box-sizing: border-box;
	position: fixed;
	display: flex;
	align-items: center;
	left: 0;
	top: 0;
	width: calc(100% - 10px);
	height: 100vh;
	height: calc(var(--vh, 1vh) * 100 - 10px);
	margin-left: 10px;
	padding: 0;
	background-color: rgba(245,245,245,1.0);
	overflow: scroll;
	-webkit-overflow-scrolling: touch;
	z-index: 9000;
	opacity: 0;
	visibility: hidden;
	transition: all .6s;
}
.slide-menu-nav.open {
	visibility: visible;
	opacity: 1;
}

/* slide-menu-nav */
.slide-menu-nav .gnav-sp {
	width: 100%;
	margin-top: -20px;
	text-align: center;
}
.slide-menu-nav .gnav-sp li {
	position: relative;
	margin-bottom: 6.5%;
}
.slide-menu-nav li:last-child {
	margin-bottom: 0;
}
.slide-menu-nav .gnav-sp a {
	position: relative;
	display: inline-block;
	font-family: 'Libre Baskerville', serif;
	font-size: 1.4rem;
	line-height: 1.4;
	letter-spacing: 0.06em;
}
.slide-menu-nav .gnav-sp a.jpn {
	position: relative;
	display: inline-block;
	font-family: YakuHanMPs_Noto, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", 'Noto Serif JP', serif;
	font-size: 1.25rem;
	line-height: 1.4;
	letter-spacing: 0.06em;
}
.slide-menu-nav .gnav01 {
	opacity: 0;
	transition: all .6s;
}
.slide-menu-nav .gnav02 {
	opacity: 0;
	transition: all .6s;
	transition-delay: .1s;
}
.slide-menu-nav .gnav03 {
	opacity: 0;
	transition: all .6s;
	transition-delay: .16s;
}
.slide-menu-nav .gnav04 {
	opacity: 0;
	transition: all .6s;
	transition-delay: .22s;
}
.slide-menu-nav .gnav05 {
	opacity: 0;
	transition: all .6s;
	transition-delay: .28s;
}
.slide-menu-nav .gnav06 {
	opacity: 0;
	transition: all .6s;
	transition-delay: .34s;
}
.slide-menu-nav.open .gnav01,
.slide-menu-nav.open .gnav02,
.slide-menu-nav.open .gnav03,
.slide-menu-nav.open .gnav04,
.slide-menu-nav.open .gnav05,
.slide-menu-nav.open .gnav06 {
	opacity: 1;
}
#top .slide-menu-nav .gnav01 a,
#story .slide-menu-nav .gnav02 a,
#intermission .slide-menu-nav .gnav03 a,
#sikou .slide-menu-nav .gnav04 a,
#our-firm .slide-menu-nav .gnav05 a,
#access .slide-menu-nav .gnav06 a {
	color: #B9B9B9;
}
#top .slide-menu-nav .gnav01 a::after,
#story .slide-menu-nav .gnav02 a::after,
#intermission .slide-menu-nav .gnav03 a::after,
#sikou .slide-menu-nav .gnav04 a::after,
#our-firm .slide-menu-nav .gnav05 a::after,
#access .slide-menu-nav .gnav06 a::after {
	content: '';
	display: block;
	position: absolute;
	top: 50%;
	left: -3px;
	width: calc(100% + 6px);
	height: 1px;
	background-color: #B9B9B9;
}

/* menu-trigger */
.menu-trigger,
.menu-trigger span {
	display: inline-block;
	transition: all .4s;
	box-sizing: border-box;
}
.menu-trigger {
	position: relative;
	width: 50px;
	height: 50px;
	background-color: #fff;
}
.menu-trigger span {
	position: absolute;
	left: 0;
	width: 24px;
	height: 1px;
	background-color: #0b2a4a;
}
#top .menu-trigger span {
	background-color: #0b2a4a;
}
#top .menu-trigger.menu-color-black span {
	background-color: #0b2a4a;
}
#top .menu-trigger.active span {
	background-color: #0b2a4a;
}
.menu-trigger.active span {
	background-color: #0b2a4a;
}
.menu-trigger span:nth-of-type(1) {
	top: 21px;
	left: 13px;
}
.menu-trigger span:nth-of-type(2) {
	bottom: 22px;
	left: 13px;
}
.menu-trigger.active span:nth-of-type(1) {
	-webkit-transform: translateY(3px) rotate(-45deg);
	transform: translateY(3px) rotate(-45deg);
}
.menu-trigger.active span:nth-of-type(2) {
	-webkit-transform: translateY(-3px) rotate(45deg);
	transform: translateY(-3px) rotate(45deg);
}


/* contents
----------------------------------------- */
/* cta-sec */
.cta-sec {
	display: flex;
	max-width: 800px;
	margin: 120px auto 100px;
	padding: 0 6.6%;
}
#top .cta-sec {
	margin-top: 90px;
}
.cta-btn {
	position: relative;
	display: block;
	width: 47%;
}
.cta-btn::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 1px;
	height: calc(100% - 26px);
	margin-top: 13px;
	background-color: #B2B2B2;
}
.cta-btn::after {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	width: 1px;
	height: calc(100% - 26px);
	margin-top: 13px;
	background-color: #B2B2B2;
}
.cta-btn-inner {
	position: relative;
	padding: 50px 0 50px 40px;
}
.cta-btn-inner::before {
	content: "";
	position: absolute;
	top: 0;
	left: 10px;
	width: calc(100% - 20px);
	height: 1px;
	background-color: #B2B2B2;
}
.cta-btn-inner::after {
	content: "";
	position: absolute;
	bottom: 0;
	left: 10px;
	width: calc(100% - 20px);
	height: 1px;
	background-color: #B2B2B2;
}
.cta-btn-inner p {
}
.cta-btn-inner p::after {
	content: "";
	position: absolute;
	right: 35px;
	top: 50%;
	width: 42px;
	height: 6px;
	margin-top: -3px;
	background: url(../images/common/cta-btn-arrow_sp.svg) 0 0 no-repeat;
	background-size: 42px 6px;
}
.cta-btn .eng {
	position: relative;
	display: inline-block;
	margin-bottom: 5px;
	font-family: 'Libre Baskerville', serif;
	letter-spacing: 0.01em;
	font-size: 2.1rem;
	line-height: 1.0;
}
.cta-btn .jpn {
	display: block;
	padding-left: 3px;
	font-size: 1.0rem;
}
.cta-ourfirm-btn {
	margin: 0 6% 0 0;
	transform: translateY(20px);
	opacity: 0;
	transition: all 1.0s;
}
.cta-sec.scrollin .cta-ourfirm-btn {
	transform: translateY(0);
	opacity: 1;
}
.cta-access-btn {
	transform: translateY(20px);
	opacity: 0;
	transition: all 1.0s;
	transition-delay: .25s;
}
.cta-sec.scrollin .cta-access-btn {
	transform: translateY(0);
	opacity: 1;
}
.cta-btn.cta-access-btn .jpn {
	padding-left: 0;
}
#our-firm .cta-ourfirm-btn .cta-label,
#access .cta-access-btn .cta-label {
	opacity: .4;
}
#our-firm .cta-ourfirm-btn .cta-label .eng::after,
#access .cta-access-btn .cta-label .eng::after {
	content: "";
	position: absolute;
	left: -2px;
	top: 50%;
	width: calc(100% + 4px);
	height: 1px;
	background-color: #111;
}

/* form-input-tbl */
.form-input-tbl {
	width: 100%;
}
.form-input-tbl th,
.form-input-tbl td {
	display: block;
	width: 100%;
}
.form-input-tbl th {
	margin-bottom: 10px;
	font-size: 1.2rem;
	color: #111;
	letter-spacing: 0.07em;
}
.form-input-tbl td {
	margin-bottom: 20px;
	font-size: 1.2rem;
	color: #111;
}

/* form */
.input-text {
	font-family: YakuHanJP_Noto, 'Noto Sans JP', sans-serif;
	width: 100%;
	height: 46px;
	box-sizing: border-box;
	padding: 2px 8px;
	border: none;
	background-color: #F0F1F3;
	color: #111;
	vertical-align: middle;
	font-size: 1.2rem;
}
.textarea {
	font-family: YakuHanJP_Noto, 'Noto Sans JP', sans-serif;
	box-sizing: border-box;
	width: 	100%;
	padding: 8px 8px;
	border: none;
	background-color: #F0F1F3;
	font-size: 1.2rem;
}
.input-select {
	font-family: YakuHanJP_Noto, 'Noto Sans JP', sans-serif;
	width: 16em;
	height: 40px;
	margin-right: 5px;
	padding: 6px 8px;
	border: none;
	background-color: #F0F1F3;
	color: #111;
	font-size: 1.2rem;
	line-height: 1.6;
	vertical-align: middle;
}
.submit-btn {
	font-family: YakuHanJP_Noto, 'Noto Sans JP', sans-serif;
	display: block;
	width: 	220px;
	margin: 30px auto 0;
	padding: 18px 0;
	background-color: #111;
	text-align: center;
	font-size: 1.2rem;
	color: #fff;
	letter-spacing: 0.1em;
	border-style: none;
}
.submit-btn:hover {
}
input[type="button"],input[type="submit"] {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}
input[type="text"],
input[type="button"],
input[type="email"],
input[type="submit"],
textarea {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
	border-radius: 0;
}

input[type="email"]:focus, input[type="number"]:focus, input[type="search"]:focus, input[type="text"]:focus, input[type="tel"]:focus, input[type="url"]:focus, textarea:focus, select:focus {
	border: 1px solid #AFB2B9;
	outline: 0;
}
input[type="submit"]:focus,
button[type="submit"]:focus {
	background-color: #AFB2B9;
	color: #fff;
	outline: 0;
}

.required-input-mark {
	color: #ff0000;
	font-size: 1.2rem;
}
.form-alert-text {
	margin-bottom: 40px;
	font-size: 1.2rem;
	line-height: 2.0;
}


/* footer
----------------------------------------- */
#footer {
	/* padding-bottom: 30px; */
}
.page-top {
	display: block;
	width: 22px;
	height: 11px;
	margin: 0 auto 60px;
	background: url(../images/common/page-top-arrow.svg) 0 0 no-repeat;
	background-size: cover;
}
.footer-gnav {
	margin-bottom: 70px;
	text-align: center;
}
.footer-gnav li {
	position: relative;
	margin-bottom: 3.0%;
}
.footer-gnav li:last-child {
	margin-bottom: 0;
}
.footer-gnav li a {
	position: relative;
	display: inline-block;
	font-family: 'Libre Baskerville', serif;
	font-size: 1.3rem;
	line-height: 1.4;
	letter-spacing: 0.06em;
}
.footer-gnav li a.jpn {
	position: relative;
	display: inline-block;
	font-family: YakuHanMPs_Noto, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", 'Noto Serif JP', serif;
	font-size: 1.25rem;
	line-height: 1.4;
	letter-spacing: 0.06em;
}
#top .footer-gnav .fnav01 a,
#story .footer-gnav .fnav02 a,
#intermission .footer-gnav .fnav03 a,
#sikou .footer-gnav .fnav04 a,
#our-firm .footer-gnav .fnav05 a,
#access .footer-gnav .fnav06 a {
	color: #B9B9B9;
}
#top .footer-gnav .fnav01 a::after,
#story .footer-gnav .fnav02 a::after,
#intermission .footer-gnav .fnav03 a::after,
#sikou .footer-gnav .fnav04 a::after,
#our-firm .footer-gnav .fnav05 a::after,
#access .footer-gnav .fnav06 a::after {
	content: '';
	display: block;
	position: absolute;
	top: 50%;
	left: -3px;
	width: calc(100% + 6px);
	height: 1px;
	background-color: #B9B9B9;
}
.footer-logo {
	width: 140px;
	margin: 0 auto 40px;
}
.footer-instagram {
	width: 22px;
	margin: 0 auto 40px;
}
.footer-info {
	color: #999;
	font-size: 1.0rem;
	text-align: center;
	letter-spacing: 0.01em;
}
.footer-address {
	padding: 0 8%;
}
.footer-tel-fax {
	margin-bottom: 15px;
}
.footer-tel-fax span:first-child {
	margin-right: 10px;
}
.footer-privacy {
	margin-bottom: 60px;
}
.footer-privacy a {
	font-family: 'Libre Baskerville', serif;
	color: #999;
}
.footer-copyright {
	font-size: 1.0rem;
	transform: scale(0.9);
	transform-origin: center center;
}

/* trace-nav */
/* .trace-nav-wrap { */
/* 	display: none; */
/* } */
#top .trace-nav-wrap {
	display: block;
}
.trace-nav {
	position: fixed;
	top: -10px;
	right: 0;
	width: 100%;
	padding: 30px 78px 0 0;
	z-index: 100000;
	text-align: right;
	opacity: 0;
	transition: all .3s;
}
.trace-nav.fixed {
	top: 0;
	opacity: 0.9;
	background: #fff;
}
.trace-nav li {
	display: inline-block;
	width: auto;
}
.trace-nav li:not(:last-child) {
	/* margin-right: 3.4%; */
}
.trace-nav a {
	position: relative;
	display: inline-block;
	font-family: 'Roboto';
	font-weight:500;
	font-size: 1.2rem;
	line-height: 1.4;
	letter-spacing: 0.06em;
	transition: color .3s;
	padding: 20px;
}
.trace-nav a:hover {
	color: #B9B9B9;
}
.trace-nav a.jpn {
	position: relative;
	display: inline-block;
	font-family: 'Roboto','Kosugi';
	font-size: 1.25rem;
	line-height: 1.4;
	letter-spacing: 0.06em;
}
#top .trace-nav .gnav01 a,
#story .trace-nav .gnav02 a,
#intermission .trace-nav .gnav03 a,
#sikou .trace-nav .gnav04 a,
#our-firm .trace-nav .gnav05 a,
#access .trace-nav .gnav06 a {
	color: #B9B9B9;
}
#top .trace-nav .gnav01 a::after,
#story .trace-nav .gnav02 a::after,
#intermission .trace-nav .gnav03 a::after,
#sikou .trace-nav .gnav04 a::after,
#our-firm .trace-nav .gnav05 a::after,
#access .trace-nav .gnav06 a::after {
	content: '';
	display: block;
	position: absolute;
	top: 50%;
	left: -3px;
	width: calc(100% + 6px);
	height: 1px;
	background-color: #B9B9B9;
}


} /* tablet end */
























































/* PC 960px - */
@media only screen and (min-width: 1200px) {
	.slide-menu-btn {
		display: none;
	}
	

.pc {
	display: block !important;
}
/* .sp {
	display: none !important;
} */
img {
	width: 100%;
	height: auto;
}


/* common
----------------------------------------- */
/* loading */
#contents-wrap {
	position: relative;
	opacity: 1;
	transition: all 2.0s;
}
#contents-wrap.fade-in {
	opacity: 1;
}
.loading-img {
	display: none;
	position: fixed;
	top: 50%;
	left: 50%;
	width: 200px;
	height: 200px;
	margin-top: -140px;
	margin-left: -100px;
	text-align: center;
	color: #fff;
	z-index: 2;
	text-align: center;
}
.loading-img img {
	width: 100%;
	height: auto;
}

/* trace-nav */
/* .trace-nav-wrap { */
/* 	display: none; */
/* } */
#top .trace-nav-wrap {
	display: block;
}
.trace-nav {
	position: fixed;
	top: -10px;
	right: 0;
	width: 100%;
	padding: 20px 100px 20px 20px;
	z-index: 100000;
	text-align: right;
	opacity: 0;
	transition: all .3s;
}
.trace-nav.fixed {
	top: 0;
	opacity: 0.9;
	background: #fff;
	border-bottom: 10px solid #004324;
}
.trace-nav li {
	display: inline-block;
	width: auto;
}
.trace-nav li:not(:last-child) {
	/* margin-right: 3.4%; */
}
.trace-nav a {
	position: relative;
	display: inline-block;
	font-family: 'Roboto';
	font-weight:500;
	font-size: 1.8rem;
	line-height: 1.4;
	letter-spacing: 0.06em;
	transition: color .3s;
	/* padding: 50px; */
	border-left: 2px #0b2a4a solid;
	padding: 1rem 4rem 1rem 4rem;
}
.trace-nav a:hover {
	color: #B9B9B9;
}
.trace-nav a.jpn {
	position: relative;
	display: inline-block;
	font-family: 'Roboto','Kosugi';
	font-size: 1.25rem;
	line-height: 1.4;
	letter-spacing: 0.06em;
}
#top .trace-nav .gnav01 a,
#story .trace-nav .gnav02 a,
#intermission .trace-nav .gnav03 a,
#sikou .trace-nav .gnav04 a,
#our-firm .trace-nav .gnav05 a,
#access .trace-nav .gnav06 a {
	color: #B9B9B9;
}
#top .trace-nav .gnav01 a::after,
#story .trace-nav .gnav02 a::after,
#intermission .trace-nav .gnav03 a::after,
#sikou .trace-nav .gnav04 a::after,
#our-firm .trace-nav .gnav05 a::after,
#access .trace-nav .gnav06 a::after {
	content: '';
	display: block;
	position: absolute;
	top: 50%;
	left: -3px;
	width: calc(100% + 6px);
	height: 1px;
	background-color: #B9B9B9;
}

/* breadcrumbs-area */
.breadcrumbs-area {
	box-sizing: border-box;
	display: block;
}
.breadcrumbs-list {
	position: absolute;
	top: 74px;
	right: -6%;
}
#sikou .breadcrumbs-list {
	top: 64px;
}
.breadcrumbs-list li {
	margin-bottom: 30px;
	font-family: 'Libre Baskerville', "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", 'Noto Serif JP', serif;
}
.breadcrumbs-list a,
.breadcrumbs-list li span {
	display: block;
	font-size: 1.1rem;
	line-height: 1;
	color: #111;
	letter-spacing: 0.03em;
	-webkit-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	vertical-align: top;
}
.breadcrumbs-list a {
	position: relative;
	transition: color .3s;
}
.breadcrumbs-list a:hover {
	color: #B9B9B9;
}
.breadcrumbs-list a::before {
	display: block;
	content: '';
	position: absolute;
	bottom: -17px;
	left: calc(50% - 1px);
	width: 1px;
	height: 4px;
	background-color: #666;
	background-size: 1px 4px;
}
.breadcrumbs-list li span {
	color: #B9B9B9;
}

/* page-nation */
.page-nation {
	padding: 0 20px;
	text-align: center;
}
.page-nation a,
.page-nation .current {
	margin: 0 2px 0;
	padding: 0 10px;
	font-family: 'Libre Baskerville', serif;
	letter-spacing: 0.01em;
	font-size: 1.6rem;
	color: #999;
}
.page-nation a {
	transition: color .3s;
}
.page-nation a:hover {
	color: #111;
}
.page-nation.white a {
	color: #999;
	transition: color .3s;
}
.page-nation.white a:hover {
	color: #fff;
}
.page-nation .current {
	text-decoration: underline;
	color: #111;
}
.page-nation.white .current {
	color: #fff;
}

/* category-link-list-area */
.category-link-list-area {
	position: relative;
	max-width: 700px;
	margin: 0 auto;
	padding: 60px 0 50px;
}
.category-link-list-area::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 1px;
	background-color: #B2B2B2;
}
.category-link-list-area::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	height: 1px;
	background-color: #B2B2B2;
}
.category-link-list-area-ttl {
	position: absolute;
	top: -5px;
	left: 50%;
	width: 150px;
	margin-left: -75px;
	font-family: 'Libre Baskerville', serif;
	letter-spacing: 0.01em;
	font-size: 1.3rem;
	text-align: center;
	background-color: #fff;
	line-height: 1;
}
.category-link-list {
	display: flex;
	flex-wrap: wrap;
}
.category-link-list a {
	margin: 0 10px 10px 0;
	padding: 3px 5px 3px;
	border: 1px solid #111;
	font-size: 1.1rem;
	letter-spacing: 0.01em;
	line-height: 1;
	vertical-align: top;
	transition: all .3s;
}
.category-link-list a:hover {
	background-color: #111;
	color: #fff;
}

/* ttl */
.sec-ttl {
}

/* link */
.sec-btn {
	position: relative;
	display: inline-block;
	padding: 1px 24px 0 25px;
	border: 1px solid #111;
	border-radius: 22px;
	font-family: 'Libre Baskerville', serif;
	font-size: 1.3rem;
	line-height: 42px;
	letter-spacing: 0.06em;
	transition: all .4s;
}
.sec-btn:hover {
	border: 1px solid #111;
	background-color: #111;
	color: #fff;
}
.sec-btn.white {
	border: 1px solid #fff;
	color: #fff;
}
.sec-btn:hover.white {
	border: 1px solid #fff;
	background-color: #fff;
	color: #111;
}
.sec-btn span {
	position: relative;
	display: inline-block;
	padding-right: 40px;
}
.sec-btn span::after {
	content: "";
	position: absolute;
	right: 0;
	top: 50%;
	width: 17px;
	height: 5px;
	margin-top: -4px;
	background: url(../images/common/sec-btn-arrow-black.svg) 0 0 no-repeat;
	background-size: 17px 5px;
	transition: all .4s;
}
.sec-btn:hover span::after {
	right: -7px;
	background: url(../images/common/sec-btn-arrow-white.svg) 0 0 no-repeat;
}
.sec-btn.white span::after {
	background: url(../images/common/sec-btn-arrow-white.svg) 0 0 no-repeat;
}
.sec-btn:hover.white span::after {
	background: url(../images/common/sec-btn-arrow-black.svg) 0 0 no-repeat;
}


/* header
----------------------------------------- */
#header {
	position: relative;
}
.header-logo {
	position: absolute;
	top: 95px;
	left: 100px;
	width: 350px;
	height: auto;
	z-index: 100;
}
#top .header-logo {
	position: absolute;
	top: 60px;
	left: 70px;
	width: 330px;
	height: auto;
	z-index: 100;
}

/* header-nav-pc */
.header-nav-pc {
	width: 100%;
}
.header-gnav-pc {
	position: fixed;
	top: 0;
	right: 0;
	width: 100%;
	z-index: 10000;
	text-align: right;
	transition: all .3s;
}
#top .header-gnav-pc {
	position: absolute;
	top: auto;
	bottom: -74px;
	right: 0;
	transition: all 1.5s;
}
#top .header-gnav-pc.fade-in {
	bottom: 0;
}
.header-gnav-pc-list {
	padding: 40px 78px 0 0;
	display: block;
	transition: all .3s;
}
.fixed .header-gnav-pc-list {
	padding: 30px 78px 0 0;
	display: block;
}
#top .header-gnav-pc-list {
	display: inline-block;
	width: 1300px;
	max-width: 1600px;
	padding: 20px 120px 40px 50px;
	background-color: #fff;
	/* text-align: center; */
	height: 90px;
	margin:30px;
	border-bottom: 10px solid #004324;
}
.header-gnav-pc-list li {
	display: inline-block;
	width: auto;
	transition: all .3s;
}
/* .header-gnav-pc-list li:not(:last-child) {
	margin-right: 3.7%;
}
.fixed .header-gnav-pc-list li:not(:last-child) {
	margin-right: 3.4%;
}
#top .header-gnav-pc-list li:not(:last-child) {
	margin-right: 8%;
} */
.header-gnav-pc-list a {
	position: relative;
	display: inline-block;
	font-family: 'Roboto';
	font-size: 1.8rem;
	line-height: 1.4;
	letter-spacing: 0.1em;
	transition: all .3s;
	border-left: 3px solid #0b2a4a;
	padding: 1rem 5rem 1rem 5rem;
}
.fixed .header-gnav-pc-list a {
	font-size: 1.2rem;
	padding: 1.5rem 1rem;
}
.header-gnav-pc-list a:hover {
	color: #B9B9B9;
}
.header-gnav-pc-list a.jpn {
	position: relative;
	display: inline-block;
	font-family: 'Roboto';
	font-size: 1.25rem;
	line-height: 1.4;
	letter-spacing: 0.06em;
}
#top .header-gnav-pc .gnav01 a,
#story .header-gnav-pc .gnav02 a,
#intermission .header-gnav-pc .gnav03 a,
#sikou .header-gnav-pc .gnav04 a,
#our-firm .header-gnav-pc .gnav05 a,
#access .header-gnav-pc .gnav06 a {
	color: #B9B9B9;
}
#top .header-gnav-pc .gnav01 a::after,
#story .header-gnav-pc .gnav02 a::after,
#intermission .header-gnav-pc .gnav03 a::after,
#sikou .header-gnav-pc .gnav04 a::after,
#our-firm .header-gnav-pc .gnav05 a::after,
#access .header-gnav-pc .gnav06 a::after {
	content: '';
	display: block;
	position: absolute;
	top: 50%;
	left: -3px;
	width: calc(100% + 6px);
	height: 1px;
	background-color: #B9B9B9;
}

/* page-visual-area */
.page-visual-area {
}
.page-ttl {
	opacity: 0;
	transition: all 2.6s;
}
.page-ttl-tagline {
	opacity: 0;
	transition: all 2.6s;
}
.page-ttl-jpn {
	opacity: 0;
	transition: all 2.6s;
	transition-delay: .3s;
}
.page-ttl-sec.fade-in .page-ttl {
	opacity: 1;
}
.page-ttl-sec.fade-in .page-ttl-tagline {
	opacity: 1;
}
.page-ttl-sec.fade-in .page-ttl-jpn {
	opacity: 1;
}


/* contents
----------------------------------------- */
/* cta-sec */
.cta-sec {
	display: flex;
	max-width: 1220px;
	margin: 200px auto 200px;
	padding: 0 40px;
}
#top .cta-sec {
	margin-top: 130px;
}
#story.detail .cta-sec {
	margin-top: 200px;
}
.cta-btn {
	position: relative;
	display: block;
	width: 47%;
	transition: all .4s;
}
.cta-btn::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 1px;
	height: calc(100% - 34px);
	margin-top: 17px;
	background-color: #B2B2B2;
	transition: all .3s;
}
.cta-btn:hover::before {
	height: 100%;
	margin-top: 0;
	background-color: #111;
}
.cta-btn::after {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	width: 1px;
	height: calc(100% - 34px);
	margin-top: 17px;
	background-color: #B2B2B2;
	transition: all .3s;
}
.cta-btn:hover::after {
	height: 100%;
	margin-top: 0;
	background-color: #111;
}
.cta-btn-inner {
	position: relative;
	padding: 90px 0 95px 100px;
}
.cta-btn-inner::before {
	content: "";
	position: absolute;
	top: 0;
	left: 15px;
	width: calc(100% - 30px);
	height: 1px;
	background-color: #B2B2B2;
	transition: all .3s;
}
.cta-btn:hover .cta-btn-inner::before {
	left: 0;
	width: 100%;
	background-color: #111;
}
.cta-btn-inner::after {
	content: "";
	position: absolute;
	bottom: 0;
	left: 15px;
	width: calc(100% - 30px);
	height: 1px;
	background-color: #B2B2B2;
	transition: all .3s;
}
.cta-btn:hover .cta-btn-inner::after {
	left: 0;
	width: 100%;
	background-color: #111;
}
.cta-btn-inner p {
}
.cta-btn-inner p::after {
	content: "";
	position: absolute;
	right: 70px;
	top: 50%;
	width: 52px;
	height: 7px;
	margin-top: -4px;
	background: url(../images/common/cta-btn-arrow_pc.svg) 0 0 no-repeat;
	background-size: 52px 7px;
	transition: all .3s;
}
.cta-btn:hover .cta-btn-inner p::after {
	right: 55px;
}
.cta-btn .eng {
	position: relative;
	display: inline-block;
	margin-bottom: 15px;
	font-family: 'Libre Baskerville', serif;
	letter-spacing: 0.01em;
	font-size: 3.5rem;
	line-height: 1.0;
}
.cta-btn .jpn {
	display: block;
	padding-left: 3px;
	font-size: 1.3rem;
}
.cta-ourfirm-btn {
	margin: 0 6% 0 0;
	transform: translateY(25px);
	opacity: 0;
	transition: all 1.0s;
}
.cta-sec.scrollin .cta-ourfirm-btn {
	transform: translateY(0);
	opacity: 1;
}
.cta-access-btn {
	transform: translateY(25px);
	opacity: 0;
	transition: all 1.0s;
	transition-delay: .15s;
}
.cta-sec.scrollin .cta-access-btn {
	transform: translateY(0);
	opacity: 1;
}
.cta-btn.cta-access-btn .jpn {
	padding-left: 0;
}
#our-firm .cta-ourfirm-btn .cta-label,
#access .cta-access-btn .cta-label {
	opacity: .4;
}
#our-firm .cta-ourfirm-btn .cta-label .eng::after,
#access .cta-access-btn .cta-label .eng::after {
	content: "";
	position: absolute;
	left: -2px;
	top: 50%;
	width: calc(100% + 4px);
	height: 1px;
	background-color: #111;
}

/* form-input-tbl */
.form-input-tbl {
	max-width: 720px;
	margin: 0 auto;
}
.form-input-tbl th {
	display: inline-block;
	width: 32%;
	margin-bottom: 30px;
	padding-top: 10px;
	font-size: 1.3rem;
	vertical-align: top;
	color: #111;
	letter-spacing: 0.07em;
}
.form-input-tbl td {
	display: inline-block;
	width: 68%;
	margin-bottom: 30px;
	font-size: 1.3rem;
	vertical-align: top;
	color: #111;
}

/* form */
.input-text {
	font-family: YakuHanJP_Noto, 'Noto Sans JP', sans-serif;
	width: 100%;
	height: 45px;
	box-sizing: border-box;
	padding: 3px 8px;
	background-color: #F0F1F3;
	color: #111;
	vertical-align: middle;
	font-size: 1.3rem;
}
.textarea {
	font-family: YakuHanJP_Noto, 'Noto Sans JP', sans-serif;
	box-sizing: border-box;
	width: 100%;
	padding: 7px 8px;
	background-color: #F0F1F3;
	font-size:  1.3rem;
	line-height: 2.2;
}
.input-select {
	font-family: YakuHanJP_Noto, 'Noto Sans JP', sans-serif;
	width: 16em;
	height: 40px;
	margin-right: 5px;
	padding: 7px 8px;
	background-color: #F0F1F3;
	color: #111;
	font-size: 1.3rem;
	line-height: 1.6;
	vertical-align: middle;
}
.submit-btn-wrapper {
	box-sizing: border-box;
	max-width: 600px;
	margin: 0 auto;
}
.submit-btn {
	font-family: YakuHanJP_Noto, 'Noto Sans JP', sans-serif;
	display: block;
	width: 	200px;
	margin: 30px auto 0;
	padding: 20px 0;
	background-color: #111;
	text-align: center;
	font-size: 1.4rem;
	color: #fff;
	letter-spacing: 0.1em;
	cursor: pointer;
	transition: all .3s;
	border-style: none;
}
.submit-btn:hover {
	background-color: #666;
}
input[type="button"],input[type="submit"] {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}
input[type="text"],
input[type="button"],
input[type="email"],
input[type="submit"],
textarea {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}
input[type="email"]:focus, input[type="number"]:focus, input[type="search"]:focus, input[type="text"]:focus, input[type="tel"]:focus, input[type="url"]:focus, textarea:focus, select:focus {
	border: 1px solid #AFB2B9;
	outline: 0;
}
input[type="submit"]:focus,
button[type="submit"]:focus {
	background-color: #AFB2B9;
	color: #fff;
	outline: 0;
}
.required-input-mark {
	color: #ff0000;
	font-size: 1.2rem;
}
.form-alert-text {
	margin-bottom: 65px;
	font-size: 1.3rem;
	line-height: 2.12;
	text-align: center;
}


/* footer
----------------------------------------- */
#footer {
	position: relative;
	/* padding: 50px; */
}
.page-top {
	position: absolute;
	top: 4px;
	right: 10%;
	display: block;
	width: 28px;
	height: 15px;
	margin: 0 auto 60px;
	background: url(../images/common/page-top-arrow.svg) 0 0 no-repeat;
	background-size: cover;
	transition: opacity .4s;
}
.page-top:hover {
	opacity: .2;
}
.footer-gnav {
	display: flex;
	justify-content: center;
	margin-bottom: 95px;
	text-align: center;
}
.footer-gnav li {
	position: relative;
	margin: 0 3% 0 0;
}
.footer-gnav li:last-child {
	margin: 0;
}
.footer-gnav li a {
	position: relative;
	display: inline-block;
	font-family: 'Roboto';
	font-size: 1.4rem;
	line-height: 1.4;
	letter-spacing: 0.06em;
	transition: color .4s;
	color:#fff;
}
.footer-gnav li a:hover {
	color: #B9B9B9;
}
.footer-gnav li a.jpn {
	position: relative;
	display: inline-block;
	font-family:'Roboto';
	font-size: 1.4rem;
	line-height: 1.4;
	letter-spacing: 0.06em;
}
#top .footer-gnav .fnav01 a,
#story .footer-gnav .fnav02 a,
#intermission .footer-gnav .fnav03 a,
#sikou .footer-gnav .fnav04 a,
#our-firm .footer-gnav .fnav05 a,
#access .footer-gnav .fnav06 a {
	color: #B9B9B9;
}
#top .footer-gnav .fnav01 a::after,
#story .footer-gnav .fnav02 a::after,
#intermission .footer-gnav .fnav03 a::after,
#sikou .footer-gnav .fnav04 a::after,
#our-firm .footer-gnav .fnav05 a::after,
#access .footer-gnav .fnav06 a::after {
	content: '';
	display: block;
	position: absolute;
	top: 50%;
	left: -3px;
	width: calc(100% + 6px);
	height: 1px;
	background-color: #B9B9B9;
}
.footer-logo {
	width: 100px;
	margin: 0;
	padding-top: 20px;
}
.footer-instagram {
	width: 22px;
	margin: 0 auto 37px;
	transition: opacity .4s;
}
.footer-instagram:hover {
	opacity: .6;
}
.footer-info {
	color: #999;
	font-size: 1.3rem;
	text-align: center;
	letter-spacing: 0.01em;
}
.footer-address {
	margin-bottom: 3px;
	padding: 0;
}
.footer-tel-fax {
	margin-bottom: 24px;
}
.footer-tel-fax span:first-child {
	margin-right: 20px;
}
.footer-privacy {
	margin-bottom: 65px;
}
.footer-privacy a {
	font-family: 'Libre Baskerville', serif;
	color: #999;
	font-size: 1.1rem;
	transition: color .4s;
}
.footer-privacy a:hover {
	color: #ccc;
}
.footer-copyright {
	font-size: 1.0rem;
	transform: scale(1.0);
	transform-origin: center center;
}


} /* pc end */














































/* PC:1201px - */
@media only screen and (min-width: 1201px) {

} /* pc end */









