/* ── Contact page — scoped under cnt- prefix ── */
:root {
  --cnt-navy: #082a46;
  --cnt-ink: #0a2540;
  --cnt-blue: #24a9df;
  --cnt-blue-dark: #12629b;
  --cnt-muted: #6b7c93;
  --cnt-soft: #f6f9fc;
  --cnt-line: #e6edf5;
  --cnt-shadow: 0 28px 80px rgba(8,42,70,.14);
  --cnt-shadow-soft: 0 14px 40px rgba(8,42,70,.07);
}

.cnt-container { width: min(1180px, calc(100% - 40px)); margin: 0 auto }

/* ── Kicker ── */
.cnt-kicker { display: inline-flex; align-items: center; gap: 10px; color: var(--cnt-blue-dark); font-size: 13px; letter-spacing: .08em; text-transform: uppercase; font-weight: 900; margin-bottom: 18px }
.cnt-kicker i { width: 9px; height: 9px; border-radius: 99px; background: var(--cnt-blue); box-shadow: 0 0 0 6px rgba(36,169,223,.12); display: inline-block; flex-shrink: 0 }

/* ── Buttons ── */
.cnt-btn { display: inline-flex; align-items: center; justify-content: center; border: 0; border-radius: 999px; min-height: 52px; padding: 0 28px; font-weight: 900; cursor: pointer; transition: .18s ease; white-space: nowrap; font-size: 15px; text-decoration: none }
.cnt-btn-primary { background: var(--cnt-blue); color: #fff; box-shadow: 0 16px 36px rgba(36,169,223,.28) }
.cnt-btn-primary:hover { transform: translateY(-1px); box-shadow: 0 22px 44px rgba(36,169,223,.34); color: #fff }
.cnt-btn-secondary { border: 1px solid #dce6f1; background: #fff; color: #24384f; box-shadow: 0 12px 30px rgba(8,42,70,.06) }
.cnt-btn-secondary:hover { transform: translateY(-1px); color: #24384f }

/* ── Hero ── */
.cnt-hero { position: relative; overflow: hidden; background: radial-gradient(circle at 20% 8%, rgba(36,169,223,.12), transparent 30%), radial-gradient(circle at 90% 12%, rgba(8,42,70,.08), transparent 24%), linear-gradient(180deg,#fff 0%,#f8fbff 100%); padding: 82px 0 106px }
.cnt-hero::after { content: ""; position: absolute; left: 0; right: 0; bottom: -1px; height: 82px; background: #fff; clip-path: polygon(0 50%,100% 0,100% 100%,0 100%) }
.cnt-hero-inner { position: relative; z-index: 2; text-align: center; max-width: 920px; margin: 0 auto }
.cnt-h1 { margin: 0; color: var(--cnt-ink); font-size: clamp(40px,5vw,68px); line-height: 1.02; letter-spacing: -.05em; font-weight: 900 }
.cnt-lead { margin: 24px auto 0; color: #4f6177; font-size: 20px; line-height: 1.68; max-width: 760px }
.cnt-btn-row { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 32px; justify-content: center }

/* ── Hero map grid ── */
.cnt-hero-map { position: relative; z-index: 2; margin-top: 46px; background: rgba(255,255,255,.92); border: 1px solid rgba(226,236,246,.96); border-radius: 34px; box-shadow: var(--cnt-shadow); padding: 28px; overflow: hidden }
.cnt-hero-map::before { content: ""; position: absolute; inset: 0; background-image: linear-gradient(rgba(36,169,223,.07) 1px,transparent 1px), linear-gradient(90deg,rgba(36,169,223,.07) 1px,transparent 1px); background-size: 42px 42px }
.cnt-map-grid { position: relative; z-index: 2; display: grid; grid-template-columns: repeat(4,1fr); gap: 16px }
.cnt-map-point { background: #fff; border: 1px solid var(--cnt-line); border-radius: 24px; padding: 22px; text-align: left; box-shadow: 0 14px 34px rgba(8,42,70,.07) }
.cnt-map-point small { display: inline-flex; color: var(--cnt-blue-dark); font-size: 12px; font-weight: 900; letter-spacing: .06em; text-transform: uppercase; margin-bottom: 12px }
.cnt-map-point strong { display: block; font-size: 20px; letter-spacing: -.04em; margin-bottom: 8px }
.cnt-map-point span { display: block; color: var(--cnt-muted); font-size: 14px; line-height: 1.5 }

/* ── Section ── */
.cnt-section { padding: 76px 0; background: #fff }
.cnt-section-soft { background: var(--cnt-soft) }
.cnt-section-head { text-align: center; max-width: 780px; margin: 0 auto 38px }
.cnt-section-head span { font-size: 13px; font-weight: 900; letter-spacing: .08em; text-transform: uppercase; color: var(--cnt-blue-dark) }
.cnt-section-head h2 { margin: 12px 0 0; font-size: 38px; letter-spacing: -.05em; color: var(--cnt-ink); line-height: 1.14 }
.cnt-section-head p { margin: 16px auto 0; color: var(--cnt-muted); line-height: 1.65; max-width: 700px }

/* ── Office grid ── */
.cnt-office-grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: 22px; align-items: stretch }
.cnt-office-featured, .cnt-office-card { background: #fff; border: 1px solid var(--cnt-line); border-radius: 30px; box-shadow: var(--cnt-shadow-soft); padding: 30px; transition: .18s ease }
.cnt-office-featured:hover, .cnt-office-card:hover { transform: translateY(-3px); box-shadow: var(--cnt-shadow) }
.cnt-office-featured { min-height: 100%; background: radial-gradient(circle at 12% 10%,rgba(36,169,223,.12),transparent 30%), linear-gradient(180deg,#fff,#fbfdff) }
.cnt-office-stack { display: grid; gap: 22px }
.cnt-office-badge { display: inline-flex; align-items: center; min-height: 30px; padding: 0 13px; border-radius: 999px; background: #ecf8fd; color: var(--cnt-blue-dark); font-size: 12px; font-weight: 900; letter-spacing: .06em; text-transform: uppercase; margin-bottom: 18px }
.cnt-office-featured h3, .cnt-office-card h3 { margin: 0 0 10px; font-size: 28px; letter-spacing: -.05em; line-height: 1.1; color: var(--cnt-ink) }
.cnt-office-card h3 { font-size: 23px }
.cnt-office-featured p, .cnt-office-card p { margin: 0; color: var(--cnt-muted); line-height: 1.65; font-size: 15px }

/* ── Address rows ── */
.cnt-address { margin-top: 24px; display: grid; gap: 12px }
.cnt-address-row { display: grid; grid-template-columns: 34px 1fr; gap: 12px; align-items: start; color: #344963; font-size: 15px; line-height: 1.55 }
.cnt-address-row i { width: 34px; height: 34px; border-radius: 12px; background: #f0f8fd; color: var(--cnt-blue-dark); display: flex; align-items: center; justify-content: center; font-style: normal; font-weight: 900 }
.cnt-address-row a { color: #344963; text-decoration: none }
.cnt-address-row a:hover { color: var(--cnt-blue) }

/* ── Office action links ── */
.cnt-office-actions { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 26px }
.cnt-mini-link { display: inline-flex; align-items: center; justify-content: center; min-height: 44px; padding: 0 18px; border-radius: 999px; border: 1px solid #dce6f1; background: #fff; color: #24384f; font-size: 13px; font-weight: 900; text-decoration: none; transition: .15s ease }
.cnt-mini-link:hover { border-color: #b5cfe4; color: #12629b }
.cnt-mini-link-primary { background: var(--cnt-blue); color: #fff; border-color: var(--cnt-blue) }
.cnt-mini-link-primary:hover { background: #1a97cc; color: #fff; border-color: #1a97cc }

/* ── Contact wrap (2-col) ── */
.cnt-contact-wrap { display: grid; grid-template-columns: .92fr 1.08fr; gap: 26px; align-items: start }

/* ── Aside note ── */
.cnt-aside { background: #082a46; color: #fff; border-radius: 34px; padding: 34px; position: sticky; top: 110px; overflow: hidden; box-shadow: var(--cnt-shadow) }
.cnt-aside::before { content: ""; position: absolute; inset: 0; background-image: url('/assets/img/cubes-pattern.svg'); background-size: 420px; opacity: .13 }
.cnt-aside > * { position: relative; z-index: 2 }
.cnt-aside-eyebrow { color: #aee5fb; font-size: 13px; font-weight: 900; letter-spacing: .08em; text-transform: uppercase }
.cnt-aside h2 { margin: 12px 0 14px; color: #fff; font-size: 36px; line-height: 1.12; letter-spacing: -.05em }
.cnt-aside p { margin: 0; color: rgba(255,255,255,.74); line-height: 1.7; font-size: 15px }
.cnt-note-list { display: grid; gap: 12px; margin-top: 26px }
.cnt-note-item { border: 1px solid rgba(255,255,255,.14); background: rgba(255,255,255,.06); border-radius: 18px; padding: 16px; color: rgba(255,255,255,.82); line-height: 1.55; font-size: 14px }
.cnt-note-item strong { display: block; color: #fff; margin-bottom: 5px }

/* ── Form card ── */
.cnt-form-card { background: #fff; border: 1px solid var(--cnt-line); border-radius: 34px; box-shadow: var(--cnt-shadow-soft); padding: 30px }
.cnt-form-head { display: flex; justify-content: space-between; gap: 18px; align-items: flex-start; margin-bottom: 24px }
.cnt-form-head h3 { margin: 0; font-size: 28px; letter-spacing: -.05em; color: var(--cnt-ink) }
.cnt-form-head p { margin: 8px 0 0; color: var(--cnt-muted); line-height: 1.55; font-size: 15px }
.cnt-form-badge { display: inline-flex; align-items: center; min-height: 30px; padding: 0 13px; border-radius: 999px; background: #ecf8fd; color: var(--cnt-blue-dark); font-size: 12px; font-weight: 900; white-space: nowrap }

/* ── Form grid / fields ── */
.cnt-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px }
.cnt-field { display: grid; gap: 7px; margin-bottom: 14px }
.cnt-field label { font-size: 13px; font-weight: 900; color: #24384f }
.cnt-field input, .cnt-field select, .cnt-field textarea { width: 100%; border: 1px solid #dce6f1; background: #fbfdff; border-radius: 16px; min-height: 52px; padding: 0 15px; color: var(--cnt-ink); outline: none; transition: .16s; font-size: 15px; font-family: inherit }
.cnt-field textarea { min-height: 142px; resize: vertical; padding-top: 14px; line-height: 1.55 }
.cnt-field input:focus, .cnt-field select:focus, .cnt-field textarea:focus { border-color: rgba(36,169,223,.75); box-shadow: 0 0 0 4px rgba(36,169,223,.12); background: #fff }
.cnt-phone-row { display: grid; grid-template-columns: 135px 1fr; gap: 10px }
.cnt-field-error { font-size: 12px; color: #e53e3e; margin-top: 4px }

/* ── Checkbox ── */
.cnt-check { display: flex; gap: 10px; align-items: flex-start; color: #53657a; font-size: 13px; line-height: 1.45; margin: 8px 0 18px }
.cnt-check input { margin-top: 2px; flex-shrink: 0 }
.cnt-check a { color: var(--cnt-blue-dark); text-decoration: underline }

/* ── Form actions ── */
.cnt-form-actions { display: flex; align-items: center; justify-content: space-between; gap: 14px; margin-top: 8px }
.cnt-form-actions p { margin: 0; color: var(--cnt-muted); font-size: 13px; line-height: 1.45 }
.cnt-form-submit { min-width: 240px }

/* ── Honeypot ── */
.cnt-hp { position: absolute; left: -9999px; opacity: 0; pointer-events: none; height: 0; overflow: hidden }

/* ── Toast / feedback ── */
.cnt-feedback { display: flex; align-items: flex-start; gap: 12px; border-radius: 18px; padding: 16px 20px; font-size: 14px; line-height: 1.55; margin-bottom: 24px }
.cnt-feedback-success { background: #ecfdf5; border: 1px solid #6ee7b7; color: #065f46 }
.cnt-feedback-error { background: #fef2f2; border: 1px solid #fca5a5; color: #991b1b }
.cnt-feedback-icon { font-size: 20px; flex-shrink: 0 }

/* ── Trust grid ── */
.cnt-trust-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 18px }
.cnt-trust-card { background: #fff; border: 1px solid var(--cnt-line); border-radius: 24px; padding: 24px; box-shadow: 0 14px 40px rgba(8,42,70,.06) }
.cnt-trust-card strong { display: block; font-size: 28px; letter-spacing: -.05em; color: var(--cnt-blue-dark); line-height: 1; margin-bottom: 7px }
.cnt-trust-card p { margin: 0; color: var(--cnt-muted); line-height: 1.55; font-size: 14px; font-weight: 700 }

/* ── Process ── */
.cnt-process { display: grid; grid-template-columns: repeat(4,1fr); gap: 18px }
.cnt-process-item { border: 1px solid var(--cnt-line); border-radius: 26px; padding: 28px; background: #fff; position: relative; overflow: hidden; box-shadow: 0 10px 28px rgba(8,42,70,.045) }
.cnt-process-item::before { content: attr(data-step); position: absolute; right: 22px; top: 18px; font-size: 52px; font-weight: 900; color: #eff5fb; letter-spacing: -.08em; pointer-events: none }
.cnt-process-item strong { display: block; font-size: 20px; margin-bottom: 9px; position: relative; color: var(--cnt-ink) }
.cnt-process-item p { margin: 0; color: var(--cnt-muted); line-height: 1.6; position: relative; font-size: 14px }

/* ── Footer CTA ── */
.cnt-footer-cta { position: relative; overflow: hidden; background: #082a46; color: #fff; padding: 90px 0 120px }
.cnt-footer-cta::before { content: ""; position: absolute; inset: 0; background-image: url('/assets/img/cubes-pattern.svg'); background-size: 420px; opacity: .16 }
.cnt-footer-cta::after { content: ""; position: absolute; left: -5%; right: -5%; bottom: -72px; height: 120px; background: #fff; transform: rotate(-3deg); transform-origin: left top }
.cnt-footer-cta .cnt-container { position: relative; z-index: 2; display: grid; grid-template-columns: 1fr auto; gap: 28px; align-items: center }
.cnt-footer-cta h2 { margin: 0; font-size: 40px; letter-spacing: -.05em; line-height: 1.1; color: #fff }
.cnt-footer-cta p { margin: 14px 0 0; color: rgba(255,255,255,.72); line-height: 1.65; max-width: 700px }

/* ── Responsive ── */
@media (max-width: 1020px) {
  .cnt-map-grid, .cnt-office-grid, .cnt-contact-wrap { grid-template-columns: 1fr }
  .cnt-trust-grid, .cnt-process { grid-template-columns: repeat(2,1fr) }
  .cnt-aside { position: relative; top: 0 }
}

@media (max-width: 760px) {
  .cnt-container { width: min(100% - 28px, 1180px) }
  .cnt-hero { padding: 54px 0 86px }
  .cnt-lead { font-size: 17px }
  .cnt-hero-map, .cnt-form-card, .cnt-aside { border-radius: 26px; padding: 18px }
  .cnt-map-grid, .cnt-grid-2, .cnt-phone-row, .cnt-trust-grid, .cnt-process { grid-template-columns: 1fr }
  .cnt-section { padding: 56px 0 }
  .cnt-section-head h2 { font-size: 28px }
  .cnt-office-featured, .cnt-office-card { padding: 22px; border-radius: 24px }
  .cnt-office-featured h3 { font-size: 23px }
  .cnt-form-head, .cnt-form-actions { flex-direction: column; align-items: stretch }
  .cnt-form-submit { width: 100% }
  .cnt-footer-cta { padding: 70px 0 104px }
  .cnt-footer-cta .cnt-container { grid-template-columns: 1fr }
  .cnt-footer-cta h2 { font-size: 28px }
  .cnt-h1 { font-size: clamp(32px,8vw,48px) }
}
