@charset "utf-8";

/* ----------------------------------------------
ベース
---------------------------------------------- */
:root {
  --bg: #f4f4f2;
  --blue: #174b7a;
  --text: #313334;
  --line: #2f628f;
  --container: 1366px;
}

html {
}

body {
  font-family: "Noto Sans JP", "メイリオ", "ヒラギノ角ゴ ProN W3",
	"HiraKakuProN-W3", "ヒラギノ角ゴ Pro W3", "HiraKakuPro-W3",
	Meiryo, "ＭＳ Ｐゴシック", "MS Pgothic", "Osaka", sans-serif,
	Helvetica, Helvetica Neue, Arial, Verdana;
  background: #ffffff;
  color: #000000;
  width: 100%;
  letter-spacing: 0.05em;
  box-sizing: border-box;
  font-size: 90%;
  line-height: 2em;
  overflow-x: hidden;
  margin: 0;
}

*,
*::before,
*::after {
}

img {
  width: 100%;
  height: auto;
  display: block;
}

a {
  text-decoration: none;
  color: #313334;
  cursor: pointer;
  display: block;
}

a:hover {
  text-decoration: none;
  color: #55c0ee;
}

figure {
  margin: 0;
}

/* ----------------------------------------------
共通
---------------------------------------------- */
.wrapper {
  position: relative;
  max-width: 1366px;
  margin: 0 auto;
  padding-left: 40px;
  padding-right: 40px;
}

.flex_box {
  display: flex;
}

.flex_a_center{
 align-items: center;
}

.pc_none {
  display: none;
}

.sp_none {
  display: initial;
}

.inline-link {
  display: inline;
  color: inherit;
  text-decoration: none;
}

.inline-link * {
  display: inline !important;
}

/* ----------------------------------------------
ヘッダー / グローバルナビ
---------------------------------------------- */
header {
  position: relative;
}

#logo {
  position: relative;
  height: 140px;
}

#logo h1 {
  position: absolute;
  top: 30px;
  margin: 0;
}

#logo h1 img {
  width: 346px;
}

#gn ul li {
  padding: 0.5em 2em 0 0;
}

#gn ul:nth-of-type(1) li:nth-of-type(1) {
  padding-left: 0;
}

#gn ul:nth-of-type(1) li a {
  text-decoration: none;
  display: block;
}

#gn_sub {
  position: absolute;
  top: 12px;
  right: 118px;
  text-align: center;
}

#gn_sub ul li {
  width: 180px;
  height: 47px;
  line-height: 47px;
}

#gn_sub ul li:nth-of-type(1) {
  background-color: #cb1c1b;
  margin-bottom: 5px;
}

#gn_sub ul li:nth-of-type(2) {
  background-color: #000000;
}

#gn_sub ul li a {
  color: #ffffff;
}

/* ----------------------------------------------
ハンバーガーメニュー
---------------------------------------------- */
.hamburger {
  display: block;
  position: fixed;
  z-index: 150;
  right: 13px;
  top: 12px;
  width: 100px;
  height: 100px;
  cursor: pointer;
  text-align: center;
  background-color: rgba(16, 70, 111, 0.6);
  border-radius: 21px;
}

.hamburger span {
  display: block;
  position: absolute;
  width: 66px;
  height: 12px;
  left: 17px;
  background: #ffffff;
  transition: 0.3s ease-in-out;
  border-radius: 100px;
}

.hamburger span:nth-child(1) {
  top: 24px;
}

.hamburger span:nth-child(2) {
  top: 45px;
}

.hamburger span:nth-child(3) {
  top: 66px;
}

.hamburger.active span:nth-child(1) {
  top: 45px;
  left: 15px;
  background: #fff;
  transform: rotate(-45deg);
}

.hamburger.active span:nth-child(2),
.hamburger.active span:nth-child(3) {
  top: 45px;
  background: #fff;
  transform: rotate(45deg);
}

nav.globalMenuSp {
  position: fixed;
  z-index: 120;
  top: 0;
  left: 0;
  color: #fff;
  text-align: center;
  width: 100%;
  opacity: 0;
  transition: opacity 0.6s ease, visibility 0.6s ease;
  display: none;
}

nav.globalMenuSp ul {
  margin: 0 auto;
  padding: 0;
  width: 100%;
}

nav.globalMenuSp ul li {
  list-style-type: none;
  width: 100%;
  transition: 0.4s all;
  display: none;
  line-height: 1.2em;
  border-bottom: dotted 1px #8e8e8e;
  padding: 1rem 0;
}

nav.globalMenuSp ul li:hover {
  background: #ddd;
}

nav.globalMenuSp ul li a {
  display: block;
  color: #313334;
  padding: 1em 0;
}

nav.globalMenuSp.active {
  opacity: 1;
  display: block;
  height: 100%;
  overflow-y: scroll;
}

nav ul:nth-of-type(1) {
  display: inline-block;
  background-color: #ffffff;
  margin: 0;
  padding: 0;
}

nav ul:nth-of-type(1) li {
  display: inline-block;
  font-weight: bold;
  list-style: none;
}

/* ----------------------------------------------
メインエリア
---------------------------------------------- */

#main_area{
	overflow: hidden;
}


#main_back {
  margin-top: 35px;
  background: url(../img/blue-b-assets/blue-b_logoback.png);
  background-repeat: no-repeat;
  background-size: 56%;
  background-position: 164% 82%;
}

#main_img {
  position: relative;
}

#main_img img:nth-of-type(2) {
  width: 45vw;
  top: -40px;
  right: 60px;
}

#main_img #main_copy1 {
	position: absolute;
	top: 4vw;
	left: 4vw;
	width: 34%;
}

#main_copy2 {
  background-color: #7dcbe1;
  color: #ffffff;
  font-weight: bold;
  text-align: center;
  border-radius: 50%;
  width: 20vw;
  height: 20vw;
  font-size: 2vw;
  line-height: 3vw;
  position: relative;
  margin-top: -12vw;
}

#main_copy2_in {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  width: 20vw;
}

#main_under_copy {
  text-align: center;
  margin-top: 6rem;
  margin-bottom: 6rem;
  font-family: "メイリオ", "ヒラギノ角ゴ ProN W3", "HiraKakuProN-W3",
	"ヒラギノ角ゴ Pro W3", "HiraKakuPro-W3", Meiryo, "ＭＳ Ｐゴシック",
	"MS Pgothic", "Osaka", sans-serif, Helvetica, Helvetica Neue, Arial,
	Verdana;
}

#main_under_copy span {
  font-weight: bold;
  font-size: clamp(26px, 4vw, 4rem);
  margin-bottom: 1.5rem;
  display: inline-block;
  position: relative;
}

#main_under_copy span img {
  height: 13rem;
}

#main_under_copy span img:nth-of-type(1) {
  width: auto;
  position: absolute;
    left: -11rem;
    top: -4rem;
}

#main_under_copy span img:nth-of-type(2) {
  width: auto;
  position: absolute;
    right: -10rem;
    top: -3rem;
}

#b_logo {
  margin-bottom: 6em;
}

#b_logo img {
  width: clamp(300px, 35%, 500px);
  margin-left: auto;
  margin-right: auto;
}

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

#b_logo {
	margin-bottom: 10em;
}

}

@media screen and (max-width: 800px) {

	#main_copy2 {
		width: 25vw;
		height: 25vw;
		font-size: 3.5vw;
		line-height: 4vw;
		position: relative;
		margin-top: -14vw;
	}

	#main_copy2_in {
		width: 20vw;
	}

	#main_under_copy {
		margin-top: 2rem;
		margin-bottom: 4rem;
	}

	#main_under_copy span img {
		height: 12rem;
	}

	#main_under_copy span img:nth-of-type(1) {
/*		right: -17rem;
		top: -12rem;*/
		display: none;
  }

	#main_under_copy span img:nth-of-type(2) {
        right: -27vw;
        top: -34vw;
         height: 15rem;
	}

}

@media screen and (max-width: 640px) {

	#main_copy2 {
		width: 30vw;
		height: 30vw;
		font-size: 4vw;
		line-height: 4.5vw;
		position: relative;
		margin-top: -17vw;
	}

	#main_copy2_in {
		width: 20vw;
	}

	#main_under_copy {
		margin-top: 2rem;
		margin-bottom: 3rem;
		padding: 0 1em;
		font-size: 0.9em;
		line-height: 1.8em;
	}

	#main_under_copy span img:nth-of-type(2) {
        right: -6rem;
        top: -17rem;
    }

	#main_under_copy span img {
		height: 11rem;
	}

	#b_logo {
		margin-bottom: 2em;
	}

}

/* ----------------------------------------------
ニュース
---------------------------------------------- */
#news {
  margin-top: 100px;
  margin-bottom: 100px;
}

.news_list {
  margin: 0 2%;
  width: 100%;
  padding: 0;
}

.news_list_item {
  padding: 1em 0;
  border-bottom: 1px dotted #e6e6e6;
  font-size: 0.8em;
  list-style: none;
}

.news_list_item:first-child {
  border-top: 1px dotted #e6e6e6;
}

.news_list_item a,
.not_a {
  position: relative;
  display: flex;
  padding-right: 30px;
}

.news_list_item a {
  text-decoration: underline;
}

.news_list_date {
  display: flex;
  margin-right: 15px;
  align-items: center;
}

.news_item,
.news_item_news {
  color: #ffffff;
  border-radius: 8px;
  width: 20em;
  text-align: center;
  margin-left: 20px;
  font-size: 0.8em;
  line-height: 2.5em;
}

.nx_green {
  background: #8ec043;
}

.nx_blue {
  background: #7dcbe0;
}

.nx_pink {
  background: #e4a6c9;
}

.nx_red {
  background: #cb1c1b;
}

.nx_orange {
  background: #e79014;
}

.arrow {
  width: 25px;
  height: 1px;
  background: #707070;
  position: absolute;
  top: 50%;
  right: 5%;
}

.arrow::after {
  content: "";
  display: block;
  width: 6px;
  height: 1px;
  background: #707070;
  transform: rotate(45deg);
  position: absolute;
  right: 0px;
  bottom: 2px;
}


@media screen and (max-width: 640px) {

	#news {
		margin-top: 4rem;
		margin-bottom: 2rem;
	}

}

/* ----------------------------------------------
about
---------------------------------------------- */
#about {
  position: relative;
  padding-top: initial;
}

#about .wrapper h2 {
  text-align: center;
  margin-top: clamp(20px, 4vw, 100px);
  padding-bottom: 60px;
  font-size: 1.6rem;
  letter-spacing: 0.3rem;
  font-weight: bold;
  line-height: 1.3em;
}

#about .flex_box > div:nth-of-type(1) {
  width: 60%;
  padding: 2rem 2rem 0 2rem;
}

#about .flex_box > div:nth-of-type(1) div {
  position: relative;
  background-color: #7dcbe1;
  color: #ffffff;
  display: block;
  padding: 1em 0.5em;
  width: clamp(80%, 80%, 26em);
  text-align: center;
  margin: 4rem auto 0 auto;
  letter-spacing: 0.2em;
  border-radius: 100rem;
  font-weight: bold;
}

#about .flex_box > div:nth-of-type(2) {
  width: 40%;
}

#about .flex_box > div:nth-of-type(2) img {
  width: 80%;
}

#about p {
  margin-left: 1rem;
}


@media screen and (max-width: 800px) {

	#about .flex_box > div:nth-of-type(1) div {
		display: block;
		padding:0.5em;
		width: clamp(80%, 80%, 26em);
		text-align: center;
		margin: 4rem auto 0 auto;
		letter-spacing: 0.2em;
		border-radius: 100rem;
		margin-bottom: 2rem;
		line-height: 1.6em;
}

	#about .flex_box > div:nth-of-type(2) img {
		width: 60%;
		margin-left: auto;
		margin-right: auto;
	}

}


@media screen and (max-width: 640px) {

	#about .flex_box > div:nth-of-type(2) img {
		width: 80%;
		margin-left: auto;
		margin-right: auto;
	}

}

/* ----------------------------------------------
支援の特徴ブロック
---------------------------------------------- */
.bb-section {
  padding: 70px 24px 80px;
  background: var(--bg);
  color: var(--blue);
  margin-top: 4rem;
}

.bb-container {
  max-width: var(--container);
  margin: 0 auto;
}

.bb-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 64px;
  align-items: start;
}

.bb-left,
.bb-right {
  min-width: 0;
}

.bb-left {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.bb-collage {
  width: 100%;
  max-width: 620px;
  margin-bottom: 28px;
}

.bb-collage img {
  width: 76%;
  height: auto;
  margin: 0 auto;
}

.bb-logo {
  margin: 0 0 26px;
  color: var(--blue);
  font-size: clamp(3.6rem, 5vw, 6rem);
  line-height: 0.95;
  font-weight: 800;
  letter-spacing: 0.02em;
  text-align: center;
}

.bb-feature {
  width: 100%;
  max-width: 620px;
  text-align: center;
}

.bb-heading {
  margin: 0 0 22px;
  color: var(--blue);
  font-size: clamp(1.5rem, 2.3vw, 3.25rem);
  line-height: 1.35;
  font-weight: 700;
}

.bb-heading--center {
  text-align: center;
}

.bb-heading--medical {
  margin-bottom: 28px;
}

.bb-list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.bb-list--feature li {
  position: relative;
  padding-left: 1.2em;
  list-style-type: none;
}

.bb-target {
  margin-bottom: 120px;
}

.bb-target p {
  margin: 0;
}

.bb-medical-list {
  margin: 0;
  padding: 0;
  list-style: none;
  border-top: 2px solid var(--line);
  font-weight: bold;
  font-size: 1.1em;
}

.bb-medical-list li {
  position: relative;
  padding: 22px 0 22px 28px;
  border-bottom: 2px solid var(--line);
  line-height: 1.4;
}

.bb-medical-list li::before {
  content: "・";
  position: absolute;
  left: 0;
  top: 22px;
}

@media screen and (max-width: 800px) {

	.bb-logo {
		margin: 0 0 26px;
		color: var(--blue);
		font-size: 10vw;
		line-height: 0.95;
		font-weight: 800;
		letter-spacing: 0.02em;
		text-align: center;
	}

	.bb-heading {
		margin: 0 0 22px;
		color: var(--blue);
		font-size: clamp(1.5rem, 2.3vw, 3.25rem);
		line-height: 1.35;
		font-weight: 700;
		text-align: center;
	}

	.bb-right p{
		text-align: center;
	}

  .bb-collage img {
    width: 62%;
    height: auto;
    margin: 0 auto;
}

}

/* ----------------------------------------------
everyday
---------------------------------------------- */
#everyday {
  padding-top: clamp(40px, 10vw, 175px);
  margin-bottom: clamp(100px, 10vw, 175px);
}

#everyday h3 {
  text-align: center;
  margin: 1rem 0 2rem 0;
  font-size: 1.5em;
  font-weight: bold;
}

#everyday h2 img {
  width: clamp(1px, 70vw, 960px);
  margin: 0 auto;
}

#everyday_2,
#everyday_3 {
  margin-top: 5vw;
}

#everyday_1 img,
#everyday_2 img,
#everyday_3 img {
  width: clamp(80%, 80%, 960px);
  margin-right: auto;
  margin-left: auto;
}

#everyday_1 p,
#everyday_2 p,
#everyday_3 p {
  font-size: clamp(16px, 1.5vw, 2rem);
  margin-top: 1rem;
  width: clamp(300px, 70%, 800px);
  margin-left: auto;
  margin-right: auto;
}

#everyday_1 p,
#everyday_3 p {
  text-align: right;
}

#everyday_2 p {
  text-align: left;
}

/* ----------------------------------------------
analysis
---------------------------------------------- */
#analysis {
  margin-bottom: clamp(100px, 10vw, 175px);
  padding-top: initial;
}

#analysis h2 {
  font-size: clamp(1.2rem, 3.2vw, 3rem);
  font-weight: bold;
  border-bottom: solid 7px;
  text-align: center;
  margin-left: auto;
  margin-right: auto;
  padding: 0.5em 1.5em;
  display: inline-block;
}

#analysis h2 div {
  display: flex;
  justify-content: center;
  align-items: center;
}

.tate {
  writing-mode: vertical-rl;
  font-size: 0.5rem;
  border-right: 1px solid;
  margin-right: 1rem;
  padding-right: 1rem;
  display: inline-block;
}

#analysis p {
  width: 70%;
  margin-left: auto;
  margin-right: auto;
  margin-top: 2rem;
  text-align: left;
}

.analysis_1,
.analysis_2,
.analysis_3,
.analysis_4 {
  text-align: center;
  margin-bottom: clamp(40px, 7vw, 80px);
}

.analysis_1 {
  margin-top: clamp(40px, 7vw, 80px);
}

.analysis_1 img,
.analysis_2 img,
.analysis_4 img {
  display: inline-block;
  width: 80%;
}

.analysis_3 img {
  display: inline-block;
  width: clamp(160px, 45%, 45%);
}

/* ----------------------------------------------
power-re
---------------------------------------------- */
#power-re {
  margin-bottom: clamp(100px, 10vw, 175px);
  padding-top: clamp(100px, 10vw, 175px);
}

#power-re_1 h2 img {
  width: clamp(300px, 45%, 45%);
  margin: 0 auto;
}

#power-re_1 p {
  width: 45%;
  margin-left: auto;
  margin-right: auto;
  margin-top: 2rem;
  margin-bottom: 4rem;
}

#power-re_2 {
  display: flex;
}

#power-re_2 > div:nth-of-type(1) {
  margin-right: 20px;
  width: 45%;
}

#power-re_2 > div:nth-of-type(1) img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

#power-re_2 > div:nth-of-type(2) {
  width: 55%;
}

#power-re_2 h2 {
  background-color: #f5da41;
  font-weight: bold;
  display: inline-block;
  padding: 0.2em 4em;
  font-size: 1.3rem;
  border-radius: 50px 50px 0 0;
  line-height: 1.3em;
}

#power-re_2 h2 img {
  width: 45%;
  margin: 0 auto;
}

#power-re_2 > div:nth-of-type(2) img {
  width: 30%;
  margin-left: 1rem;
}

#power-re_ex {
  border: 1px solid #000000;
  padding: 2em;
}

#power-re_ex h3 {
  font-weight: bold;
  margin-bottom: 1em;
  font-size: 1.3rem;
}

/* ----------------------------------------------
mail
---------------------------------------------- */
#mail {
  position: relative;
  padding-top: clamp(40px, 10vw, 175px);
}

#mail .wrapper h2 {
  text-align: center;
}

#mail_h {
  text-align: center;
  margin-top: 2rem;
  font-family: "メイリオ", "ヒラギノ角ゴ ProN W3", "HiraKakuProN-W3",
	"ヒラギノ角ゴ Pro W3", "HiraKakuPro-W3", Meiryo, "ＭＳ Ｐゴシック",
	"MS Pgothic", "Osaka", sans-serif, Helvetica, Helvetica Neue, Arial,
	Verdana;
}

#mail_h span {
  font-weight: bold;
  font-size: clamp(26px, 4vw, 4rem);
  margin-bottom: 3.5rem;
  display: inline-block;
  position: relative;
  color: var(--blue);
}

#mail_h span::before {
  content: "";
  display: inline-block;
  width: 200px;
  height: 200px;
  background-image: url(../img/blue-b-assets/bird.png);
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  position: absolute;
  top: -77px;
  left: -220px;
}

#mail_h span img {
  height: 14rem;
}

#mail_h span img:nth-of-type(1) {
  width: auto;
  position: absolute;
  left: -16rem;
  top: -4rem;
  width: 36%;
  height: auto;
}

#mail_h span img:nth-of-type(2) {
  width: auto;
  position: absolute;
  right: -20rem;
  top: -3rem;
}

.pri_box {
  border: 1px solid var(--blue);
  border-radius: 1em;
  background: #fff;
  padding: 2.5em;
  height: 14em;
  overflow: auto;
  overflow-x: hidden;
  overflow-y: scroll;
  font-size: 0.9em;
  line-height: 1.2em;
  margin-top: 60px;
  width: 80%;
  margin-left: auto;
  margin-right: auto;
}

input:focus,
textarea:focus {
  outline: 2px #55c0ee solid;
}

/* validationEngine を使うなら残す */
.fstep dt {
  padding: 0;
  margin: 0 auto;
  font-size: 1.2rem;
  font-weight: bold;
  color: var(--blue);
}

.fstep dd::after {
  position: absolute;
  content: "";
  bottom: -14px;
  left: 50%;
  transform: translate(-50%, -50%);
  height: 10px;
  width: 100%;
  z-index: 100;
  background-image: linear-gradient(
	to right,
	var(--blue),
	var(--blue) 3px,
	transparent 3px,
	transparent 8px
  );
  background-size: 8px 2px;
  background-position: left bottom;
  background-repeat: repeat-x;
}

.fstep .che_box span::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  background: #fff;
  width: 42px;
  height: 42px;
  border-radius: 5px;
  border: 4px solid var(--blue);
}

.fstep input[type="checkbox"]:checked + span::after {
  content: "";
  display: block;
  position: absolute;
  top: 8px;
  left: 15px;
  width: 10px;
  height: 18px;
  transform: rotate(40deg);
  border-bottom: 10px solid var(--blue);
  border-right: 10px solid var(--blue);
}

.fstep input[type="checkbox"]:checked + span {
  color: var(--blue);
}

.fstep .formError .formErrorContent {
  width: 100%;
  background: var(--blue);
  position: relative;
  color: #ffffff;
  font-weight: bold;
  text-indent: 0.5em;
  min-width: 120px;
  font-size: 16px;
  padding: 0.3em 0;
}

.right_button {
  position: relative;
  background-color: #7dcbe1;
  color: #ffffff;
  display: block;
  padding: 1em 0.5em;
  width: clamp(80%, 80%, 26em);
  text-align: center;
  margin: 4rem auto 0 auto;
  letter-spacing: 0.1em;
  border-radius: 100rem;
  font-weight: bold;
  font-size: 1.4rem;
}


@media screen and (max-width: 640px) {

	.right_button {
		padding: 1em 0.5em;
		width: clamp(80%, 80%, 26em);
		text-align: center;
		margin: 1rem auto 0 auto;
		letter-spacing: 0.1em;
		border-radius: 100rem;
		font-weight: bold;
		font-size: 1rem;
	}

}

/* ----------------------------------------------
company
---------------------------------------------- */
#company {
  position: relative;
  background-color: #94d4ef;
  background-image: url(../img/blue-b-assets/blue_dot.png);
  padding-top: clamp(100px, 10vw, 175px);
  padding-bottom: clamp(100px, 10vw, 175px);
}

#company ul {
  display: flex;
  flex-wrap: wrap;
  padding: 0;
}

#company li {
  width: 80%;
  background-color: #ffffff;
  border-radius: 12px;
  padding: 40px;
  margin-bottom: 2%;
  margin-left: auto;
  margin-right: auto;
  list-style: none;
}

#company li:nth-of-type(even) {
  margin-left: 2%;
}

#company h2 {
  text-align: center;
  margin-bottom: 80px;
}

#company ul h2 {
  text-align: center;
  margin-top: 0;
  margin-bottom: 40px;
  position: relative;
}

#company h2 img {
  width: 80%;
  display: inline-block;
}

#company ul li h2 img {
  width: 45%;
  display: inline-block;
}

#company ul h2::after {
  position: absolute;
  content: "";
  bottom: -47px;
  left: 50%;
  transform: translate(-50%, -50%);
  height: 15px;
  width: 100%;
  z-index: 100;
  border-bottom: solid 4px var(--blue);
}

#company dl {
  display: flex;
  flex-wrap: wrap;
  line-height: 1.2em;
  margin-top: 85px;
}

#company dt {
  font-weight: bold;
  width: 30%;
  margin-bottom: 1rem;
}

#company dd {
  width: 70%;
  margin-bottom: 1rem;
}

.gmap {
  margin-top: 40px;
  text-align: center;
}


@media screen and (max-width: 640px) {

	#company {
		position: relative;
		background-color: #94d4ef;
		background-image: url(../img/blue-b-assets/blue_dot.png);
		margin-top: 2rem;
		padding-top: 4rem;
		padding-bottom: clamp(100px, 10vw, 175px);
	}

}

/* ----------------------------------------------
footer
---------------------------------------------- */
footer {
  display: flex;
  flex-wrap: wrap;
  padding-top: 65px;
}

footer div:nth-of-type(1) {
  width: 45%;
  padding-left: 60px;
  line-height: 1.6em;
}

footer div:nth-of-type(2) {
  width: 55%;
  padding-right: 60px;
  padding-left: 2em;
}

footer div:nth-of-type(2) li {
  display: inline-block;
  margin-right: 2em;
  margin-bottom: 1em;
  border-radius: 3em;
  padding: 0.5em 1em;
  background-color: #7dcbe1;
  list-style: none;
}

footer div:nth-of-type(2) li a {
  color: #ffffff;
}

footer h2 img {
  width: clamp(200px, 40%, 400px);
}

/* ----------------------------------------------
レスポンシブ
---------------------------------------------- */
@media screen and (max-width: 1024px) {

}

@media screen and (max-width: 800px) {
  .wrapper {
	max-width: initial;
	min-width: initial;
	padding: 0 1rem;
  }

  #logo {
	height: 66px;
  }

  #logo h1 {
	top: 20px;
	left: 10px;
  }

  #logo h1 img {
	width: 50%;
  }

  #gn_sub,
  #gn {
	display: none;
  }

  #main_back {
	margin-top: 10%;
	background-repeat: no-repeat;
	background-size: 59%;
	background-position: 158% 87%;
  }

  #main_img img:nth-of-type(2) {
	width: 68vw;
	top: -50px;
	right: 5px;
  }


  #main_copy2_in {
	width: 30vw;
  }

  .news_list {
	margin: 0 2%;
	width: initial;
  }

	.news_list_item a,
	.not_a {
		display: block;
	}

  #about .flex_box {
	flex-direction: column;
  }

  #about .flex_box > div:nth-of-type(1) {
	width: 100%;
  }

  #about .flex_box > div:nth-of-type(2) {
	width: 80%;
	margin-left: auto;
	margin-right: auto;
  }

  .bb-section {
	padding: 40px 16px 56px;
	margin-top: 4rem;
  }

  .bb-grid {
	grid-template-columns: 1fr;
	gap: 48px;
  }

  .bb-left {
	order: 1;
  }

  .bb-right {
	order: 2;
	padding-top: 0;
  }

  .bb-collage,
  .bb-feature {
	max-width: none;
  }

  .bb-target {
	margin-bottom: 56px;
  }

  .bb-medical-list li {
	padding: 18px 0 18px 24px;
  }

  .bb-medical-list li::before {
	top: 18px;
  }

  #analysis p,
  #power-re_1 p {
	width: 80%;
  }

  #power-re_2 {
	flex-direction: column;
  }

  #power-re_2 > div:nth-of-type(1),
  #power-re_2 > div:nth-of-type(2) {
	width: 80%;
	margin-left: auto;
	margin-right: auto;
  }

  #power-re_2 > div:nth-of-type(2) {
	margin-top: 35px;
  }

  #mail {
	margin-right: 0;
	margin-left: 0;
  }

  #mail_h span img {
	height: 14rem;
  }

  #company ul {
	flex-direction: column;
  }

  #company li {
	width: 100%;
	padding: 1.5em;
  }

  #company li:nth-of-type(even) {
	margin-left: 0;
  }

  footer div:nth-of-type(1),
  footer div:nth-of-type(2) {
	width: 90%;
	padding-left: 0;
	padding-right: 0;
	margin-left: auto;
	margin-right: auto;
  }

  footer div:nth-of-type(1) {
	margin-bottom: 3em;
  }
}

@media screen and (max-width: 769px) {
  .arrow {
	/* display: none; */
  }
}

@media screen and (max-width: 640px) {

  .sp_none {
	display: none;
  }

    .pc_none {
	display: initial;
  }

  nav.globalMenuSp ul li {
	padding-top: 0.3rem;
	padding-bottom: 0.3rem;
  }

  .hamburger {
	width: 60px;
	height: 60px;
	background-color: rgba(16, 70, 111, 0.5);
	border-radius: 12px;
  }

  .hamburger span {
	width: 46px;
	height: 10px;
	left: 7px;
  }

  .hamburger span:nth-child(1) {
	top: 10px;
  }

  .hamburger span:nth-child(2) {
	top: 26px;
  }

  .hamburger span:nth-child(3) {
	top: 42px;
  }

  .hamburger.active span:nth-child(1) {
	top: 25px;
	left: 7px;
  }

  .hamburger.active span:nth-child(2),
  .hamburger.active span:nth-child(3) {
	top: 25px;
  }

  #logo h1 {
	top: 0px;
	left: 5px;
  }

  #logo h1 img {
	width: clamp(240px, 50%, 400px);
  }

  #main_back {
	margin-top: 15px;
	background-size: 56%;
	background-position: 164% 82%;
  }

  #main_under_copy span img:nth-of-type(1) {
	left: -4rem;
	top: 3rem;
  }

	#main_img #main_copy1 {
		top: 34px;
		width: clamp(115px, 53vw, 1000px);
		left: 24px;
	}

  #everyday h2 img {
	width: 90%;
  }

  #everyday_1 img,
  #everyday_2 img,
  #everyday_3 img {
	width: 100%;
  }

  #analysis p,
  #power-re_1 p {
	width: 85%;
  }

  #power-re {
	margin-bottom: 40px;
	padding-top: 40px;
  }

  #power-re_2 > div:nth-of-type(1),
  #power-re_2 > div:nth-of-type(2) {
	width: 100%;
  }

  #mail_h {
	margin-bottom: 2rem;
  }

  #mail_h span img {
	height: 10rem;
  }
}

@media screen and (max-width: 480px) {
  .arrow {
	display: none;
  }

  .news_list_item a,
  .not_a {
	padding-right: 0;
  }

  #company ul li h2 img {
	width: 65%;
  }

  footer div:nth-of-type(2) li {
	display: block;
	text-align: center;
	margin-right: 0;
	margin-bottom: 1em;
	border-radius: 3em;
	padding: 0.5em 1em;
	background-color: #7dcbe1;;
  }
}