  /* Contact page deltas. Loaded on the Contact page on top of theme.css
     (which already carries .sec-test carousel + .sec-urgent). Holds the
     hero, trust bar, contact form + sidebar, and the locations grid. */

  /* ---- HERO (ember + blueprint grid, matching the service pillars) ---- */
  .page-contact .hero {
    background:
      linear-gradient(rgba(255,255,255,.07) 1px, transparent 1px) 0 0 / 100% 80px,
      linear-gradient(90deg, rgba(255,255,255,.07) 1px, transparent 1px) 0 0 / 80px 100%,
      var(--ember-deep);
    padding: 150px 0 80px; position: relative; overflow: hidden; color: #fff;
  }
  .page-contact .hero::before {
    content: ""; position: absolute; width: 800px; height: 800px;
    border-radius: 50%; background: #c12a22; right: -260px; top: -360px; pointer-events: none;
  }
  .page-contact .hero-inner { position: relative; z-index: 2; max-width: 740px; }
  .page-contact .hero h1 { font-size: 56px; font-weight: 800; line-height: 1.08; letter-spacing: -.03em; margin-bottom: 24px; }
  .page-contact .hero h1 em { font-style: normal; color: var(--amber); }
  .page-contact .hero-lede { font-size: 18px; line-height: 1.6; color: rgba(255,255,255,.85); max-width: 580px; margin: 0; }
  @media (max-width: 768px) { .page-contact .hero h1 { font-size: 38px; } .page-contact .hero { padding: 120px 0 60px; } }

  /* ---- TRUST BAR ---- */
  .trust-bar { background: var(--ink); border-bottom: 3px solid var(--amber); padding: 20px 0; }
  .trust-bar-inner { max-width: 1280px; margin: 0 auto; padding: 0 56px; display: grid; grid-template-columns: repeat(4, 1fr); gap: 28px; }
  .trust-item { display: flex; align-items: center; gap: 12px; color: #fff; }
  .trust-item svg { width: 22px; height: 22px; color: var(--amber); flex-shrink: 0; }
  .trust-item-text { font-size: 14px; font-weight: 600; }
  .trust-item-text span { display: block; font-size: 12px; opacity: .6; font-weight: 400; }
  @media (max-width: 900px) { .trust-bar-inner { grid-template-columns: 1fr 1fr; gap: 18px; } }

  /* ---- CONTACT FORM + SIDEBAR ---- */
  .sec-contact { padding: 80px 0; background: var(--cream); }
  .contact-grid { display: grid; grid-template-columns: 1fr 460px; gap: 72px; align-items: start; }
  .contact-form-wrap h2 { font-size: 42px; font-weight: 700; letter-spacing: -.03em; line-height: 1.1; margin-bottom: 12px; }
  .contact-form-wrap .sub { font-size: 16px; color: var(--ink-soft); line-height: 1.6; margin-bottom: 40px; max-width: 520px; }
  .cform { display: flex; flex-direction: column; gap: 0; background: #fff; padding: 40px; border-radius: 10px; box-shadow: 0 4px 24px -8px rgba(20,17,15,.10); }
  .cform-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
  .cfield { display: flex; flex-direction: column; gap: 6px; margin-bottom: 20px; }
  .cfield label { font-size: 12px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-soft); }
  .cfield .opt { color: var(--ember); font-weight: 500; }
  .cfield input, .cfield select, .cfield textarea {
    padding: 14px 16px; border: 1.5px solid var(--cream-2); border-radius: 6px;
    font-family: inherit; font-size: 15px; color: var(--ink); background: #fff; outline: none; width: 100%;
  }
  .cfield textarea { resize: vertical; min-height: 110px; }
  .cfield input::placeholder, .cfield textarea::placeholder { color: rgba(74,69,65,.45); }
  .cfield input:focus, .cfield select:focus, .cfield textarea:focus { border-color: var(--ember); box-shadow: 0 0 0 3px rgba(217,52,43,.1); }
  .cform-submit {
    padding: 18px 32px; background: var(--ember); color: #fff; border: none; border-radius: 6px;
    font-family: inherit; font-size: 16px; font-weight: 700; cursor: pointer;
    display: inline-flex; align-items: center; justify-content: center; gap: 10px;
    transition: background .2s, color .2s, gap .2s, transform .2s, box-shadow .2s;
  }
  .cform-submit::after { content: "→"; }
  .cform-submit:hover { background: var(--ink); color: var(--amber); gap: 14px; transform: translateY(-1px); box-shadow: 0 12px 28px -10px rgba(20,17,15,.3); }
  .cform-note { font-size: 13px; color: var(--ink-soft); margin-top: 14px; line-height: 1.5; }
  .cform-note a { color: var(--ember); font-weight: 600; }
  .form-success { display: none; text-align: center; padding: 56px 32px; background: #fff; border-radius: 10px; box-shadow: 0 4px 24px -8px rgba(20,17,15,.10); }
  .form-success.show { display: flex; flex-direction: column; align-items: center; gap: 16px; }
  .success-icon { width: 72px; height: 72px; border-radius: 50%; background: rgba(217,52,43,.1); color: var(--ember); display: flex; align-items: center; justify-content: center; }
  .success-icon svg { width: 36px; height: 36px; }
  .form-success h3 { font-size: 26px; font-weight: 800; letter-spacing: -.02em; }
  .form-success p { font-size: 16px; color: var(--ink-soft); max-width: 400px; line-height: 1.6; }

  /* sidebar */
  .contact-sidebar { display: flex; flex-direction: column; gap: 24px; position: sticky; top: 32px; }
  .cside-block { padding: 28px 32px; border-radius: 10px; border: 1px solid var(--line); background: #fff; }
  .cside-block.blue { background: var(--blue); border-color: transparent; color: #fff; }
  .cside-heading { font-size: 22px; font-weight: 800; letter-spacing: -.015em; line-height: 1.2; margin-bottom: 10px; }
  .cside-block.blue .cside-heading,
  .cside-block.dark .cside-heading { color: #fff; }
  .phone-big { font-size: 34px; font-weight: 800; letter-spacing: -.02em; margin: 6px 0 8px; }
  .phone-label { font-size: 12px; opacity: .8; letter-spacing: .06em; text-transform: uppercase; font-weight: 600; }
  .cside-trust { list-style: none; display: flex; flex-direction: column; gap: 8px; margin: 16px 0 0; padding: 0; }
  .cside-trust li { font-size: 14px; display: flex; align-items: flex-start; gap: 10px; color: rgba(255,255,255,.85); }
  .cside-trust li::before { content: "✓"; color: var(--amber); font-weight: 800; flex-shrink: 0; margin-top: 1px; }
  .cside-block.dark { background: var(--ink); border-color: transparent; }
  .cside-certs { display: flex; flex-direction: column; gap: 12px; }
  .cert-row { display: flex; align-items: center; gap: 14px; padding: 12px 0; border-bottom: 1px solid rgba(255,255,255,.12); }
  .cert-row:last-child { border-bottom: none; padding-bottom: 0; }
  .cert-icon { width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; color: var(--amber); }
  .cert-icon svg { width: 20px; height: 20px; }
  .cert-name { font-size: 15px; font-weight: 700; color: #fff; }
  .cert-desc { font-size: 13px; color: rgba(255,255,255,.85); line-height: 1.55; margin-top: 2px; }
  @media (max-width: 900px) { .contact-grid { grid-template-columns: 1fr; gap: 40px; } .contact-sidebar { position: static; } .cform-row { grid-template-columns: 1fr; gap: 0; } }

  /* ---- LOCATIONS ---- */
  .sec-locations { padding: 80px 0; background: #fff; }
  .locations-head { margin-bottom: 48px; }
  .locations-head h2 { font-size: 42px; font-weight: 700; letter-spacing: -.03em; line-height: 1.1; margin-bottom: 12px; }
  .locations-head p { font-size: 16px; color: var(--ink-soft); max-width: 560px; line-height: 1.65; }
  .locations-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 16px; }
  .loc-card { background: var(--cream); border: 1px solid var(--line); border-radius: 10px; padding: 28px 24px; transition: border-color .2s, box-shadow .2s, transform .2s; }
  .loc-card:hover { border-color: var(--ember); box-shadow: 0 12px 32px -10px rgba(217,52,43,.12); transform: translateY(-4px); }
  .loc-icon { color: var(--ember); margin-bottom: 16px; }
  .loc-icon svg { width: 32px; height: 32px; display: block; }
  .loc-name { font-size: 18px; font-weight: 800; letter-spacing: -.01em; margin-bottom: 8px; }
  .loc-coverage { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--ember); margin-bottom: 12px; }
  .loc-coverage::before { content: ""; width: 8px; height: 8px; border-radius: 50%; background: var(--ember); flex-shrink: 0; animation: locPulse 2s ease-out infinite; }
  .loc-towns { font-size: 13px; color: var(--ink-soft); line-height: 1.6; }
  @keyframes locPulse { 0% { box-shadow: 0 0 0 0 rgba(217,52,43,.5); } 70% { box-shadow: 0 0 0 8px rgba(217,52,43,0); } 100% { box-shadow: 0 0 0 0 rgba(217,52,43,0); } }
  @media (max-width: 960px) { .locations-grid { grid-template-columns: 1fr 1fr 1fr; } }
  @media (max-width: 600px) { .locations-grid { grid-template-columns: 1fr 1fr; } }
