/* ============================================================
   quote-form.css — Multi-step quote wizard
   Depends on site.css design tokens. Consistent with coverage-checker.css
   ============================================================ */

.quote-wrap { max-width: 720px; margin: 0 auto; }

/* Resume banner */
.quote-resume { display: none; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap;
  background: var(--bg-warm); border: 1px solid var(--gold); border-radius: 4px; padding: 16px 20px; margin-bottom: 28px; }
.quote-resume.is-visible { display: flex; }
.quote-resume p { margin: 0; font-size: 15px; color: var(--ink-2); }
.quote-resume .quote-resume-actions { display: flex; gap: 8px; }

/* Progress bar */
.quote-progress { margin-bottom: 36px; }
.quote-progress-meta { display: flex; justify-content: space-between; font-size: 13px; font-weight: 500; color: var(--muted); margin-bottom: 10px; letter-spacing: 0.02em; }
.quote-progress-track { height: 6px; background: var(--bg-soft); border-radius: 999px; overflow: hidden; }
.quote-progress-fill { height: 100%; background: var(--gold); border-radius: 999px; transition: width 0.35s ease; width: 25%; }

/* Step container + fade */
.quote-step { display: none; opacity: 0; transition: opacity 0.25s ease; }
.quote-step.is-active { display: block; opacity: 1; }
.quote-step h2 { font-size: clamp(28px, 3.4vw, 38px); font-weight: 500; letter-spacing: -0.02em; margin-bottom: 10px; }
.quote-step .quote-sub { font-size: 17px; color: var(--ink-2); margin-bottom: 32px; }

/* Service selection tiles */
.quote-services { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
@media (max-width: 640px) { .quote-services { grid-template-columns: 1fr; } }
.quote-service-tile { display: flex; align-items: center; gap: 16px; text-align: left; width: 100%;
  padding: 20px; border: 1px solid var(--line); border-radius: 4px; background: var(--bg); cursor: pointer;
  font-family: inherit; font-size: 16px; font-weight: 500; color: var(--ink); transition: border-color 0.15s ease, background 0.15s ease, transform 0.12s ease; }
.quote-service-tile:hover { border-color: var(--ink); background: var(--bg-soft); }
.quote-service-tile.is-selected { border-color: var(--gold); background: var(--bg-warm); }
.quote-service-tile:active { transform: translateY(1px); }
.quote-service-icon { flex-shrink: 0; width: 40px; height: 40px; color: var(--gold); }
.quote-service-icon svg { width: 100%; height: 100%; }

/* Fields */
.quote-field { margin-bottom: 28px; }
.quote-field > label.quote-q { display: block; font-size: 16px; font-weight: 500; color: var(--ink); margin-bottom: 14px; }
.quote-field .quote-optional { font-weight: 400; color: var(--muted); font-size: 13px; }
.quote-pills { display: flex; flex-wrap: wrap; gap: 8px; }
.quote-pill { padding: 11px 18px; border: 1px solid var(--line); border-radius: 999px; background: var(--bg);
  font-family: inherit; font-size: 15px; color: var(--ink-2); cursor: pointer; transition: all 0.15s ease; }
.quote-pill:hover { border-color: var(--ink); color: var(--ink); }
.quote-pill.is-selected { background: var(--ink); color: #fff; border-color: var(--ink); }
.quote-input, .quote-textarea { width: 100%; font-family: inherit; font-size: 16px; color: var(--ink);
  padding: 14px 16px; border: 1px solid var(--line); border-radius: 4px; background: var(--bg); transition: border-color 0.15s ease; }
.quote-input::placeholder, .quote-textarea::placeholder { color: var(--muted); }
.quote-input:focus, .quote-textarea:focus { outline: none; border-color: var(--ink); }
.quote-textarea { min-height: 110px; resize: vertical; }
.quote-input.has-error, .quote-textarea.has-error { border-color: #b4232a; }

/* Notice (e.g. lease warning) */
.quote-notice { display: flex; gap: 12px; align-items: flex-start; padding: 16px 18px; margin-bottom: 28px;
  background: var(--bg-warm); border: 1px solid var(--gold); border-radius: 4px; font-size: 14.5px; color: var(--ink-2); line-height: 1.5; }
.quote-notice svg { flex-shrink: 0; width: 20px; height: 20px; color: var(--gold); margin-top: 1px; }

/* Field-level error */
.quote-err { display: none; color: #b4232a; font-size: 13.5px; margin-top: 8px; }
.quote-err.is-visible { display: block; }

/* Nav buttons */
.quote-nav { display: flex; justify-content: space-between; gap: 12px; margin-top: 8px; }
.quote-btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; font-family: inherit;
  font-size: 16px; font-weight: 500; padding: 15px 28px; border-radius: 999px; cursor: pointer; border: 1px solid transparent; transition: background 0.18s ease, color 0.18s ease, border-color 0.18s ease, transform 0.12s ease; }
.quote-btn-primary { background: var(--ink); color: #fff; }
.quote-btn-primary:hover { background: var(--accent); }
.quote-btn-gold { background: var(--gold); color: #fff; }
.quote-btn-gold:hover { background: #b58c40; }
.quote-btn-ghost { background: transparent; color: var(--ink-2); border-color: var(--line); }
.quote-btn-ghost:hover { color: var(--ink); border-color: var(--ink); }
.quote-btn:active { transform: translateY(1px); }
.quote-btn[disabled] { opacity: 0.45; cursor: not-allowed; }

/* Contact grid */
.quote-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
@media (max-width: 640px) { .quote-grid-2 { grid-template-columns: 1fr; } }

/* Confirmation */
.quote-confirm { text-align: center; padding: 20px 0; }
.quote-confirm .cc-check { width: 64px; height: 64px; margin: 0 auto 20px; border-radius: 50%; background: rgba(46,160,87,0.12); display: flex; align-items: center; justify-content: center; }
.quote-confirm .cc-check svg { width: 34px; height: 34px; stroke: #2ea057; fill: none; stroke-width: 2.5; }
.quote-confirm h2 { font-size: clamp(26px, 3.4vw, 36px); margin-bottom: 12px; }
.quote-confirm p { font-size: 17px; color: var(--ink-2); margin-bottom: 6px; }
.quote-confirm .quote-confirm-sub { font-size: 15px; color: var(--muted); margin-bottom: 32px; }
.quote-next { text-align: left; max-width: 480px; margin: 0 auto 32px; background: var(--bg-soft); border-radius: 4px; padding: 24px 28px; }
.quote-next h3 { font-size: 14px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--muted); font-weight: 500; margin-bottom: 16px; }
.quote-next ol { margin: 0; padding-left: 20px; }
.quote-next li { font-size: 15px; color: var(--ink-2); margin-bottom: 10px; line-height: 1.5; }
.quote-confirm-actions { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }

/* Submit error */
.quote-submit-error { display: none; color: #b4232a; font-size: 14px; margin-top: 14px; text-align: center; }
.quote-submit-error.is-visible { display: block; }


/* ----- Mobile polish: pill buttons hit 44px tap target ----- */
@media (max-width: 768px) {
  .quote-pill { padding: 13px 20px; min-height: 44px; }
}

/* ----- Photo upload slots (EV charger flow) ----- */
.quote-photos-intro { font-size: 14.5px; color: var(--ink-2); line-height: 1.5; margin: -8px 0 18px; }
.quote-photo-slots { display: flex; flex-direction: column; gap: 18px; }
.quote-photo-slot { padding: 14px 16px; border: 1px solid var(--line); border-radius: 4px; background: var(--bg); }
.quote-photo-slot-label { font-size: 15px; font-weight: 500; color: var(--ink); margin-bottom: 4px; }
.quote-photo-slot-hint { font-size: 13.5px; color: var(--muted); margin-bottom: 12px; line-height: 1.5; }

/* Thumbnails grid (multiple photos per slot, wraps cleanly) */
.quote-photo-thumbs { display: flex; flex-wrap: wrap; gap: 12px; }
.quote-photo-thumbs:empty { display: none; }
.quote-photo-thumb { display: flex; flex-direction: column; align-items: center; gap: 6px; }
.quote-photo-thumb img { width: 80px; height: 80px; border-radius: 4px; object-fit: cover; display: block; border: 1px solid var(--line); }
.quote-photo-remove { background: none; border: none; padding: 0; font-family: inherit; font-size: 12px; color: var(--muted); text-decoration: underline; text-underline-offset: 2px; cursor: pointer; }
.quote-photo-remove:hover { color: var(--ink); }

/* Control area: 0 photos = native file input; 1-5 = pill 'Add another'; 6 = 'plenty' note */
.quote-photo-control { margin-top: 12px; }
.quote-photo-control:empty { display: none; }
.quote-photo-input { display: block; font-family: inherit; font-size: 14px; color: var(--ink-2); max-width: 100%; }
.quote-photo-input::file-selector-button { font-family: inherit; font-size: 14px; padding: 8px 14px; margin-right: 12px; border: 1px solid var(--line); border-radius: 999px; background: var(--bg-soft); color: var(--ink); cursor: pointer; transition: border-color 0.15s ease, background 0.15s ease; }
.quote-photo-input::file-selector-button:hover { border-color: var(--ink); background: var(--bg); }
.quote-photo-input.is-hidden { position: absolute; opacity: 0; width: 1px; height: 1px; pointer-events: none; }
.quote-photo-addmore { display: inline-flex; align-items: center; padding: 8px 16px; border: 1px solid var(--line); border-radius: 999px; background: var(--bg-soft); color: var(--ink); cursor: pointer; font-family: inherit; font-size: 14px; font-weight: 500; transition: border-color 0.15s ease, background 0.15s ease; }
.quote-photo-addmore:hover { border-color: var(--ink); background: var(--bg); }
.quote-photo-maxed { font-size: 13px; color: var(--muted); margin: 4px 0 0; }

/* Small ancillary notes */
.quote-photo-skipped { font-size: 13px; color: var(--muted); margin: 8px 0 0; }
.quote-photo-skipped:empty { display: none; }
.quote-photo-status { margin-top: 8px; font-size: 13.5px; color: var(--muted); line-height: 1.5; }
.quote-photo-status:empty { display: none; }

/* In-flight 'Hang on...' note shown by the step-2 Next guard */
.quote-photos-wait { display: none; margin-top: 14px; font-size: 13.5px; color: var(--gold); font-weight: 500; }
.quote-photos-wait.is-visible { display: block; }

@media (max-width: 480px) {
  .quote-photo-slot { padding: 12px 14px; }
  .quote-photo-thumb img { width: 76px; height: 76px; }
}

/* ----- Document upload (PDF/image) for R&R roofing branch ----- */
.quote-document { /* inherits .quote-field spacing */ }
.quote-doc-status { margin-top: 4px; font-size: 14px; color: var(--ink); line-height: 1.5; }
.quote-doc-input { display: block; font-family: inherit; font-size: 14px; color: var(--ink-2); max-width: 100%; }
.quote-doc-input::file-selector-button { font-family: inherit; font-size: 14px; padding: 8px 14px; margin-right: 12px; border: 1px solid var(--line); border-radius: 999px; background: var(--bg-soft); color: var(--ink); cursor: pointer; transition: border-color 0.15s ease, background 0.15s ease; }
.quote-doc-input::file-selector-button:hover { border-color: var(--ink); background: var(--bg); }
.quote-doc-uploaded { display: inline-flex; align-items: center; gap: 8px; flex-wrap: wrap; padding: 8px 14px; border: 1px solid var(--line); border-radius: 4px; background: var(--bg-warm); }
.quote-doc-check { color: #2ea057; font-weight: 600; }
.quote-doc-filename { color: var(--ink-2); font-size: 13.5px; max-width: 320px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.quote-doc-remove { background: none; border: none; padding: 0; font-family: inherit; font-size: 13px; color: var(--muted); text-decoration: underline; text-underline-offset: 2px; cursor: pointer; }
.quote-doc-remove:hover { color: var(--ink); }
.quote-doc-progress { font-size: 13.5px; color: var(--muted); margin: 0; }
.quote-doc-fail { font-size: 13.5px; color: #b4232a; margin: 0 0 8px; }
@media (max-width: 480px) {
  .quote-doc-filename { max-width: 180px; }
}

/* ----- EV install estimate (shown on the confirmation step for EV charger flow only) ----- */
.quote-estimate-amount { font-size: clamp(32px, 4.5vw, 44px); font-weight: 600; letter-spacing: -0.02em; color: var(--ink); margin: 8px 0 16px; line-height: 1.1; }
.quote-estimate-disclaimer { font-size: 13px; color: var(--muted); line-height: 1.55; margin: 0; font-style: italic; }
