/* Source: design-source/html/contact.html */
:root {
    --bg: #f7f6f2; --bg-2: #ffffff; --bg-paper: #f1ede2; --bg-dark: #0b0b0c;
    --line: #e3e1d9; --line-2: #d8d6cf;
    --ink-0: #0b0b0c; --ink-1: #1a1a1e; --ink-2: #3d3d44; --ink-3: #8a8a92;
    --accent: #ff6a3d; --moss: #6b7d5a;
  }
  * { box-sizing: border-box; }
  html, body { margin: 0; padding: 0; background: var(--bg); color: var(--ink-1); }
  body { font-family: "Inter Tight", system-ui, sans-serif; -webkit-font-smoothing: antialiased; line-height: 1.55; }
  ::selection { background: var(--accent); color: #fff; }
  a { color: inherit; text-decoration: none; }
  .container { max-width: 1200px; margin: 0 auto; padding-inline: clamp(20px, 4vw, 56px); }

  .eyebrow { font-family: "JetBrains Mono", monospace; font-size: 12.5px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--accent); display: inline-flex; align-items: center; gap: 10px; margin: 0 0 22px; }
  .eyebrow .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--accent); }

  .lg { font-family: "Inter Tight", sans-serif; font-weight: 600; letter-spacing: -0.055em; line-height: 1; display: inline-flex; align-items: baseline; color: var(--ink-0); }
  .lg .acc { color: var(--accent); }

  /* NAV */
  .nav-wrap { position: sticky; top: 0; z-index: 50; background: rgba(247,246,242,0.85); backdrop-filter: blur(14px); border-bottom: 1px solid var(--line); }
  .nav { display: flex; align-items: center; gap: 32px; padding: 18px 0; }
  .nav .logo-link { font-size: 34px; }
  .nav .crumb { font-family: "JetBrains Mono", monospace; font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-3); display: inline-flex; align-items: center; gap: 8px; padding-left: 14px; border-left: 1px solid var(--line-2); }
  .nav .crumb b { color: var(--ink-0); font-weight: 600; }
  .nav .links { display: flex; gap: 28px; margin-left: auto; align-items: center; }
  .nav .links a { font-size: 17px; font-weight: 500; color: var(--ink-1); transition: color 150ms ease; }
  .nav .links a:hover { color: var(--ink-0); }
  .nav .links a.active { color: var(--accent); font-weight: 700; }
  .nav .phone { font-family: "JetBrains Mono", monospace; font-size: 15px; color: var(--ink-0); padding: 10px 18px; border: 1.5px solid var(--ink-0); border-radius: 999px; transition: all 150ms ease; font-weight: 600; }
  .nav .phone:hover { background: var(--ink-0); color: #fff; }
  @media (max-width: 1024px) { .nav .links, .nav .crumb { display: none; } }
  @media (max-width: 520px) {
    .nav { gap: 12px; }
    .nav .logo-link { font-size: 31px; }
    .nav .phone { white-space: nowrap; font-size: 12.5px; padding: 10px 13px; }
  }

  /* HERO */
  .hero { padding: 80px 0 56px; border-bottom: 1px solid var(--line); }
  h1 {
    font-family: "Source Serif 4", Georgia, serif; font-weight: 500;
    font-size: clamp(48px, 6.4vw, 96px);
    line-height: 1.0; letter-spacing: -0.022em;
    color: var(--ink-0); margin: 0 0 28px; text-wrap: balance; max-width: 18ch;
  }
  h1 em { font-style: italic; color: var(--accent); font-weight: 500; }
  h1 p, .faq-section h2 p { margin: 0; display: inline; }
  .hero .lede { font-family: "Source Serif 4", Georgia, serif; font-size: clamp(20px, 2vw, 24px); line-height: 1.5; color: var(--ink-1); margin: 0; max-width: 56ch; font-weight: 400; }
  .hero .lede p { margin: 0; }
  .hero .lede em { font-style: italic; color: var(--ink-2); }

  /* MAIN */
  .main { padding: 80px 0; border-bottom: 1px solid var(--line); }
  .grid { display: grid; grid-template-columns: minmax(0, 1.16fr) minmax(360px, 0.84fr); gap: 64px; align-items: start; }
  @media (max-width: 980px) { .grid { grid-template-columns: 1fr; gap: 32px; } }

  /* FORM */
  .form-card {
    background: var(--bg-2); border: 1px solid var(--line); border-radius: 18px;
    padding: 40px; box-shadow: 0 24px 60px -10px rgba(60,40,20,0.10);
  }
  .form-card--quote {
    border-radius: 28px;
    padding: 0;
    overflow: hidden;
  }
  @media (max-width: 600px) { .form-card { padding: 28px 24px; } }
  @media (max-width: 600px) { .form-card--quote { padding: 0; } }
  .form-card h2 { font-family: "Source Serif 4", Georgia, serif; font-weight: 600; font-size: 30px; letter-spacing: -0.018em; color: var(--ink-0); margin: 0 0 8px; line-height: 1.15; }
  .form-card h2 em { font-style: italic; color: var(--accent); font-weight: 500; }
  .form-card .sub { font-size: 15.5px; color: var(--ink-2); margin: 0 0 26px; line-height: 1.5; }
  .form-row { display: grid; gap: 18px; margin-bottom: 18px; }
  .form-row.two { grid-template-columns: 1fr 1fr; }
  @media (max-width: 540px) { .form-row.two { grid-template-columns: 1fr; } }
  .field { display: flex; flex-direction: column; gap: 8px; }
  .field label, .field .field-label { font-family: "JetBrains Mono", monospace; font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-3); font-weight: 600; }
  .field label .req, .field .field-label .req { color: var(--accent); }
  .field input, .field textarea, .field select {
    background: var(--bg);
    border: 1.5px solid var(--line);
    border-radius: 10px;
    padding: 13px 14px;
    font-family: "Inter Tight", sans-serif;
    font-size: 15.5px;
    color: var(--ink-0);
    transition: border-color 150ms ease, background 150ms ease;
    outline: none;
    width: 100%;
  }
  .field textarea { resize: vertical; min-height: 120px; line-height: 1.5; font-family: inherit; }
  .field input::placeholder, .field textarea::placeholder { color: var(--ink-3); }
  .field input:focus, .field textarea:focus, .field select:focus { border-color: var(--accent); background: #fff; }
  .field select { appearance: none; background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'><path d='M3 5l3 3 3-3' fill='none' stroke='%233d3d44' stroke-width='1.5' stroke-linecap='round'/></svg>"); background-repeat: no-repeat; background-position: right 14px center; padding-right: 38px; }

  /* Service chip select */
  .chips { display: flex; flex-wrap: wrap; gap: 8px; }
  .chip {
    font-family: "JetBrains Mono", monospace;
    font-size: 12px; letter-spacing: 0.06em;
    color: var(--ink-1);
    background: var(--bg);
    border: 1.5px solid var(--line);
    padding: 9px 14px; border-radius: 999px;
    cursor: pointer;
    user-select: none;
    transition: all 150ms ease;
  }
  .chip:hover { border-color: var(--ink-2); }
  .chip.on { background: var(--ink-0); color: #fff; border-color: var(--ink-0); }
  .chip input { display: none; }
  .chip:has(input:checked) { background: var(--ink-0); color: #fff; border-color: var(--ink-0); }

  /* Budget radios — segmented */
  .seg { display: grid; grid-template-columns: repeat(4, 1fr); border: 1.5px solid var(--line); border-radius: 10px; overflow: hidden; background: var(--bg); }
  @media (max-width: 540px) { .seg { grid-template-columns: 1fr 1fr; } }
  .seg label {
    text-align: center; padding: 12px 8px;
    font-family: "JetBrains Mono", monospace; font-size: 12px;
    color: var(--ink-1); cursor: pointer; transition: all 150ms ease;
    border-right: 1px solid var(--line);
    text-transform: none; letter-spacing: 0;
  }
  .seg label:last-child { border-right: 0; }
  .seg input { display: none; }
  .seg input:checked + label, .seg label:has(input:checked) { background: var(--ink-0); color: #fff; }

  .submit-row { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-top: 22px; flex-wrap: wrap; }
  .submit-row .note { font-family: "JetBrains Mono", monospace; font-size: 11px; letter-spacing: 0.06em; color: var(--ink-3); max-width: 28ch; line-height: 1.5; }
  .btn { display: inline-flex; align-items: center; gap: 10px; padding: 15px 28px; border-radius: 999px; font-size: 16px; font-weight: 600; transition: all 180ms ease; cursor: pointer; border: 0; }
  .btn.pri { background: var(--accent); color: #fff; box-shadow: 0 8px 24px rgba(255,106,61,0.32); font-family: inherit; }
  .btn.pri:hover { background: #f25a2c; transform: translateY(-2px); }
  .btn.dark { background: var(--ink-0); color: #fff; }
  .btn.dark:hover { background: var(--accent); }

  .contact-quote-form {
    padding: clamp(38px, 4vw, 56px);
    display: flex;
    flex-direction: column;
    gap: 22px;
    background: var(--bg-2);
  }
  @media (max-width: 600px) { .contact-quote-form { padding: 28px 24px; } }
  .contact-quote-form .wpcf7,
  .contact-quote-form .wpcf7 form {
    margin: 0;
  }
  .contact-quote-form .wpcf7 form {
    display: flex;
    flex-direction: column;
    gap: 22px;
  }
  .contact-quote-form .wpcf7 p {
    margin: 0;
  }
  .contact-quote-form .wpcf7 form > p:has(.qc-submit-wrap) {
    display: flex;
    flex-direction: column;
    gap: 22px;
  }
  .contact-quote-form .wpcf7 br {
    display: none;
  }
  .contact-quote-form .wpcf7-response-output {
    margin: 0;
    border-radius: 12px;
    font: 600 13px/1.4 "Inter Tight", system-ui, sans-serif;
  }
  .qc-field-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 22px;
  }
  .qc-field-row > p {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 22px;
    margin: 0;
  }
  @media (max-width: 520px) { .qc-field-row { grid-template-columns: 1fr; } }
  @media (max-width: 520px) { .qc-field-row > p { grid-template-columns: 1fr; } }
  .qc-field {
    display: flex;
    flex-direction: column;
    gap: 9px;
  }
  .qc-label {
    font-family: "JetBrains Mono", monospace;
    font-size: 11.5px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--ink-3);
    font-weight: 600;
  }
  .qc-field input,
  .qc-field textarea {
    width: 100%;
    font-family: "Inter Tight", sans-serif;
    font-size: 17px;
    color: var(--ink-0);
    background: var(--bg);
    border: 1px solid var(--line-2);
    border-radius: 10px;
    padding: 15px 16px;
    transition: border-color 150ms ease, background 150ms ease, box-shadow 150ms ease;
    outline: none;
    resize: vertical;
  }
  .qc-field textarea {
    min-height: 178px;
    line-height: 1.5;
  }
  .qc-field input::placeholder,
  .qc-field textarea::placeholder {
    color: var(--ink-3);
  }
  .qc-field input:focus,
  .qc-field textarea:focus {
    border-color: var(--accent);
    background: var(--bg-2);
    box-shadow: 0 0 0 3px rgba(255,106,61,0.12);
  }
  .qc-chips,
  .qc-chips .wpcf7-form-control {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
  }
  .qc-chips .wpcf7-list-item {
    margin: 0;
  }
  .qc-chips .wpcf7-list-item label {
    display: inline-flex;
    align-items: center;
  }
  .qc-chips .wpcf7-list-item input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
  }
  .qc-chips .wpcf7-list-item-label {
    font-family: "Inter Tight", sans-serif;
    font-size: 15px;
    font-weight: 500;
    color: var(--ink-1);
    background: var(--bg);
    border: 1px solid var(--line-2);
    padding: 9px 16px;
    border-radius: 999px;
    cursor: pointer;
    transition: all 150ms ease;
    letter-spacing: -0.005em;
  }
  .qc-chips .wpcf7-list-item-label:hover {
    border-color: var(--ink-0);
    color: var(--ink-0);
  }
  .qc-chips input:checked + .wpcf7-list-item-label {
    background: var(--ink-0);
    border-color: var(--ink-0);
    color: #fff;
  }
  .qc-submit-wrap {
    margin-top: 4px;
    align-self: flex-start;
    display: inline-flex;
    align-items: center;
    position: relative;
  }
  .qc-submit {
    align-self: flex-start;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 17px 54px 17px 28px;
    background: var(--accent);
    color: #fff;
    border: 0;
    border-radius: 999px;
    font-family: "Inter Tight", sans-serif;
    font-size: 17px;
    font-weight: 600;
    cursor: pointer;
    transition: all 180ms ease;
    box-shadow: 0 8px 24px rgba(255,106,61,0.32);
    letter-spacing: -0.005em;
  }
  .qc-submit:hover {
    background: #f25a2c;
    transform: translateY(-2px);
  }
  .qc-submit-wrap .arr {
    position: absolute;
    right: 24px;
    width: 14px;
    height: 14px;
    color: #fff;
    pointer-events: none;
  }
  .contact-quote-form .wpcf7-spinner {
    margin: 0 0 0 8px;
  }

  /* RIGHT — schedule with Waqid */
  .side-card {
    background: var(--bg-paper);
    border: 1px solid var(--line);
    border-radius: 18px;
    padding: 32px;
  }
  .side-card h3 { font-family: "Source Serif 4", Georgia, serif; font-weight: 600; font-size: 26px; letter-spacing: -0.014em; color: var(--ink-0); margin: 0 0 6px; line-height: 1.15; }
  .side-card h3 em { font-style: italic; color: var(--accent); font-weight: 500; }
  .side-card .meta { font-family: "JetBrains Mono", monospace; font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-3); margin-bottom: 22px; }

  .waqid {
    display: grid; grid-template-columns: 88px 1fr; gap: 18px; align-items: center;
    background: var(--bg-2);
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 18px 20px;
  }
  .waqid .portrait { width: 88px; height: 88px; border-radius: 50%; overflow: hidden; background: var(--bg-paper); border: 1px solid var(--line-2); display: grid; place-items: center; flex-shrink: 0; }
  .waqid .portrait img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .waqid .who b { display: block; font-family: "Source Serif 4", Georgia, serif; font-weight: 600; font-size: 20px; color: var(--ink-0); letter-spacing: -0.01em; }
  .waqid .who .role { font-family: "JetBrains Mono", monospace; font-size: 10.5px; letter-spacing: 0.14em; color: var(--accent); text-transform: uppercase; margin-top: 4px; display: block; }
  .waqid .who .tag { font-size: 14px; color: var(--ink-2); margin-top: 6px; line-height: 1.45; }

  .creds { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; margin-top: 18px; background: var(--bg-2); border: 1px solid var(--line); border-radius: 14px; overflow: hidden; }
  .creds .c { padding: 16px 14px; text-align: center; border-right: 1px solid var(--line); }
  .creds .c:last-child { border-right: 0; }
  .creds .c .n { font-family: "Source Serif 4", Georgia, serif; font-size: 28px; font-weight: 600; color: var(--ink-0); letter-spacing: -0.02em; line-height: 1; }
  .creds .c .n em { font-style: italic; color: var(--accent); font-weight: 500; }
  .creds .c .l { font-family: "JetBrains Mono", monospace; font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-3); margin-top: 8px; line-height: 1.4; }

  .bullets { list-style: none; padding: 0; margin: 18px 0 22px; display: flex; flex-direction: column; gap: 10px; }
  .bullets li { font-size: 14.5px; color: var(--ink-1); line-height: 1.5; padding-left: 22px; position: relative; }
  .bullets li::before { content: ""; position: absolute; left: 0; top: 9px; width: 10px; height: 1.5px; background: var(--accent); }
  .bullets li b { color: var(--ink-0); font-weight: 600; }

  .call-cta {
    display: flex; align-items: center; justify-content: space-between; gap: 14px;
    background: var(--ink-0); color: #fff;
    border-radius: 14px; padding: 18px 22px;
    transition: background 180ms ease;
  }
  .call-cta:hover { background: var(--accent); }
  .call-cta .lab { font-family: "JetBrains Mono", monospace; font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: rgba(255,255,255,0.65); display: block; margin-bottom: 4px; }
  .call-cta .num { font-family: "JetBrains Mono", monospace; font-size: 22px; font-weight: 600; letter-spacing: -0.01em; color: #fff; }
  .call-cta svg { color: #fff; width: 20px; height: 20px; }

  .hours-card {
    background: var(--bg-2);
    border: 1px solid var(--line);
    border-radius: 18px;
    padding: 28px 32px;
    margin-top: 24px;
  }
  .hours-card h3 { font-family: "Source Serif 4", Georgia, serif; font-weight: 600; font-size: 22px; margin: 0 0 14px; color: var(--ink-0); letter-spacing: -0.012em; }
  .hours-grid { display: grid; grid-template-columns: 1fr auto; gap: 4px 24px; font-family: "JetBrains Mono", monospace; font-size: 13px; }
  .hours-grid .day { color: var(--ink-2); padding: 6px 0; border-bottom: 1px dashed var(--line-2); }
  .hours-grid .time { color: var(--ink-0); padding: 6px 0; border-bottom: 1px dashed var(--line-2); text-align: right; }
  .hours-grid .day.now { color: var(--accent); font-weight: 600; }
  .hours-grid .time.now { color: var(--accent); font-weight: 600; }
  .hours-grid .day.now::before { content: "→ "; }

  .live-now {
    margin-top: 18px;
    display: inline-flex; align-items: center; gap: 8px;
    font-family: "JetBrains Mono", monospace; font-size: 12px; color: var(--moss);
    padding: 8px 14px; border-radius: 999px; background: rgba(107,125,90,0.1); border: 1px solid rgba(107,125,90,0.2);
  }
  .live-now::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--moss); animation: pulse 2s ease-in-out infinite; }
  @keyframes pulse { 0%,100% { opacity: 1; } 50% { opacity: 0.4; } }

  /* OFFICE */
  .office { padding: 80px 0; border-bottom: 1px solid var(--line); background: var(--bg-paper); }
  .office .grid { grid-template-columns: 1fr 1fr; gap: 48px; }
  .office h2 { font-family: "Source Serif 4", Georgia, serif; font-weight: 500; font-size: clamp(36px, 4.4vw, 56px); line-height: 1.04; letter-spacing: -0.018em; color: var(--ink-0); margin: 0 0 24px; max-width: 16ch; }
  .office h2 em { font-style: italic; color: var(--accent); font-weight: 500; }
  .office p { font-size: 17px; line-height: 1.6; color: var(--ink-1); margin: 0 0 14px; max-width: 50ch; }
  .office p strong { color: var(--ink-0); font-weight: 600; }
  .office .addr-block {
    margin-top: 22px; padding: 18px 22px;
    background: var(--bg-2); border: 1px solid var(--line); border-radius: 12px;
    font-family: "JetBrains Mono", monospace; font-size: 13.5px; line-height: 1.7; color: var(--ink-1);
  }
  .office .addr-block b { color: var(--ink-0); }
  .office-map {
    background: var(--bg-2); border: 1px solid var(--line); border-radius: 16px;
    aspect-ratio: 5 / 4; overflow: hidden; position: relative;
  }
  .office-map iframe { width: 100%; height: 100%; border: 0; display: block; filter: saturate(0.85); }
  .office-map .map-link { position: absolute; left: 14px; bottom: 14px; background: var(--ink-0); color: #fff; font-family: "JetBrains Mono", monospace; font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; padding: 9px 14px; border-radius: 999px; display: inline-flex; align-items: center; gap: 8px; box-shadow: 0 6px 18px rgba(0,0,0,0.18); }
  .office-map .map-link:hover { background: var(--accent); }

  /* FAQ light */
  .faq-section { padding: 80px 0; border-bottom: 1px solid var(--line); }
  .faq-section .head { max-width: 720px; margin: 0 auto 48px; text-align: center; }
  .faq-section h2 { font-family: "Source Serif 4", Georgia, serif; font-weight: 500; font-size: clamp(36px, 4.4vw, 56px); line-height: 1.04; letter-spacing: -0.018em; color: var(--ink-0); margin: 0 0 16px; }
  .faq-section h2 em { font-style: italic; color: var(--accent); font-weight: 500; }
  .faq-section .head p { font-size: 18px; color: var(--ink-1); margin: 0; line-height: 1.6; }
  .faq-list { max-width: 880px; margin: 0 auto; border-top: 1px solid var(--line); }
  .faq-item { border-bottom: 1px solid var(--line); padding: 24px 0; cursor: pointer; display: grid; grid-template-columns: 1fr auto; gap: 20px; }
  .faq-item h4 { font-family: "Source Serif 4", Georgia, serif; font-weight: 500; font-size: 21px; letter-spacing: -0.012em; color: var(--ink-0); margin: 0; line-height: 1.3; transition: color 150ms ease; }
  .faq-item:hover h4 { color: var(--accent); }
  .faq-item .toggle { width: 30px; height: 30px; border: 1.5px solid var(--ink-0); border-radius: 50%; display: grid; place-items: center; transition: all 200ms ease; }
  .faq-item.open .toggle { background: var(--ink-0); color: #fff; }
  .faq-item.open .toggle svg { transform: rotate(45deg); }
  .faq-item .toggle svg { transition: transform 200ms ease; }
  .faq-item .ans { grid-column: 1 / -1; font-size: 16px; color: var(--ink-2); line-height: 1.6; max-width: 64ch; max-height: 0; overflow: hidden; transition: max-height 250ms ease, margin-top 200ms ease; }
  .faq-item.open .ans { max-height: 280px; margin-top: 12px; }

  /* FOOTER */
  footer.site { padding: 72px 0 28px; background: var(--bg); border-top: 1px solid var(--line); }
  footer.site .top { display: grid; grid-template-columns: 1.4fr repeat(3, 1fr); gap: 40px; padding-bottom: 48px; border-bottom: 1px solid var(--line); }
  @media (max-width: 880px) { footer.site .top { grid-template-columns: 1fr 1fr; } }
  footer.site .brand .logo-link { font-size: 36px; display: inline-block; margin-bottom: 14px; }
  footer.site .brand p { font-size: 16px; line-height: 1.55; color: var(--ink-1); margin: 0 0 14px; max-width: 36ch; }
  footer.site .brand .addr { font-family: "JetBrains Mono", monospace; font-size: 13.5px; line-height: 1.7; color: var(--ink-3); }
  footer.site .footer-heading { font-family: "JetBrains Mono", monospace; font-weight: 500; font-size: 12.5px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-3); margin: 0 0 16px; }
  footer.site ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 9px; }
  footer.site ul a { font-size: 15px; color: var(--ink-1); }
  footer.site ul a:hover { color: var(--accent); }
  footer.site .bottom { padding-top: 22px; display: flex; justify-content: space-between; font-family: "JetBrains Mono", monospace; font-size: 12.5px; letter-spacing: 0.06em; color: var(--ink-3); flex-wrap: wrap; gap: 12px; }

  .arr { display: inline-block; width: 1em; height: 1em; vertical-align: -0.1em; }
