/* Mortaro Authority — niche ad-landing pages v4 (rizkad-style, conversion-focused).
   Reuses home.css (statrow, compare, tiers, reassure, process, mock2). */

/* ---- Niche hero (centred: copy, then dental preview below) ---- */
.hero--niche { padding-block: clamp(22px,3vw,40px) clamp(40px,5vw,72px); }
.nhero__title { font-size: clamp(2.3rem, 1.2rem + 4.4vw, 5rem); max-width: 17ch; margin-inline: auto; font-weight: 780; line-height: .95; letter-spacing: -.04em; color: var(--ink); }
.hero--niche .hero__sub { max-width: 54ch; }
.nhero__preview { max-width: 920px; margin: clamp(36px,5vw,64px) auto 0; }
.nhero__caption { text-align: center; margin-top: var(--s4); font-family: var(--font-cond); font-weight: 600; font-size: .8rem; letter-spacing: .06em; text-transform: uppercase; color: var(--text-muted); }
@media (max-width: 940px) { .nhero__title { max-width: 100%; } }

/* ---- Pain points ---- */
.pain-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px,1fr)); gap: var(--s5); margin-top: var(--s8); }
.pain { padding: var(--s6); border: 1.5px solid var(--line); border-radius: var(--radius-lg); background: var(--paper); }
.pain__no { font-family: var(--font-display); font-weight: 780; font-size: 2rem; color: var(--brass); line-height: 1; display: block; margin-bottom: var(--s4); }
.pain p { color: var(--text); margin: 0; }

/* ---- Coverage pills ---- */
.terms__label { font-family: var(--font-cond); font-weight: 600; font-size: .85rem; letter-spacing: .1em; text-transform: uppercase; color: var(--brass); display: block; margin-bottom: var(--s4); }
.coverage { display: flex; flex-wrap: wrap; gap: var(--s3); }
.coverage--center { justify-content: center; }
.cov { font-family: var(--font-cond); font-weight: 600; font-size: .85rem; letter-spacing: .04em; text-transform: uppercase; padding: 10px 16px; border: 1.5px solid var(--line); border-radius: 999px; color: var(--ink); background: var(--paper); display: inline-flex; align-items: center; gap: .55em; }
.cov::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--brass); }
.cov--off { color: var(--text-muted); border-style: dashed; }
.cov--off::before { background: var(--text-muted); }

/* ---- Testimonial quote ---- */
.quote { max-width: 880px; margin-inline: auto; text-align: center; }
.quote p { font-family: var(--font-display); font-weight: 740; font-size: var(--fs-h2); line-height: 1.05; letter-spacing: -.03em; margin: 0 auto var(--s5); color: var(--ink); }
.quote cite { font-family: var(--font-cond); font-weight: 600; font-size: .9rem; letter-spacing: .06em; text-transform: uppercase; color: var(--brass); font-style: normal; }

/* ---- Exclusivity band (brass feature) ---- */
.exclusive { text-align: center; background: var(--brass); color: var(--cream); }
.exclusive__inner { max-width: 900px; margin-inline: auto; display: flex; flex-direction: column; align-items: center; }
.exclusive .eyebrow { justify-content: center; margin-bottom: var(--s5); color: var(--cream); }
.exclusive .eyebrow::before { opacity: .6; }
.exclusive h2 { max-width: 18ch; margin-bottom: var(--s5); color: var(--cream); }
.exclusive h2 em { color: var(--ink); font-style: italic; }
.exclusive .lead { max-width: 54ch; margin-bottom: var(--s6); color: rgba(244,243,239,.9); }
.exclusive .spotmeter__pips i { background: rgba(255,255,255,.32); }
.exclusive .spotmeter__pips i.on { background: var(--ink); }
.exclusive .spotmeter__txt { color: rgba(244,243,239,.92); }
.exclusive .btn--primary { background: var(--ink); color: var(--cream); }
.exclusive .btn--primary:hover { background: #000; }

/* ---- Niche index (archive) ---- */
.niche-index { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: var(--s5); }
.niche-card { display: flex; flex-direction: column; gap: var(--s4); padding: var(--s7); border: 1.5px solid var(--line); border-radius: var(--radius-lg); background: var(--paper); transition: border-color .2s, transform .2s var(--ease); min-height: 220px; }
.niche-card:hover { border-color: var(--brass); transform: translateY(-3px); }
.niche-card__k { font-family: var(--font-cond); font-weight: 600; font-size: .8rem; letter-spacing: .12em; text-transform: uppercase; color: var(--brass); }
.niche-card__h { font-family: var(--font-display); font-weight: 740; font-size: var(--fs-h3); letter-spacing: -.02em; color: var(--ink); line-height: 1.05; flex: 1; }
.niche-card__go { font-family: var(--font-cond); font-weight: 600; letter-spacing: .04em; text-transform: uppercase; font-size: .82rem; color: var(--ink); display: inline-flex; align-items: center; gap: .5em; }
.niche-card:hover .niche-card__go { color: var(--brass); }
.niche-card:hover .btn__arrow { transform: translateX(4px); }

/* ---- Free review bonus band ---- */
.bonus__card { display: grid; grid-template-columns: auto 1fr; gap: clamp(28px,4vw,64px); align-items: center; max-width: 980px; margin: var(--s8) auto 0; padding: clamp(28px,4vw,52px); border: 1.5px solid var(--brass); border-radius: var(--radius-lg); background: var(--paper); }
.bonus__qr { display: flex; flex-direction: column; align-items: center; gap: var(--s4); }
.qr { display: grid; grid-template-columns: repeat(11, 1fr); gap: 2px; width: 168px; height: 168px; padding: 12px; background: #fff; border-radius: 10px; box-shadow: var(--shadow-card); }
.qr i { background: transparent; border-radius: 1px; }
.qr i.on { background: var(--ink); }
.bonus__scan { font-family: var(--font-cond); font-weight: 600; font-size: .78rem; letter-spacing: .08em; text-transform: uppercase; color: var(--brass); }
.bonus__list { display: grid; gap: var(--s4); }
.bonus__list li { display: flex; gap: var(--s3); align-items: flex-start; font-size: var(--fs-body); color: var(--text); }
.bonus__list li svg { color: var(--brass); flex: none; margin-top: .35em; }
.bonus__list strong { font-weight: 700; }
@media (max-width: 720px) { .bonus__card { grid-template-columns: 1fr; justify-items: center; text-align: left; } }

/* ---- Live build snapshot (auto-scrolling real-site preview) ---- */
.livesnap { --ls-h: 520px; display: block; max-width: 760px; margin-inline: auto; border-radius: var(--radius-lg); overflow: hidden; background: #fff; box-shadow: var(--shadow-float); transition: transform .3s var(--ease); }
.livesnap:hover { transform: translateY(-4px); }
.livesnap__chrome { display: flex; align-items: center; gap: 7px; padding: 12px 16px; background: var(--night); }
.livesnap__chrome i { width: 9px; height: 9px; border-radius: 50%; background: rgba(255,255,255,.18); }
.livesnap__chrome i:first-child { background: var(--brass); }
.livesnap__url { margin-left: 10px; font-family: var(--font-cond); font-weight: 600; font-size: 12px; letter-spacing: .03em; color: var(--on-dark-muted); }
.livesnap__live { margin-left: auto; display: inline-flex; align-items: center; gap: .45em; font-family: var(--font-cond); font-weight: 600; font-size: 11px; letter-spacing: .06em; text-transform: uppercase; color: var(--brass-bright); }
.livesnap__dot { width: 7px; height: 7px; border-radius: 50%; background: var(--success); }
@media (prefers-reduced-motion: no-preference) { .livesnap__dot { animation: pulse 2s infinite; } }
.livesnap__view { display: block; height: var(--ls-h); background-size: 100% auto; background-repeat: no-repeat; background-position: 50% top; }
@media (prefers-reduced-motion: no-preference) {
  .livesnap__view { animation: livescroll 28s ease-in-out infinite alternate; }
  @keyframes livescroll { from { background-position: 50% top; } to { background-position: 50% bottom; } }
}
.livesnap:hover .livesnap__view { animation-play-state: paused; }
@media (max-width: 600px) { .livesnap { --ls-h: 400px; } }
