/* Contact Page */
:root {
  --primary: #003B5C;
  --primary-light: #005A8C;
  --accent: #00A6D6;
  --accent-light: #40C4E8;
  --white: #FFFFFF;
  --off-white: #F8F9FB;
  --gray-100: #F0F2F5;
  --gray-200: #E2E6EC;
  --gray-300: #C0C8D4;
  --gray-600: #6E7985;
  --gray-800: #2D3540;
  --dark: #0D1B2A;
  --radius: 20px;
  --radius-lg: 32px;
}

* { margin: 0; padding: 0; box-sizing: border-box }
html { scroll-behavior: smooth }
body { font-family: var(--font-body); color: var(--gray-800); background: var(--white); line-height: 1.6 }

/* Hero */
.contact-hero { position: relative; padding: 140px 4% 80px; text-align: center; overflow: hidden; background: linear-gradient(135deg, var(--primary) 0%, var(--primary-light) 100%) }
.contact-hero-bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center; opacity: 0; transition: opacity 1s ease-out }
.contact-hero-bg.loaded { opacity: .25 }
.contact-hero-overlay { position: absolute; inset: 0; background: linear-gradient(135deg, rgba(0,59,92,.85) 0%, rgba(0,90,140,.75) 100%) }
.contact-hero-inner { position: relative; z-index: 1; max-width: 800px; margin: 0 auto }
.contact-hero h1 { font-family: var(--font-heading); font-size: clamp(2.2rem, 4vw, 3.2rem); color: var(--white); margin-bottom: 16px }
.contact-hero p { color: rgba(255,255,255,0.85); font-size: 1.1rem }

/* Flash Messages */
.contact-flash { padding: 0 4%; margin-top: -20px; position: relative; z-index: 10 }
.contact-flash-inner { max-width: 700px; margin: 0 auto; display: flex; align-items: center; gap: 12px; padding: 16px 24px; border-radius: 12px; font-size: .95rem; font-weight: 500 }
.contact-flash-success .contact-flash-inner { background: #e8f9f0; color: #1a7a4a; border: 1px solid #b8e8cc }
.contact-flash-error .contact-flash-inner { background: #fef2f2; color: #b91c1c; border: 1px solid #fca5a5 }

/* Map Background */
.contact-map-wrapper { position: relative; width: 100%; overflow: hidden }
#contact-map { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 0; opacity: 0; pointer-events: none; transition: opacity 1.2s ease-out }
#contact-map.map-visible { opacity: .35 }

/* Content */
.contact-content { position: relative; z-index: 1; padding: 80px 4% 100px; max-width: 1200px; margin: 0 auto }
.contact-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 60px; align-items: start }

/* Form Wrapper */
.contact-form-wrapper h2 { font-family: var(--font-heading); font-size: 1.8rem; color: var(--primary); margin-bottom: 8px }
.form-subtitle { color: var(--gray-600); font-size: .95rem; margin-bottom: 32px }

.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-bottom: 20px }
.form-group { display: flex; flex-direction: column }
.form-group label { font-size: .85rem; font-weight: 600; color: var(--gray-800); margin-bottom: 6px }
.form-group .required { color: var(--accent) }

.form-group input,
.form-group textarea {
  padding: 12px 16px;
  border: 1px solid var(--gray-200);
  border-radius: 12px;
  font-family: inherit;
  font-size: .9rem;
  font-weight: 400;
  color: var(--gray-800);
  background: var(--off-white);
  outline: none;
  transition: all .3s;
  resize: vertical;
}
.form-group input:focus,
.form-group textarea:focus {
  border-color: var(--accent);
  background: var(--white);
  box-shadow: 0 0 0 3px rgba(0,166,214,.1);
}
.form-group input::placeholder,
.form-group textarea::placeholder { color: var(--gray-300) }

.contact-submit {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 12px;
  padding: 14px 36px;
  background: linear-gradient(135deg, var(--accent), var(--accent-light));
  color: var(--white);
  border: none;
  border-radius: 50px;
  font-family: inherit;
  font-size: .95rem;
  font-weight: 700;
  cursor: pointer;
  transition: all .3s;
}
.contact-submit:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0,166,214,.3) }
.contact-submit:disabled { opacity: .6; cursor: not-allowed; transform: none; box-shadow: none }

/* Info Sidebar */
.contact-info { display: flex; flex-direction: column; gap: 24px }
.info-card {
  background: var(--off-white);
  border: 1px solid var(--gray-200);
  border-radius: 16px;
  padding: 24px;
  transition: all .3s;
}
.info-card:hover { border-color: var(--accent); box-shadow: 0 8px 24px rgba(0,166,214,.08) }
.info-icon { width: 44px; height: 44px; background: linear-gradient(135deg, var(--accent), var(--accent-light)); border-radius: 12px; display: flex; align-items: center; justify-content: center; margin-bottom: 14px; color: var(--white) }
.info-card h3 { font-size: 1rem; font-weight: 700; color: var(--primary); margin-bottom: 6px }
.info-card p { font-size: .9rem; color: var(--gray-600); margin: 0 }
.info-card a { font-size: .9rem; color: var(--accent); text-decoration: none; font-weight: 500; transition: color .3s }
.info-card a:hover { color: var(--primary) }

.social-links { display: flex; gap: 12px; flex-wrap: wrap }
.social-link { font-size: .85rem; color: var(--accent); text-decoration: none; font-weight: 600; padding: 4px 12px; background: rgba(0,166,214,.08); border-radius: 20px; transition: all .3s }
.social-link:hover { background: rgba(0,166,214,.15); color: var(--primary) }

/* Responsive */
@media(max-width: 768px) {
  .contact-hero { padding: 120px 4% 60px }
  .contact-content { padding: 50px 4% 80px }
  .contact-grid { grid-template-columns: 1fr; gap: 40px }
  .form-row { grid-template-columns: 1fr }
}
