    /* ─── Contact Page Styling ──────────────────────────────────── */
    .contact-hero {
      padding: 140px 24px 56px;
      text-align: center;
      background:
        radial-gradient(circle at 25% 25%, rgba(232,144,64,0.12) 0%, transparent 50%),
        radial-gradient(circle at 75% 50%, rgba(232,144,64,0.08) 0%, transparent 55%);
    }
    [data-theme="light"] .contact-hero {
      background:
        radial-gradient(circle at 25% 25%, rgba(192,104,32,0.09) 0%, transparent 50%),
        radial-gradient(circle at 75% 50%, rgba(192,104,32,0.06) 0%, transparent 55%);
    }
    .contact-hero .eyebrow {
      font-size: 0.78rem;
      font-weight: 700;
      letter-spacing: 2.4px;
      text-transform: uppercase;
      color: var(--color-accent);
      margin-bottom: 14px;
    }
    .contact-hero h1 {
      font-family: 'Fraunces', Georgia, serif;
      font-weight: 700;
      font-size: clamp(2.2rem, 5.5vw, 3.6rem);
      letter-spacing: -0.02em;
      line-height: 1.08;
      max-width: 780px;
      margin: 0 auto 18px;
    }
    .contact-hero p.lead {
      max-width: 620px;
      margin: 0 auto;
      color: var(--color-muted);
      font-size: 1.08rem;
      line-height: 1.65;
    }

    .contact-layout {
      max-width: 1120px;
      margin: 0 auto;
      padding: 64px 24px 40px;
      display: grid;
      grid-template-columns: 1fr 1.25fr;
      gap: 56px;
      align-items: start;
    }

    /* Left: contact info card */
    .contact-info {
      background: var(--color-surface);
      border: 1px solid var(--color-border);
      border-radius: 16px;
      padding: 36px 32px;
      position: sticky;
      top: 100px;
      box-shadow: var(--shadow-card);
    }
    .contact-info h2 {
      font-family: 'Fraunces', Georgia, serif;
      font-size: 1.5rem;
      font-weight: 700;
      letter-spacing: -0.01em;
      margin-bottom: 8px;
    }
    .contact-info > p.info-lead {
      color: var(--color-muted);
      font-size: 0.95rem;
      line-height: 1.6;
      margin-bottom: 24px;
    }

    .contact-method {
      display: flex;
      gap: 14px;
      align-items: flex-start;
      padding: 16px 0;
      border-bottom: 1px solid var(--color-border);
    }
    .contact-method:last-of-type { border-bottom: none; }
    .contact-method .ci-icon {
      font-size: 1.3rem;
      line-height: 1;
      width: 38px; height: 38px;
      border-radius: 10px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      background: var(--badge-bg);
      border: 1px solid var(--badge-border);
      flex-shrink: 0;
    }
    .contact-method .ci-body { flex: 1; }
    .contact-method .ci-label {
      font-size: 0.78rem;
      font-weight: 600;
      text-transform: uppercase;
      letter-spacing: 1.4px;
      color: var(--color-muted);
      margin-bottom: 4px;
    }
    .contact-method .ci-value {
      display: block;
      font-size: 1.02rem;
      font-weight: 600;
      color: var(--color-text);
      text-decoration: none;
      line-height: 1.4;
    }
    .contact-method .ci-value:hover { color: var(--color-accent); }
    .contact-method .ci-note {
      display: block;
      font-size: 0.85rem;
      color: var(--color-muted);
      margin-top: 2px;
    }

    .response-promise {
      margin-top: 22px;
      padding: 14px 16px;
      background: var(--badge-bg);
      border: 1px solid var(--badge-border);
      border-radius: 10px;
      font-size: 0.88rem;
      line-height: 1.5;
      color: var(--badge-color);
    }
    .response-promise strong { font-weight: 700; }

    /* Right: form card */
    .contact-form-card {
      background: var(--color-surface);
      border: 1px solid var(--color-border);
      border-radius: 16px;
      padding: 36px 36px 32px;
      box-shadow: var(--shadow-card);
    }
    .contact-form-card h2 {
      font-family: 'Fraunces', Georgia, serif;
      font-size: 1.6rem;
      font-weight: 700;
      letter-spacing: -0.01em;
      margin-bottom: 6px;
    }
    .contact-form-card > p.form-lead {
      color: var(--color-muted);
      font-size: 0.95rem;
      margin-bottom: 26px;
    }

    /* Form overrides / local to this page */
    .c-form { display: grid; gap: 18px; }
    .c-form-row {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 16px;
    }
    .c-form-group { display: flex; flex-direction: column; gap: 6px; }
    .c-form-group label {
      font-size: 0.85rem;
      font-weight: 600;
      color: var(--color-text);
    }
    .c-form-group .required { color: var(--color-accent); }
    .c-form-group input,
    .c-form-group textarea,
    .c-form-group select {
      font-family: 'DM Sans', sans-serif;
      font-size: 0.98rem;
      padding: 12px 14px;
      background: var(--input-bg);
      border: 1px solid var(--color-border);
      border-radius: 10px;
      color: var(--color-text);
      transition: border-color 0.15s, box-shadow 0.15s;
    }
    .c-form-group input:focus,
    .c-form-group textarea:focus,
    .c-form-group select:focus {
      outline: none;
      border-color: var(--color-accent);
      box-shadow: 0 0 0 3px rgba(232, 144, 64, 0.15);
    }
    .c-form-group textarea {
      min-height: 140px;
      resize: vertical;
      font-family: inherit;
    }
    .c-form-group .hint {
      font-size: 0.8rem;
      color: var(--color-muted);
    }

    .consent-row {
      display: flex;
      gap: 10px;
      align-items: flex-start;
      font-size: 0.88rem;
      line-height: 1.55;
      color: var(--color-muted);
    }
    .consent-row input[type="checkbox"] {
      margin-top: 3px;
      width: 18px;
      height: 18px;
      accent-color: var(--color-accent);
      flex-shrink: 0;
    }
    .consent-row a { color: var(--color-accent); text-decoration: underline; text-underline-offset: 3px; }

    .c-submit {
      font-family: 'DM Sans', sans-serif;
      font-size: 1rem;
      font-weight: 600;
      padding: 14px 24px;
      background: var(--color-accent);
      color: #0a0604;
      border: none;
      border-radius: 10px;
      cursor: pointer;
      transition: transform 0.15s, background 0.2s, box-shadow 0.2s;
      justify-self: start;
      box-shadow: 0 8px 24px rgba(232, 144, 64, 0.25);
    }
    .c-submit:hover {
      transform: translateY(-2px);
      background: var(--color-accent-dk);
    }
    .c-submit:focus-visible { outline: 2px solid var(--color-accent); outline-offset: 3px; }

    /* Hidden honeypot */
    .hp-field {
      position: absolute;
      left: -9999px;
      width: 1px;
      height: 1px;
      overflow: hidden;
    }

    /* ─── FAQ ───────────────────────────────────────────────────── */
    .faq-section {
      max-width: 920px;
      margin: 24px auto 0;
      padding: 40px 24px 96px;
    }
    .faq-section h2 {
      font-family: 'Fraunces', Georgia, serif;
      font-size: clamp(1.6rem, 3.5vw, 2.2rem);
      font-weight: 700;
      letter-spacing: -0.01em;
      margin-bottom: 10px;
    }
    .faq-section .section-sub {
      color: var(--color-muted);
      margin-bottom: 28px;
      font-size: 1rem;
    }
    .faq-list details {
      background: var(--color-surface);
      border: 1px solid var(--color-border);
      border-radius: 12px;
      padding: 18px 22px;
      margin-bottom: 12px;
      transition: border-color 0.2s;
    }
    .faq-list details[open] { border-color: var(--color-accent); }
    .faq-list summary {
      cursor: pointer;
      list-style: none;
      font-weight: 600;
      font-size: 1rem;
      display: flex;
      justify-content: space-between;
      gap: 16px;
      align-items: center;
    }
    .faq-list summary::-webkit-details-marker { display: none; }
    .faq-list summary::after {
      content: '+';
      font-size: 1.5rem;
      font-weight: 300;
      color: var(--color-accent);
      transition: transform 0.25s;
    }
    .faq-list details[open] summary::after { content: '−'; }
    .faq-list .faq-body {
      padding-top: 12px;
      color: var(--color-muted);
      font-size: 0.95rem;
      line-height: 1.65;
    }

    /* ─── Responsive ─────────────────────────────────────────── */
    @media (max-width: 880px) {
      .contact-layout {
        grid-template-columns: 1fr;
        gap: 28px;
        padding: 48px 22px 24px;
      }
      .contact-info {
        position: static;
        padding: 28px 24px;
      }
      .contact-form-card { padding: 28px 24px 26px; }
      .c-form-row { grid-template-columns: 1fr; }
      .contact-hero { padding: 110px 22px 44px; }
    }

    @media (max-width: 768px) {
      .contact-hero {
        padding: 100px 20px 40px;
      }
      .contact-hero p.lead {
        font-size: 1rem;
      }
      .contact-layout {
        padding: 40px 20px 20px;
        gap: 24px;
      }
      .contact-info {
        padding: 24px 20px;
      }
      .contact-form-card {
        padding: 24px 20px 22px;
      }
      .c-form-group input,
      .c-form-group textarea,
      .c-form-group select {
        width: 100%;
        box-sizing: border-box;
      }
      .faq-section {
        padding: 32px 20px 72px;
      }
    }

    @media (max-width: 600px) {
      .contact-hero {
        padding: 90px 16px 36px;
      }
      .contact-layout {
        padding: 32px 16px 16px;
      }
      .contact-info {
        padding: 20px 16px;
      }
      .contact-form-card {
        padding: 20px 16px 18px;
        border-radius: 12px;
      }
      .contact-form-card h2 {
        font-size: 1.35rem;
      }
      .c-submit {
        width: 100%;
        justify-self: stretch;
        text-align: center;
        justify-content: center;
        min-height: 48px;
      }
      .faq-section {
        padding: 28px 16px 56px;
      }
      .faq-list details {
        padding: 14px 16px;
      }
      .faq-list summary {
        font-size: 0.95rem;
      }
    }

