/* Roof Payout Calculator — additions layered on top of site styles.css */

.policy-help {
  display: none;
  margin-top: 8px;
  padding: 12px 14px;
  border-left: 5px solid var(--orange);
  background: #fff7ed;
  border-radius: 8px;
  color: #4a2a10;
  font-weight: 700;
  font-size: 0.95rem;
}

.field-row {
  display: grid;
  gap: 12px;
  grid-template-columns: 1fr;
}

@media (min-width: 560px) {
  .field-row { grid-template-columns: 1fr 1fr; }
}

#results {
  display: grid;
  gap: 20px;
  max-width: 1120px;
  margin: 28px auto 0;
}

#results .result-card { padding: 22px; }
#results .result-amount { font-size: clamp(2.4rem, 9vw, 4rem); }

.chart-wrap {
  width: 100%;
  overflow-x: auto;
  padding: 12px 0;
}

.payout-chart {
  width: 100%;
  height: auto;
  max-width: 720px;
  display: block;
  margin: 0 auto;
}

.breakdown {
  width: 100%;
  border-collapse: collapse;
  margin-top: 12px;
}

.breakdown td {
  padding: 10px 8px;
  border-bottom: 1px solid var(--border);
  font-size: 0.98rem;
}

.breakdown td:last-child {
  text-align: right;
  font-variant-numeric: tabular-nums;
  font-weight: 800;
  color: var(--navy);
  white-space: nowrap;
}

.breakdown tr.row-strong td {
  background: #f3f8fc;
  font-weight: 900;
  color: var(--navy);
}

.flags-card {
  border-left: 6px solid var(--orange);
}

.flag-list,
.info-list {
  margin: 0;
  padding-left: 20px;
  display: grid;
  gap: 10px;
}

.flag-list li { color: #4a2a10; font-weight: 700; }

.cta-stack {
  display: grid;
  gap: 14px;
}

.email-capture {
  padding: 18px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--soft-blue);
}

.email-row {
  display: grid;
  gap: 10px;
  grid-template-columns: 1fr;
}

@media (min-width: 520px) {
  .email-row { grid-template-columns: 1fr auto; }
}

.pillar-content {
  max-width: 820px;
  margin: 0 auto;
}

.pillar-content h2 {
  margin-top: 36px;
}

.pillar-content p {
  color: var(--ink);
  font-size: 1.05rem;
  margin-bottom: 14px;
}

@media print {
  #roofForm, .cta-stack, .email-capture { display: none !important; }
  #results { display: block !important; }
}
