@charset "UTF-8";

/* ================
      common
================ */
body {
	min-width: auto;
	line-height: 1.7;
}
.sp {
	display: block;
}
.pc {
	display: none;
	visibility: hidden;
}
section h2 {
	font-size: 2.3rem;
	padding-top: 48px;
	padding-bottom: 3px;
}
h2 .en {
	font-size: 1.7rem;
	padding-bottom: 0;
}
.s-contents p {
	padding-top: 12px;
}
.sp-inner {
	padding: 0 3%;
}
.pt {
	padding-top: 42px;
}
.indent {
	text-indent: 1.2em;
	display: block;
}

/* 斜線 */
.d-line,
.d-line-w {
	width: 0.1em;
	height: 28px;
}

/* 下線 */
.under-line::before {
	width: 28%;
}

/* ボタン */
.btn,
.btn-w {
	margin-top: 58px;
}

/* ロード画面 */
#loader svg path {
	stroke-dasharray: 1280;
	stroke-dashoffset: 1280;
}

/* ================
      header
================ */
#header {
	height: 59px;
	min-width: inherit;
	width: 100vw;
}
#header.header-bg {
	background-color: transparent;
	height: 59px;
	color: #fff;
}
#header.header-bg .nav ul li + li {
	border: none;
}
#header h1,
.h-rogo {
	margin-left: 11px;
	min-width: inherit;
	z-index: 2;
}
#header h1 img,
.h-rogo img {
	width: 124px;
	min-width: auto;
}
#nav {
	transform: translateX(100%);
	-webkit-transition: 1s;
	transition: 1s;
	position: fixed;
	width: 100vw;
	height: 100vh;
	top: 0;
	left: 0;
	z-index: 1;
	background: linear-gradient(110deg, #767676, #323232);
}
#nav.open {
	transform: translateX(0);
}
#header nav {
	flex-direction: column;
	height: auto;
}
.nav ul {
	flex-wrap: wrap;
	margin-top: 28%;
	padding: 0 6%;
}
.nav ul li {
	width: 50%;
	margin-bottom: 14%;
	text-align: center;
	padding: inherit;
}
.nav ul li + li {
	border: none;
}

.nav ul li::before,
.nav ul li + li::after {
  display: none;
}

.nav ul li a {
	position: static;
	display: inline-block;
	padding: 0 0.3em 5px;
	border-bottom: solid 2px #fff;
}
.nav ul li a::after {
	display: none;
}

.nav ul .msystem {
  width: 100%;
}

.nav ul .msystem a {
  border-bottom: none;
}

.contact-link {
	background: #fff;
	display: inline-block;
	width: 212px;
	height: 75px;
	color: #171717;
	font-size: 1.8rem;
}
.contact-link::before {
	background-image: url(../../img/mail.png);
	width: 19px;
	height: 14px;
	top: 50%;
	left: 18%;
	transform: translateY(-50%);
}
.contact-link::after {
	top: 50%;
	transform: translateY(-50%);
	left: 32%;
}
.nav .sp-menu {
	text-align: center;
	margin-top: 7%;
	color: #fff;
}
.nav .sp-menu address {
	font-size: 1.4rem;
}
.nav .sp-menu address span {
	font-family: var(--noto);
	font-size: 3.3rem;
}
.nav .sp-menu address span::before {
	content: "";
	display: inline-block;
	background: url(../../img/tel-w.png) no-repeat center / contain;
	width: 30px;
	height: 30px;
	margin-right: 10px;
}
.sp-menu-logo {
	margin: 5% 0 4%;
}
.sp-menu .sns {
	margin-top: 5%;
}

/* ハンバーガー */
body.is-menuOpen {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
body.is-menuOpen main,
body.is-menuOpen footer {
	opacity: 0;
}
#hamburger {
	width: 69px;
	height: 100%;
	background: linear-gradient(110deg, #767676, #323232);
	position: relative;
	z-index: 1;
}
#hamburger.open {
	background: transparent;
}
#hamburger span {
	content: "";
	position: absolute;
	width: 30px;
	height: 0.1em;
	background-color: #fff;
	top: 15px;
	left: 50%;
	transform: translateX(-50%);
	-webkit-transition: 0.7s;
	transition: 0.7s;
}
#hamburger span:nth-child(2) {
	top: 22px;
	-webkit-transition: 0.1s;
	transition: 0.1s;
}
#hamburger span:nth-child(3) {
	top: 29px;
}
#hamburger.open span {
	width: 40px;
	top: 23px;
	left: 23%;
}
#hamburger.open span:nth-child(1) {
	transform: rotate(-45deg);
}
#hamburger.open span:nth-child(2) {
	width: 0;
}
#hamburger.open span:nth-child(3) {
	transform: rotate(45deg);
}
#hamburger p {
	color: #fff;
	text-align: center;
	padding-top: 32px;
	font-size: 0.9rem;
	font-family: var(--noto);
	text-transform: uppercase;
	letter-spacing: 0.02em;
}
#hamburger.open p:nth-child(4) {
	display: none;
}
#hamburger p:last-child {
	opacity: 0;
	-webkit-transition: 0.3s;
	transition: 0.3s;
}
#hamburger.open p:last-child {
	opacity: 1;
	padding-top: 39px;
}
/* ================
      contact
================ */
.contact .s-contents {
	width: auto;
	padding: 0 3%;
}
.inquiry {
	margin-top: 45px;
	flex-direction: column;
}
.inquiry .c-btn {
	margin: 48px auto 68px;
	max-width: 360px;
}
/* ================
      link
================ */
.link {
	padding-top: inherit;
}
.link h2 {
	padding-bottom: 49px;
}
.link-list {
	width: 90%;
	flex-direction: column;
	margin-left: 10%;
	max-width: none;
}
.link .link-list li {
	width: auto;
	margin-bottom: 39px;
	margin-left: 0;
}
.link .link-list li::after {
	margin-left: 6px;
}

/* ================
      footer
================ */
.footer-wrapper {
	width: 94%;
	min-width: auto;
	display: block;
	padding-bottom: 23px;
}
.footer-logo {
	grid-row: 2 / 3;
	grid-column: 1;
	text-align: center;
}
.footer-logo img {
	width: 213px;
}
.footer-logo address {
	padding-top: 28px;
}
.g-nav ul {
	flex-wrap: wrap;
	padding: 0 21px;
	justify-content: flex-start;
  line-height: 1.7;
}
.g-nav ul li {
	margin-left: inherit;
	width: 57%;
	margin-bottom: 36px;
}

.g-nav ul li:nth-child(even) {
  width: 40%;
}

.g-nav ul:nth-child(2) {
	margin-top: 8px;
	font-size: 1.4rem;
}
.footer-low {
	margin: 20px auto 0;
	flex-direction: column;
	align-items: center;
  position: relative;
}

.footer-low .lp{
  width: 85%;
  margin: 3em auto 1em;
}

.lp-link {
  position: static;
  margin-bottom: .7em;
}

.lp-link a {
	padding: 10px 80px;
}
.sns {
	margin-top: 20px;
	margin-left: 0;
}
small {
	font-size: 70%;
}

.footer-wrapper .twitter {
  position: static;
  width: 90%;
  margin-top: 1.2em;
}

/* ================
      2nd
================ */
.second-ttl {
	height: 27vh;
}
.second-ttl::before {
	left: -244px;
}
.second-ttl::after {
	min-width: 430px;
	height: 2000px;
	right: 322px;
	top: -190px;
}
.second-bg {
	height: 100%;
}
.second-ttl h1 {
	font-size: 1.6rem;
	padding-left: 11px;
	padding-top: 11vh;
}
.second-ttl h1 svg {
	width: 210px;
	height: auto;
}

/* パンくずリスト */
.breadcrumb ul {
	margin-left: 11px;
	margin-top: 9px;
}

.flex-contents {
	flex-direction: column-reverse;
}
.flex-contents .s-contents {
	min-width: inherit;
	width: auto;
	padding-bottom: 53px;
	padding-top: 0;
	margin: 0;
}
.flex-contents .name {
	font-size: 2.1rem;
}
.flex-contents h2 .en {
	color: #fff;
}
.flex-contents .d-line {
	background: #fff;
}
.side-img {
	width: 75vw;
	min-width: 340px;
	margin: 36px 0 0 auto;
}

@media screen and (max-width: 420px) {
	.second-ttl::after {
		min-width: 319px;
		right: 328px;
	}
}

/* ================
      form
================ */
/* form */
.form-wrapper {
	padding-bottom: 35px;
}
.form {
	width: auto;
	margin-top: 23px;
}
.form-txt {
	padding-top: 37px;
}
.confirm-list {
	margin-top: 27px;
}
.form table {
	width: 100%;
	margin-top: 32px;
}
.form table th,
.form table td {
	width: 100%;
	display: block;
	height: auto;
}
.form table th {
	margin-top: 18px;
}
.form table td input,
.form table td textarea {
	margin: 11px 0;
}
.form table tr td input[type="email"][name="メールアドレス"],
.form table tr td input[type="tel"][name="電話番号"] {
	margin-bottom: 7px;
}
.form table tr td input[type="email"][name="メールアドレス(確認)"] {
	margin-top: 7px;
}
.form table td .ml,
.form table td .mtb,
.form table td .mt {
	display: block;
	width: 100%;
}
.form .required,
.form .any {
	margin-right: 11px;
}

.f-select .select-year {
	width: 88px;
	padding: 0.8em 1.5em;
}
.select-text {
	margin: 4px;
}

/* ================
    form*確認画面
================ */

/* 確認項目 */
#formWrap form {
	width: 100%;
}
.formList {
	flex-direction: column;
	padding: 22px 0.5em;
}
.formList dt,
.formList dd {
	width: 100%;
}
.formList dt {
	padding-bottom: 9px;
}
