@charset "UTF-8";
/*---------------------------------
  Basic
---------------------------------*/
html {
  scroll-behavior: smooth;
}

body {
	color: #333;
  font-family: 'Jost','Noto Sans Japanese', serif;
  font-size: 16px;
  font-weight: 500;
	line-height: 1.8em;
  background: #f2f0e9;
	margin: 0;
	padding: 0;
  position: relative;
}

h1,h2,h3,h4,h5 {
  letter-spacing: 0.1em;
	margin: 0;
	padding: 0;
}

h1,h2,h3 {
  font-weight: 900;
}

img {
	width: 100%;
	border: 0;
	vertical-align: bottom;
  display: block;
}

p,ul,li,dl,dt,dd,th,td {
	margin: 0;
	padding: 0;
}

ol,ul,li {
	list-style: none;
}

i {
	vertical-align: middle;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

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

::selection {
	background: #dfe1e5;
}

::-moz-selection {
	background: #dfe1e5;
}

@media screen and (max-width: 896px) {	
	body {
		font-size: 14px;
		min-width: 300px;
	}
}

/*---------------------------------
  ScrollTrigger
---------------------------------*/
.invisible {
  transition: all 1s ease;
  opacity: 0.0;
}

.visible {
  transition: all 1s ease;
  opacity: 1.0;
}

/*---------------------------------
  Link
---------------------------------*/
a:link, a:visited, a:hover, a:active {
	color: #333;
	text-decoration: none;
}

.btn {
	max-width: 300px;
	height: 60px;
	line-height: 60px;
	color: #fff !important;
	font-weight: 700;
	text-align: center;
	letter-spacing: 0.1em;
	border-radius: 3px;
	padding: 0 2em;
	display: block;
	position: relative;
}

.btn_forward:after {
	content: "\f105";
	font-family: 'Font Awesome 5 Free';
	position: absolute;
	right: 1.5em;
}

.btn_forward:hover:after {
	right: 1.3em;
	opacity: 0.8;
	transition: 0.3s;
}

.btn_back:after {
	content: "\f104";
	font-family: 'Font Awesome 5 Free';
	position: absolute;
	left: 1.5em;
}

.btn_back:hover:after {
	left: 1.3em;
	opacity: 0.8;
	transition: 0.3s;
}

/*---------------------------------
  Common
---------------------------------*/
.contents_wrap {
  margin-top: 7em;
}

.wrapper {
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 1em;
}

.text_box p:nth-child(n+2) {
  margin-top: 1em;
}

.index_wrap h2 {
  color: #006aba;
  font-size: clamp(21px, 3vw, 60px);
  margin-bottom: 1em;
  text-align: center;
}

.index_wrap h2 span {
  font-size: clamp(14px, 3vw, 18px);
  margin-top: 1em;
  display: block;
}

@media print, screen and (max-width: 896px) {
  .contents_wrap {
    margin-top: 3em;
  }
  
  .wrapper {
    padding: 0 4%;
  }
}

/*---------------------------------
  Header
---------------------------------*/
header {
  font-weight: 600;
  padding: 1.5em 4%;
}

header h1 img {
  width: 250px;
}

.header_content {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}

.header_box {
  margin-left: auto;
}

.header_box nav {
  display: flex;
  flex-wrap: wrap;
}

.header_box nav li a {
  padding: 0.5em 1em;
}

.header_box nav li a:hover {
  opacity: 0.8;
  transition: 0.3s;
}

@media print, screen and (max-width: 896px) {
  .header_box {
    display: none;
  }
}

/*---------------------------------
  hero
---------------------------------*/
.hero_wrap {
  margin-top: 4em;
}

.hero_content {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  position: relative;
}

.hero_content:before {
  content: '';
  width: 95%;
  height: 100%;
  border-radius: 1em;
  background: #f7d346;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  margin: 0 auto;
  padding: 3em;
  z-index: -2;
}

.hero_box {
  text-align: center;
  margin: 5em 0;
}

.hero_box h3 {
  color: #006aba;
  font-size: clamp(16px, 2.5vw, 24px);
  border-radius: 3em;
  background: #fff;
	position: relative;
  display: inline-block;
  margin: 0 auto;
  padding: 0.5em 1.5em;
  z-index: 0;
}

.hero_box h3:after {
	content: "";
	position: absolute;
	bottom: -10px;
  left: 50%;
	width: 0px;
	height: 0px;
	border-style: solid;
	border-width: 10px 10px 0 10px;
	border-color: #fff transparent transparent transparent;
	margin-left: -10px;
	display: block;
}

.hero_box h2 {
  color: #006aba;
  font-size: clamp(24px, 4vw, 70px);
  margin: 1em 0 1em 0;
}

.hero_box .text_box p {
  font-size: clamp(14px, 2.5vw, 18px);
  font-weight: 600;
  line-height: 2em;
  letter-spacing: 0.05em;
}

.hero_content ul li {
  position: absolute;
  z-index: -1;
}

.hero_content ul li:first-of-type {
  width: 18%;
  top: -3em;
  left: 0;
}

.hero_content ul li:nth-of-type(2) {
  width: 11%;
  top: -2em;
  right: 5%;
}

.hero_content ul li:nth-of-type(3) {
  width: 15%;
  top: -3em;
  left: 23%;
}

.hero_content ul li:nth-of-type(4) {
  width: 15%;
  bottom: -2em;
  right: 0;
}

.hero_content ul li:nth-of-type(5) {
  width: 23%;
  bottom: -2em;
  left: 5%;
}

.hero_content ul li:nth-of-type(6) {
  width: 19%;
  top: 38%;
  right: 4%;
}

.hero_content ul li:nth-of-type(7) {
  width: 12%;
  top: 31%;
  left: 9%;
}

.hero_content ul li:nth-of-type(8) {
  width: 13%;
  top: -1em;
  right: 20%;
}

.hero_btn {
  width: 150px;
  height: 150px;
  color: #fff !important;
  font-size: 14px;
  font-weight: 600;
  text-align: center;
  letter-spacing: 0.1em;
  border-radius: 50%;
  background: #ef5b47;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  position: absolute;
  bottom: -3em;
  right: 17%;
  z-index: 1;
  border: double 10px #f2f0e9;
  padding: 5px;
}

.hero_btn span {
  font-size: 12px;
  font-weight: 500;
}

.hero_btn:before {
	content: "\f0e0";
	font-family: 'Font Awesome 5 Free';
  font-size: 120%;
  font-weight: 500;
  margin-bottom: 0.5em;
}

.hero_btn:hover {
  border: none;
  transition: 0.3s;
}

@media print, screen and (max-width: 896px) {
  .hero_btn {
    display: none;
  }
}

/*---------------------------------
  point
---------------------------------*/
.point_content {
  padding: 5em 3em;
  position: relative;
  z-index: 2;
}

.point_content:before {
  content: '';
  width: 100vw;
  height: 100%;
  border-radius: 0 1em 1em 0;
  background-color: #edf7ff;
	background-image:
	 repeating-linear-gradient(-45deg,
	 #cbe9ff, #cbe9ff 4px,
	 transparent 0, transparent 8px);
  position: absolute;
  top: 0;
  right: 0px;
  display: block;
  z-index: -1;
}

.point_box {
  display: flex;
  flex-wrap: wrap;
}

.point_inner {
  width: calc(100% / 2 - 2em);
  border-radius: 0.5em;
  background: #fff;
  margin: 2em 1em;
  padding: 5%;
  position: relative;
}

.point_number {
  color: #ef5b47;
  font-size: clamp(18px, 3vw, 70px);
  font-weight: 900;
  position: absolute;
  top: -10px;
  left: 0.5em;
}

.point_inner h3 {
  font-size: clamp(16px, 3vw, 24px);
  text-align: center;
  line-height: 1.5em;
  margin: 0.5em 0 1em 0;
}

.point_inner h3 span {
  color: #006aba;
  background: linear-gradient(transparent 70%, #f7d346 70%);
}

@media print, screen and (max-width: 896px) {
  .point_content {
    padding: 5em 1em;
  }
  
  .point_box {
    flex-direction: column;
  }
  
  .point_inner {
    width: calc(100% - 2em);
  }
}

/*---------------------------------
  gallery
---------------------------------*/
.gallery_wrap {
  background: #006aba;
  padding: 5em 0;
}

.gallery_content h2 {
  color: #fff;
}

.gallery_box ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}

.gallery_box ul li {
  width: calc(100% / 6);
  height: auto;
  padding: 1em;
  overflow: hidden;
}

.gallery_box ul li img {
  /*max-width: 224px;*/
  border-radius: 0.5em;
  margin: auto;
}

@media print, screen and (max-width: 896px) {
  .gallery_box ul li {
    width: calc(100% / 4);
  }
}

/*---------------------------------
  flow
---------------------------------*/
.flow_wrap {
  width: 100%;
  overflow: hidden;
}

.flow_content {
  padding: 5em 3em;
  position: relative;
  z-index: 2;
}

.flow_content:before {
  content: '';
  width: 100vw;
  height: 100%;
  border-radius: 1em 0 0 1em;
  background-color: #edf7ff;
	background-image:
	 repeating-linear-gradient(-45deg,
	 #cbe9ff, #cbe9ff 4px,
	 transparent 0, transparent 8px);
  position: absolute;
  top: 0;
  left: 0px;
  display: block;
  z-index: -1;
}

.flow_inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  border-radius: 0.5em;
  background: #fff;
  padding: 2em;
  position: relative;
}

.flow_inner:not(:last-child):after {
	content: "";
	position: absolute;
	bottom: -20px;
  left: 50%;
	width: 0px;
	height: 0px;
	border-style: solid;
	border-width: 20px 20px 0 20px;
	border-color: #fff transparent transparent transparent;
	margin-left: -20px;
	display: block;
}

.flow_inner:nth-of-type(n+2) {
  margin-top: 4em;
}

.flow_title {
  width: 200px;
  text-align: center;
}

.flow_title p {
  color: #fff;
  font-size: clamp(12px, 3vw, 14px);
  background: #ef5b47;
  border-radius: 3em;
  margin-bottom: 0.5em;
}

.flow_title h3 {
  font-size: clamp(16px, 3vw, 18px);
}

.flow_text {
  width: calc(100% - 200px);
  padding-left: 2em;
}

.flow_text p a {
  text-decoration: underline;
}

@media print, screen and (max-width: 896px) {
  .flow_content {
    padding: 5em 2em;
  }
  
  .flow_inner {
    flex-direction: column;
  }
  
  .flow_text {
    width: 100%;
    padding: 0;
  }
  
  .flow_title {
    margin-bottom: 1em;
  }
}

/*---------------------------------
  banner
---------------------------------*/
.banner_content {
  display: flex;
  flex-wrap: wrap;
}

.chunichi_banner {
  background: #006eb9;
}

.gcase_banner {
  background: #013d66;
}

.supermate_banner {
  background: #137458;
}

.banner_box {
  width: calc(100% / 3 - 2em);
  text-align: center;
  border-radius: 0.5em;
  margin: 0.5em 1em;
  padding: 2em 1em 1em 1em;
  position: relative;
  cursor: pointer;
}

.banner_box:hover {
  opacity: 0.8;
  transition: 0.3s;
}

.banner_thumb {
  max-width: 75px;
  position: absolute;
  top: -1em;
  left: 0;
  right: 0;
  margin: 0 auto;
}

.banner_box h3 {
  font-size: clamp(13px, 2.5vw, 16px);
  font-weight: 600;
  margin: 1em 0 0.5em 0;
}

.banner_box h3 a {
  color: #fff !important;
}

.banner_box ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}

.banner_box ul li {
  color: #666;
  font-size: 12px;
  line-height: 1.5em;
  border-radius: 3px;
  background: #f5f5f5;
  margin: 5px;
  padding: 0 0.5em;
}

@media print, screen and (max-width: 896px) {
  .banner_content {
    flex-direction: column;
  }
  
  .banner_box {
    width: calc(100% - 2em);
  }
  
  .banner_box:nth-of-type(n+2) {
    margin-top: 3em;
  }
}

/*---------------------------------
  お問い合わせ
---------------------------------*/
.form_content {
  border-radius: 0.5em;
  background: #fff;
  padding: 5em 4%;
}

/*---------------------------------
  Thanks
---------------------------------*/
.thanks_content .text_box p:nth-last-child(2)	{
	font-size: 21px;
	font-weight: 600;
  letter-spacing: 0.1em;
}

.thanks_content .text_box p:nth-last-child(2):before {
  content: "\f095";
	font-family: 'Font Awesome 5 Free';
  font-size: 21px;
  font-weight: 600;
  display: inline-block;
	vertical-align: middle;
	margin-right: 0.5em;
}

@media print, screen and (max-width: 896px) {
  .thanks_content .text_box p:nth-last-child(2)	{
    font-size: 18px;
  }
  
  .thanks_content .text_box p:nth-last-child(2):before {
    font-size: 16px;
  }
}

/*---------------------------------
  Footer
---------------------------------*/
footer {
  color: #fff;
	background: #006eb9;
  padding: 5em 0 2em 0;
}

.sitemap_box nav {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}

.sitemap_box nav li a {
  color: #fff;
  font-size: clamp(12px, 3vw, 14px);
  padding: 0.5em 1em;
}

.sitemap_box nav li a:hover {
  text-decoration: underline;
}

address {
	color: #fff;
	font-size: 0.7em;
	font-style: normal;
	text-align: center;
	padding: 2em 0;
}
