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


header {
	background-color: #F9F9F9;
}

/* ===== FAQ (画像風) ===== */
.about {
  padding: 40px 0 80px;
  margin: 90px 0 0;
  background: #fff;
  color: #111;
}


@media (max-width: 1000px) {
.about {
  margin: 70px 0 0;  
  padding: 0 0 80px;
}	
}

.about_container {
  max-width: 1200px;
	width: 95%;
  margin: 0 auto;
}

.about_container h3 {
	font-size: 18px;
	font-weight: bold;
	padding: 50px 0 20px;
	color: #585858;
}


#title_box {
padding: 40px 0 50px;	
}

#title_box h1 {
  margin: 0;
  font-size: 28px;
  font-weight: 700;
  letter-spacing: 0.02em;
	text-align: center;
	color: #373737;
	
}

#title_box p {
  margin: 6px 0 0;
  font-size: 12px;
  letter-spacing: 0.18em;

	text-align: center;
	color: #A8A8A8;
}


.companyMessage {
	max-width: 1280px;
	margin: 0 auto 100px;
	background-image: linear-gradient(#ff86a5, #ff938f);
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 90px 0 30px 65px;
	border-radius: 25px;
	overflow: hidden;
}

@media (max-width: 1000px) {
.companyMessage {
	padding: 45px 30px;
	border-radius: 25px;
	overflow: hidden;
	display: block;
	margin: 0 auto 50px;
}	
}


.companyMessage_text {
	width: 65%;
}

@media (max-width: 1000px) {
.companyMessage_text {
	width: 100%;
}	
}


.companyMessage figure {
	width: 35%;
	margin: 0 -1% 0 0;
}

@media (max-width: 1000px) {
.companyMessage figure {
	display: none;
}	
}


.companyMessage_text h2 {
	font-size: 56px;
	margin: 0 0 50px;
	color: #FFF;
}

@media (max-width: 1000px) {
.companyMessage_text h2 {
	font-size: 36px;
	margin: 0 0 30px;
}	
}


.companyMessage_text p {
	font-size: 16px;
	margin: 0 0 50px;
	color: #FFF;
	line-height: 1.8;
}



#concept {
	position: relative;
}

#concept_text {
	width: 56%;
	padding: 40px 0 100px;
	margin: 0 0 0 auto;
}

@media (max-width: 1000px) {
#concept_text {
	width: 100%;
	padding: 40px 0 30px;
}	
}


#concept img {
	display: block;
	position: absolute;
	width: 40%;
	top: 20%;
	left: -2%;
}

@media (max-width: 1000px) {
#concept img {
	position: relative;
	width: 70%;
	max-width: 500px;
	top: auto;
	left: auto;
	margin: 0 auto 50px;
}	
}

#concept_text h2 {
	font-size: 36px;
	color: #848484;
	margin: 0 0 40px;
} 

@media screen and (max-width:500px) {
#concept_text h2 {
	font-size: 20px;
} 	
}


#concept_text h2 span {
	font-size: 27px;
} 

@media screen and (max-width:500px) {
#concept_text h2 span {
	font-size: 19px;
} 	
}


#concept_text p {
	font-size: 18px;
	color: #5C5C5C;
	line-height: 1.6;
	margin: 0 0 30px;
}


@media screen and (max-width:1000px) {
#concept_text p {
	font-size: 15px;
}	
}



/* ===== Card (gray panel) ===== */
.companyCard {
  background: #f6f6f6;
  border-radius: 10px;
  padding: 26px 34px;
  margin: 0 0 26px;
}

/* ===== Definition table-like list ===== */
.companyTable {
  margin: 0;
}

.companyTable__row {
  display: grid;
  grid-template-columns: 180px 1fr;
  column-gap: 48px;
  padding: 14px 0;
}

.companyTable__row + .companyTable__row {
  border-top: 1px solid rgba(0,0,0,0.06);
}

.companyTable__th {
  margin: 0;
  font-size: 14px;
  font-weight: 700;
  color: #5a5a5a;
}

.companyTable__td {
  margin: 0;
  font-size: 14px;
  line-height: 1.9;
  color: #4a4a4a;
}

/* ===== Tabs ===== */
.companyTabs {
  margin-top: 10px;
}

.tabs__head {
  display: flex;
  gap: 28px;
  border-bottom: 1px solid rgba(0,0,0,0.12);
  padding: 0 2px;
}

.tabs__tab {
  appearance: none;
  border: none;
  background: transparent;
  padding: 12px 4px 14px;
  font-size: 14px;
  font-weight: 700;
  color: #6a6a6a;
  cursor: pointer;
  position: relative;
}

.tabs__tab.is-active {
  color: #2a2a2a;
}

.tabs__tab.is-active::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  height: 2px;
  background: #2a2a2a;
}

.tabs__tab:focus-visible {
  outline: 2px solid #2a2a2a;
  outline-offset: 3px;
}

/* Panels */
.tabs__panels {
  padding-top: 18px;
}

.tabs__panel {
  display: none;
}

.tabs__panel.is-active {
  display: block;
}

/* ===== Content ===== */
.companyContent {
  padding: 8px 2px 0;
}

.companyContent__title {
  padding: 35px 0 20px;
  font-size: 16px;
  font-weight: 800;
  color: #2a2a2a;
}

.companyContent__text {
  margin: 0 0 25px;
  font-size: 14px;
  line-height: 2.0;
  color: #4a4a4a;
}

/* ISO badge area */
.companyContent__badge {
  margin: 16px 0 6px;
}

.isoBadge {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: #fff;
  min-width: 100px;
}

.isoBadge__top {
  font-weight: 900;
  letter-spacing: 0.06em;
}

.isoBadge__sub {
  margin-top: 4px;
  font-size: 10px;
  letter-spacing: 0.12em;
  color: #666;
}

/* ===== Responsive ===== */
@media (max-width: 900px) {
  .companyCard {
    padding: 18px 18px;
  }

  .companyTable__row {
    grid-template-columns: 140px 1fr;
    column-gap: 20px;
  }
}

@media (max-width: 640px) {
  .company__title {
    font-size: 28px;
  }

  .companyTable__row {
    grid-template-columns: 1fr;
    row-gap: 6px;
  }

  .companyTable__th {
    font-size: 13px;
  }

  .companyTable__td {
    font-size: 14px;
  }

  .tabs__head {
    gap: 18px;
  }

  .tabs__tab {
    font-size: 14px;
    padding: 12px 2px 12px;
  }
}
