/* ============================================================
   Bluff & Bay Interiors - marketing / conversion pages
   (campaign landing page, style quiz, new-build checklist)
   Loads after styles.css; reuses brand tokens + .btn classes.
   ============================================================ */

/* ---------- shared section helpers ---------- */
.lp-narrow { max-width: 760px; margin: 0 auto; }
.lp-eyebrow { font-size: 12.5px; font-weight: 600; letter-spacing: .2em; text-transform: uppercase; color: var(--gold); margin-bottom: 16px; }

/* ---------- pain points ---------- */
.pains { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 20px; }
.pain { background: #fff; border: 1px solid var(--cream-edge); border-radius: 12px; padding: 28px 26px; }
.pain .p-fear { font-family: 'Cormorant Garamond', serif; font-size: 22px; font-weight: 600; color: var(--ink); margin-bottom: 8px; }
.pain .p-fix { font-size: 14.5px; color: var(--muted); line-height: 1.6; }
.pain .p-fix b { color: var(--pine); }

/* ---------- 3 steps ---------- */
.lp-steps { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 24px; }
.lp-step { text-align: center; padding: 10px; }
.lp-step .num { width: 52px; height: 52px; margin: 0 auto 16px; border-radius: 50%; background: var(--gold); color: var(--pine-deep); display: flex; align-items: center; justify-content: center; font-family: 'Cormorant Garamond', serif; font-size: 26px; font-weight: 700; }
.lp-step h3 { font-size: 24px; font-weight: 600; color: var(--pine); margin-bottom: 8px; }
.lp-step p { font-size: 14.5px; color: var(--muted); }

/* ---------- trust row ---------- */
.trust { display: flex; gap: 18px 50px; flex-wrap: wrap; justify-content: center; align-items: center; }
.trust .stat { text-align: center; }
.trust .stat .n { font-family: 'Cormorant Garamond', serif; font-size: 46px; font-weight: 600; color: var(--gold); line-height: 1; }
.trust .stat .l { font-size: 13px; color: var(--cream-text); margin-top: 6px; }
.guarantee { background: rgba(244,237,225,.08); border: 1px solid rgba(244,237,225,.2); border-radius: 12px; padding: 22px 26px; max-width: 520px; }
.guarantee b { color: var(--gold); }

/* ---------- magnet cards ---------- */
.magnets { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 22px; }
.magnet { background: var(--cream); border-radius: 14px; padding: 30px 28px; display: flex; flex-direction: column; }
.magnet .tag { font-size: 11px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--gold); margin-bottom: 10px; }
.magnet h3 { font-size: 26px; font-weight: 600; color: var(--pine); margin-bottom: 10px; }
.magnet p { font-size: 14.5px; color: var(--muted); margin-bottom: 18px; flex: 1; }

/* ---------- inline lead form ---------- */
.lead-card { background: #fff; border-radius: 16px; padding: 38px 34px; box-shadow: 0 20px 50px rgba(46,90,92,.12); }

/* ---------- quiz ---------- */
.quiz-wrap { max-width: 720px; margin: 0 auto; }
.quiz-card { background: #fff; border-radius: 16px; box-shadow: 0 20px 50px rgba(46,90,92,.12); padding: 38px 34px; }
.quiz-progress { height: 6px; background: var(--cream-edge); border-radius: 999px; overflow: hidden; margin-bottom: 26px; }
.quiz-progress .bar { height: 100%; background: var(--gold); width: 0; transition: width .3s ease; }
.quiz-q { font-family: 'Cormorant Garamond', serif; font-size: clamp(24px, 3.4vw, 34px); font-weight: 600; color: var(--pine); margin-bottom: 22px; line-height: 1.15; }
.quiz-opts { display: grid; gap: 12px; }
.quiz-opt { text-align: left; background: #fff; border: 1px solid var(--border); border-radius: 10px; padding: 16px 18px; font-size: 15.5px; color: var(--ink); cursor: pointer; transition: border-color .15s ease, background .15s ease, transform .1s ease; }
.quiz-opt:hover { border-color: var(--pine); background: var(--cream); transform: translateY(-1px); }
.quiz-meta { display: flex; justify-content: space-between; align-items: center; margin-top: 22px; font-size: 13px; color: var(--mist); }
.quiz-back { background: none; border: none; color: var(--muted); cursor: pointer; font-size: 13px; }
.quiz-result { text-align: center; }
.quiz-result .badge { display: inline-block; background: var(--cream); color: var(--gold); font-size: 11px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; padding: 6px 14px; border-radius: 999px; margin-bottom: 18px; }
.quiz-result h2 { font-size: clamp(30px, 4.4vw, 46px); font-weight: 600; color: var(--pine); margin-bottom: 14px; }
.quiz-result p { font-size: 16px; color: var(--muted); max-width: 52ch; margin: 0 auto 22px; }
.quiz-capture { display: flex; gap: 10px; flex-wrap: wrap; justify-content: center; max-width: 460px; margin: 0 auto; }
.quiz-capture input { flex: 1; min-width: 200px; padding: 14px 16px; border: 1px solid var(--border-input); border-radius: 9px; font-size: 15px; }
.quiz-capture input:focus { outline: none; border-color: var(--pine); }

/* ---------- checklist ---------- */
.check-list { background: #fff; border-radius: 14px; padding: 8px 30px; box-shadow: 0 10px 30px rgba(46,90,92,.08); }
.check-item { display: grid; grid-template-columns: 26px 1fr; gap: 14px; align-items: start; padding: 18px 0; border-bottom: 1px solid var(--cream-edge); }
.check-item:last-child { border-bottom: none; }
.check-item .box { width: 22px; height: 22px; border: 2px solid var(--gold); border-radius: 6px; margin-top: 2px; }
.check-item .phase { font-size: 11px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--gold); margin-bottom: 4px; }
.check-item h4 { font-size: 16.5px; font-weight: 600; color: var(--ink); margin-bottom: 3px; }
.check-item p { font-size: 14px; color: var(--muted); margin: 0; }
.gate { max-width: 460px; margin: 0 auto; text-align: center; background: #fff; border-radius: 16px; padding: 38px 34px; box-shadow: 0 20px 50px rgba(46,90,92,.12); }
.gate input { width: 100%; padding: 14px 16px; border: 1px solid var(--border-input); border-radius: 9px; font-size: 15px; margin-bottom: 14px; }
.gate input:focus { outline: none; border-color: var(--pine); }
.is-hidden { display: none !important; }

@media print {
  .site-header, .cta-band, .site-footer, .no-print { display: none !important; }
  .check-list { box-shadow: none; }
}
