/* ======================================================= */
/* ====== COMPANY INTRODUCTION CSS ======================= */
/* ======================================================= */

.intro-section {
    background-color: #f9fafb; /* bg-gray-50 */
    padding-bottom: 5rem;
}
.intro-container {
    /* width: 100%; */
    max-width: 72rem; /* max-w-6xl */
    margin: 0 auto;
    padding: 0 1rem;
}

.intro-block {
    /* Holds one section like Introduction or Vision */
}

.section-heading {
    font-size: 1.5rem; /* text-2xl */
    font-weight: 600;
    color: #1f2937;
    border-bottom: 1px solid #e5e7eb; /* border-b */
    padding-bottom: 1rem;
}

.intro-grid {
    margin-top: 2rem;
    display: grid;
    grid-template-columns: 1fr;
    gap: 2rem;
    align-items: center;
}
@media (min-width: 1024px) {
    .intro-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 3rem;
    }
}

/* --- Logo/Image Side --- */
.logo-area {
    display: flex;
    justify-content: center;
}
@media (min-width: 1024px) {
    .logo-area {
        grid-column: span 1 / span 1;
    }
}
.logo-card {
    background-color: white;
    padding: 2rem;
    border-radius: 0.5rem;
    box-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1);
    border: 1px solid #e5e7eb;
    display: inline-block; /* to fit content */
}
.vision-card {
    width: 80%;
    background-color: white;
    padding: .5em;
    border-radius: 0.5rem;
    box-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1);
    border: 1px solid #e5e7eb;
    display: inline-block; /* to fit content */
}
.company-logo {
    width: 12rem; /* w-48 */
    height: 12rem; /* h-48 */
    object-fit: contain;
}
.vision-img {
    width: 100%; /* w-48 */
    height: 100%; /* h-48 */
    object-fit: contain;
}

/* --- Text Side --- */
.text-area {
    color: #4b5563;
    line-height: 1.75; /* leading-relaxed */
    display: flex;
    flex-direction: column;
    gap: 1rem; /* space-y-4 */
}
@media (min-width: 1024px) {
    .text-area {
        grid-column: span 2 / span 2;
    }
}

/* --- Specific style for Vision grid to reverse order --- */
@media (min-width: 1024px) {
    .vision-grid .text-area {
        order: 1; /* Text comes first */
    }
    .vision-grid .logo-area {
        order: 2; /* Image comes second */
    }
}