/* contact.css — Large, site-matching Contact page */

/* Use site theme variables where available */
:root {
  --accent-1: #00bcd4;
  --accent-2: #0097a7;
  --muted: #cfeff6;
  --card-radius: 16px;
  --text: #082f30;
  --max-width: 1200px;
}

/* Reset basics */
* { box-sizing: border-box; }
body { margin:0; font-family: "Poppins", system-ui, sans-serif; color:var(--text); background: linear-gradient(180deg,#f8fdff,#ffffff); }

/* Container */
.container { max-width: var(--max-width); margin: 0 auto; padding: 0 20px; }

/* HERO (big) */
.contact-hero {
  background: linear-gradient(180deg,#001f2e,#002f4b);
  color: #fff;
  padding: 80px 0 48px;
}
.hero-inner { display:flex; gap:32px; align-items:center; justify-content:space-between; }
.hero-left { flex:1 1 65%; }
.hero-right { flex:1 1 30%; display:flex; justify-content:flex-end; }
.hero-title { font-size:3rem; margin:0 0 12px; letter-spacing:0.3px; font-weight:800; }
.hero-sub { margin:0 0 18px; font-size:1.05rem; opacity:0.92; }
.hero-cta .btn-primary, .hero-cta .btn-ghost { margin-right:12px; }

/* big stat box on right */
.contact-stats { display:flex; gap:14px; justify-content:flex-end; align-items:center; }
.stat { background: linear-gradient(180deg,#022d35,#003a47); color:#fff; padding:18px 22px; border-radius:12px; text-align:center; box-shadow:0 10px 30px rgba(0,0,0,0.2); }
.stat .num { font-size:1.6rem; font-weight:800; }
.stat .label { font-size:0.85rem; opacity:0.85; }

/* PAGE GRID */
.page-grid { display:grid; grid-template-columns: 1fr 420px; gap:32px; padding: 36px 0 80px; align-items:start; }

/* OFFICES GRID (left) */
.offices-section .section-head { font-size:1.6rem; margin:0 0 6px; color:var(--accent-1); font-weight:800; }
.offices-section .section-sub { color:#16504f; margin:0 0 18px; }

.offices-grid { display:grid; grid-template-columns: repeat(2, 1fr); gap:18px; }
.office-card {
  background: #fff; border-left:6px solid var(--accent-1); border-radius:12px; padding:18px;
  box-shadow: 0 14px 40px rgba(2,40,46,0.06); transition: transform .18s, box-shadow .18s;
}
.office-card:hover { transform: translateY(-6px); box-shadow:0 20px 50px rgba(2,40,46,0.09); }
.office-card h3 { margin:0 0 8px; color:#006b6d; font-size:1.05rem; }
.office-card p { margin:6px 0; color:#163839; font-size:0.98rem; line-height:1.5; }
.phone-row { margin-top:8px; }
.phone-row a { text-decoration:none; color:#007471; font-weight:800; margin-right:10px; }
.copy-tel-btn { margin-left:8px; padding:6px 8px; border-radius:8px; background:#eefaf9; border:0; cursor:pointer; font-weight:700; color:#004d4f; }

/* CONTACT ASIDE (right) - sticky and roomy */
.contact-aside { position:relative; }
.contact-card.large-card { position: sticky; top:110px; padding:20px; border-radius:12px; background:#fff; box-shadow:0 16px 46px rgba(0,0,0,0.07); }
.section-head.small { font-size:1.2rem; margin-bottom:6px; color:var(--accent-1); }
.lede { margin:0 0 14px; color:#164f4f; font-size:0.98rem; }

/* FORM LAYOUT */
.contact-form .form-grid { display:grid; grid-template-columns: 1fr 1fr; gap:12px; }
.contact-form .form-row.full { grid-column: 1 / -1; }
.contact-form label { display:block; font-weight:700; color:#064648; margin-bottom:8px; }
.contact-form input, .contact-form textarea {
  width:100%; padding:12px 14px; border-radius:10px; border:1px solid #e6eef0; font-size:0.96rem; color:#072a2a;
}
.contact-form input:focus, .contact-form textarea:focus { outline:none; box-shadow:0 12px 32px rgba(0,188,212,0.08); border-color:var(--accent-1); }
.req { color:#e74c3c; margin-left:6px; }
.error { color:#c62828; font-size:0.85rem; min-height:18px; margin-top:6px; }

/* Form actions */
.form-actions { text-align:right; margin-top:12px; }
.btn-primary.wide { display:inline-block; padding:12px 18px; border-radius:10px; background: linear-gradient(90deg,var(--accent-1),var(--accent-2)); color:#001; font-weight:800; border:0; cursor:pointer; }
.wa-link { display:inline-block; margin-top:12px; color:var(--accent-1); font-weight:800; text-decoration:none; }

/* POPUP */
.popup-backdrop { position:fixed; inset:0; display:none; align-items:center; justify-content:center; background:rgba(0,0,0,0.6); z-index:13000; padding:18px; }
.popup-backdrop[aria-hidden="false"] { display:flex; }
.popup-card { background:#fff; padding:20px; border-radius:12px; width:100%; max-width:520px; text-align:center; box-shadow:0 20px 60px rgba(0,0,0,0.25); }
.btn-muted { padding:8px 12px; border-radius:8px; border:0; background:#f0f6f6; cursor:pointer; }

/* RESPONSIVE */
@media (max-width:1100px) {
  .hero-title { font-size:2.4rem; }
  .page-grid { grid-template-columns: 1fr 380px; gap:24px; }
  .offices-grid { grid-template-columns:1fr 1fr; }
}
@media (max-width:880px) {
  .hero-inner { flex-direction:column; gap:20px; align-items:flex-start; padding:0 10px; }
  .page-grid { grid-template-columns:1fr; padding:24px 0; }
  .offices-grid { grid-template-columns:1fr; }
  .contact-card.large-card { position: static; top:auto; }
  .contact-form .form-grid { grid-template-columns:1fr; }
}

/* Accessibility focus */
a:focus, button:focus, input:focus, textarea:focus { outline: 3px solid rgba(0,188,212,0.16); outline-offset:3px; }
