/* ============================================================
   CONTACT v2 — Finovate-style layout, APTR brand (navy/amber)
   Loads AFTER styles.css.
   ============================================================ */

/* ---- centered hero ---- */
.lc-hero { position: relative; overflow: hidden; background: var(--paper); padding: clamp(52px,7vw,100px) 0 clamp(36px,4vw,56px); text-align: center; }
.lc-hero .lc-glow { position: absolute; border-radius: 50%; filter: blur(72px); pointer-events: none; }
.lc-hero .lc-glow.g1 { top: -120px; left: 8%; width: 280px; height: 280px; background: var(--blue); opacity: .12; }
.lc-hero .lc-glow.g2 { top: -90px; right: 6%; width: 240px; height: 240px; background: var(--amber); opacity: .14; }
.lc-pill { display: inline-flex; align-items: center; gap: 8px; font-size: 11.5px; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--blue); background: #fff; border: 1px solid var(--line); border-radius: 100px; padding: 8px 18px; box-shadow: var(--shadow-sm); }
.lc-pill::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--amber); }
.lc-hero h1 { margin-top: 22px; font-size: clamp(40px,6vw,74px); line-height: 1.04; letter-spacing: -0.03em; color: var(--navy); }
.lc-hero h1 .accent { color: var(--blue); }
.lc-hero p { margin: 18px auto 0; max-width: 42ch; color: var(--ink-soft); font-size: clamp(16px,1.5vw,19px); }

/* ---- info row ---- */
.lc-info { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; margin-top: clamp(32px,4vw,52px); }
.lc-info-item { display: flex; align-items: center; gap: 16px; justify-content: center; }
.lc-info-item .ii-ic { width: 56px; height: 56px; border-radius: 50%; background: var(--navy); color: var(--amber); display: grid; place-items: center; flex: none; }
.lc-info-item .ii-ic svg { width: 23px; height: 23px; }
.lc-info-item .ii-l { font-size: 13px; font-weight: 700; color: var(--muted); }
.lc-info-item .ii-v { font-family: var(--ff-display); font-weight: 600; font-size: 16px; color: var(--navy); margin-top: 3px; letter-spacing: -0.01em; }

/* ---- get in touch card ---- */
.gt-card { display: grid; grid-template-columns: 1fr 1fr; border-radius: var(--radius-xl); overflow: hidden; box-shadow: var(--shadow-md); border: 1px solid var(--line); background: #fff; }
.gt-form { background: var(--paper); padding: clamp(30px,3.5vw,52px); position: relative; }
.gt-form h2 { font-size: clamp(28px,3vw,40px); margin-top: 16px; color: var(--navy); }
.gt-form .gt-sub { margin-top: 12px; color: var(--ink-soft); font-size: 15.5px; max-width: 40ch; }
.gt-form .site-form { margin-top: 26px; }
.gt-media { position: relative; min-height: 440px; }
.gt-media image-slot { width: 100%; height: 100%; display: block; }
.gt-callout { position: absolute; left: 18px; right: 18px; bottom: 18px; background: #fff; border-radius: 22px; box-shadow: var(--shadow-lg); display: flex; align-items: center; gap: 14px; padding: 15px 22px; }
.gt-callout .gc-ic { width: 42px; height: 42px; border-radius: 50%; background: var(--amber); color: var(--navy); display: grid; place-items: center; flex: none; }
.gt-callout .gc-ic svg { width: 19px; height: 19px; }
.gt-callout p { font-size: 13.5px; color: var(--ink); line-height: 1.45; }
.gt-callout a { color: var(--blue); font-weight: 700; }

/* ---- office locations ---- */
.loc-head h2 { font-size: clamp(28px,3.4vw,44px); color: var(--navy); }
.loc-head p { margin-top: 12px; color: var(--ink-soft); font-size: 16px; max-width: 52ch; }
.loc-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; margin-top: clamp(28px,3vw,40px); }
.loc { background: #fff; border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 26px 26px 22px; display: flex; flex-direction: column; min-height: 246px; transition: transform .35s var(--ease), box-shadow .35s var(--ease); }
.loc:hover { transform: translateY(-5px); box-shadow: var(--shadow-md); }
.loc .loc-pill { align-self: flex-start; font-size: 10.5px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--muted); border: 1px solid var(--line); border-radius: 100px; padding: 5px 13px; }
.loc h3 { font-size: 22px; color: var(--navy); margin-top: 18px; }
.loc .loc-addr { margin-top: 12px; color: var(--ink-soft); font-size: 14.5px; line-height: 1.5; }
.loc .loc-phone { display: flex; align-items: center; gap: 9px; margin-top: 14px; font-size: 14px; font-weight: 600; color: var(--navy); }
.loc .loc-phone svg { width: 16px; height: 16px; color: var(--blue); flex: none; }
.loc .loc-link { margin-top: auto; display: inline-flex; align-items: center; justify-content: space-between; gap: 10px; font-size: 13.5px; font-weight: 700; color: var(--navy); border-top: 1px solid var(--line); padding-top: 18px; margin-top: 20px; }
.loc .loc-link .ll-arr { width: 32px; height: 32px; border-radius: 50%; background: var(--amber); color: var(--navy); display: grid; place-items: center; transition: transform .3s var(--ease); flex: none; }
.loc .loc-link .ll-arr svg { width: 15px; height: 15px; }
.loc:hover .loc-link .ll-arr { transform: rotate(-45deg); }
.loc.hq { position: relative; overflow: hidden; background: linear-gradient(155deg, var(--navy), #001b4a); border-color: transparent; color: #fff; }
.loc.hq .loc-pill { color: #fff; border-color: rgba(255,255,255,0.3); }
.loc.hq h3 { color: #fff; }
.loc.hq .loc-addr { color: rgba(255,255,255,0.78); }
.loc.hq .loc-phone { color: #fff; }
.loc.hq .loc-phone svg { color: var(--amber); }
.loc.hq .loc-link { color: #fff; border-top-color: rgba(255,255,255,0.16); position: relative; z-index: 2; }
.loc.hq .hq-swoosh { position: absolute; right: -30px; bottom: 20px; width: 200px; height: 200px; color: var(--amber); opacity: .9; pointer-events: none; }
.loc.hq .hq-swoosh path { fill: none; stroke: currentColor; stroke-width: 34; stroke-linecap: round; }

/* ---- consultation row ---- */
.cons-row { display: grid; grid-template-columns: 1.12fr 0.88fr; gap: 18px; }
.cons-media image-slot { width: 100%; height: 100%; min-height: 360px; display: block; box-shadow: var(--shadow-md); }
.cons-card { position: relative; overflow: hidden; background: var(--amber); color: var(--navy); border-radius: var(--radius-xl); padding: clamp(32px,4vw,52px); display: flex; flex-direction: column; }
.cons-card .cc-aster { position: absolute; top: 22px; right: 30px; color: var(--navy); opacity: .55; }
.cons-card .cc-aster svg { width: 30px; height: 30px; }
.cons-card .lc-pill { align-self: flex-start; background: rgba(0,39,106,0.1); border-color: transparent; color: var(--navy); box-shadow: none; }
.cons-card .lc-pill::before { background: var(--navy); }
.cons-card h3 { font-size: clamp(26px,2.6vw,36px); color: var(--navy); margin-top: 20px; max-width: 18ch; line-height: 1.12; }
.cons-card .btn { margin-top: auto; align-self: flex-start; }

/* ---- responsive ---- */
@media (max-width: 1000px) {
  .lc-info { grid-template-columns: 1fr; gap: 16px; max-width: 440px; margin-left: auto; margin-right: auto; }
  .lc-info-item { justify-content: flex-start; }
  .gt-card { grid-template-columns: 1fr; }
  .gt-media { min-height: 320px; order: -1; }
  .loc-grid { grid-template-columns: repeat(2,1fr); }
  .cons-row { grid-template-columns: 1fr; }
  .cons-media image-slot { min-height: 280px; }
  .cons-card h3 { max-width: none; }
}
@media (max-width: 560px) {
  .loc-grid { grid-template-columns: 1fr; }
  .gt-form .form-row { grid-template-columns: 1fr; }
}
