/*
 * KYMJOJOBS Contact Page (V2) Stylesheet - FULL WIDTH UPDATE
 */

:root {
    --kymjo-primary-blue: #1A237E;
    --kymjo-accent-blue: #0073aa;
    --kymjo-dark-text: #333;
    --kymjo-light-text: #6c757d;
    --kymjo-background-light: #f8f9fa;
    --kymjo-background-white: #ffffff;
    --kymjo-border-color: #dee2e6;
    --kymjo-success-green: #28a745;
    --kymjo-warning-orange: #ffc107;
    --kymjo-border-radius: 8px;
    --kymjo-box-shadow: 0 4px 15px rgba(0, 0, 0, 0.07);
}

.kymjo-contact-page-wrapper .container {
    max-width: 1140px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 15px;
    padding-right: 15px;
}

/* Hero Section - Background is now full-width */
.contact-hero-section {
    background-color: var(--kymjo-background-white);
    color: var(--kymjo-primary-blue);
    padding: 80px 0; /* Padding top/bottom, no side padding */
    text-align: center;
}

.contact-hero-title {
    font-size: 2.8rem;
    font-weight: 700;
    margin-bottom: 1rem;
}

.contact-hero-subtitle {
    font-size: 1.1rem;
    max-width: 700px;
    margin: 0 auto;
    opacity: 0.9;
}

/* Main Content Section - Background is now light grey */
.contact-main-content-section {
    background-color: var(--kymjo-background-light);
    padding: 60px 0;
}

.contact-main-content-grid {
    display: grid;
    grid-template-columns: 1fr 1.5fr;
    gap: 40px;
}

.contact-details-panel,
.contact-form-panel {
    background: var(--kymjo-background-white);
    padding: 30px;
    border-radius: var(--kymjo-border-radius);
    box-shadow: var(--kymjo-box-shadow);
    align-self: start;
}

.contact-form-panel {
    padding: 40px;
}

.panel-title {
    font-size: 1.5rem;
    font-weight: 600;
    margin-top: 0;
    margin-bottom: 25px;
    color: var(--kymjo-primary-blue);
    border-bottom: 2px solid var(--kymjo-border-color);
    padding-bottom: 10px;
}

.info-item { display: flex; align-items: center; margin-bottom: 20px; }
.info-icon svg { width: 24px; height: 24px; color: var(--kymjo-accent-blue); margin-right: 15px; }
.info-text strong { display: block; color: var(--kymjo-dark-text); font-weight: 600; }
.info-text a, .info-text span { color: var(--kymjo-light-text); text-decoration: none; transition: color 0.3s; }
.info-text a:hover { color: var(--kymjo-accent-blue); }
.social-links-block { margin-top: 40px; }
.social-links-container { display: flex; gap: 15px; }
.social-icon { display: inline-block; transition: transform 0.3s, opacity 0.3s; }
.social-icon svg { width: 28px; height: 28px; }
.social-icon:hover { transform: translateY(-3px); opacity: 0.8; }

#kymjojobs-contact-form .kymjojobs-form-group,
#kymjojobs-contact-form .kymjojobs-form-group-icon { margin-bottom: 25px; }
#kymjojobs-contact-form label { display: block; font-weight: 600; margin-bottom: 8px; color: var(--kymjo-dark-text); }
#kymjojobs-contact-form label .required { color: #e53935; }
#kymjojobs-contact-form input[type="text"],
#kymjojobs-contact-form input[type="email"],
#kymjojobs-contact-form textarea { width: 100%; padding: 12px 15px; border: 1px solid var(--kymjo-border-color); border-radius: var(--kymjo-border-radius); font-size: 1rem; transition: border-color 0.3s, box-shadow 0.3s; }
#kymjojobs-contact-form input:focus,
#kymjojobs-contact-form textarea:focus { outline: none; border-color: var(--kymjo-accent-blue); box-shadow: 0 0 0 3px rgba(0, 115, 170, 0.15); }
.kymjojobs-form-group-icon .input-with-icon { position: relative; }
.kymjojobs-form-group-icon .input-with-icon svg { position: absolute; left: 15px; top: 50%; transform: translateY(-50%); width: 20px; height: 20px; color: var(--kymjo-light-text); pointer-events: none; }
.kymjojobs-form-group-icon .input-with-icon input { padding-left: 45px; }
.kymjo-button-primary { background-color: var(--kymjo-accent-blue); color: var(--kymjo-background-white); border: none; padding: 15px 25px; font-size: 1rem; font-weight: 600; border-radius: var(--kymjo-border-radius); cursor: pointer; transition: background-color 0.3s, transform 0.2s; display: inline-flex; align-items: center; justify-content: center; }
.kymjo-button-primary:hover:not(:disabled) { background-color: var(--kymjo-primary-blue); transform: translateY(-2px); }
.kymjo-button-primary.full-width { width: 100%; }
.kymjo-button-primary:disabled { background-color: #a0a0a0; cursor: wait; }

.contact-success-message { text-align: center; padding: 40px 20px; }
.contact-success-message .success-icon { width: 70px; height: 70px; line-height: 70px; font-size: 3rem; background-color: var(--kymjo-success-green); color: white; border-radius: 50%; margin: 0 auto 20px; }
.contact-success-message h3 { font-size: 1.8rem; color: var(--kymjo-dark-text); margin-bottom: 10px; }
.form-status-notice.limit_reached { background-color: #fff3cd; color: #856404; padding: 20px; border: 1px solid #ffeeba; border-radius: var(--kymjo-border-radius); }

/* Map & FAQ Sections - Backgrounds are now full-width */
.contact-map-section,
.contact-faq-section {
    padding: 60px 0;
}
.contact-map-section { background-color: var(--kymjo-background-white); }
.contact-faq-section { background-color: var(--kymjo-background-light); }

.section-heading.centered-heading { text-align: center; font-size: 2.2rem; font-weight: 700; color: var(--kymjo-primary-blue); margin-bottom: 40px; }
.google-map-embed-wrapper { position: relative; padding-bottom: 56.25%; height: 0; overflow: hidden; border-radius: var(--kymjo-border-radius); box-shadow: var(--kymjo-box-shadow); }
.google-map-embed-wrapper iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
.faq-accordion { max-width: 800px; margin: 0 auto; }
.faq-item { background: var(--kymjo-background-white); border: 1px solid var(--kymjo-border-color); border-radius: var(--kymjo-border-radius); margin-bottom: 15px; overflow: hidden; }
.faq-question { display: flex; justify-content: space-between; align-items: center; padding: 20px; font-size: 1.1rem; font-weight: 600; cursor: pointer; user-select: none; }
.faq-icon { font-size: 1.5rem; font-weight: 300; color: var(--kymjo-accent-blue); transition: transform 0.3s ease; }
.faq-answer { max-height: 0; overflow: hidden; transition: max-height 0.4s ease-out, padding 0.4s ease-out; }
.faq-answer p { padding: 0 20px 20px; margin: 0; line-height: 1.6; color: var(--kymjo-light-text); }
.faq-item.active .faq-question { color: var(--kymjo-primary-blue); }
.faq-item.active .faq-icon { transform: rotate(45deg); }
.faq-item.active .faq-answer { max-height: 300px; }

@media (max-width: 992px) {
    .contact-main-content-grid { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
    .contact-hero-title { font-size: 2.2rem; }
    .contact-form-panel { padding: 25px; }
    .section-heading.centered-heading { font-size: 1.8rem; }
}