.page-hero { padding: 80px 0; background: var(--bg-blue); }

.page-hero .hero-art .badge { position: absolute; bottom: 18px; left: 18px; background: var(--blue); color: #fff; padding: 8px 14px; font-family: var(--display); font-weight: 800; font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; border-radius: 4px; }

.page-hero p { color: var(--ink-soft); font-size: 18px; max-width: 48ch; line-height: 1.6; }

.contact-grid { padding: 100px 0; }

.contact-grid .grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: 64px; align-items: start; }

@media (max-width: 980px) { .contact-grid .grid { grid-template-columns: 1fr; gap: 40px; } }

.form { background: #fff; border: 1px solid var(--line); padding: 48px; border-radius: 12px; box-shadow: 0 12px 32px -16px rgba(51,51,153,0.1); }

.form-status { background: #f5fbf5; border: 1px solid #9fd4b5; color: #1d4f2e; padding: 20px 22px; border-radius: 12px; margin-bottom: 24px; font-weight: 600; }

.form .head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 32px; gap: 16px; }

.form h3 { font-size: 32px; color: var(--blue); }

.form .step { font-family: var(--display); font-weight: 700; font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--saffron-deep); }

.field { display: grid; gap: 8px; margin-bottom: 22px; }

.field label { font-family: var(--display); font-weight: 700; font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--blue); }

.field input, .field select, .field textarea {
  font-family: var(--body); font-size: 15px;
  padding: 14px 16px;
  border: 1.5px solid var(--line);
  background: #fff;
  border-radius: 6px;
  color: var(--ink);
  width: 100%;
}

.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--blue); }

.field textarea { min-height: 120px; resize: vertical; }

.row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }

@media (max-width: 720px) { .row2 { grid-template-columns: 1fr; } }

.country-pick { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }

.country-pick label { border: 1.5px solid var(--line); padding: 16px; border-radius: 6px; cursor: pointer; background: #fff; display: flex; align-items: center; gap: 12px; transition: all 0.2s; }

.country-pick input { display: none; }

.country-pick label:has(input:checked) { border-color: var(--blue); background: var(--blue-soft); }

.country-pick .flag { width: 36px; height: 24px; border-radius: 3px; border: 1px solid var(--line); }

.country-pick .flag.nz { background: linear-gradient(135deg, #00247D 0% 50%, #CC142B 50% 100%); }

.country-pick .flag.au { background: linear-gradient(135deg, #00008B 0% 50%, #FF0000 50% 100%); }

.country-pick .name { font-family: var(--display); font-weight: 700; font-size: 16px; color: var(--blue); }

.country-pick .sub { font-family: var(--display); font-size: 10px; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-muted); margin-top: 2px; }

.form-foot { display: flex; justify-content: space-between; align-items: center; margin-top: 12px; gap: 16px; flex-wrap: wrap; }

.form-foot .privacy { font-size: 12px; color: var(--ink-muted); max-width: 36ch; }

.contact-side { display: flex; flex-direction: column; gap: 24px; }

.quick { background: var(--blue); color: #fff; padding: 36px; border-radius: 12px; }

.quick .lbl { font-family: var(--display); font-weight: 700; font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--saffron); }

.quick h4 { color: #fff; font-size: 26px; margin-top: 12px; }

.quick p { color: #B5BAD8; font-size: 14px; margin-top: 8px; }

.quick .item { display: grid; grid-template-columns: 110px 1fr; gap: 16px; padding: 16px 0; border-top: 1px solid rgba(255,255,255,0.1); align-items: center; }

.quick .item:first-of-type { margin-top: 18px; }

.quick .ttl { font-family: var(--display); font-weight: 700; font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--saffron); }

.quick .v { color: #fff; font-size: 15px; font-family: var(--display); font-weight: 600; }

.quick .v a { color: #fff; }

.quick .v a:hover { color: var(--saffron); }

.hours { background: #fff; border: 1px solid var(--line); padding: 28px; border-radius: 12px; }

.hours .lbl { font-family: var(--display); font-weight: 700; font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--saffron-deep); }

.hours h4 { color: var(--blue); font-size: 22px; margin-top: 8px; margin-bottom: 16px; }

.hours .item { display: flex; justify-content: space-between; padding: 10px 0; border-bottom: 1px solid var(--line); font-family: var(--display); }

.hours .item:last-child { border: 0; }

.hours .day { font-weight: 600; font-size: 13px; color: var(--ink); }

.hours .h { font-weight: 700; font-size: 13px; color: var(--blue); }

.offices { background: var(--bg-paper); padding: 100px 0; }

.office-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; margin-top: 56px; border-top: 2px solid var(--blue); border-left: 1px solid var(--line); }

.office { border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); padding: 32px; min-height: 280px; display: flex; flex-direction: column; justify-content: space-between; background: #fff; transition: all 0.2s; }

.office:hover { background: var(--bg-blue); }

.office.featured { background: var(--blue); color: #fff; }

.office.featured:hover { background: var(--blue-deep); }

.office .country { font-family: var(--display); font-weight: 700; font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--saffron-deep); }

.office.featured .country { color: var(--saffron); }

.office h4 { font-size: 26px; color: var(--blue); margin-top: 8px; }

.office.featured h4 { color: #fff; }

.office .addr { color: var(--ink-soft); font-size: 14px; margin-top: 10px; line-height: 1.5; }

.office.featured .addr { color: #B5BAD8; }

.office .person { font-family: var(--display); font-size: 11px; letter-spacing: 0.06em; color: var(--ink-soft); margin-top: 16px; padding-top: 16px; border-top: 1px solid var(--line); }

.office.featured .person { color: #B5BAD8; border-color: rgba(255,255,255,0.15); }

.office .person strong { font-family: var(--display); font-size: 16px; font-weight: 700; color: var(--blue); display: block; margin-top: 4px; letter-spacing: 0; text-transform: none; }

.office.featured .person strong { color: #fff; }

.office.cta { background: var(--saffron); color: var(--blue); }

.office.cta:hover { background: var(--saffron-deep); color: #fff; }

.office.cta h4 { color: var(--blue); }

@media (max-width: 880px) { .office-grid { grid-template-columns: 1fr; } }
