/* About Page Styles - Namespaced with about- prefix to avoid conflicts */

/* Ensure proper base styles */
.about-breadcrumb,
.about-top-message-section,
.about-main-container {
    font-family: "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Meiryo", "Noto Sans JP", sans-serif;
    color: #333;
    line-height: 1.8;
}

/* Fix for fixed header */
body.page-template-page-about,
body.page-template-page-about-php {
    padding-top: 0;
}

.about-breadcrumb {
    max-width: 1200px;
    margin: 120px auto 20px;
    padding: 0 20px;
    font-size: 13px;
    color: #666;
}

.about-breadcrumb a {
    color: #666;
    text-decoration: none;
}

.about-breadcrumb a:hover {
    text-decoration: underline;
}

.about-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}

/* Top Message Section */
.about-top-message-section {
    background-color: #fafafa;
    padding: 60px 0;
    margin-top: 0px;
    margin-bottom: 60px;
}

.about-section-title-main {
    text-align: center;
    font-size: 32px;
    font-weight: 300;
    margin-bottom: 50px;
    letter-spacing: 0.1em;
}

.about-top-message-content {
    display: flex;
    align-items: top;
    gap: 60px;
    max-width: 1000px;
    margin: 0 auto;
}

.about-top-message-image {
    flex-shrink: 0;
}

.about-top-message-image img {
    width: 250px;
    height: 250px;
    border-radius: 50%;
    object-fit: cover;
}

.about-top-message-text {
    flex: 1;
}

.about-top-message-quote {
    font-size: 24px;
    color: #2449A4;
    margin-bottom: 20px;
    line-height: 1.6;
    position: relative;
}

.about-top-message-quote::before {
    content: '"';
    font-size: 48px;
    color: #2449A4;
    position: absolute;
    left: -30px;
    top: -10px;
}

.about-top-message-quote::after {
    content: '"';
    font-size: 48px;
    color: #2449A4;
    margin-left: 5px;
}

.about-top-message-author {
    text-align: right;
    font-size: 14px;
    color: #666;
    margin-bottom: 30px;
}

.about-read-more-btn {
    text-align: center;
    margin-top: 30px;
}

.about-read-more-btn button {
    background-color: #fff;
    border: 1px solid #2449A4;
    color: #2449A4;
    padding: 10px 30px;
    font-size: 14px;
    cursor: pointer;
    border-radius: 4px;
    transition: all 0.3s;
}

.about-read-more-btn button:hover {
    background-color: #2449A4;
    color: #fff;
}

.about-message-full-text {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.5s ease;
    margin-top: 20px;
}

.about-message-full-text.about-expanded {
    max-height: 1000px;
}

.about-message-full-text p {
    margin-bottom: 20px;
    line-height: 1.8;
}

/* Main Content */
.about-main-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 40px 20px;
}

/* Hero Section */
.kyotsu-hero-section {
    background-image: url('https://wrt.solutions/sol2025/wp-content/uploads/2025/11/aboutback.jpg');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    padding: 100px 20px;
    margin: 0 0 0px 0;
    text-align: center;
    position: relative;
    overflow: hidden;
}

.kyotsu-hero-section::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(135deg, rgba(70, 193, 147, 0.85) 0%, rgba(36, 152, 164, 0.84) 50%, rgba(34, 26, 128, 0.85) 100%);
    pointer-events: none;
    z-index: 1;
}

.kyotsu-hero-section::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: 
        radial-gradient(circle at 20% 50%, rgba(255, 255, 255, 0.1) 0%, transparent 50%),
        radial-gradient(circle at 80% 50%, rgba(255, 255, 255, 0.1) 0%, transparent 50%);
    pointer-events: none;
    z-index: 2;
}

.kyotsu-hero-content {
    position: relative;
    z-index: 3;
    max-width: 1200px;
    margin: 0 auto;
}

.kyotsu-hero-label {
    font-size: 16px;
    letter-spacing: 0.3em;
    color: rgba(255, 255, 255, 0.9);
    font-weight: 600;
    margin-bottom: 20px;
    text-transform: uppercase;
}

.kyotsu-hero-title {
    font-size: 48px;
    font-weight: 300;
    color: #ffffff;
    margin-bottom: 30px;
    letter-spacing: 0.15em;
    line-height: 1.3;
}

.kyotsu-hero-divider {
    width: 100px;
    height: 4px;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.8), transparent);
    margin: 0 auto;
}

.kyotsu-section-header {
    text-align: center;
    margin-bottom: 60px;
}

.kyotsu-section-label {
    font-size: 14px;
    letter-spacing: 0.2em;
    color: #2449A4;
    font-weight: 600;
    margin-bottom: 15px;
}

.kyotsu-section-title-main {
    font-size: 32px;
    font-weight: 300;
    margin-bottom: 20px;
    letter-spacing: 0.1em;
    color: #333;
}

.kyotsu-section-divider {
    width: 80px;
    height: 3px;
    background: linear-gradient(90deg, transparent, #2449A4, transparent);
    margin: 0 auto;
}
@media (max-width: 768px) {
   .kyotsu-section-title-main {
        font-size: 26px;
    }

    .kyotsu-hero-section {
        padding: 80px 20px;
    }

    .kyotsu-hero-label {
        font-size: 14px;
        letter-spacing: 0.25em;
    }

    .kyotsu-hero-title {
        font-size: 36px;
        letter-spacing: 0.1em;
    }

    .kyotsu-hero-divider {
        width: 80px;
        height: 3px;
    }
}

@media (max-width: 480px) {
    .kyotsu-hero-section {
        padding: 60px 15px;
    }

    .kyotsu-hero-label {
        font-size: 13px;
        letter-spacing: 0.2em;
    }

    .kyotsu-hero-title {
        font-size: 28px;
        letter-spacing: 0.08em;
    }

    .kyotsu-hero-divider {
        width: 60px;
        height: 3px;
    }
}


/* Page Title */
.about-page-title {
    text-align: center;
    font-size: 36px;
    font-weight: 300;
    margin-bottom: 60px;
    letter-spacing: 0.1em;
}

/* Directors Section */
.about-directors-section {
    margin-bottom: 80px;
}

.about-section-title {
    text-align: center;
    font-size: 28px;
    font-weight: 300;
    margin-bottom: 40px;
    letter-spacing: 0.05em;
}

.about-directors-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 40px;
    margin-bottom: 40px;
}

.about-director-card {
    text-align: center;
}

.about-director-image {
    width: 100%;
    height: 280px;
    background-color: #e0e0e0;
    margin-bottom: 20px;
    overflow: hidden;
}

.about-director-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.about-director-position {
    font-size: 13px;
    color: #666;
    margin-bottom: 5px;
}

.about-director-name {
    font-size: 20px;
    font-weight: bold;
    color: #333;
}

/* Organization Chart & Flow Section */
.about-org-chart-section,
.about-flow-section {
    margin-bottom: 80px;
}

.about-org-chart-container,
.about-flow-container {
    background-color: #fff;
    padding: 20px;
    border-radius: 8px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
}

.about-org-chart-container img,
.about-flow-container img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 4px;
  max-width: 1000px;
  margin: 30px auto;
}

/* Customer Container Styles */
.customer-container {
    margin-top: 40px;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(550px, 1fr));
    gap: 30px;
}

.customer-container .section {
    margin-bottom: 0;
    padding: 40px;
    background-color: #fff;
    border-radius: 16px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    animation: fadeIn 0.6s ease;
}

.customer-container .section:nth-child(2) {
    animation-delay: 0.2s;
}

.customer-container .section:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.12);
}

.customer-container .section-header {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    margin-bottom: 24px;
    padding-bottom: 20px;
    border-bottom: 3px solid;
}

.customer-container .customer-support .section-header {
    border-bottom-color: #667eea;
}

.customer-container .repair .section-header {
    border-bottom-color: #f093fb;
}

.customer-container .section-icon {
    width: 60px;
    height: 60px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.customer-container .customer-support .section-icon {
    background: linear-gradient(135deg, #667eea, #764ba2);
}

.customer-container .repair .section-icon {
    background: linear-gradient(135deg, #f093fb, #f5576c);
}

.customer-container .section-title {
    font-size: 1.5rem;
    font-weight: 700;
    color: #1a202c;
    margin: 0 0 12px 0;
}

.customer-container .availability-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: linear-gradient(135deg, #667eea, #764ba2);
    color: white;
    padding: 10px 20px;
    border-radius: 50px;
    font-weight: 600;
    font-size: 0.95rem;
    margin-bottom: 8px;
    box-shadow: 0 4px 12px rgba(102, 126, 234, 0.3);
}

.customer-container .requirement {
    color: #718096;
    font-size: 0.85rem;
    margin-bottom: 0;
    font-style: italic;
}

.customer-container .service-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 16px;
    margin-bottom: 24px;
}
.customer-container .service-card {
    background: linear-gradient(135deg, #f8fafc 0%, #ffffff 100%);
    border-radius: 12px;
    padding: 0;
    border-left: 4px solid;
    transition: all 0.3s ease;
    overflow: hidden;
    position: relative;
    display: flex;
    flex-direction: row-reverse;
}
.customer-container .service-card.no-image {
    padding: 20px;
    flex-direction: column;
}
.customer-container .service-card.no-image .service-card-content {
    padding: 0;
}
.customer-container .service-card-images {
  width: 200px;
  height: 100%;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  padding: 0 10px;
}
.customer-container .service-card-image {
  width: 100%;
  height: 50%;
  object-fit: cover;
  display: block;
  margin: 15px auto;
}
.customer-container .service-card .service-card-content {
    flex: 1;
}

.customer-container .customer-support .service-card {
    border-left-color: #667eea;
}

.customer-container .repair .service-card {
    border-left-color: #f093fb;
}

.customer-container .service-card:hover {
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.15);
}

.customer-container .service-card-content {
    padding: 20px;
}

.customer-container .service-card h3 {
    font-size: 1rem;
    font-weight: 600;
    color: #1a202c;
    margin-bottom: 12px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.customer-container .service-card h3::before {
    content: '';
    width: 8px;
    height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
}

.customer-container .customer-support .service-card h3::before {
    background: #667eea;
}

.customer-container .repair .service-card h3::before {
    background: #f093fb;
}

.customer-container .service-card ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.customer-container .service-card li {
    padding: 6px 0 6px 20px;
    color: #4a5568;
    font-size: 0.9rem;
    position: relative;
    line-height: 1.6;
}

.customer-container .service-card li::before {
    content: '✓';
    position: absolute;
    left: 0;
    font-weight: 600;
}

.customer-container .customer-support .service-card li::before {
    color: #667eea;
}

.customer-container .repair .service-card li::before {
    color: #f093fb;
}

.customer-container .service-card .sub-category {
    display: block;
    font-size: 0.8rem;
    color: #718096;
    margin-top: 4px;
    font-style: italic;
}

.customer-container .other-services {
    background: linear-gradient(135deg, #fff5e6 0%, #ffffff 100%);
    border-radius: 12px;
    padding: 20px;
    border: 2px solid #d4af37;
    margin-top: 20px;
}

.customer-container .other-services h3 {
    font-size: 1rem;
    font-weight: 600;
    color: #1a202c;
    margin-bottom: 12px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.customer-container .other-services h3::before {
    content: '★';
    color: #d4af37;
}

.customer-container .other-services ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 10px;
}

.customer-container .other-services li {
    padding: 8px 0 8px 24px;
    color: #4a5568;
    font-size: 0.9rem;
    position: relative;
}

.customer-container .other-services li::before {
    content: '→';
    position: absolute;
    left: 0;
    color: #d4af37;
    font-weight: 600;
}

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@media (max-width: 768px) {
    .customer-container {
        grid-template-columns: 1fr;
    }
    
    .customer-container .section {
        padding: 30px 20px;
    }
    
    .customer-container .section-header {
        flex-direction: column;
        align-items: flex-start;
    }
    
    .customer-container .service-grid {
        grid-template-columns: 1fr;
    }
    
    .customer-container .other-services ul {
        grid-template-columns: 1fr;
    }
}

/* CS Improvement Section */
.about-cs-section {
    margin-bottom: 80px;
}

.about-four-c-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 30px;
    margin-top: 40px;
}

.about-c-card {
    padding: 30px;
    border-radius: 8px;
    border: 2px solid;
    transition: transform 0.3s, box-shadow 0.3s;
}

.about-c-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 16px rgba(0,0,0,0.15);
}

.about-c-card.about-customer-value {
    border-color: #4a90e2;
    background: linear-gradient(135deg, #f0f7ff 0%, #e3f2fd 100%);
}

.about-c-card.about-customer-cost {
    border-color: #9b59b6;
    background: linear-gradient(135deg, #f8f4ff 0%, #f3e5f5 100%);
}

.about-c-card.about-convenience {
    border-color: #27ae60;
    background: linear-gradient(135deg, #f0fff4 0%, #e8f5e9 100%);
}

.about-c-card.about-communication {
    border-color: #e67e22;
    background: linear-gradient(135deg, #fff8f0 0%, #fff3e0 100%);
}

.about-c-card-title {
    font-size: 20px;
    font-weight: bold;
    margin-bottom: 15px;
}

.about-c-card.about-customer-value .about-c-card-title {
    color: #4a90e2;
}

.about-c-card.about-customer-cost .about-c-card-title {
    color: #9b59b6;
}

.about-c-card.about-convenience .about-c-card-title {
    color: #27ae60;
}

.about-c-card.about-communication .about-c-card-title {
    color: #e67e22;
}

.about-c-card ul {
    list-style: none;
    padding: 0;
}

.about-c-card li {
    margin-bottom: 10px;
    padding-left: 20px;
    position: relative;
    font-size: 14px;
    line-height: 1.6;
}

.about-c-card li::before {
    content: '●';
    position: absolute;
    left: 0;
    color: inherit;
}

/* Company Info Section */
.about-company-section {
    padding: 80px 0;
    background: linear-gradient(135deg, #f8f9fa 0%, #ffffff 100%);
}

.about-section-content {
    max-width: 1000px;
    margin: 0 auto;
    padding: 0 20px;
}

.about-section-header {
    text-align: center;
    margin-bottom: 60px;
    animation: fadeInDown 0.8s ease;
}

.about-section-label {
    font-size: 1rem;
    color: #2449A4;
    font-weight: 600;
    letter-spacing: 0.2em;
    margin-bottom: 12px;
}

.about-section-title-main {
    font-size: 2.5rem;
    font-weight: 700;
    color: #1a202c;
    margin-bottom: 20px;
}

.about-section-divider {
    width: 80px;
    height: 4px;
    background: linear-gradient(90deg, #2449A4, #4a90e2);
    margin: 0 auto;
    border-radius: 2px;
}

.about-table-wrapper {
    background: white;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.1);
    animation: fadeInUp 0.8s ease;
}

/* Company Info Table */
.about-company-info-table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 0;
    background-color: #fff;
}

.about-company-info-table tr {
    border-bottom: 1px solid #e2e8f0;
    transition: background 0.2s ease;
}

.about-company-info-table tr:hover {
    background: #f8fafc;
}

.about-company-info-table th {
    width: 200px;
    padding: 24px 32px;
    text-align: left;
    background: #34495e;
    color: white;
    font-weight: 600;
    font-size: 1rem;
    vertical-align: top;
    border-bottom: 1px solid rgba(36, 73, 164, 0.3);
    letter-spacing: 0.05em;
}

.about-company-info-table td {
    padding: 24px 32px;
    color: #2d3748;
    font-size: 0.95rem;
    line-height: 1.8;
    vertical-align: top;
    border-bottom: 1px solid #e2e8f0;
}

.about-company-info-table tr:last-child th,
.about-company-info-table tr:last-child td {
    border-bottom: none;
}

.about-company-name {
    font-weight: 600;
    color: #1a202c;
    font-size: 1.05rem;
}

.about-highlight-text {
    font-weight: 600;
    color: #1a202c;
}

.about-capital {
    font-size: 1.1rem;
}

/* Office Info Styles */
.about-office-info {
    display: block;
}

.about-office-details {
    display: block;
}

.about-office-address {
    color: #2449A4;
    text-decoration: none;
    font-weight: 500;
    transition: color 0.3s ease;
}

.about-office-address:hover {
    color: #4a90e2;
    text-decoration: underline;
}

.about-office-contact {
    margin-top: 8px;
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
}

.about-contact-item {
    color: #4a5568;
    font-size: 0.9rem;
}

/* Representative Styles */
.about-representative {
    display: block;
}

.about-representative-position {
    font-size: 0.85rem;
    color: #718096;
    margin-bottom: 4px;
}

.about-representative-name {
    font-weight: 600;
    color: #1a202c;
    font-size: 1.05rem;
}

/* Parent Company */
.about-parent-link {
    font-weight: 600;
    color: #2449A4;
    text-decoration: none;
    transition: color 0.3s ease;
}

.about-parent-link:hover {
    color: #4a90e2;
    text-decoration: underline;
}

.about-company-info-table a {
    color: #2449A4;
    text-decoration: none;
}

.about-company-info-table a:hover {
    text-decoration: underline;
}

/* Animations */
@keyframes fadeInDown {
    from {
        opacity: 0;
        transform: translateY(-30px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(30px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Section */
.about-section {
    margin-bottom: 80px;
}

/* Company Guide Cards */
.about-guide-cards {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 30px;
    margin-bottom: 80px;
}

.about-guide-card {
    border: 1px solid #e0e0e0;
    padding: 0;
    text-align: center;
    transition: box-shadow 0.3s;
    background-color: #fff;
}

.about-guide-card:hover {
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
}

.about-guide-card-image {
    width: 100%;
    height: 200px;
    background-color: #f5f5f5;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 48px;
    color: #2449A4;
    font-weight: bold;
}

.about-guide-card-content {
    padding: 20px;
}

.about-guide-card-link {
    color: #333;
    text-decoration: none;
    display: block;
}

.about-guide-card-link:hover {
    color: #2449A4;
}

.about-guide-card-title {
    font-size: 16px;
    margin-bottom: 5px;
}

.about-guide-card-description {
    font-size: 13px;
    color: #666;
}

/* Business Strategy Section */
.about-strategy-section {
    background-color: #fafafa;
    padding: 60px 0;
    margin: 0 -20px;
}

.about-strategy-content {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}

.about-strategy-link {
    display: block;
    text-align: center;
    padding: 30px;
    background-color: #fff;
    border: 1px solid #e0e0e0;
    text-decoration: none;
    color: #333;
    transition: box-shadow 0.3s;
}

.about-strategy-link:hover {
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
}

.about-strategy-link-title {
    font-size: 20px;
    margin-bottom: 15px;
    color: #2449A4;
}

.about-strategy-link-description {
    font-size: 14px;
    color: #666;
    line-height: 1.6;
}

/* Global Expansion Section */
.about-global-section {
    text-align: center;
}

.about-global-stats {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 40px;
    margin-top: 40px;
}

.about-stat-item {
    padding: 30px;
    background-color: #fafafa;
}

.about-stat-label {
    font-size: 14px;
    color: #666;
    margin-bottom: 10px;
}

.about-stat-value {
    font-size: 32px;
    font-weight: 300;
    color: #333;
}

.about-stat-value span {
    font-size: 18px;
}

.about-update-date {
    text-align: center;
    margin-top: 40px;
    font-size: 14px;
    color: #666;
}

/* Service Network Section */
.about-network-section {
    margin-top: 60px;
}

.about-network-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    margin-top: 30px;
}

.about-network-item {
    text-align: center;
    padding: 30px 20px;
    background-color: #fafafa;
    border-radius: 4px;
}

.about-network-value {
    font-size: 36px;
    font-weight: 300;
    color: #2449A4;
    margin-bottom: 10px;
}

.about-network-label {
    font-size: 14px;
    color: #666;
}

/* Partners Section with Slider */
.about-partners-section {
    margin-top: 60px;
    overflow: hidden;
    padding: 40px 0;
    background: linear-gradient(180deg, #ffffff 0%, #fafafa 100%);
}

.about-partners-note {
    text-align: center;
    font-size: 14px;
    color: #666;
    margin-bottom: 40px;
}

.about-slider-container {
    margin-bottom: 20px;
    overflow: hidden;
    position: relative;
}

.about-slider-track {
    display: flex;
    animation-timing-function: linear;
    animation-iteration-count: infinite;
    will-change: transform;
}

.about-slider-track-1 {
    animation: about-scroll-left 40s linear infinite;
}

.about-slider-track-2 {
    animation: about-scroll-right 45s linear infinite;
}

.about-slider-track-3 {
    animation: about-scroll-left 50s linear infinite;
}

@keyframes about-scroll-left {
    0% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(-50%);
    }
}

@keyframes about-scroll-right {
    0% {
        transform: translateX(-50%);
    }
    100% {
        transform: translateX(0);
    }
}

.about-slider-track:hover {
    animation-play-state: paused;
}

.about-partner-logo {
    flex: 0 0 180px;
    height: 90px;
    margin: 0 12px;
    background-color: #fff;
    border: 2px solid #e0e0e0;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 15px;
    transition: all 0.3s ease;
    box-shadow: 0 2px 4px rgba(0,0,0,0.05);
    overflow: hidden;
}

.about-partner-logo img {
    max-width: 100%;
    max-height: 100%;
    width: auto;
    height: auto;
    object-fit: contain;
}

.about-partner-logo:hover {
    border-color: #2449A4;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
    transform: translateY(-3px);
}

/* Responsive Design */
@media (max-width: 768px) {
    .about-top-message-content {
        flex-direction: column;
        gap: 30px;
    }

    .about-directors-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    .about-guide-cards,
    .about-global-stats,
    .about-network-grid,
    .about-four-c-grid {
        grid-template-columns: 1fr;
        padding: 0 15px;
    }

    .about-page-title {
        font-size: 24px;
    }

    .about-section-title {
        font-size: 22px;
    }

    .about-top-message-quote {
        font-size: 20px;
        text-align: center;
    }
    .about-top-message-quote::before, .about-top-message-quote::after {
        display: none;
    }
.about-top-message-image {
  text-align: center;
}
.about-top-message-author {
  text-align: center;
}

.about-main-container {
  padding: 40px 0px;
}

    .about-partner-logo {
        flex: 0 0 140px;
        height: 80px;
    }

    .about-strategy-section {
        margin: 0;
    }

    .about-company-section {
        padding: 60px 0 !important;
    }

    .about-section-title-main {
        font-size: 1.8rem !important;
    }

    .about-company-info-table th,
    .about-company-info-table td {
        padding: 20px 16px !important;
        font-size: 0.9rem !important;
    }

    .about-company-info-table th {
        display: block;
        width: 100% !important;
        border-bottom: none !important;
    }

    .about-company-info-table td {
        display: block;
        width: 100% !important;
        border: none;
    }

    .about-company-info-table tr {
        display: block;
        margin-bottom: 20px;
        border: none;
        border-radius: 8px;
        overflow: hidden;
    }
.about-director-image img {
  object-position: top;
}

}

    @media (max-width: 480px) {
        .about-directors-grid {
            grid-template-columns: 1fr;
        }
.customer-container .service-grid {
    display: block;
}

.customer-container .service-card {
  flex-direction: column-reverse;
  flex-wrap: wrap;
  margin-bottom: 20px;
}
.customer-container .service-card li {
  padding: 6px 0 0px 20px;
}
.customer-container .service-card-image {
  margin: 0px auto 10px;
}
.customer-container .service-card-images {
  width: 100%;
}
.customer-container .other-services li {
  padding: 0px 0 0px 24px;
}

.about-slider-track-1,.about-slider-track-3 {
  animation: about-scroll-left 16s linear infinite;
}
.about-slider-track-2 {
  animation: about-scroll-right 16s linear infinite;
}
    }

