﻿@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=Zen+Maru+Gothic&display=swap');

html {
  font-size:62.5%;
}

body {
  font-size:1.4rem;
  font-family: "Noto Sans JP", serif;
  overflow-x: hidden;
    text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%; /* Safari */
}

*, *::before, *::after {
  box-sizing:border-box;
}
.clearfix::after {
  content:'';
  display:block;
  clear:both;
}

body,
p,
ul,
li,
div,
h1 {
  margin: 0;
  padding: 0;
}

ul,
ol {
  list-style: none;
}


a {
  text-decoration: none;

}

main {
  padding-top:90px;
  width: 100%;
}

center {
	font-size:0;
	line-height:0;
	margin:0;
	padding:0;
}

.jump{
         display: block;
         margin-top: -85px;
         padding-top: 85px;
}

/* パターン1 */
.l-header {
  display: block;
  z-index: 999;
  position: fixed;
  top: 0;
  right: 0;
  left: 0;
  width: 100%;
  background: #fff;
}


.c-hamburger {
  position: relative;
  width: inherit;
  height: inherit;
  margin: 0;
  border: transparent;
  background-color: transparent;
  cursor: pointer;
}



.c-hamburger span {
  display: block;
  position: relative;
  left: 50%;
  width: 24px;
  height: 2px;
  transform: translateX(-50%);
  background: black;
  transition: all 0.4s;
}

.c-hamburger span:nth-of-type(1) {
  top: -4px;
}

.c-hamburger span:nth-of-type(2) {
  top: 1px;

  transform: translateX(-0.45deg);
}

.c-hamburger span:nth-of-type(3) {
  top: 6px;
  transform: translateX(-0.45deg);
}

.c-hamburger.is-active span:nth-of-type(1) {
  top: 0;
  transform: translateX(-50%) rotate(225deg);
}

.c-hamburger.is-active span:nth-of-type(2) {
  opacity: 0;
}

.c-hamburger.is-active span:nth-of-type(3) {
  top: -4px;
  transform: translateX(-50%) rotate(-225deg);
}

.p-header__nav {
  display: flex;
  z-index: 10;
  position: absolute;
  top: 0;
  right: -100%;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100vh;
  background: transparent;
  opacity: 0;
  transition: top 0.6s, right 0.6s, opacity 0.6s;
}

.p-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: inherit;
  padding: 10px 20px;
  max-width:1024px;
  margin:0 auto;

}

.p-header__hamburger {
  z-index: 100;
  position: absolute;
  top: 0;
  right: 0;
  width: 95px;
  height: 100%;
}

.p-header__nav.is-active {
  position: fixed;
  top: 0;
  right: 0;
  opacity: 1;
  background-color: #fff;
}

.p-nav__list {
  display: block;
  padding-right: 20px;
  padding-left: 20px;
}

.p-nav__item {
  position: relative;
  width: 100%;
}

.p-nav__link {
  color: black;
  display: block;
  padding: 0 20px;
  width: 100%;
  font-size:18px;
  font-weight:600;
}

@media screen and (min-width: 768px) {

  .p-header__hamburger {
    display: none;
  }

  .p-nav__inner {
    margin-right: auto;
    margin-left: auto;
    max-width: initial;
    width: 100%;
  }

  .p-header__nav {
    position: static;
    opacity: 1;
    height: inherit;
    width: initial;
  }

  .p-nav__list {
    padding-right: 0;
    padding-left: 0;
    display: flex;
  }
}

@media screen and (min-width:1024px) {

	.btn-contact {
		border-radius: 100vh;
		color:#fff;
		background:linear-gradient(90deg, rgba(240, 131, 0,1) 20.014116646039604%,rgba(240, 184, 0,1) 80.01566367574256%);
	}
	
	.p-nav__item:last-child {
		padding-left:20px;
	}
	
	.p-nav__link {
		line-height:48px;
	}

}

#wrap-slide {
	position: relative;
	padding-top:185px;
	padding-bottom:80px;
}
#wrap-slide::after {
	content: "";
	position: absolute;
	width:100%;
	bottom:0;
	height:270px;
	background:linear-gradient(
	  90deg, 
	  #F0B800 25%,
	  #F08300 100%
	);
}

.swiper {
	position: relative;
	width:100%;
	max-width:1024px;
	margin:0 auto 0;
	overflow: visible !important;
}
.swiper::before {
	content:url("../img/slide-catch01.png");
	position: absolute;
	top:-115px;
	left:0;
	z-index:999;
}
.swiper::after {
	content:url("../img/slide-catch02.png");
	position: absolute;
	bottom:-85px;
	right:15px;
	z-index:999;
}

/* スライドの動き等速 */
.swiper-wrapper {
  transition-timing-function: linear;
}
.swiper-slide {
  margin-left:-12px;
  margin-right:-12px;
  padding-left:12px;
  padding-right:12px;
}
.swiper-slide img {
  height: auto;
  width: 100%;
  min-width:338px;
  max-width:338px;
  border-radius: 10px;
}

.visual {
 background-color: #9f9f9f;
 margin-bottom: 60px;
}


#news {
}
#news .inner{
	position:relative;
	width:100%;
	max-width:1024px;
	margin:80px auto 80px;
	min-height:480px;
	background: url("../img/bg-news.png") no-repeat left bottom;
}

.news-area {
	wudth:750px;
	margin:0 0 0 408px;
}
.news-area dt.title{
	padding-bottom:45px;
}
.news-area dd.area{
	box-sizing: border-box;
	width:750px;
	margin:0;
	padding:30px;
	background:linear-gradient(
	  90deg, 
	  #F08300 0,
	  #F0B800 100%
	);
	border-radius: 10px;
	height:340px;
	color:#fff;
}

#edit {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  overflow: auto;
  height:250px;
  font-size:16px;
}
#edit a{
	color:#fff;
}
#edit a:hover{
	text-decoration:underline;
}
#edit dt, #edit dd {
  box-sizing: border-box;
}
#edit dt {
  display: flex;
  align-items: center;
  width: 20%;
  padding: 20px;
  border-bottom: 1px solid #DBDBDB;
}
#edit dt:last-of-type,
#edit dd:last-of-type {
  border: none;
}
#edit dd {
  display: flex;
  align-items: center;
  width: 80%;
  margin-left: 0;
  padding: 20px;
  border-bottom: 1px solid #DBDBDB;
}


#contact .contact-wrap {
	position: relative;
	padding-top:180px;
	padding-bottom:80px;
}
#contact .contact-wrap::after {
	content: "";
	position: absolute;
	width:100%;
	bottom:0;
	height:280px;
	background:linear-gradient(
	  90deg, 
	  #F0B800 25%,
	  #F08300 100%
	);
}
#contact .inner {
	position: relative;
	margin:0 auto;
	width:1024px;
	height:285px;
	background: #F2F6F7;
	z-index: 999;
	border-radius: 20px;
	box-shadow: 3px 3px 12px gray;
}
#contact .inner::before {
	content: url("../img/contact-catch.png");
	position: absolute;
	top:-70px;
	left:50%;
 	transform: translateX(-50%); 
}
#contact .flex {
	padding-top:120px;
	width:770px;
	margin:0 auto;
	display:flex;
	justify-content: space-between;
}
#contact .flex p{
	font-size:24px;
	line-height:1.6;
}
#contact .flex .btn {
	border-radius: 30px;
	font-size:26px;
	margin-top:8px;
	padding:10px 1em;
	color:#fff;
	background:linear-gradient(90deg, rgba(240, 131, 0,1) 20.014116646039604%,rgba(240, 184, 0,1) 80.01566367574256%);
	line-heught:2em;
	height:2.4em;
}

#contact .flex .btn:hover {
	background:rgba(240, 131, 0,1);
}



footer {
	width: 100%;
	padding:75px 0;
	background-color: #002366;
	color:#fff;
	text-align: center;
}
footer .inner{
	width:100%;
	max-width:1024px;
	margin:0 auto 0;
}

.foot-nav {
	width:100%;
	margin:50px auto 40px;
	text-align: left;
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	gap:40px;
}

.foot-nav li a{
	text-decoration: none;
	color:#fff;
	font-weight:600;
	font-size:16px;
}
.foot-nav li a:hover{
	text-decoration:underline;
	text-underline-offset: 6px;
}

.foot-nav li a span{
	font-weight:normal;
}

#breadcrumb-wrap {
    background:#fafafafa;
}

.breadcrumb {
	width:100%;
	max-width:1024px;
	margin:0 auto 50px;
    display: flex;
    gap: 0 20px;
    list-style: none;
    padding: 6px 0 6px 18px;
    border-radius: 3px;
    overflow: hidden;
    font-size: .9em;
    background:#f2f2f2;
}

.breadcrumb li {
    display: flex;
    align-items: center;
    position: relative;
    padding-right: 20px;
}

.breadcrumb li:first-child a::before {
    display: inline-block;
    width: 1em;
    height: 1em;
    margin-right: 4px;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M20 20C20 20.5523 19.5523 21 19 21H5C4.44772 21 4 20.5523 4 20V11L1 11L11.3273 1.6115C11.7087 1.26475 12.2913 1.26475 12.6727 1.6115L23 11L20 11V20ZM11 13V19H13V13H11Z' fill='%23333333'%3E%3C/path%3E%3C/svg%3E");
    background-repeat: no-repeat;
    vertical-align: text-bottom;
    content: '';
}

.breadcrumb li:not(:last-child)::before,
.breadcrumb li:not(:last-child)::after{
    position: absolute;
    width: 0;
    height: 0;
    border-top: 20px solid transparent;
    border-bottom: 20px solid transparent;
    content:'';
}

.breadcrumb li:not(:last-child)::before{
    right: 0;
    border-left: 10px solid #c6cdd3;
}

.breadcrumb li:not(:last-child)::after{
    right: 1px;
    border-left: 10px solid #f2f2f2;
}

.breadcrumb a {
    color: #333333;
    text-decoration: none;
}

.ptitle-inner {
    width:1024px;
	margin:50px auto 25px;
}

.privacypolicy_in{
	width: 960px;
	margin: 0 auto;
}
.privacypolicy_in .sub_center_ttl{
	font-size: 26px;
	line-height: 42px;
	font-weight: 500;
	margin-bottom: 48px;
	text-align: center;
}
.privacypolicy_in .policy_ttl{
	font-size: 20px;
	margin: 48px 0 24px;
}
.privacypolicy_in p{ margin-bottom: 12px;font-size:16px;}
.privacypolicy_in ul{margin: 0 0 12px 24px;font-size:16px;}
.privacypolicy_in ul li{list-style: disc;}

.Form {
  margin-top: 40px;
  margin-left: auto;
  margin-right: auto;
  max-width: 960px;
}
@media screen and (max-width: 480px) {
  .Form {
    margin-top: 40px;
  }
}
.Form-Item {
  border-top: 1px solid #ddd;
  padding-top: 24px;
  padding-bottom: 24px;
  width: 100%;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 480px) {
  .Form-Item {
    padding-left: 14px;
    padding-right: 14px;
    padding-top: 16px;
    padding-bottom: 16px;
    flex-wrap: wrap;
  }
}
.Form-Item:nth-child(5) {
  border-bottom: 1px solid #ddd;
}
.Form-Item-Label {
  width: 100%;
  max-width: 248px;
  letter-spacing: 0.05em;
  font-weight: bold;
  font-size: 18px;
}
@media screen and (max-width: 480px) {
  .Form-Item-Label {
    max-width: inherit;
    display: flex;
    align-items: center;
    font-size: 15px;
  }
}
.Form-Item-Label.isMsg {
  margin-top: 8px;
  margin-bottom: auto;
}
@media screen and (max-width: 480px) {
  .Form-Item-Label.isMsg {
    margin-top: 0;
  }
}
.Form-Item-Label-Required {
  border-radius: 6px;
  margin-right: 8px;
  padding-top: 8px;
  padding-bottom: 8px;
  width: 48px;
  display: inline-block;
  text-align: center;
  background: #F08300;
  color: #fff;
  font-size: 14px;
}
@media screen and (max-width: 480px) {
  .Form-Item-Label-Required {
    border-radius: 4px;
    padding-top: 4px;
    padding-bottom: 4px;
    width: 32px;
    font-size: 10px;
  }
}
.Form-Item-Input {
  border: 1px solid #ddd;
  border-radius: 6px;
  margin-left: 40px;
  padding-left: 1em;
  padding-right: 1em;
  height: 48px;
  flex: 1;
  width: 100%;
  max-width: 610px;
  background: #eaedf2;
  font-size: 18px;
}
@media screen and (max-width: 480px) {
  .Form-Item-Input {
    margin-left: 0;
    margin-top: 18px;
    height: 40px;
    flex: inherit;
    font-size: 15px;
  }
}
.Form-Item-Textarea {
  border: 1px solid #ddd;
  border-radius: 6px;
  margin-left: 40px;
  padding-left: 1em;
  padding-right: 1em;
  height: 216px;
  flex: 1;
  width: 100%;
  max-width: 610px;
  background: #eaedf2;
  font-size: 18px;
}
@media screen and (max-width: 480px) {
  .Form-Item-Textarea {
    margin-top: 18px;
    margin-left: 0;
    height: 200px;
    flex: inherit;
    font-size: 15px;
  }
}
.Form-Btn {
  border-radius: 6px;
  margin-top: 32px;
  margin-left: auto;
  margin-right: auto;
  padding-top: 20px;
  padding-bottom: 20px;
  width: 280px;
  display: block;
  letter-spacing: 0.05em;
  background: #F08300;
  color: #fff;
  font-weight: bold;
  font-size: 20px;
}
@media screen and (max-width: 480px) {
  .Form-Btn {
    margin-top: 24px;
    padding-top: 8px;
    padding-bottom: 8px;
    width: 160px;
    font-size: 16px;
  }
}

#company {
	margin-top:50px;
}

.company_in{
	width: 960px;
	margin: 0 auto;
}

#table01 {
	width:100%;
	max-width:1024px;
	margin:0 auto 80px;
	border-collapse: separate ;
	color:#333;
}

#table01 th,
#table01 td {
	padding: 24px 0;
	border-bottom:1px solid #DBDBDB;
	color:#333;
	font-size:16px;
	line-height:1.4;
}

#table01 th {
  width: 30%;
}

@media only screen and (max-width: 480px) {
  #table01 th,
  #table01 td {
    width: 100%;
    display: block;
  }

  #table01 th {
    width: 100%;
  }

  #table01 td {
    padding-top: 0;
  }
}

.profile {
	width:96%;
	max-width:960px;
	margin:0 auto 40px;
}

.profile h2 {
	position: relative;
	padding: 1rem .5rem;
	font-size:26px;
	line-height:1.6;
}

.profile h2:after {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 5px;
  content: '';
  background-image: -webkit-gradient(linear, left top, right top, from(#fa709a), to(#fee140));
  background-image: -webkit-linear-gradient(left, #fa709a 0%, #fee140 100%);
  background-image: linear-gradient(to right, #fa709a 0%, #fee140 100%);
}

.profile .flex {
	display: flex;
	gap:24px;
}
@media screen and (max-width: 480px) {
	.profile .flex {
		flex-direction: column;
	}
	.profile-txt {
		order:1;
	}
	.profile-img {
		order:2;
	}
}

.profile .flex .profile-img {
	margin-top:24px;
}

.profile .flex .profile-img img {
	width:100%;
	max-width:400px;
	height:auto !important;
	margin-bottom:30px;
}

.profile dl {
	max-width:900px;
	min-width:520px;
	margin:12px auto;
	border-bottom:1px dotted #999;
	padding: 5px 0 5px 0;
	font-size:16px;
	line-height:1.5;
}
.profile dl dt {
	font-size:20px;
	color:#900;
	border-left: solid 4px #900;
	margin:0;
	padding: 0 0 0 10px;
	font-weight: bold;
}
.profile dl dd {
	border-left: solid 4px #900;
	margin:0;
	padding: 0.5em 0.5em 0.5em 1em;
	line-height:1.6;
}


.qa-7 {
	width:96%;
	margin:24px auto;
    max-width: 960px;
    margin-bottom: 10px;
    border: none;
    border-radius: 5px;
    box-shadow: 0 4px 4px rgb(0 0 0 / 2%), 0 2px 3px -2px rgba(0 0 0 / 5%);
    background-color: #fff;
	font-size:20px;
	line-height:1.6;
}

.qa-7 summary {
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: relative;
    padding: 1em 2em 1em 3em;
    color: #333333;
	font-size:20px;
    font-weight: 600;
    cursor: pointer;
}

.qa-7 summary::before,
.qa-7 p::before {
    position: absolute;
    left: 1em;
    font-weight: 600;
    font-size: 1.3em;
}

.qa-7 summary::before {
    color: #75bbff;
    content: "Q";
}

.qa-7 summary::after {
    transform: translateY(-25%) rotate(45deg);
    width: 7px;
    height: 7px;
    margin-left: 10px;
    border-bottom: 3px solid #333333b3;
    border-right: 3px solid #333333b3;
    content: '';
    transition: transform .5s;
}

.qa-7[open] summary::after {
    transform: rotate(225deg);
}

.qa-7 p {
    position: relative;
    transform: translateY(-10px);
    opacity: 0;
    margin: 0;
    padding: .3em 3em 1.5em;
    color: #333;
    transition: transform .5s, opacity .5s;
}

.qa-7[open] p {
	margin-left:0.5em;
    transform: none;
    opacity: 1;
}

.qa-7 p::before {
    color: #ff8d8d;
    line-height: 1.2;
    content: "A";
}

#works {
	margin-top:50px;
}

.works_in{
	width: 960px;
	margin: 0 auto;
}

.seminar {
	width:98%;
	max-width:900px;
	margin:0 auto 50px;
	padding:24px;
	border:#ccc 1px solid;
	font-family: "Zen Maru Gothic", sans-serif;
	background: #F9FAF5;
}
.seminar h1{
	margin:0 0 0.2em;
	padding:0;
	font-size:30px;
	line-height:1;
}
.seminar h2{
	margin:0;
	padding:0;
	font-size:26px;
	line-height:1.4;
}
.seminar ul.history {
	margin:0.5em 0.5em 0 2em !important;
	padding:0.5em;
	font-size:18px;
/*
	font-weight:bold;
*/
	list-style: inside;
}

.seminar p{
	margin:1em;
	padding:0;
	font-size:18px;
	line-height:1.4;
}


.page-intro {
	margin:24px auto 12px;
	text-align: center;
}
.page-intro .theme {
	font-size:3rem;
}
.dots {
	-webkit-text-emphasis: filled;
	text-emphasis: filled;
	color:#ff6600;
	font-size:3.4rem;
}
.intro {
	margin:1em 0;
	font-size:1.8rem;
}

.p-search_seminar__info_detail {
    display: block;
    text-decoration: none;
    padding:10px 24px;
    margin:0 auto;
    box-shadow: #00000016 0 3px 6px;
    position: relative;
    transition: .3s;
	background: #fff;
}
.top24 {
	margin-top:24px;
}
.p-search_seminar__info_wrapper {
    display: inline-block;
    color: #014831;
}
.p-search_seminar__info_day {
    display: inline-block;
	font-weight:bold;
    font-size: 18px;
    line-height: 1.2;
    vertical-align: middle;
}
.p-search_seminar__info_week {
	font-weight:bold;
    font-size: 15px;
    margin-left: 7px;
}
.p-search_seminar__info_time {
	font-weight:bold;
    font-size: 15px;
    margin-left: 25px;
    position: relative;
}
.p-search_seminar__info_area {
	font-weight:bold;
    font-size: 18px;
    line-height: 1.5;
    display: inline-block;
    margin-left: 25px;
    vertical-align: middle;
}
.p-search_seminar__info_tag {
    display: inline-block;
    color: #fff;
    text-align: center;
    vertical-align: middle;
    width: 87px;
    line-height: 3em;
    margin-left: 25px;
    background-color: #585858;
}

.pintro {
	margin:1em;
}
.pintro p{
	font-size:18px;
	line-height:1.5;
}

.work-list h1{
	width:100%;
	max-width:960px;
	padding:3px;
	margin:24px auto 24px;
	font-size:26px;
	font-weight:bold;
	line-height:32px;
	border-bottom: 5px solid;
	border-image: linear-gradient(90deg, #FEE141 0, #FA719A 100%);
	border-image-slice: 1;
}

.work-list ul {
	width:100%;
	max-width:960px;
	list-style: none;
	margin:24px auto;
	display: flex;
	flex-direction: column;
	gap:8px;
}
