@charset "utf-8";
/* CSS Document */

/* font
=========================================== */
@font-face {/*Zen Kaku Gothic Antique*/
  font-family: "Zen Kaku Gothic Antique";
  src: url('../fonts/font/ZenKakuGothicAntique-Regular.ttf');
  src:
  url('../fonts/font/ZenKakuGothicAntique-Regular.woff2') format('woff2'),
  url('../fonts/font/ZenKakuGothicAntique-Regular.woff') format('woff'),
  url('../fonts/font/ZenKakuGothicAntique-Regular.ttf') format('truetype');
	font-weight: 400;
}
@font-face {/*Zen Kaku Gothic Antiqueミディアム*/
  font-family: "Zen Kaku Gothic Antique";
  src: url('../fonts/font/ZenKakuGothicAntique-Medium.ttf');
  src:
  url('../fonts/font/ZenKakuGothicAntique-Medium.woff2') format('woff2'),
  url('../fonts/font/ZenKakuGothicAntique-Medium.woff') format('woff'),
  url('../fonts/font/ZenKakuGothicAntique-Medium.ttf') format('truetype');
	font-weight: 500;
}
@font-face {/*Zen Kaku Gothic Antiqueボールド*/
  font-family: "Zen Kaku Gothic Antique";
  src: url('../fonts/font/ZenKakuGothicAntique-Bold.ttf');
  src:
  url('../fonts/font/ZenKakuGothicAntique-Bold.woff2') format('woff2'),
  url('../fonts/font/ZenKakuGothicAntique-Bold.woff') format('woff'),
  url('../fonts/font/ZenKakuGothicAntique-Bold.ttf') format('truetype');
	font-weight: 700;
}
@font-face {/*Zen Kaku Gothic Antiqueブラック*/
  font-family: "Zen Kaku Gothic Antique";
  src: url('../fonts/font/ZenKakuGothicAntique-Black.ttf');
  src:
  url('../fonts/font/ZenKakuGothicAntique-Black.woff2') format('woff2'),
  url('../fonts/font/ZenKakuGothicAntique-Black.woff') format('woff'),
  url('../fonts/font/ZenKakuGothicAntique-Black.ttf') format('truetype');
	font-weight: 900;
}
@font-face {/*Oswald*/
  font-family: "Oswald";
  src: url('../fonts/font/Oswald-Medium.ttf');
  src:
  url('../fonts/font/Oswald-Medium.woff2') format('woff2'),
  url('../fonts/font/Oswald-Medium.woff') format('woff'),
  url('../fonts/font/Oswald-Medium.ttf') format('truetype');
	font-weight: 500;
}

/* Link
=========================================== */

a:link, a:visited {
	color: #0A0A0A;text-decoration: none;
}
a:hover, a:active {
	color: #0A0A0A;text-decoration: underline;
}
a {
	outline: none;transition: 0.3s;
}
a img {transition: 0.3s;}

:focus { outline: none;}

/* LAYOUT
=========================================== */
html.showPage,
html.showPage body{min-width: 1200px;margin: 0 auto;}

body {
	color: #0A0A0A;
	background: #FFFFFF;
	font-size:16px;
	line-height:1.6;
	font-family: YakuHanJP,"Zen Kaku Gothic Antique",sans-serif;
	font-weight: 500;
    font-style: normal;
	max-width:1920px;
	overflow: hidden;
	margin:0 auto;
}

h1,h2,h3,h4,h5,h6 {font-weight:700;}
body,li,th,td,p,dt,dd{}
body#tinymce{min-width:inherit!important;}

p {}
.wrap {width: 1100px;margin:0 auto;position:relative;}
table {width:100%;}
img {max-width:100%;height:auto;}

/*共通設定*/
.btn01 {width: 300px;height: 54px;margin-top: 40px;}
.btn01 a {display: flex;justify-content: space-between;align-items: center;width: 100%;height: 100%;padding: 0 50px 0 40px;background: #FFFFFF;border: 1px solid #063257;box-sizing: border-box;border-radius: 50px;position: relative;}
.btn01 a .btn-text {color: #063257;font-weight: 700;transition: 0.3s;}
.btn01 a .arrow {display: block;width: 24px;height: 24px;border-radius: 50%;background-color: #063257;background-image: url("../img/common/btn_arrow.svg");background-repeat: no-repeat;background-position: center;background-size: 6px;position: absolute;top: 50%;right: 14px;transform: translateY(-50%);transition: 0.3s;}
.btn01 a:hover {text-decoration: none;background: #063257;}
.btn01 a:hover .btn-text {color: #FFFFFF;}
.btn01 a:hover .arrow {background-color: #FFFFFF;background-image: url("../img/common/btn_arrow02.svg");}

.btn01.shiro a {background: transparent;border: 1px solid #FFFFFF;}
.btn01.shiro a .btn-text {color: #FFFFFF;}
.btn01.shiro a .arrow {background-color: #FFFFFF;background-image: url("../img/common/btn_arrow02.svg");}
.btn01.shiro a:hover {background: #FFFFFF;}
.btn01.shiro a:hover .btn-text {color: #063257;}
.btn01.shiro a:hover .arrow {background-color: #063257;background-image: url("../img/common/btn_arrow.svg");}

.btn02 {display: inline-block;}
.btn02 a {display: inline-flex;align-items: center;}
.btn02 a .btn-text {font-weight: 700;color: #063257;transition: 0.3s;}
.btn02 a .arrow {display: inline-block;width: 24px;height: 24px;border-radius: 50%;background-color: #063257;background-image: url("../img/common/btn_arrow.svg");background-repeat: no-repeat;background-position: center;background-size: 6px;margin-left: 12px;}

.btn_contact {width: 460px;height: 100px;}
.btn_contact a {display: flex;justify-content: center;align-items: center;width: 100%;height: 100%;background: #FFFFFF;border: 1px solid #063257;box-sizing: border-box;border-radius: 50px;text-align: center;position: relative;}
.btn_contact a .btn-text {display: inline-block;padding-left: 39px;box-sizing: border-box;color: #063257;font-size: 20px;font-weight: 900;position: relative;transition: 0.3s;}
.btn_contact a .btn-text::before {content: "";display: block;width: 23px;height: 18px;background: url("../img/common/icon_mail.png") no-repeat center;background-size: contain;position: absolute;top: 9px;left: 0;}
.btn_contact a:hover {text-decoration: none;opacity: 0.7;}

.title01 {display: flex;align-items: flex-end;margin-bottom: 40px;}
.title01 .en {display: inline-block;font-family: "Oswald";font-size: 80px;font-weight: 500;text-transform: uppercase;}
.title01 .ja {display: inline-block;font-size:16px;font-weight: 900;margin: 0 0 36px 30px;}

.tel_box {text-align: center;}
.tel_box .tel {}
.tel_box .tel .num {font-size: 50px;}
.tel_box .tel .num span {font-size: 24px;}
.tel_box .tel-text {margin-top: -5px;}
.tel_box .tel-text span {display: inline-block;margin-right: 10px;}
.tel_box .tel-text span:last-child {margin-right: 0;}

.under-cont > section {padding: 100px 0;}
.under-cont > section.bg-gray {background: #F5F5F5;}
.under-cont > section.bg-kon {background: #063257;}

/*ウェブフォント*/
.normal {font-weight: 400;}
.medium{font-weight: 500;}
.bold{font-weight: 700;}
.black{font-weight: 900;}

.common_text {line-height: 1.75;}

.text_uppercase {text-transform: uppercase;}
.text_capitalize {text-transform: capitalize;}

.tcenter {text-align: center;}
.tleft {text-align: left;}
.tright {text-align: right;}

.oswald {font-family: "Oswald";font-weight: 500;}

.tate {writing-mode: vertical-rl;white-space: pre;letter-spacing: -0.3em;}
.tate .tate-line {display: inline-block;writing-mode: horizontal-tb;letter-spacing: 0;transform: rotate(90deg);margin: 10px 0 -5px;}
.tate .tate-line02 {writing-mode:sideways-rl;}
.safari .tate {letter-spacing: 0.1em;}
.safari .tate .tate-line {margin: 5px -10px;}
@-moz-document url-prefix(){
    .tate {letter-spacing: 0.1em;}
	.tate .tate-line {margin: 5px -10px;}
}

/*色*/
.shiro {color:#fff;}
.kon {color: #063257;}
.orange {color: #FF5813;}

.flex{width: 100%;
    margin: 0 ;
    padding: 0;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-box;
    display: -webkit-flexbox;
    display: -moz-flexbox;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: flex;
    -webkit-box-lines: multiple;
    -moz-box-lines: multiple;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

/* header */
/*-------------------------------------------*/
#header {width:100%;height: 100px;min-width:1200px;max-width: 1920px;position:fixed;transition: 0.3s;left:0;right: 0;top:0;margin: auto;z-index: 100;background: #FFFFFF;}
#header .header_inner {height: 100%;justify-content: space-between;align-items: center;flex-wrap: nowrap;}
#header .header_inner .logo_box {width: auto;margin-left: 15px;position: relative;z-index: 1;}
#header .header_inner .logo {width: 360px;}
#header .header_inner .logo a {display: block;width: 100%;}
#header .header_inner .logo a:hover {text-decoration: none;opacity: 0.7;}

#header .header_inner .right {height: 100%;justify-content: flex-end;align-items: center;}
#header .header_inner .right .header-contact_btn {width: 140px;height: 100%;}
#header .header_inner .right .header-contact_btn a {display: block;width: 100%;height: 100%;padding-top: 48px;box-sizing: border-box;background: #063257;text-align: center;position: relative;}
#header .header_inner .right .header-contact_btn a::before {content: "";display: block;width: 18px;height: 14px;background: url("../img/common/icon_mail.png") no-repeat center;background-size: contain;position: absolute;top: 25px;left: 50%;transform: translateX(-50%);filter: brightness(0) saturate(100%) invert(98%) sepia(11%) saturate(439%) hue-rotate(200deg) brightness(117%) contrast(100%);}
#header .header_inner .right .header-contact_btn a .btn-text {font-weight: 700;color: #FFFFFF;text-align: center;}
#header .header_inner .right .header-contact_btn a:hover {text-decoration: none;opacity: 0.7;}

/*gnav*/
.gnav {height: 26px;margin-right: 50px;}
.gnav > ul.flex {width:auto;height: 100%;flex-wrap: nowrap;}
.gnav > ul > li {margin-right: 36px;}
.gnav > ul > li:last-child {margin-right: 0;}
.gnav > ul > li > a {display: flex;flex-wrap: nowrap;height: 100%;justify-content: center;width: auto;max-width: 100%;}
.gnav > ul > li > a > span {transition: 0.3s;white-space: nowrap;}
.gnav > ul > li > a:hover {text-decoration: none;color: #FF5813;}

.gnav .gnav_first {position: relative;z-index: 1;}
.gnav .gnav_first > p {display: flex;height: 100%;padding-right: 14px;position: relative;white-space: nowrap;}
.gnav .gnav_first > p::after {content: "";display: inline-block;width: 10px;height: 6px;background: url("../img/common/gnav_arrow.svg") no-repeat center;background-size: cover;transition: 0.3s;position: absolute;top: 11px;right: 0;}
.gnav .gnav_first:hover > p {color: #FF5813;}
.gnav .gnav_first:hover > p::after {transform: rotate(180deg);}
.gnav_bg {
	width: auto;
	height: auto;
    position: absolute;
	visibility: hidden;
	opacity: 0;
	transition: 0.3s;
	overflow: auto;
	max-height: calc(100vh - 80px);
	padding-top: 4px;
	box-sizing: border-box;
	left: 50%;
	transform: translateX(-50%);
	z-index: -1;
}
.gnav_second {
	box-sizing: border-box;
    transition: 0.3s;
	visibility: hidden;
	opacity: 0;
	position: relative;
	background: #FFFFFF;
	padding: 30px;
	border-radius: 10px;
}
.gnav_first:hover .gnav_bg {
  visibility: visible;
  opacity: 1;
}
.gnav_first:hover .gnav_second {
  visibility: visible;
  opacity: 1;
}
.gnav_second ul li {
	margin-bottom: 20px;
}
.gnav_second ul li:last-child {
	margin-bottom: 0;
}
.gnav_second ul li a {
	display: block;
	padding-left: 24px;
	box-sizing: border-box;
	position: relative;
	white-space: nowrap;
}
.gnav_second ul li a::before{
	content: "";
	display: block;
	width: 17px;
	height: 17px;
	background-image: url("../img/common/gnav_arrow02.png");
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	position: absolute;
	top: 4px;
	left: 0;
}
.gnav_second ul li a:hover {
	text-decoration: none;
	color: #FF5813;
}

/* main */
/*-------------------------------------------*/
#main {margin-top:100px;}
#main.home_main {width: 100%; height: 680px;background: url("../img/main/main_img.png") no-repeat center;background-size: cover;position: relative;z-index: 1;}
#main.home_main .main_title {width: 1248px;position: absolute;bottom: 110px;left: 50%;transform: translateX(-50%);}
#main.home_main .main_title .grad-text01 {min-width: 740px;padding: 3px 16px 7px 20px;font-family: "Zen Kaku Gothic Antique";font-size: 44px;background-image: none;margin-bottom: 10px;position: relative;overflow: hidden;}
#main.home_main .main_title .grad-text01::before {content: "";inset: 0;display: block;width: 100%;height: 100%;background: url(../img/main/text-bg01.jpg) no-repeat center;background-size: cover;position: absolute;transform: scaleX(0);transform-origin: left;animation: bg-slide 0.5s ease-out forwards;animation-delay: 0.2s;}
#main.home_main .main_title .grad-text01 .text {position: relative;z-index: 1;display: inline-block;clip-path: inset(0 100% 0 0);animation: text-reveal 0.6s ease-out forwards;animation-delay: 0.5s; /* 背景が終わってから */}
#main.home_main .main_title .grad-text01:last-child {margin-bottom: 0;}
#main.home_main .main_title .grad-text01:last-child::before {background: url(../img/main/text-bg02.jpg) no-repeat center;background-size: cover;animation-delay: 0.7s;}
#main.home_main .main_title .grad-text01:last-child .text {animation-delay: 1.2s;}

/* 背景アニメーション */
@keyframes bg-slide {
	to {
		transform: scaleX(1);
	}
}

/* 文字表示アニメーション */
@keyframes text-reveal {
	to {
		clip-path: inset(0 0 0 0);
	}
}

/* 下層 main */
/*-------------------------------------------*/
#main.kasou {width: 100%;padding: 80px 0;}
#main.kasou .main_title .ja {display: block;font-size:48px;}
#main.kasou .main_title .en {display: block;font-size: 22px;font-family: "Oswald";font-weight: 500;color: #063257;margin-top: 10px;text-transform: uppercase;}

#main-img {width: 100%;height: 460px;background-image: url("../img/main/kasou_main.jpg");background-repeat: no-repeat;background-position: center;background-size: cover;}

/*パンくず*/
div#bread {width: 100%;padding: 20px 0;border-top: 1px solid #ECE9E9;}
ul.bread-list {font-size:12px;justify-content: flex-start;}
ul.bread-list li {line-height: 12px;position: relative;padding-right: 16px;box-sizing: border-box;}
ul.bread-list li a {text-decoration:none;line-height: 12px;}
ul.bread-list li a:hover {text-decoration:underline;}
ul.bread-list li::after{content:"";display: block;width: 8px;height: 1px;background: #0A0A0A;position: absolute;top: 50%;right: 3px;}
ul.bread-list li:last-child {padding-right: 0;}
ul.bread-list li:last-child::after{display: none;}

/* TOPへ戻る・追従 */
/*-------------------------------------------*/
#fixed_trigger {position: absolute;left: 0;top:116px;z-index: -100;}

/* footer */
/*-------------------------------------------*/
#contact-sec {padding: 140px 0 80px;background: url("../img/common/bg_footer.png") no-repeat center top;background-size: cover;text-align: center;}
#contact-sec .title01 {display: block;text-align: center;margin-bottom: 40px;}
#contact-sec .title01 .en {display: block;font-size: 66px;}
#contact-sec .title01 .ja {display: block;margin: 0}
#contact-sec .grad-text01 {margin-bottom: 20px;}

#contact-sec .btn_box {width: 100%;justify-content: space-between;align-items: center;padding: 0 30px;box-sizing: border-box;margin-top: 50px;}
#contact-sec .btn_box .box {width: 460px;}

#contact-sec .btn_box .box.box_left {display: flex;align-items: flex-start;}
#contact-sec .btn_box .box.box_left .icon {width: 80px;height: 80px;background: #FFFFFF;border: 1px solid #063257;border-radius: 50%;margin-right: 20px;position: relative;margin-top: 15px;}
#contact-sec .btn_box .box.box_left .icon img {width: 24px;position: absolute;top: 50%;left: 50%;transform: translate(-50%, -50%);}
#contact-sec .btn_box .box.box_left .tel_box .tel .num {color: #063257;}
#contact-sec .btn_box .box.box_left .tel_box .tel-text {color: #063257;}

#contact-sec .btn_box .box.box_right .btn_contact {width: 100%;}

#footer {padding: 70px 0 80px;}
#footer .footer_box {justify-content: space-between;flex-wrap: nowrap;margin-bottom: 100px;}
#footer .footer_box .left {width: 360px;}
#footer .footer_box .left .logo {width: 360px;margin-bottom: 40px;}
#footer .footer_box .left .logo a {display: block;width: 100%;}
#footer .footer_box .left .logo a:hover {text-decoration: none;opacity: 0.7;}

#footer .footer_box .right {width: 680px;}
.navs-list {width: 100%;justify-content: flex-end;display:flex;}
.navs-list > ul.navs-list00 {width: 200px;margin-right: 40px;}
.navs-list > ul.navs-list00:last-child {margin-right: 0;}
.navs-list > ul.navs-list00 > li {margin-bottom: 20px;}
.navs-list > ul.navs-list00 > li:last-child {margin-bottom:0;}
.navs-list > ul.navs-list00 > li > a, .navs-list > ul.navs-list00 > li .nav-midashi {display: block;font-weight: 700;padding-bottom: 10px;border-bottom: 1px solid #EEEEEE;box-sizing: border-box;position: relative;}
.navs-list > ul.navs-list00 > li > a::before, .navs-list > ul.navs-list00 > li .nav-midashi::before {content: "";display: block;width: 14px;height: 1px;background: #FF5813;position: absolute;bottom: -1px;left: 0;z-index: 1;}
.navs-list > ul.navs-list00 > li .sp-nav {margin-top: 20px;}
.navs-list > ul.navs-list00 > li .sp-nav li {margin-bottom: 10px;}
.navs-list > ul.navs-list00 > li .sp-nav li:last-child {margin-bottom:0;}
.navs-list > ul.navs-list00 > li a:hover {text-decoration: none;color: #FF5813;}

#footer .bottom_box {justify-content: flex-end;align-items: center;flex-direction: row-reverse;position: relative;}
#footer .bottom_box .link_list {width: auto;}
#footer .bottom_box .link_list li {font-size: 14px;}
#footer .bottom_box .link_list li::after {content: "／";margin: 0 10px;}
#footer .bottom_box .link_list li:last-child::after {display: none;}
#footer .bottom_box .link_list li a:hover {text-decoration: none;color: #FF5813;}
#footer .bottom_box .copyright {font-size: 14px;margin-right: 80px;}
#footer .bottom_box .logo_tdb {width: 260px;height: 100px;padding: 25px 18px 0;background: #FFFFFF;border: 1px solid #EEEEEE;box-sizing: border-box;position: absolute;top: 50%;right: 0;transform: translateY(-50%);}
#footer .bottom_box .logo_tdb img {width: 224px;}
#footer .bottom_box .logo_tdb p {color: #324A9B;}

/* wideWrap
=========================================== */
section{width:100%;}

aside,footer{position:relative;}

/* CLEARFIX
=========================================== */

.cf:after {
	content: ".";
	display: block;
	clear: both;
	height: 0;
	visibility: hidden;
	overflow: hidden;
	font-size: 0.1em;
	line-height: 0;
}
.cf {
	min-height: 1px;
}
* html .cf {
	height: 1px;/*¥*//*/
  height: auto;
  overflow: hidden;
  /**/
}

.no-pc{display: inline-block;pointer-events: none;text-decoration: none!important;}

.sp{display:none!important;}
