/* ==========================================================================
   1. GLOBAL PAGE STYLES (Fixes Horizontal Scroll)
   ========================================================================== */
html, body {
    overflow-x: hidden;
    width: 100%;
}

main {
    overflow: hidden;
    width: 100%;
}

.page-hero {
    padding: 80px 0 40px;
    text-align: center;
    background: radial-gradient(circle at top, rgba(79, 70, 229, 0.05), transparent);
}

.page-hero h1 {
    font-size: 52px;
    font-weight: 800;
    max-width: 800px;
    margin: 20px auto;
    letter-spacing: -2px;
}

.page-hero p {
    font-size: 18px;
    color: var(--gray);
    max-width: 650px;
    margin: 0 auto;
}

/* ==========================================================================
   2. VALUES SECTION
   ========================================================================== */
.values-section { padding-bottom: 80px; }
.values-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
    margin-top: 50px;
}

.value-card {
    background: #fff;
    padding: 40px;
    border-radius: 24px;
    border: 1px solid var(--border);
    transition: var(--transition);
}

.value-card:hover { transform: translateY(-10px); box-shadow: 0 20px 40px rgba(0,0,0,0.05); }
.value-card i { font-size: 40px; color: var(--primary-indigo); margin-bottom: 20px; display: block; }
.value-card h3 { margin-bottom: 15px; font-weight: 800; }

/* ==========================================================================
   3. CONTACT PAGE SPECIFICS
   ========================================================================== */
.contact-page { padding: 80px 0; }
.contact-grid {
    display: grid;
    grid-template-columns: 1fr 1.2fr;
    gap: 80px;
    align-items: center;
}

.contact-info-panel h2 { font-size: 48px; font-weight: 800; margin: 20px 0; }
.direct-contact { margin-top: 40px; display: flex; flex-direction: column; gap: 30px; }

/* Fixed Icon/Contact Alignment */
.c-item { 
    display: flex; 
    align-items: center; 
    gap: 20px; 
    text-align: left;
}

.c-item i { 
    flex-shrink: 0; /* Prevents icon box from squishing */
    font-size: 24px; 
    color: var(--primary-green); 
    background: #ebfbf5; /* Soft green from your image */
    padding: 18px; 
    border-radius: 16px; 
}

.c-item span { 
    display: block; 
    font-size: 13px; 
    color: var(--gray); 
    font-weight: 700; 
    text-transform: uppercase; 
    margin-bottom: 4px;
}

.c-item strong { 
    font-size: 18px; 
    color: var(--dark); 
    word-break: break-all; /* CRITICAL: Prevents email from breaking layout */
}

/* ==========================================================================
   4. GLASS FORM (Optimized for Mobile)
   ========================================================================== */
.glass-form {
    background: #fff;
    padding: 40px;
    border-radius: 30px;
    border: 1px solid var(--border);
    box-shadow: 0 40px 100px rgba(15, 23, 42, 0.06);
}

.f-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.f-group { margin-bottom: 25px; display: flex; flex-direction: column; gap: 8px; }
.f-group label { font-size: 14px; font-weight: 700; }
.f-group input, .f-group textarea {
    padding: 15px;
    border-radius: 12px;
    border: 2px solid var(--border);
    outline: none;
    font-size: 15px;
    transition: 0.3s;
    width: 100%; /* Ensure full width inside container */
}

.f-group input:focus, .f-group textarea:focus { border-color: var(--primary-indigo); background: #f8fafc; }

/* ==========================================================================
   5. RESPONSIVE MEDIA QUERIES
   ========================================================================== */

/* Tablets & Large Phones (Under 1024px) */
@media (max-width: 1024px) {
    .contact-grid { grid-template-columns: 1fr; gap: 60px; text-align: center; }
    .values-grid { grid-template-columns: 1fr; }
    .c-item { justify-content: center; } /* Centers contact info for tablets */
    .page-hero h1 { font-size: 42px; }
    .contact-info-panel h2 { font-size: 40px; }
}

/* Mobile Screens (Under 768px) */
@media (max-width: 767px) {
    .page-hero { padding: 60px 0 30px; }
    .page-hero h1 { font-size: 34px; }
    
    .contact-page { padding: 40px 0; }
    .contact-info-panel h2 { font-size: 32px; }
    
    /* Reduce padding so form doesn't push off screen */
    .glass-form { padding: 25px; } 
    
    .f-row { grid-template-columns: 1fr; gap: 0; } /* Inputs stack on mobile */
    
    .c-item { 
        flex-direction: row; 
        text-align: left; 
        align-items: center; 
        justify-content: flex-start; /* Keep left aligned for easier reading */
    }

    .c-item i { padding: 14px; font-size: 20px; }
    .c-item strong { font-size: 16px; }
}

/* Very Small Mobile (Under 480px) */
@media (max-width: 480px) {
    .container { padding: 0 20px; }
    .page-hero h1 { font-size: 28px; }
    .contact-info-panel h2 { font-size: 28px; }
    .c-item { gap: 15px; }
}