/* contact — page-specific styles */
/* ============== UNIFIED SECTION HEAD ============== */
.section-head {
  display: grid;
  grid-template-columns: var(--label-col) 1fr 220px;
  gap: var(--label-gap);
  align-items: end;
  padding: var(--section-pad) var(--gutter) 64px;
  max-width: var(--col-max); margin: 0 auto;
}
.section-head .sh-rail { display: flex; flex-direction: column; gap: 14px; padding-bottom: 10px; }
.section-head .sh-num {
  font-family: var(--display);
  font-weight: 500; font-size: 13px;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ink);
  display: inline-flex; align-items: center; gap: 14px;
}
.section-head .sh-num::before { content: ""; width: 28px; height: 1px; background: var(--amber); }
.section-head .sh-label {
  font-size: 11.5px; letter-spacing: 0.18em; font-weight: 500;
  color: var(--grey); text-transform: uppercase;
}
.section-head .sh-title {
  font-family: var(--display); font-weight: 600;
  font-size: clamp(44px, 5.6vw, 88px);
  letter-spacing: -0.034em; line-height: 0.96;
  margin: 0; max-width: 16ch; text-wrap: balance;
  color: var(--ink);
}
.section-head .sh-title em { font-style: normal; border-bottom: 4px solid var(--amber); padding-bottom: 4px; }
.section-head .sh-meta {
  font-size: 11.5px; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--grey); font-weight: 500;
  text-align: right; line-height: 1.7; padding-bottom: 10px;
}

/* ============== HERO ============== */
.contact-hero {
  position: relative;
  border-bottom: 1px solid var(--rule);
  padding: 140px var(--gutter) 120px;
  max-width: var(--col-max); margin: 0 auto;
  display: grid;
  grid-template-columns: var(--label-col) 1fr 360px;
  gap: var(--label-gap);
  align-items: end;
}
.contact-hero .rail { display: flex; flex-direction: column; gap: 14px; }
.contact-hero .rail .num { display: none; }
.contact-hero .rail .label {
  font-size: 13px; letter-spacing: 0.16em; color: var(--ink);
  text-transform: uppercase; font-weight: 500;
  font-family: var(--display);
  display: inline-flex; align-items: center; gap: 14px;
}
.contact-hero .rail .label::before { content: ""; width: 28px; height: 1px; background: var(--amber); }
.contact-hero h1 {
  font-family: var(--display); font-weight: 600;
  font-size: clamp(64px, 9vw, 156px);
  letter-spacing: -0.04em; line-height: 0.92;
  margin: 0; max-width: 14ch; text-wrap: balance;
}
.contact-hero h1 em { font-style: normal; border-bottom: 8px solid var(--amber); padding-bottom: 6px; }
.contact-hero .side {
  font-family: var(--body); color: var(--ink-3);
  font-size: 17px; line-height: 1.55;
  max-width: 36ch;
  padding-bottom: 8px;
}
.contact-hero .side .strong {
  font-family: var(--display);
  font-weight: 500;
  color: var(--ink);
  display: block;
  font-size: 15px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: 18px;
}
.contact-hero .side .response {
  display: inline-flex; align-items: center; gap: 10px;
  margin-top: 18px;
  font-family: var(--display); font-weight: 500;
  font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ink-2);
}
.contact-hero .side .response .pip {
  width: 8px; height: 8px; background: var(--green);
  border-radius: 50%; display: inline-block;
  box-shadow: 0 0 0 4px rgba(124,179,66,0.18);
}

/* ============== CHANNELS GRID ============== */
.channels {
  background: var(--white);
  border-bottom: 1px solid var(--rule);
}
.channels-inner {
  max-width: var(--col-max); margin: 0 auto;
  padding: 0 var(--gutter);
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  border-left: 1px solid var(--rule);
}
.channel {
  padding: 80px 56px 88px;
  border-right: 1px solid var(--rule);
  position: relative;
  display: flex; flex-direction: column;
}
.channel .ch-rail {
  display: flex; align-items: center; gap: 14px;
  font-family: var(--display); font-weight: 500;
  font-size: 13px; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ink);
  margin-bottom: 56px;
}
.channel .ch-rail::before { content: ""; width: 28px; height: 1px; background: var(--amber); }
.channel .ch-rail .ch-label {
  color: var(--ink);
  font-size: 13px;
  letter-spacing: 0.16em;
  margin-left: 0;
}
.channel h3 {
  font-family: var(--display); font-weight: 600;
  font-size: clamp(28px, 2.2vw, 36px);
  letter-spacing: -0.022em; line-height: 1.05;
  margin: 0 0 32px;
  max-width: 14ch; text-wrap: balance;
}
.channel .lines {
  display: flex; flex-direction: column; gap: 14px;
  margin-bottom: 32px;
}
.channel .lines a, .channel .lines span {
  font-family: var(--display); font-weight: 500;
  font-size: clamp(22px, 1.8vw, 28px);
  letter-spacing: -0.012em;
  color: var(--ink);
  line-height: 1.2;
  display: inline-block;
  border-bottom: 1px solid transparent;
  padding-bottom: 4px;
  transition: border-color 180ms ease;
  width: max-content;
  max-width: 100%;
}
.channel .lines a:hover { border-color: var(--ink); }
.channel .note {
  margin-top: auto;
  font-size: 13px; color: var(--ink-3);
  line-height: 1.55;
  max-width: 32ch;
}
.channel .note .role {
  display: block;
  font-family: var(--display); font-weight: 500;
  font-size: 11.5px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--grey);
  margin-bottom: 8px;
}

/* Address channel has multi-line address as the main content */
.channel.is-address .addr-block {
  font-family: var(--display); font-weight: 500;
  font-size: clamp(18px, 1.4vw, 22px);
  letter-spacing: -0.008em; line-height: 1.5;
  color: var(--ink);
  max-width: 28ch;
  margin: 0 0 28px;
}
.channel.is-address .addr-line { display: block; }
.channel.is-address .pin {
  font-size: 11.5px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--grey);
  font-weight: 500;
  display: inline-flex; align-items: center; gap: 10px;
  margin-bottom: 18px;
}
.channel.is-address .pin::before { content: ""; width: 10px; height: 10px; background: var(--amber); }
.channel.is-address .directions {
  display: inline-flex; align-items: center; gap: 12px;
  font-family: var(--display); font-weight: 500;
  font-size: 13px; letter-spacing: 0.06em; text-transform: uppercase;
  border-bottom: 1px solid var(--ink); padding-bottom: 4px;
  width: max-content;
  margin-top: auto;
}
.channel.is-address .directions .arr { color: var(--amber); }

/* ============== ENQUIRY FORM ============== */
.enquiry {
  background: var(--paper);
  border-bottom: 1px solid var(--rule);
}
.enquiry-inner {
  max-width: var(--col-max); margin: 0 auto;
  padding: 140px var(--gutter) 140px;
  display: grid;
  grid-template-columns: var(--label-col) 1fr;
  gap: var(--label-gap);
}
.enquiry-rail { display: flex; flex-direction: column; gap: 14px; padding-top: 6px; }
.enquiry-rail .label {
  font-size: 13px; letter-spacing: 0.16em; font-weight: 500;
  color: var(--ink); text-transform: uppercase;
  font-family: var(--display);
  display: inline-flex; align-items: center; gap: 14px;
}
.enquiry-rail .label::before { content: ""; width: 28px; height: 1px; background: var(--amber); }
.enquiry-rail .desc {
  font-size: 13.5px; color: var(--ink-3); line-height: 1.55;
  max-width: 26ch;
  margin-top: 16px;
}
.enquiry h2 {
  font-family: var(--display); font-weight: 600;
  font-size: clamp(40px, 4.4vw, 64px);
  letter-spacing: -0.028em; line-height: 1.02;
  margin: 0 0 56px;
  max-width: 22ch; text-wrap: balance;
}
.enquiry h2 em { font-style: normal; border-bottom: 4px solid var(--amber); padding-bottom: 3px; }

.form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border-top: 1px solid var(--rule);
}
.field {
  position: relative;
  border-bottom: 1px solid var(--rule);
  padding: 26px 0 22px;
}
.field.col-span-2 { grid-column: 1 / -1; }
.field.right { border-left: 1px solid var(--rule); padding-left: 32px; }
.field.left { padding-right: 32px; }
.field label {
  display: block;
  font-family: var(--display); font-weight: 500;
  font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--grey);
  margin-bottom: 14px;
}
.field label .req { color: var(--amber); margin-left: 4px; }
.field input, .field textarea, .field select {
  width: 100%;
  border: 0;
  background: transparent;
  font-family: var(--display); font-weight: 500;
  font-size: 18px;
  letter-spacing: -0.005em;
  color: var(--ink);
  padding: 0;
  outline: none;
}
.field input::placeholder, .field textarea::placeholder {
  color: var(--grey-2); font-weight: 400;
}
.field textarea {
  resize: vertical;
  min-height: 120px;
  line-height: 1.5;
  font-size: 17px;
}
.field select {
  appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' stroke='%230A0A0A' stroke-width='1.4' fill='none'/></svg>");
  background-repeat: no-repeat;
  background-position: right 0 center;
  background-size: 12px;
  padding-right: 28px;
  cursor: pointer;
}

.field-chip-row {
  display: flex; flex-wrap: wrap; gap: 8px;
  margin-top: 4px;
}
.chip {
  font-family: var(--display); font-weight: 500;
  font-size: 13px; letter-spacing: 0.02em;
  padding: 9px 16px;
  border: 1px solid var(--rule);
  background: var(--white);
  color: var(--ink-2);
  cursor: pointer;
  user-select: none;
  transition: border-color 160ms ease, color 160ms ease, background 160ms ease;
}
.chip:hover { border-color: var(--ink-3); }
.chip.is-on {
  background: var(--ink); color: var(--paper);
  border-color: var(--ink);
}

.form-foot {
  margin-top: 40px;
  display: flex; align-items: center; justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
}
.form-foot .fine {
  font-size: 12px; color: var(--ink-3);
  max-width: 52ch; line-height: 1.55;
}
.btn-submit {
  display: inline-flex; align-items: center; gap: 14px;
  background: var(--ink); color: var(--paper);
  padding: 18px 28px;
  font-family: var(--display); font-weight: 500;
  font-size: 14px; letter-spacing: 0.04em; text-transform: uppercase;
  border: 0; cursor: pointer;
  transition: background 160ms ease;
}
.btn-submit .arr { color: var(--amber); transition: transform 220ms ease; }
.btn-submit:hover { background: #000; }
.btn-submit:hover .arr { transform: translateX(4px); }

/* ============== LOCATION STRIP ============== */
.locate {
  background: var(--ink);
  color: var(--paper);
  padding: 100px 0;
}
.locate-inner {
  max-width: var(--col-max); margin: 0 auto;
  padding: 0 var(--gutter);
  display: grid;
  grid-template-columns: var(--label-col) 1fr auto;
  gap: var(--label-gap);
  align-items: end;
}
.locate .rail {
  display: flex; flex-direction: column; gap: 14px;
  padding-bottom: 10px;
}
.locate .rail .label {
  font-size: 13px; letter-spacing: 0.16em; color: var(--paper);
  text-transform: uppercase; font-weight: 500;
  font-family: var(--display);
  display: inline-flex; align-items: center; gap: 14px;
}
.locate .rail .label::before { content: ""; width: 28px; height: 1px; background: var(--amber); }
.locate h2 {
  font-family: var(--display); font-weight: 600;
  font-size: clamp(40px, 4.6vw, 72px);
  letter-spacing: -0.03em; line-height: 1;
  margin: 0;
  max-width: 18ch; text-wrap: balance;
}
.locate h2 em { font-style: normal; border-bottom: 4px solid var(--amber); padding-bottom: 4px; }
.locate .pins {
  display: flex; flex-direction: column; gap: 18px;
  font-size: 11.5px; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--grey-2); font-weight: 500;
  text-align: right;
  padding-bottom: 12px;
}
.locate .pins .pin {
  display: inline-flex; align-items: center; gap: 12px;
  justify-content: flex-end;
}
.locate .pins .pin b { color: var(--paper); font-weight: 500; }
.locate .pins .pin .dot { width: 6px; height: 6px; background: var(--amber); display: inline-block; }

.locate-meta {
  max-width: var(--col-max); margin: 80px auto 0;
  padding: 0 var(--gutter);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 48px;
  border-top: 1px solid #1f1f1f;
  padding-top: 56px;
}
.locate-meta .item .k {
  font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--grey-2); font-weight: 500;
  margin-bottom: 14px;
}
.locate-meta .item .v {
  font-family: var(--display); font-weight: 500;
  font-size: 22px; letter-spacing: -0.012em; line-height: 1.3;
  color: var(--paper);
}
.locate-meta .item .sub {
  font-size: 13px; color: var(--grey-2);
  margin-top: 6px; line-height: 1.5;
}

/* ============== HOURS ============== */
.hours {
  background: var(--paper);
  border-top: 1px solid var(--rule);
}
.hours-inner {
  max-width: var(--col-max); margin: 0 auto;
  padding: 80px var(--gutter);
  display: grid;
  grid-template-columns: var(--label-col) 1fr 1fr;
  gap: var(--label-gap);
  align-items: center;
}
.hours .label {
  font-size: 11.5px; letter-spacing: 0.18em; color: var(--grey);
  text-transform: uppercase; font-weight: 500;
  display: flex; align-items: center; gap: 14px;
}
.hours .label::before { content: ""; width: 28px; height: 1px; background: var(--amber); }
.hours .row {
  display: flex; justify-content: space-between;
  font-family: var(--display); font-weight: 500;
  font-size: 15px;
  border-bottom: 1px solid var(--rule);
  padding: 18px 0;
}
.hours .row:last-child { border-bottom: 0; }
.hours .row .d { color: var(--ink); }
.hours .row .t { color: var(--ink-3); letter-spacing: 0.04em; }
.hours .row.is-closed .t { color: var(--grey); }


/* ============== RESPONSIVE ============== */
@media (max-width: 1200px) {
  :root { --label-col: 200px; --label-gap: 40px; }
  .contact-hero { grid-template-columns: var(--label-col) 1fr; }
  .contact-hero .side { grid-column: 1 / -1; max-width: 60ch; }
  .channels-inner { grid-template-columns: 1fr 1fr; }
  .channel:nth-child(3) { grid-column: 1 / -1; border-bottom: 1px solid var(--rule); }
  .locate-meta { grid-template-columns: 1fr 1fr; row-gap: 32px; }
}
@media (max-width: 860px) {
  :root { --gutter: 24px; --section-pad: 80px; }
  .hide-sm { display: none; }
  .header-main { grid-template-columns: auto 1fr; height: 72px; gap: 24px; }
  .nav { display: none; }
  .brand-logo { height: 44px; }
  .contact-hero { grid-template-columns: 1fr; gap: 28px; padding: 80px var(--gutter); }
  .contact-hero h1 { font-size: clamp(48px, 12vw, 80px); }
  .section-head { grid-template-columns: 1fr; gap: 24px; padding-bottom: 40px; }
  .section-head .sh-meta { text-align: left; }
  .channels-inner { grid-template-columns: 1fr; }
  .channel { padding: 56px 28px; border-bottom: 1px solid var(--rule); }
  .channel:nth-child(3) { border-bottom: 0; }
  .enquiry-inner { grid-template-columns: 1fr; gap: 40px; padding: 80px var(--gutter); }
  .form-grid { grid-template-columns: 1fr; }
  .field.right { border-left: 0; padding-left: 0; }
  .field.left { padding-right: 0; }
  .locate-inner { grid-template-columns: 1fr; gap: 28px; }
  .locate .pins { text-align: left; align-items: flex-start; }
  .locate .pins .pin { justify-content: flex-start; }
  .locate-meta { grid-template-columns: 1fr 1fr; gap: 32px; }
  .hours-inner { grid-template-columns: 1fr; gap: 28px; }
  footer .grid { grid-template-columns: 1fr 1fr; gap: 48px; }
  footer .bottom { flex-direction: column; gap: 16px; align-items: flex-start; }
}

/* ===================================================================
   MOBILE NAV + REFINEMENTS
   =================================================================== */
.m-toggle { display: none; }
.m-nav { display: none; }
/* Hamburger drawer takes over for tablet + phone (desktop nav cannot fit below ~1180px) */
@media (max-width: 1180px) {
  .nav { display: none; }
  .header-actions .header-cta { display: none; }
  .m-toggle {
    display: flex; flex-direction: column; justify-content: center; align-items: center; gap: 5px;
    width: 44px; height: 44px; border: 0; background: transparent; cursor: pointer; padding: 0; margin-left: 4px;
  }
  .m-toggle span { display: block; width: 24px; height: 2px; background: var(--ink); transition: transform .25s ease, opacity .2s ease; }
  .m-toggle.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
  .m-toggle.is-open span:nth-child(2) { opacity: 0; }
  .m-toggle.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
  .m-nav {
    display: flex; flex-direction: column;
    position: fixed; top: 104px; left: 0; right: 0; bottom: 0;
    background: var(--ink); color: var(--paper);
    padding: 14px var(--gutter) 36px; z-index: 59; overflow-y: auto;
    opacity: 0; visibility: hidden; transform: translateY(-10px);
    transition: opacity .26s ease, transform .26s ease, visibility 0s linear .26s;
  }
  body.m-open { overflow: hidden; }
  body.m-open .m-nav { opacity: 1; visibility: visible; transform: none; transition: opacity .26s ease, transform .26s ease, visibility 0s; }
  .m-nav a {
    font-family: var(--display); font-weight: 500; font-size: 27px; letter-spacing: -0.02em; color: var(--paper);
    padding: 16px 0; border-bottom: 1px solid rgba(255,255,255,0.14); display: flex; align-items: center; justify-content: space-between;
  }
  .m-nav a .arr { color: var(--amber); font-size: 19px; }
  .m-nav a.m-cta { margin-top: 22px; border: 1px solid rgba(255,255,255,0.28); padding: 17px 20px; font-size: 17px; }
  .m-nav .m-meta { margin-top: 24px; font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--grey-2); line-height: 1.9; }
}
/* Phone-only refinements */
@media (max-width: 720px) {
  :root { --section-pad: 78px; }
  .m-nav a { font-size: 26px; }
  footer .bottom { flex-wrap: wrap; gap: 14px; }
  .cap-hero .banner .meta-strip .cell { min-width: 150px; }
  footer .grid { grid-template-columns: 1fr; }
  .channel { padding: 52px 24px; }
  .channel .lines a, .channel .lines span { width: auto; overflow-wrap: anywhere; font-size: 20px; }
  /* contain wide tables so they scroll inside their section, not the page */
  .compare .inner, .params .inner { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .compare .tbl, .params .ptbl { display: table; width: auto; min-width: 560px; white-space: nowrap; }
  .cat-index .idx-row { grid-template-columns: 1fr; gap: 10px; align-items: start; }
  .cat-index .idx-row .ix-num { display: none; }
  .cat-index .idx-row .ix-name { font-size: 22px; }
  .cat-index .idx-row .ix-go { font-size: 12px; white-space: nowrap; justify-self: start; }
}
