@charset "utf-8";

/* ------------------------------------------------------------ philosophy */
#philosophy{ padding: 110px 0 130px; }
#philosophy .title{ padding: 0 0 55px; }

.philosophy-wrap{ display: flex; justify-content: center; align-items: center; gap: 25px; }
.philosophy__media{ width: 300px; }
.philosophy__text{ width: 53%; }
.philosophy__desc{ font-size: 20px; line-height: 2; }


/* ------------------------------------------------------------ policy */
#policy{ padding: 60px 0 100px; background: #F1F1ED; }
#policy .title{ padding: 0 0 60px; }
.policy-cards{ display: flex; flex-direction: column; gap: 14px; }
.policy-card{ display: flex; align-items: stretch; gap: 65px; background: #fff; border-radius: 10px; padding: 40px 50px 50px; }
.policy-card__title{ width: 330px; font-size: 27px; line-height: 1.5; font-family: 'Noto-Sans-JP-Bold'; }
.policy-card__body{ flex: 1; }
.policy-card__text{ font-size: 20px; line-height: 2; }


/* ------------------------------------------------------------ company */
#company{ padding: 80px 0 0; }
.info-row{ display: flex; align-items: center; gap: 10px; padding: 43px 0 28px; border-bottom: 1px solid #D1D1D1; }
.info-row__label{ width: 140px; font-size: 18px; font-family: 'Noto-Sans-JP-Bold'; line-height: 2; }
.info-row__value{ width: calc(100% - 140px); font-size: 18px; line-height: 2; }
.info-pair{ display: inline-flex; align-items: center; gap: 14px; margin-right: 34px; white-space: nowrap; }


/* ------------------------------------------------------------ access */
#access{ padding: 150px 0 130px; }
#access .title{ padding: 0 0 43px; }
.access__desc{ padding: 20px 0 0; font-size: 18px; line-height: 1.5; text-align: center; }
.access__map{ width: 100%; height: 500px; margin: 0 0 53px; }
.access__map iframe{ width: 100%; }

.parking{ display: flex; align-items: center; justify-content: space-between; }
.parking__text{ width: 50%; }
.parking__title{ padding: 0 0 35px; font-size: 24px; font-family: 'Noto-Sans-JP-Bold'; }
.parking__desc{ font-size: 20px; }

.parking__media{ width: 45%; text-align: right; }
.parking__media img{ width: 100%; height: auto; }


/* ------------------------------------------------------------ history */
#history{padding: 60px 0; background: #F1F1ED; }

#history .title{ padding: 0 0 40px; }
.history-list{ padding: 60px 50px 70px; background: #fff; border-radius: 10px; }
.history-item{ position: relative; padding: 0 0 50px; }
.history-item::before{ content: ""; position: absolute; left: 0; top: 10px; bottom: 10px; width: 1px; height: 100%; background: var(--main-color); }
.history-item:last-child{ padding-bottom: 0; }
.history-item:last-child::before{ display: none; }

.history-item__dot{ position: absolute; left: 0; top: 6px; transform: translateX(-50%); width: 15px; height: 15px; border-radius: 50%; background: var(--main-color); }
.history-item__row{ display: flex; align-items: flex-start; gap: 10px; padding-left: 24px; }
.history-item__date{ width: 70px; line-height: 2; }
.history-item__year{ line-height: 1.5; font-family: 'Noto-Sans-JP-Medium'; }
.history-item__card{ width: calc(100% - 70px); }
.history-item__text{ display: flex; align-items: flex-start; gap: 5px; padding: 0 0 30px; }
.history-item__text:last-child{ padding-bottom: 0; }
.history-item__month{ display: inline-block; width: 50px; line-height: 2; }
.history-item__desc{ line-height: 2; }



/* ----------------------------- mobile ------------------------------- */
@media only screen and (max-width: 768px) {

/* ------------------------------------------------------------ philosophy */
	#philosophy{ padding: 50px 0 0; }
	#philosophy .title{ padding: 0 0 20px; }
	
	.philosophy-wrap{ flex-direction: column-reverse; gap: 20px; text-align: center; }
	.philosophy__media{ width: 35%; margin: 0 0 0 auto; }
	.philosophy__media img{ width: 100%; height: auto; display: block; }
	.philosophy__text{ width: 100%; }
	.philosophy__desc{ font-size: 13px; line-height: 2; }
  

/* ------------------------------------------------------------ policy */
	#policy{ padding: 50px 0; }
	#policy .title{ padding: 0 0 20px; }
	
	.policy-card{ flex-direction: column; gap: 15px; padding: 25px 5% 30px; }
	.policy-card__title{ width: 100%; font-size: 17px; line-height: 1.5; }
	.policy-card__text{ font-size: 14px; line-height: 2; }


/* ------------------------------------------------------------ company */
	#company{ padding: 50px 0 0; }
	.info-row{ flex-direction: column; align-items: flex-start; gap: 5px; padding: 24px 0 18px; }
	.info-row__label{ width: 100%; font-size: 15px; line-height: 1.6; }
	.info-row__value{ width: 100%; font-size: 15px; line-height: 1.9; }
	
	.info-pair{ display: inline-flex; gap: 10px; margin: 0 18px 8px 0; white-space: normal; }


/* ------------------------------------------------------------ access */
	#access{ padding: 70px 0 70px; }
	#access .title{ padding: 0 0 20px; }
	
	.access__desc{ padding: 12px 0 0; font-size: 14px; line-height: 1.5; }
	.access__map{ height: 300px; margin: 0 0 35px; }
	.access__map iframe{ height: 300px; }
	.parking{ flex-direction: column; align-items: flex-start; gap: 16px; }
	
	.parking__text{ width: 100%; }
	.parking__title{ padding: 0 0 7px; font-size: 18px; }
	.parking__desc{ font-size: 15px; line-height: 1.8; }
	.parking__media{ width: 100%; text-align: left; }
	.parking__media img{ width: 100%; height: auto; display: block; }
	

/* ------------------------------------------------------------ history */

	#history{ padding: 45px 0; }
	#history .title{ padding: 0 0 25px; }
	
	.history-list{ padding: 35px 5% 40px; border-radius: 10px; }
	.history-item{ padding: 0 0 20px; }
	.history-item::before{ top: 8px; bottom: 8px; }
	
	.history-item__dot{ top: 4px; width: 12px; height: 12px; }
	.history-item__row{ flex-direction: column; gap: 10px; padding-left: 20px; }
	.history-item__date{ width: auto; }
	.history-item__year{ font-size: 14px; }
	.history-item__card{ width: 100%; }
	.history-item__text{ gap: 10px; padding: 0 0 16px; }
	.history-item__month{ width: 44px; }
	.history-item__desc{ font-size: 13px; line-height: 1.5; }






}
