/**

 * About Page Styles

 * Template: page-about.php

 */

body main .about-page {
	background-image: url("../../images/optimized/rs-background.png");
	background-position: center 600px;
	background-repeat: no-repeat;
	background-size: contain;
	
}

/* ============================================

   Vision Hero Section

   ============================================ */



.vision-hero {

    position: relative;

    min-height: 620px;
    margin-top: -100px;

    background-size: contain;

    background-position: right;

    background-repeat: no-repeat;

    display: flex;

    align-items: center;

}



.vision-hero__overlay {

    position: absolute;

    top: 0;

    left: 0;

    right: 0;

    bottom: 0;

    /*background: linear-gradient(

        to right,

        rgba(255, 255, 255, 0.95) 0%,

        rgba(255, 255, 255, 0.8) 40%,

        rgba(255, 255, 255, 0.4) 70%,

        rgba(255, 255, 255, 0.1) 100%

    );*/

}



.vision-hero .container {

    position: relative;

    z-index: 1;

	width: 100%;
	
	max-width: 50%;
	
    margin: 0px 0px 0px 10%;
	
    padding: 40px 40px 40px 40px;
	
	background-color: rgba(238,255,235,0.70);
	
	border-radius: 20px;

}



.vision-hero__title {

    font-size: clamp(48px, 8vw, 80px);

    color: #0e857a;

    font-weight: bold;

    letter-spacing: 0.15em;

    margin: 0;

    line-height: 1.2;

}



/* ============================================

   Vision Statement Section

   ============================================ */



.vision-statement {
	
	width: 100%;
	
	max-width: 1180px;

    margin: 0px auto;

    padding: 80px 0;

    /*background-color: #fff;*/

}



.vision-primary {

	font-size: var(--font-size-h3);

    /*font-size: clamp(24px, 3vw, 32px);*/

    font-weight: bold;

    color: var(--color-accent-green-dark);

    margin-bottom: 30px;

    line-height: 1.6;

}



.vision-secondary {

	font-size: var(--font-size-h3);

    font-weight: bold;

    color: var(--color-accent-green-dark);

    line-height: 1.9;

    margin-bottom: 40px;

}



.vision-mission-content {

    font-size: 20px;

    color: #666;

    line-height: 1.9;

}



.vision-mission-content p {

    margin-bottom: 0;
    margin-top: 0;

	font-size: var(--font-size-base);
    color: var(--color-text-dark);

}



.vision-mission-content h3 {

	font-size: var(--font-size-base);

    font-weight: bold;

    color: var(--color-accent-green-dark);

    margin-top: 40px;

    margin-bottom: 20px;

}



/* ============================================

   Company Overview Section

   ============================================ */

.company-overview {
	
	width: 100%;
	
	max-width: 1180px;

    margin: 0px auto;

    padding: 80px 0;

}
.company-section-header {

    padding: 12px 20px ;

	font-size: var(--font-size-h3);
	
	color: #0e857a;

    font-weight: bold;

    margin-bottom: 30px;

}




/*
.company-overview {

    padding: 80px 0;

    background-color: #f9f9f9;

}



.company-section-header {

    background-color: var(--color-primary);

    color: white;

    padding: 12px 20px;

    font-size: 22px;

    font-weight: bold;

    margin-bottom: 30px;

    border-radius: 2px;

}



.company-info-table {

    width: 100%;

    border-collapse: collapse;

    margin-bottom: 60px;

    background-color: white;

    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);

}



.company-info-table th {

    background-color: var(--color-primary);

    color: white;

    padding: 12px 20px;

    text-align: left;

    font-weight: bold;

    width: 200px;

    vertical-align: top;

    border-right: 1px solid #fff;

}



.company-info-table td {

    padding: 12px 20px;

    border-bottom: 1px solid #e5e5e5;

    background-color: white;

    line-height: 1.8;

}



.company-info-table tr:last-child td {

    border-bottom: none;

}

*/

/* Company subsections with green headers */

.company-subsection {


}



.company-subsection-title {


    font-size: var(--font-size-base);
	
    color: var(--color-text-dark);

    margin-bottom: 0;

}

.company-subsection-content {



}



.company-subsection-content p {

    font-size: var(--font-size-base);
	
    color: var(--color-text-dark);

    margin-bottom: 0;

}

.grid-table {
  display: grid;
  grid-template-columns: 150px 1fr;
  align-items: start; /* 上揃え */
}

.grid-table .company-subsection-title {
  /*padding-top: 20px; !* コンテンツのpaddingと揃える *!*/
}

.grid-table > div {
  padding: 8px 10px;
}
/*
.company-subsection {

    margin-bottom: 50px;

}



.company-subsection-title {

    background-color: var(--color-primary);

    color: white;

    padding: 10px 20px;

    font-size: 18px;

    font-weight: bold;

    margin-bottom: 20px;

    border-radius: 2px;

}



.company-subsection-content {

    background-color: white;

    padding: 20px;

    line-height: 1.8;

    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);

}



.company-subsection-content p {

    margin-bottom: 15px;

}



.company-subsection-content ul {

    list-style: disc;

    padding-left: 25px;

    margin-bottom: 15px;

}



.company-subsection-content li {

    margin-bottom: 8px;

}
*/


/* ============================================

   President's Message (if included)

   ============================================ */



.president-message {

    padding: 80px 0;

    background-color: #fff;

}



.president-message .section__title {

    font-size: 28px;

    font-weight: bold;

    color: #333;

    margin-bottom: 30px;

    padding-bottom: 15px;

    border-bottom: 3px solid var(--color-primary);

}



.president-message__content {

    font-size: 16px;

    line-height: 1.9;

    color: #666;

}



.president-message__content p {

    margin-bottom: 20px;

}



/* ============================================

   Map Section

   ============================================ */



.company-map {

    padding: 80px 0;

    background-color: #f9f9f9;

}



.company-map .section__title {

    font-size: 28px;

    font-weight: bold;

    color: #333;

    margin-bottom: 30px;

    padding-bottom: 15px;

    border-bottom: 3px solid var(--color-primary);

}



.map-container {

    position: relative;

    width: 100%;

    padding-bottom: 56.25%; /* 16:9 aspect ratio */

    height: 0;

    overflow: hidden;

    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);

}



.map-container iframe {

    position: absolute;

    top: 0;

    left: 0;

    width: 100%;

    height: 100%;

    border: none;

}



/* ============================================

   Contact CTA Section

   ============================================ */



.section--cta {

    padding: 80px 0;

    background-color: var(--color-primary);

}



.section--cta .cta-box {

    text-align: center;

    color: white;

}



.section--cta h2 {

    font-size: 32px;

    font-weight: bold;

    margin-bottom: 20px;

    color: white;

}



.section--cta p {

    font-size: 18px;

    margin-bottom: 30px;

    color: white;

}



.cta-buttons {

    display: flex;

    justify-content: center;

    gap: 20px;

    flex-wrap: wrap;

}



.cta-buttons .btn {

    padding: 15px 40px;

    font-size: 16px;

    font-weight: bold;

    text-decoration: none;

    border-radius: 4px;

    transition: all 0.3s ease;

}



.cta-buttons .btn-primary {

    background-color: white;

    color: var(--color-primary);

}



.cta-buttons .btn-primary:hover {

    background-color: #f0f0f0;

    transform: translateY(-2px);

    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);

}



.cta-buttons .btn-outline {

    background-color: transparent;

    color: white;

    border: 2px solid white;

}



.cta-buttons .btn-outline:hover {

    background-color: white;

    color: var(--color-primary);

    transform: translateY(-2px);

}


/* ============================================

   Logo Section

   ============================================ */

.logo-animo {
	
	width: 100%;

    margin: 0px auto;

    padding: 0px 0px 80px 0;

}
.logo-animo .logo-container {
	
	width: 178px;

    margin: 0px auto;

}

/* ============================================

   Responsive Design

   ============================================ */



@media (max-width: 768px) {

    .vision-hero {

        min-height: 350px;

    }



    .vision-hero__title {

        font-size: 48px;

    }

	.vision-hero .container {

		position: absolute;
		
		bottom: 0px;

		z-index: 1;

		width: 100%;

		max-width: 50%;

		margin: 0px 0px 0px 0px;

		padding: 20px 40px 20px 20px;

	}


    .vision-statement,

    .company-overview,

    .president-message,

    .company-map,

    .section--cta {

        padding: 50px 0;

    }



    .company-info-table {

        display: block;

    }



    .company-info-table tbody {

        display: block;

    }



    .company-info-table tr {

        display: block;

        margin-bottom: 20px;

        border: 1px solid #e5e5e5;

    }



    .company-info-table th,

    .company-info-table td {

        display: block;

        width: 100%;

        border: none;

    }



    .company-info-table th {

        border-bottom: 1px solid rgba(255, 255, 255, 0.3);

    }



    .cta-buttons {

        flex-direction: column;

        align-items: center;

    }



    .cta-buttons .btn {

        width: 100%;

        max-width: 300px;

    }

}



@media (max-width: 480px) {

    .vision-hero {

        min-height: 250px;

    }



    .vision-hero__title {

        font-size: 36px;

    }



    .vision-primary {

        font-size: 20px;

    }



    .vision-secondary {

        font-size: 15px;

    }



    .company-section-header {

        font-size: 18px;

        padding: 10px 15px;

    }



    .company-info-table th,

    .company-info-table td {

        padding: 10px 15px;

    }

}

