/* =========================================================
   VoteSMS — inner-page components (loads AFTER campaign.css,
   reuses its tokens: --navy --red --ivory --cream --serif …)
   ========================================================= */

/* ---- Sub-hero (ivory editorial, matches homepage hero) ---- */
.subhero{ background:var(--ivory); padding:62px 0 56px; border-bottom:1px solid var(--line); }
.subhero h1{ font-size:clamp(2.3rem,4.8vw,3.6rem); margin:14px 0 0; }
.subhero .lead{ font-size:1.16rem; color:var(--slate); max-width:620px; margin:20px 0 0; }
.subhero .hero-cta{ margin-top:28px; }
.subhero.center{ text-align:center; }
.subhero.center .lead{ margin:20px auto 0; }
.subhero.center .hero-cta{ justify-content:center; }
.breadcrumb{ font-size:.82rem; color:var(--mute); font-weight:500; margin:0; }
.breadcrumb a{ color:var(--mute); }
.breadcrumb a:hover{ color:var(--navy); }
.breadcrumb span{ color:var(--red); font-weight:600; }

/* ---- Pricing tiers ---- */
.tiers{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; align-items:start; }
.tier{ background:var(--paper); border:1px solid var(--line); border-radius:18px; padding:34px 30px; display:flex; flex-direction:column; gap:10px; }
.tier-featured{ background:var(--navy); border-color:var(--navy); box-shadow:var(--shadow); }
.tier-featured .tier-name,.tier-featured .tier-price,.tier-featured .tier-feats li{ color:#fff; }
.tier-badge{ align-self:flex-start; background:#D42A2A; color:#fff; font-size:.66rem; font-weight:700; letter-spacing:.08em; padding:5px 12px; border-radius:999px; }
.tier-name{ font-family:var(--sans); font-weight:700; font-size:1.05rem; color:var(--navy); }
.tier-price{ font-family:var(--serif); font-size:2.7rem; font-weight:600; color:var(--navy); line-height:1; }
.tier-price span{ font-family:var(--sans); font-size:1rem; font-weight:500; color:var(--slate); }
.tier-featured .tier-price span,.tier-featured .tier-desc{ color:rgba(255,255,255,.75); }
.tier-desc{ color:var(--slate); font-size:.95rem; margin-bottom:6px; }
.tier-feats{ list-style:none; padding:0; margin:0 0 8px; display:grid; gap:11px; }
.tier-feats li{ font-size:.94rem; color:var(--ink); padding-left:26px; position:relative; }
.tier-feats li::before{ content:"✓"; position:absolute; left:0; color:var(--red); font-weight:700; }
.tier-featured .tier-feats li::before{ color:#FF9C6E; }
.tier .btn{ margin-top:auto; width:100%; justify-content:center; }
.price-enterprise{ margin-top:24px; background:var(--navy); border-radius:18px; padding:30px 34px; display:flex; align-items:center; justify-content:space-between; gap:28px; flex-wrap:wrap; }
.price-enterprise h3{ color:#fff; font-size:1.5rem; margin:0 0 6px; }
.price-enterprise p{ color:rgba(255,255,255,.8); margin:0; max-width:640px; font-size:.97rem; }
.price-enterprise strong{ color:#fff; }
.price-enterprise .btn{ flex:none; }

/* ---- FAQ ---- */
.faq{ max-width:820px; margin:0 auto; display:grid; gap:14px; }
.faq-item{ background:var(--paper); border:1px solid var(--line); border-radius:14px; padding:22px 26px; }
.faq-item h3{ font-family:var(--sans); font-weight:700; font-size:1.05rem; margin:0 0 8px; color:var(--navy); }
.faq-item p{ color:var(--slate); margin:0; font-size:.96rem; }

/* ---- About: mission ---- */
.mission{ display:grid; grid-template-columns:.85fr 1.15fr; gap:48px; align-items:start; }
.mission h2{ margin-top:14px; }
.mission p{ color:var(--slate); line-height:1.75; margin:0 0 16px; font-size:1.04rem; }

/* ---- Blog grid ---- */
.post-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.post-card{ background:var(--paper); border:1px solid var(--line); border-radius:16px; overflow:hidden; transition:transform .18s ease,box-shadow .18s ease; }
.post-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-sm); }
.post-img{ height:170px; padding:20px; display:flex; align-items:flex-start; }
.post-img.navy{ background:linear-gradient(140deg,var(--navy),#173a63); }
.post-img.red{ background:linear-gradient(140deg,var(--red),#8c0c20); }
.post-tag{ background:rgba(255,255,255,.18); color:#fff; font-size:.72rem; font-weight:600; padding:6px 12px; border-radius:999px; }
.post-body{ padding:22px 24px 26px; }
.post-body h3{ font-size:1.22rem; margin:0 0 12px; line-height:1.22; }
.post-body .link{ color:var(--accent-ink); font-weight:600; font-size:.9rem; }

/* ---- Blog article ---- */
.article{ max-width:760px; margin:0 auto; }
.article h2{ font-size:1.7rem; margin:36px 0 12px; }
.article h3{ font-size:1.3rem; margin:28px 0 10px; }
.article h4{ font-size:1.12rem; margin:22px 0 8px; }
.article p,.article ul{ color:var(--slate); margin:0 0 16px; line-height:1.78; font-size:1.05rem; }
.article ul{ padding-left:22px; } .article li{ margin-bottom:8px; }
.article-back{ margin-top:36px; }

/* ---- Video grid + lightbox ---- */
.video-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.video-card{ display:block; width:100%; text-align:left; background:none; border:0; padding:0; cursor:pointer; font:inherit; }
.video-thumb{ position:relative; height:200px; border-radius:14px; background-size:cover; background-position:center; background-color:var(--navy); display:grid; place-items:center; }
.video-thumb .play{ width:56px; height:56px; border-radius:50%; background:#fff; display:grid; place-items:center; color:var(--red); font-size:1.05rem; padding-left:3px; transition:transform .15s ease; }
.video-card:hover .play{ transform:scale(1.08); }
.video-card h3{ font-size:1.08rem; margin:13px 0 5px; }
.video-meta{ color:var(--slate); font-size:.85rem; }
.vid-modal{ position:fixed; inset:0; z-index:120; display:flex; align-items:center; justify-content:center; padding:24px; }
.vid-modal[hidden]{ display:none; }
.vid-backdrop{ position:absolute; inset:0; background:rgba(7,21,40,.85); }
.vid-box{ position:relative; width:min(900px,100%); }
.vid-frame{ position:relative; padding-top:56.25%; border-radius:14px; overflow:hidden; background:#000; box-shadow:var(--shadow); }
.vid-frame iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; }
.vid-close{ position:absolute; top:-44px; right:0; background:none; border:0; color:#fff; font-size:2rem; line-height:1; cursor:pointer; }

/* ---- Support category cards = .cap as links ---- */
a.cap{ text-decoration:none; }
.cap .cap-link{ margin-top:14px; color:var(--accent-ink); font-weight:600; font-size:.88rem; display:inline-block; }

/* ---- Final CTA band (cream, centered) ---- */
.cta-final{ background:var(--cream); text-align:center; }
.cta-final .eyebrow{ justify-content:center; }
.cta-final h2{ font-size:clamp(2rem,3.6vw,2.8rem); margin:16px 0 0; }
.cta-final p{ color:var(--slate); font-size:1.1rem; margin:16px auto 0; max-width:560px; }
.cta-final-actions{ display:flex; gap:14px; justify-content:center; margin-top:28px; flex-wrap:wrap; }

/* ---- Responsive ---- */
@media (max-width:960px){
  .tiers,.post-grid,.video-grid{ grid-template-columns:repeat(2,1fr); }
  .mission{ grid-template-columns:1fr; gap:28px; }
}
@media (max-width:640px){
  .tiers,.post-grid,.video-grid{ grid-template-columns:1fr; }
  .subhero{ padding:46px 0 40px; }
}
