/* Contact Page Styles */
.contact-main-section { padding: 80px 20px; }
.contact-grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: 60px; }
.contact-intro { color: var(--text-secondary); line-height: 1.8; margin-bottom: 40px; }
.contact-cards { display: flex; flex-direction: column; gap: 20px; margin-bottom: 40px; }
.contact-info-card { background: var(--bg-card); padding: 25px; border-radius: 15px; border: 1px solid rgba(0, 212, 255, 0.2); display: flex; gap: 20px; transition: var(--transition); }
.contact-info-card:hover { border-color: var(--primary-color); transform: translateX(10px); box-shadow: 0 10px 40px rgba(0, 212, 255, 0.3); }
.contact-icon { width: 60px; height: 60px; background: rgba(0, 212, 255, 0.1); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 24px; color: var(--primary-color); flex-shrink: 0; }
.contact-details h3 { font-size: 18px; margin-bottom: 8px; }
.contact-details a { color: var(--primary-color); text-decoration: none; transition: var(--transition); }
.contact-details a:hover { color: var(--secondary-color); }
.contact-details p { color: var(--text-secondary); font-size: 14px; }
.social-connect h3 { font-size: 20px; margin-bottom: 20px; }
.social-icons-large { display: flex; gap: 15px; }
.social-large { display: flex; flex-direction: column; align-items: center; gap: 10px; padding: 20px; background: var(--bg-card); border: 1px solid rgba(0, 212, 255, 0.2); border-radius: 15px; text-decoration: none; color: var(--primary-color); transition: var(--transition); flex: 1; }
.social-large:hover { border-color: var(--primary-color); transform: translateY(-5px); box-shadow: 0 10px 30px rgba(0, 212, 255, 0.3); }
.social-large i { font-size: 32px; }
.social-large span { font-size: 14px; }
.form-card-3d { background: var(--bg-card); padding: 40px; border-radius: 20px; border: 1px solid rgba(0, 212, 255, 0.2); }
.form-card-3d h3 { font-size: 28px; margin-bottom: 30px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.form-group { margin-bottom: 25px; }
.form-group label { display: flex; align-items: center; gap: 8px; color: var(--text-secondary); margin-bottom: 10px; font-size: 14px; }
.form-group input, .form-group textarea { width: 100%; padding: 15px; background: rgba(0, 212, 255, 0.05); border: 2px solid rgba(0, 212, 255, 0.2); border-radius: 10px; color: var(--text-primary); font-size: 16px; font-family: inherit; transition: var(--transition); }
.form-group input:focus, .form-group textarea:focus { outline: none; border-color: var(--primary-color); box-shadow: 0 0 0 3px rgba(0, 212, 255, 0.1); }
.form-group textarea { resize: vertical; min-height: 120px; }
.btn-full { width: 100%; justify-content: center; }
.form-success { display: none; text-align: center; padding: 40px; }
.form-success i { font-size: 60px; color: var(--primary-color); margin-bottom: 20px; display: block; }
.form-success h4 { font-size: 24px; margin-bottom: 10px; }
.form-success p { color: var(--text-secondary); }
.availability-section { padding: 80px 20px; background: linear-gradient(135deg, rgba(0, 212, 255, 0.1), rgba(0, 153, 255, 0.1)); }
.availability-card { background: var(--bg-card); padding: 50px; border-radius: 20px; border: 1px solid rgba(0, 212, 255, 0.2); display: flex; gap: 40px; align-items: center; }
.availability-icon { font-size: 80px; color: var(--primary-color); }
.availability-content h2 { font-size: 32px; margin-bottom: 15px; }
.availability-content p { color: var(--text-secondary); margin-bottom: 20px; line-height: 1.8; }
.availability-tags { display: flex; flex-wrap: wrap; gap: 15px; }
.availability-tags span { background: rgba(0, 212, 255, 0.1); color: var(--primary-color); padding: 10px 20px; border-radius: 25px; font-size: 14px; border: 1px solid rgba(0, 212, 255, 0.3); display: flex; align-items: center; gap: 8px; }
.faq-section { padding: 80px 20px; }
.faq-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 30px; }
.faq-item { background: var(--bg-card); padding: 30px; border-radius: 15px; border: 1px solid rgba(0, 212, 255, 0.2); transition: var(--transition); }
.faq-item:hover { border-color: var(--primary-color); transform: translateY(-5px); box-shadow: 0 10px 30px rgba(0, 212, 255, 0.2); }
.faq-question { display: flex; align-items: center; gap: 15px; margin-bottom: 15px; }
.faq-question i { font-size: 24px; color: var(--primary-color); }
.faq-question h3 { font-size: 18px; }
.faq-item p { color: var(--text-secondary); line-height: 1.7; }
@media (max-width: 968px) { .contact-grid { grid-template-columns: 1fr; } .form-row { grid-template-columns: 1fr; } .availability-card { flex-direction: column; text-align: center; } .social-icons-large { flex-direction: column; } }
