/* calculator.css — styles shared by the CoverageMath calculator pages. */

.calc-intro { padding: 1.5rem 0 0.5rem; text-align: center; }
.calc-intro h1 { margin-bottom: 0.25rem; }
.calc-lead { font-size: 1.05rem; color: var(--text-muted); max-width: 62ch; margin-left: auto; margin-right: auto; }
.calc-intro .trust-row { justify-content: center; }

/* Plain-language explainer */
.explainer { max-width: 70ch; margin: 0 auto 1.5rem; }
.explainer p { color: var(--text-muted); }

/* Layout: form + results */
.calc-layout { display: grid; gap: 1.25rem; }
@media (min-width: 880px) {
  .calc-layout { grid-template-columns: minmax(0, 1fr) minmax(0, 1.1fr); align-items: start; }
}

/* Form */
.calc-form fieldset { border: none; margin: 0 0 1rem; padding: 0; }
.calc-form legend { font-weight: 700; font-size: 1.05rem; padding: 0; margin-bottom: 0.75rem; }
.field { margin-bottom: 1rem; }
.field.small { margin-bottom: 0.65rem; }
.field label { display: block; font-weight: 600; font-size: 0.92rem; margin-bottom: 0.35rem; }
.field .hint { font-weight: 400; color: var(--text-faint); font-size: 0.82rem; display: block; margin-top: 0.1rem; }

.input-wrap { position: relative; display: flex; align-items: center; }
.input-wrap .affix { position: absolute; color: var(--text-faint); font-size: 0.95rem; pointer-events: none; }
.input-wrap .affix:first-child { left: 0.8rem; }
.calc-form input[type='number'],
.calc-form input[type='text'],
.calc-form select {
  width: 100%; font-size: 1rem; font-family: inherit;
  padding: 0.65rem 0.8rem; border: 1px solid var(--border); border-radius: 10px;
  background: var(--surface); color: var(--text); appearance: none;
}
.input-wrap:has(.affix:first-child) input { padding-left: 1.6rem; }
.calc-form input:focus, .calc-form select:focus { border-color: var(--accent); }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 0.75rem; }
@media (max-width: 520px) { .field-row { grid-template-columns: 1fr; } }

/* Optional expander (MAGI helper) */
.opt-fields { padding: 0.5rem 0.85rem 0.25rem; border-left: 2px solid var(--border); margin: 0 0 1rem 0.4rem; }
details.helper { margin: 0.25rem 0 1rem; border: 1px solid var(--border); border-radius: 10px; background: var(--surface-2); }
details.helper summary { cursor: pointer; padding: 0.6rem 0.85rem; font-weight: 600; font-size: 0.9rem; color: var(--accent); }
details.helper[open] summary { border-bottom: 1px solid var(--border); }
details.helper .helper-body { padding: 0.75rem 0.85rem; }
.helper-result { font-weight: 700; margin: 0.5rem 0 0; }

/* Enrollee age rows */
.ages-list { display: flex; flex-direction: column; gap: 0.5rem; }
.age-row { display: grid; grid-template-columns: 1fr auto; gap: 0.5rem; align-items: center; }
.age-row .age-label { font-size: 0.85rem; color: var(--text-muted); }

.info-note {
  background: color-mix(in srgb, var(--teal) 10%, transparent);
  border: 1px solid color-mix(in srgb, var(--teal) 30%, transparent);
  border-radius: 8px; padding: 0.7rem 0.85rem; font-size: 0.85rem; color: var(--text-muted); margin-top: 0.5rem;
}

/* Results */
.results-panel { min-height: 0; }
.results-empty { border: 1px dashed var(--border); border-radius: var(--radius); padding: 2rem 1.25rem; text-align: center; color: var(--text-faint); }

/* Plain-English headline sentence */
.result-headline { font-size: 1.05rem; line-height: 1.5; margin: 0 0 1rem; }
.result-headline strong { color: var(--accent-hover); }

/* Hero subsidy number */
.ptc-hero {
  background: linear-gradient(160deg, var(--surface), var(--surface-2));
  border: 1px solid var(--border); border-top: 3px solid var(--success);
  border-radius: var(--radius); padding: 1.1rem 1.25rem; text-align: center; box-shadow: var(--shadow); margin-bottom: 1rem;
}
.ptc-hero .ptc-amount { font-size: 2.1rem; font-weight: 800; color: var(--success); font-variant-numeric: tabular-nums; }
.ptc-hero .ptc-label { font-size: 0.85rem; color: var(--text-faint); }
.ptc-hero.zero .ptc-amount { color: var(--text-muted); }

/* Result stat grid */
.result-stats { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0.6rem; margin: 1rem 0; }
.result-stat { background: var(--surface); border: 1px solid var(--border); border-radius: 10px; padding: 0.75rem; }
.result-stat .rs-num { font-size: 1.15rem; font-weight: 800; font-variant-numeric: tabular-nums; }
.result-stat .rs-label { font-size: 0.76rem; color: var(--text-faint); }
@media (max-width: 420px) { .result-stats { grid-template-columns: 1fr; } }

/* COBRA vs Marketplace — side-by-side comparison cards */
.compare-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0.75rem; margin: 1rem 0; }
@media (max-width: 460px) { .compare-grid { grid-template-columns: 1fr; } }
.compare-card {
  position: relative; border: 1px solid var(--border); border-radius: var(--radius);
  background: var(--surface); padding: 1rem 0.9rem 0.9rem; text-align: center; box-shadow: var(--shadow);
}
.compare-card.is-cheaper { border-color: color-mix(in srgb, var(--success) 55%, transparent); background: color-mix(in srgb, var(--success) 9%, var(--surface)); }
.compare-name { font-weight: 700; font-size: 0.95rem; color: var(--text-muted); }
.compare-amount { font-size: 1.7rem; font-weight: 800; font-variant-numeric: tabular-nums; margin: 0.25rem 0 0.1rem; }
.compare-amount .compare-per { font-size: 0.7rem; font-weight: 600; color: var(--text-faint); }
.compare-total { font-size: 0.85rem; color: var(--text-muted); }
.compare-sub { font-size: 0.78rem; color: var(--success); font-weight: 600; margin-top: 0.2rem; }
.compare-tag {
  position: absolute; top: -0.6rem; left: 50%; transform: translateX(-50%);
  font-size: 0.62rem; font-weight: 800; letter-spacing: 0.04em; text-transform: uppercase;
  color: #052e16; background: var(--success); padding: 0.12rem 0.6rem; border-radius: 999px; white-space: nowrap;
}

/* Eligibility flags */
.flag-row { display: flex; flex-wrap: wrap; gap: 0.5rem; margin: 0.75rem 0; }
.flag {
  display: inline-flex; align-items: center; gap: 0.35rem; font-size: 0.82rem; font-weight: 600;
  padding: 0.3rem 0.65rem; border-radius: 999px; border: 1px solid var(--border); background: var(--surface-2); color: var(--text-muted);
}
.flag.good { color: var(--success); background: color-mix(in srgb, var(--success) 14%, transparent); border-color: color-mix(in srgb, var(--success) 35%, transparent); }
.flag.warn { color: var(--warn-text); background: var(--warn-bg); border-color: var(--warn-border); }

/* Cliff-awareness block — the signature feature */
.cliff-block { border-radius: var(--radius); padding: 1rem 1.15rem; margin: 1rem 0; border: 1px solid var(--border); }
.cliff-block.below { background: color-mix(in srgb, var(--success) 8%, var(--surface)); border-left: 4px solid var(--success); }
.cliff-block.above { background: var(--warn-bg); border-left: 4px solid var(--warn); }
.cliff-block h3 { margin: 0 0 0.4rem; font-size: 1rem; }
.cliff-block p { margin: 0; font-size: 0.92rem; color: var(--text-muted); }
.cliff-block strong { color: var(--text); }

/* Approximate-data label */
.approx-label { font-size: 0.78rem; color: var(--text-faint); font-style: italic; margin-top: 0.35rem; }

/* Content sections */
.content-section { margin-top: 2.5rem; }
.content-section h2 { border-bottom: 1px solid var(--border); padding-bottom: 0.35rem; }

/* Data tables (FPL table, bracket ladder) */
.data-table { width: 100%; border-collapse: collapse; margin: 1rem 0; font-size: 0.95rem; }
.data-table th, .data-table td { text-align: left; padding: 0.55rem 0.6rem; border-bottom: 1px solid var(--border); }
.data-table th { color: var(--text-muted); }
.data-table td.num, .data-table th.num { text-align: right; font-variant-numeric: tabular-nums; }
.data-table caption { text-align: left; color: var(--text-faint); font-size: 0.85rem; margin-bottom: 0.4rem; }

/* FAQ */
.faq dt { font-weight: 700; margin-top: 1rem; }
.faq dd { margin: 0.25rem 0 0; color: var(--text-muted); }

/* Glossary */
.glossary-list dt { font-weight: 700; margin-top: 1rem; }
.glossary-list dd { margin: 0.25rem 0 0; color: var(--text-muted); }
.glossary-where { font-size: 0.85rem; margin: 0.35rem 0 0; color: var(--text-faint); }

/* Sources */
.sources-list { font-size: 0.9rem; color: var(--text-muted); }
.sources-list li { margin: 0.35rem 0; }

/* Related calculators */
.related-grid { display: grid; gap: 0.85rem; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); margin-top: 1rem; }
.related-card { display: block; text-decoration: none; color: inherit; }
.related-card h3 { margin: 0 0 0.3rem; font-size: 1.05rem; color: var(--accent); }
.related-card p { margin: 0; font-size: 0.9rem; color: var(--text-muted); }

.error-banner { background: #fef2f2; color: #991b1b; border: 1px solid #fecaca; padding: 0.85rem 1rem; border-radius: 10px; margin: 1rem 0; }
[data-theme='dark'] .error-banner { background: #2a1414; color: #fca5a5; border-color: #5b2121; }

@page { margin: 14mm; }
