/* Conveyancing estimator — v7 theme (hairlines, paper, gold) */

.estimator-shell {
  background: var(--surface);
  border: 1px solid var(--hairline-strong);
  border-radius: var(--radius);
  position: relative;
}
.estimator-shell::before {
  content: ""; position: absolute; top: -7px; left: -7px;
  width: 30px; height: 30px;
  border-top: 2px solid var(--gold); border-left: 2px solid var(--gold);
}
.estimator-shell::after {
  content: ""; position: absolute; bottom: -7px; right: -7px;
  width: 30px; height: 30px;
  border-bottom: 2px solid var(--gold); border-right: 2px solid var(--gold);
}

.estimator-intro { padding: 40px 44px 0; max-width: 820px; }
.estimator-intro h2 { margin-bottom: 10px; }
.estimator-intro p { font-size: 16px; }

.estimator-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(320px, 0.95fr);
  gap: 30px;
  padding: 30px 44px 44px;
}

.estimator-form {
  background: var(--paper);
  border: 1px solid var(--hairline);
  border-radius: var(--radius);
  padding: 28px;
}

.estimator-actions {
  display: flex; flex-wrap: wrap; gap: 12px;
  margin-top: 24px;
}
.estimator-button, .estimator-reset { min-width: 170px; }

.estimator-results {
  background: var(--paper-deep);
  border: 1px solid var(--hairline-strong);
  border-top: 3px solid var(--gold);
  border-radius: var(--radius);
  padding: 28px;
  min-height: 100%;
}

.results-head {
  display: flex; justify-content: space-between;
  gap: 16px; align-items: flex-start;
  margin-bottom: 20px;
}
.results-head h3 { margin: 2px 0 0; }
.results-head .kicker { margin-bottom: 4px; }

.estimate-badge {
  display: inline-flex; align-items: center;
  padding: 9px 14px;
  border-radius: var(--radius);
  background: var(--surface);
  border: 1px solid var(--hairline-strong);
  color: var(--gold-deep);
  font-size: 11px; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase;
  white-space: nowrap;
}

.results-placeholder, .results-body {
  background: var(--surface);
  border: 1px solid var(--hairline);
  border-radius: var(--radius);
  padding: 22px;
}
.results-placeholder { color: var(--muted); font-size: 15px; }

.results-list { display: grid; gap: 0; }
.result-row {
  display: flex; justify-content: space-between;
  gap: 12px; align-items: baseline;
  padding: 11px 0;
  border-bottom: 1px solid var(--hairline);
}
.result-row:last-child { border-bottom: 0; }
.result-label { font-size: 14.5px; font-weight: 500; color: var(--ink-soft); }
.result-value {
  font-weight: 600; color: var(--ink); text-align: right;
  font-variant-numeric: tabular-nums;
}

.result-total {
  margin-top: 18px;
  padding: 20px 22px;
  border-radius: var(--radius);
  background: var(--night);
  border: 1px solid var(--night);
}
.result-total .result-label {
  font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.18em;
  color: var(--gold);
}
.result-total .result-value {
  display: block; margin-top: 6px;
  font-family: var(--serif);
  font-size: 38px; font-weight: 600; line-height: 1;
  color: #fff; text-align: left;
}

.results-meta { margin-top: 18px; display: flex; flex-wrap: wrap; gap: 8px; }
.results-chip {
  display: inline-flex; align-items: center;
  padding: 7px 12px;
  border-radius: var(--radius);
  background: var(--surface);
  border: 1px solid var(--hairline-strong);
  color: var(--ink-soft);
  font-size: 12.5px; font-weight: 600;
}

.results-footnote { margin-top: 16px; color: var(--muted); font-size: 13.5px; line-height: 1.6; }
.results-cta { margin: 18px 0 0; }

@media (max-width: 980px) {
  .estimator-layout { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .estimator-intro { padding: 26px 20px 0; }
  .estimator-layout { padding: 22px 20px 26px; }
  .estimator-form, .estimator-results { padding: 20px; }
  .results-head, .result-row { flex-direction: column; align-items: flex-start; }
  .result-value { text-align: left; }
  .result-total .result-value { font-size: 32px; }
}
