/* ============================================================
   Honest-pricing pillar page — aligned with the landing/about
   "Precision" design system. Tokens (--np-*) live in main.css;
   brand fonts (Bricolage Grotesque + Instrument Sans) load in public_base.
   ============================================================ */
.hp-page { position: relative; overflow: hidden; font-family: var(--np-font-body); color: var(--np-ink); padding: 3rem 1.5rem 4.5rem; }
.hp-page::before {
    content: ""; position: absolute; top: 0; left: 0; right: 0; height: 620px; z-index: 0; pointer-events: none;
    background:
        radial-gradient(640px 340px at 88% 4%, rgba(16, 185, 129, 0.14), transparent 60%),
        radial-gradient(560px 380px at 4% 2%, rgba(37, 99, 235, 0.10), transparent 62%),
        radial-gradient(420px 300px at 70% 22%, rgba(129, 140, 248, 0.08), transparent 65%);
}
.hp-page::after {
    content: ""; position: absolute; top: 0; left: 0; right: 0; height: 600px; z-index: 0; pointer-events: none;
    background-image: radial-gradient(circle, rgba(15, 23, 42, 0.05) 1px, transparent 1.4px);
    background-size: 24px 24px;
    -webkit-mask-image: linear-gradient(to bottom, #000 56%, transparent 100%);
    mask-image: linear-gradient(to bottom, #000 56%, transparent 100%);
}
.hp-container { position: relative; z-index: 1; max-width: 880px; margin: 0 auto; }
.hp-page h1, .hp-page h2 {
    font-family: var(--np-font-display); color: var(--np-navy);
    font-weight: 800; letter-spacing: -0.025em; line-height: 1.14; margin: 0;
}
.hp-page p { margin: 0; line-height: 1.6; }
.hp-page a { text-decoration: none; }

.hp-back { display: inline-flex; align-items: center; gap: 0.4rem; margin-bottom: 1.6rem; font-size: 0.88rem; font-weight: 500; color: var(--np-muted); transition: color 0.18s ease, gap 0.18s ease; }
.hp-back:hover { color: var(--np-navy); gap: 0.6rem; }

/* --- Hero --- */
.hp-hero { text-align: center; margin-bottom: 3rem; }
.hp-eyebrow { display: inline-flex; align-items: center; gap: 0.5rem; font-size: 0.78rem; font-weight: 600; letter-spacing: 0.13em; text-transform: uppercase; color: var(--np-green-strong); margin-bottom: 0.9rem; }
.hp-eyebrow i { font-size: 0.95rem; }
.hp-hero .hp-title { font-size: clamp(2rem, 4.4vw, 2.9rem); letter-spacing: -0.035em; max-width: 22ch; margin: 0 auto 1rem; }
.hp-hero .hp-lead { font-size: 1.12rem; color: var(--np-muted); max-width: 46rem; margin: 0 auto; line-height: 1.65; }

.hp-section-title { font-size: clamp(1.4rem, 2.6vw, 1.85rem); margin: 0 0 1.3rem; }

/* --- Comparison table --- */
.hp-compare-wrap { margin: 3rem 0; }
.hp-compare-scroll { overflow-x: auto; border: 1px solid var(--np-line); border-radius: var(--np-radius-lg); background: #fff; box-shadow: var(--np-shadow); }
.hp-compare { width: 100%; border-collapse: collapse; font-size: 0.92rem; min-width: 540px; }
.hp-compare thead th { text-align: left; font-weight: 600; color: var(--np-faint); font-size: 0.74rem; letter-spacing: 0.1em; text-transform: uppercase; padding: 0.95rem 1.1rem; border-bottom: 1px solid var(--np-line); background: var(--np-bg-soft); }
.hp-compare tbody th { text-align: left; font-weight: 600; color: var(--np-navy); padding: 0.9rem 1.1rem; }
.hp-compare tbody td { padding: 0.9rem 1.1rem; color: var(--np-muted); white-space: nowrap; }
.hp-compare tbody tr + tr th, .hp-compare tbody tr + tr td { border-top: 1px solid var(--np-line); }
.hp-compare .hp-bad { color: var(--np-faint); }
.hp-compare .hp-good { color: var(--np-green-strong); font-weight: 600; }
.hp-compare .hp-good i { margin-right: 0.3rem; }
.hp-compare-note { margin: 0.95rem 0 0; font-size: 0.82rem; color: var(--np-faint); }

/* --- Tenets (Q&A blocks) --- */
.hp-tenets { display: grid; gap: 1rem; margin: 3rem 0; }
.hp-tenet { background: #fff; border: 1px solid var(--np-line); border-radius: var(--np-radius-lg); padding: 1.7rem 1.9rem; transition: border-color 0.18s var(--np-ease), transform 0.18s var(--np-ease), box-shadow 0.18s var(--np-ease); }
.hp-tenet:hover { border-color: var(--np-green); transform: translateY(-3px); box-shadow: var(--np-shadow); }
.hp-tenet-q { font-family: var(--np-font-display); font-size: 1.12rem; font-weight: 700; color: var(--np-navy); margin: 0 0 0.6rem; line-height: 1.3; }
.hp-tenet-a { color: var(--np-muted); line-height: 1.7; margin: 0 0 1rem; }
.hp-tenet-x { display: flex; gap: 0.55rem; align-items: flex-start; margin: 0; padding-top: 0.9rem; border-top: 1px dashed var(--np-line-strong); font-size: 0.86rem; color: var(--np-faint); line-height: 1.55; }
.hp-tenet-x i { color: var(--np-faint); margin-top: 0.14rem; flex-shrink: 0; }

/* --- Why-in-writing band (navy + glow) --- */
.hp-why { position: relative; overflow: hidden; background: var(--np-navy); border-radius: var(--np-radius-lg); padding: 2.6rem; margin: 3rem 0; }
.hp-why::before { content: ""; position: absolute; inset: 0; pointer-events: none; background: radial-gradient(620px 300px at 12% -25%, rgba(16, 185, 129, 0.20), transparent 60%); }
.hp-why > * { position: relative; }
.hp-why .hp-why-title { color: #fff; font-size: clamp(1.4rem, 2.6vw, 1.8rem); margin: 0 0 1rem; }
.hp-why p { color: rgba(255, 255, 255, 0.72); line-height: 1.75; margin: 0 0 0.9rem; }
.hp-why p:last-child { margin-bottom: 0; }

/* --- Quick answers (accordion) --- */
.hp-faq { margin: 3rem 0; }
.hp-faq-list { display: flex; flex-direction: column; border-top: 1px solid var(--np-line); }
.hp-faq-item { border-bottom: 1px solid var(--np-line); }
.hp-faq-q { display: flex; align-items: center; justify-content: space-between; gap: 1.2rem; cursor: pointer; list-style: none; padding: 1.2rem 0.25rem; font-family: var(--np-font-display); font-weight: 700; font-size: 1.02rem; color: var(--np-navy); transition: color 0.15s ease; }
.hp-faq-q::-webkit-details-marker { display: none; }
.hp-faq-q:hover { color: var(--np-green-strong); }
.hp-faq-toggle { flex-shrink: 0; font-size: 0.95rem; color: var(--np-faint); transition: transform 0.28s var(--np-ease), color 0.28s var(--np-ease); }
.hp-faq-item[open] .hp-faq-toggle { transform: rotate(45deg); color: var(--np-green-strong); }
.hp-faq-a { color: var(--np-muted); font-size: 0.95rem; line-height: 1.65; margin: 0; padding: 0 2.6rem 1.25rem 0.25rem; }

/* --- CTA --- */
.hp-cta { display: flex; flex-direction: column; align-items: center; gap: 0.85rem; text-align: center; margin-top: 3rem; }
.hp-btn-primary { display: inline-flex; align-items: center; gap: 0.55rem; font-weight: 600; font-size: 0.98rem; padding: 0.85rem 1.5rem; border-radius: var(--np-radius-sm); background: var(--np-green); color: #fff; box-shadow: 0 14px 32px -12px rgba(16, 185, 129, 0.6); transition: background 0.15s ease, transform 0.15s ease; }
.hp-btn-primary:hover { background: var(--np-green-strong); color: #fff; transform: translateY(-2px); }
.hp-cta-secondary { font-size: 0.9rem; font-weight: 500; color: var(--np-muted); }
.hp-cta-secondary:hover { color: var(--np-navy); text-decoration: underline; }

/* --- Scroll reveal (gated by the .reveals-ready class added in <head>) --- */
.reveals-ready .reveal { opacity: 0; transform: translateY(26px); transition: opacity 0.7s var(--np-ease), transform 0.7s var(--np-ease); will-change: opacity, transform; }
.reveals-ready .reveal.is-visible { opacity: 1; transform: none; }

@media (max-width: 640px) {
    .hp-tenet { padding: 1.4rem; }
    .hp-why { padding: 1.6rem; }
}
@media (prefers-reduced-motion: reduce) {
    .reveals-ready .reveal { opacity: 1 !important; transform: none !important; transition: none !important; }
    .hp-faq-toggle { transition: none; }
}
