/*
 * WEDOS.protection — Shared CSS
 * Version: 1.0.0
 * Načtěte přes functions.php nebo Code Snippets plugin.
 * HTML bloky v Gutenbergu pak nepotřebují vlastní <style> tag.
 *
 * Struktura:
 * 1. Design tokens
 * 2. Shared utilities
 * 3. Segment selector
 * 4. Context bar
 * 5. Pricing cards
 * 6. Feature matrix
 * 7. Add-on pack cards
 * 8. Tables (volume + add-ons)
 * 9. Dark CTA section
 * 10. Section layout helpers
 * 11. Responsive
 */

@import url("https://fonts.googleapis.com/css2?family=Sora:wght@600;700&family=Inter:wght@400;500;600&display=swap");

/* ══════════════════════════════════════════════════
   1. DESIGN TOKENS
   ══════════════════════════════════════════════════ */
.wpcp,
.wpcw,
.wphp {
  --dark:            #0C0933;
  --dark-mid:        #172554;
  --blue-main:       #234F9F;
  --blue-cta:        #2563EB;
  --blue-cta-hover:  #1D4ED8;
  --blue-very-light: #EFF6FF;
  --neutral:         #E3E6EA;
  --white:           #FFFFFF;
  --protection:      #22BF7E;
  --protection-soft: rgba(34,191,126,.12);
  --protection-text: #16A34A;
  --eyebrow:         #93C5FD;
  --text:            #0F172A;
  --muted:           #475569;
  --surface-2:       #F8FAFC;
  --amber:           #B45309;
  --amber-soft:      #FBF1E3;
  --shadow:          0 1px 2px rgba(12,9,51,.04), 0 10px 30px rgba(12,9,51,.06);
  --r:               8px;
  --font-sora:       "Sora", system-ui, -apple-system, sans-serif;
  --font-inter:      "Inter", system-ui, -apple-system, sans-serif;
  --maxw:            1280px;

  font-family: var(--font-inter);
  color: var(--text);
  font-size: 16px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
}

/* ══════════════════════════════════════════════════
   2. SHARED UTILITIES
   ══════════════════════════════════════════════════ */
.wpcp *, .wpcp *::before, .wpcp *::after,
.wpcw *, .wpcw *::before, .wpcw *::after,
.wphp *, .wphp *::before, .wphp *::after {
  box-sizing: border-box; margin: 0; padding: 0;
}

.wpcp .inner,
.wpcw .inner,
.wphp .inner {
  width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 24px;
}

/* Section label / eyebrow */
.wpcp .section-label,
.wpcw .section-label,
.wphp .section-label {
  display: flex; align-items: center; gap: 8px; margin-bottom: 12px;
  font-family: var(--font-inter); font-weight: 600;
  font-size: 12px; letter-spacing: .08em; text-transform: uppercase; color: var(--blue-cta);
}
.wpcp .section-label .dash,
.wpcw .section-label .dash,
.wphp .section-label .dash {
  display: block; width: 20px; height: 2px; border-radius: 1px; background: var(--blue-cta); flex: none;
}
.wpcp .section-label.on-dark,
.wpcw .section-label.on-dark,
.wphp .section-label.on-dark { color: var(--eyebrow); }
.wpcp .section-label.on-dark .dash,
.wpcw .section-label.on-dark .dash,
.wphp .section-label.on-dark .dash { background: #3B82F6; }

/* Section layout */
.wpcp-section { padding: 100px 0; }
.wpcp-section.white { background: var(--white); }
.wpcp-section.tint  { background: var(--blue-very-light); }
.wpcp-section.dark  { background: var(--dark); position: relative; overflow: hidden; }
.wpcp-section.dark::before {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(ellipse 80% 60% at 50% 0%, rgba(37,99,235,.10) 0%, transparent 70%);
}
.wpcp-section.dark .inner { position: relative; z-index: 1; }

/* Section head */
.wpcp-section-head { margin-bottom: 48px; }
.wpcp-section-head h2 {
  font-family: var(--font-sora); font-weight: 600; font-size: 48px;
  color: var(--text); letter-spacing: -.02em; line-height: 1.1; margin-bottom: 12px;
}
.wpcp-section-head h2.on-dark { color: #fff; }
.wpcp-section-head .lede { font-size: 18px; color: var(--muted); max-width: 600px; line-height: 1.7; }
.wpcp-section-head .lede.on-dark { color: rgba(255,255,255,.65); }

/* ══════════════════════════════════════════════════
   3. HERO
   ══════════════════════════════════════════════════ */
.wpcp-hero {
  background: var(--dark); padding: 100px 0 80px;
  position: relative; overflow: hidden;
}
.wpcp-hero::before {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(ellipse 80% 60% at 50% 0%, rgba(37,99,235,.10) 0%, transparent 70%);
}
.wpcp-hero .inner { position: relative; z-index: 1; text-align: center; }
.wpcp-hero h1 {
  font-family: var(--font-sora); font-weight: 600; font-size: 48px;
  color: #fff; letter-spacing: -.02em; line-height: 1.1; margin-bottom: 18px;
}
.wpcp-hero h1 .accent { color: var(--protection); }
.wpcp-hero .lede {
  color: rgba(255,255,255,.65); font-size: 18px; line-height: 1.75;
  max-width: 620px; margin: 0 auto;
}

/* Homepage widget heading */
.wpcw-head,
.wphp-head { text-align: center; margin-bottom: 32px; }
.wpcw-head h2,
.wphp-head h2 {
  font-family: var(--font-sora); font-weight: 600; font-size: 48px;
  color: var(--text); letter-spacing: -.02em; line-height: 1.1; margin-bottom: 14px;
}
.wpcw-head p,
.wphp-head p { font-size: 18px; color: var(--muted); max-width: 580px; margin: 0 auto; line-height: 1.7; }

/* ══════════════════════════════════════════════════
   4. SEGMENT SELECTOR
   ══════════════════════════════════════════════════ */
.wpcp-seg-section,
.wpcw-seg-section,
.wphp-seg-section {
  background: var(--white); padding: 40px 0 0; text-align: center;
}
.wpcp-seg-row,
.wpcw-seg-row,
.wphp-seg-row {
  display: inline-flex; gap: 0;
  background: var(--surface-2); border: 1px solid var(--neutral);
  border-radius: var(--r); padding: 4px;
}
.wpcp-seg-btn,
.wpcw-seg-btn,
.wphp-seg-btn {
  font-family: var(--font-inter); font-size: 14px; font-weight: 500;
  color: var(--muted); background: none; border: none;
  padding: 10px 24px; border-radius: 6px; cursor: pointer;
  transition: background .15s, color .15s; white-space: nowrap;
}
.wpcp-seg-btn .sub,
.wpcw-seg-btn .sub,
.wphp-seg-btn .sub {
  display: block; font-size: 11px; color: var(--muted); margin-top: 2px; font-weight: 400;
}
.wpcp-seg-btn.active,
.wpcw-seg-btn.active,
.wphp-seg-btn.active { background: var(--blue-cta); color: #fff; }
.wpcp-seg-btn.active .sub,
.wpcw-seg-btn.active .sub,
.wphp-seg-btn.active .sub { color: rgba(255,255,255,.65); }
.wpcp-seg-btn:not(.active):hover,
.wpcw-seg-btn:not(.active):hover,
.wphp-seg-btn:not(.active):hover { color: var(--blue-cta); background: var(--blue-very-light); }

/* ══════════════════════════════════════════════════
   5. CONTEXT BAR
   ══════════════════════════════════════════════════ */
.wpcp-ctx-wrap,
.wpcw-ctx-wrap,
.wphp-ctx-wrap { text-align: center; padding: 24px 0 36px; background: var(--white); }
.wpcp-ctx,
.wpcw-ctx,
.wphp-ctx {
  display: inline-block; font-size: 14px; color: var(--muted);
  background: var(--surface-2); border: 1px solid var(--neutral);
  border-radius: var(--r); padding: 8px 20px;
}
.wpcp-ctx strong,
.wpcw-ctx strong,
.wphp-ctx strong { color: var(--text); font-weight: 500; }

/* ══════════════════════════════════════════════════
   6. PRICING CARDS
   ══════════════════════════════════════════════════ */
.wpcp-cards-section,
.wpcw-cards,
.wphp-cards { background: var(--white); padding: 0 0 100px; }

.wpcp-grid,
.wpcw-grid,
.wphp-grid {
  display: flex; flex-wrap: wrap; gap: 20px;
  justify-content: center; align-items: stretch;
}

.wpcp-card,
.wpcw-card,
.wphp-card {
  background: var(--white); border: 1px solid var(--neutral);
  border-radius: var(--r); box-shadow: var(--shadow);
  padding: 32px 28px 28px; display: flex; flex-direction: column;
  width: 360px; flex: 0 0 360px; position: relative; overflow: hidden;
  transition: box-shadow .2s, transform .2s;
}
.wpcp-card:hover,
.wpcw-card:hover,
.wphp-card:hover {
  box-shadow: 0 2px 8px rgba(12,9,51,.06), 0 16px 40px rgba(12,9,51,.10);
  transform: translateY(-2px);
}
.wpcp-card.featured,
.wpcw-card.featured,
.wphp-card.featured { border: 2px solid var(--blue-cta); }
.wpcp-card.hidden,
.wpcw-card.hidden,
.wphp-card.hidden { display: none; }

/* Badge */
.wpcp-card .badge,
.wpcw-card .badge,
.wphp-card .badge {
  position: absolute; top: 0; right: 0;
  font-family: var(--font-sora); font-size: 10px; font-weight: 600;
  letter-spacing: .06em; text-transform: uppercase;
  padding: 5px 14px; border-radius: 0 var(--r) 0 var(--r);
}
.wpcp-card .badge.pop,
.wpcw-card .badge.pop,
.wphp-card .badge.pop { background: var(--blue-cta); color: #fff; }
.wpcp-card .badge.part,
.wpcw-card .badge.part,
.wphp-card .badge.part { background: var(--dark-mid); color: rgba(255,255,255,.8); }

/* Plan name */
.wpcp-card h3.plan-name,
.wpcw-card h3.plan-name,
.wphp-card h3.plan-name {
  font-family: var(--font-sora); font-weight: 600; font-size: 24px;
  color: var(--text); margin-bottom: 6px; letter-spacing: -.01em;
  min-height: 64px;
}
.wpcp-card .plan-desc,
.wpcw-card .plan-desc,
.wphp-card .plan-desc {
  font-size: 14px; color: var(--muted); line-height: 1.55;
  margin-bottom: 20px; min-height: 38px;
}
.wpcp-card .plan-desc strong,
.wpcw-card .plan-desc strong,
.wphp-card .plan-desc strong { color: var(--text); font-weight: 500; }

/* Price */
.wpcp-card .price-row,
.wpcw-card .price-row,
.wphp-card .price-row { display: flex; align-items: baseline; gap: 3px; margin-bottom: 4px; }
.wpcp-card .price-eur,
.wpcw-card .price-eur,
.wphp-card .price-eur {
  font-family: var(--font-sora); font-weight: 600;
  font-size: 20px; color: var(--muted); align-self: flex-start; margin-top: 6px;
}
.wpcp-card .price-num,
.wpcw-card .price-num,
.wphp-card .price-num {
  font-family: var(--font-sora); font-weight: 600;
  font-size: 40px; color: var(--text); letter-spacing: -.02em; line-height: 1;
}
.wpcp-card .price-num.free,
.wpcw-card .price-num.free,
.wphp-card .price-num.free { color: var(--protection); }
.wpcp-card .price-per,
.wpcw-card .price-per,
.wphp-card .price-per { font-size: 14px; color: var(--muted); margin-left: 2px; }
.wpcp-card .price-note,
.wpcw-card .price-note,
.wphp-card .price-note { font-size: 13px; color: var(--muted); margin-bottom: 20px; min-height: 18px; }
.wpcp-card .price-note .hl,
.wpcw-card .price-note .hl,
.wphp-card .price-note .hl { color: var(--blue-cta); font-weight: 600; }
.wpcp-card .divider,
.wpcw-card .divider,
.wphp-card .divider { border: none; border-top: 1px solid var(--neutral); margin: 16px 0; }

/* Features list */
.wpcp-card .feats,
.wpcw-card .feats,
.wphp-card .feats { list-style: none; padding: 0; flex: 1; }
.wpcp-card .feats li,
.wpcw-card .feats li,
.wphp-card .feats li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 14px; color: var(--text); margin-bottom: 9px; line-height: 1.45;
}
.wpcp-card .feats li .ico,
.wpcw-card .feats li .ico,
.wphp-card .feats li .ico { flex: none; width: 16px; margin-top: 1px; font-size: 13px; font-weight: 700; }
.wpcp-card .feats li .ico.yes,
.wpcw-card .feats li .ico.yes,
.wphp-card .feats li .ico.yes { color: var(--protection); }
.wpcp-card .feats li .ico.no,
.wpcw-card .feats li .ico.no,
.wphp-card .feats li .ico.no { color: var(--neutral); }

/* CTA buttons */
.wpcp-card .cta,
.wpcw-card .cta,
.wphp-card .cta {
  display: block; text-align: center; margin-top: 20px;
  font-family: var(--font-inter); font-size: 16px; font-weight: 500;
  padding: 14px 24px; border-radius: var(--r);
  text-decoration: none; border: none; cursor: pointer;
  transition: background .15s, color .15s, border-color .15s;
}
.wpcp-card .cta.primary,
.wpcw-card .cta.primary,
.wphp-card .cta.primary { background: var(--blue-cta); color: #fff; border: none; }
.wpcp-card .cta.primary:hover,
.wpcw-card .cta.primary:hover,
.wphp-card .cta.primary:hover { background: var(--blue-cta-hover); }
.wpcp-card .cta.secondary,
.wpcw-card .cta.secondary,
.wphp-card .cta.secondary { background: transparent; border: 1px solid var(--blue-cta); color: var(--blue-cta); }
.wpcp-card .cta.secondary:hover,
.wpcw-card .cta.secondary:hover,
.wphp-card .cta.secondary:hover { background: var(--blue-cta); color: #fff; border-color: var(--blue-cta); }
.wpcp-card .cta.neutral,
.wpcw-card .cta.neutral,
.wphp-card .cta.neutral { background: transparent; border: 1px solid var(--neutral); color: var(--text); }
.wpcp-card .cta.neutral:hover,
.wpcw-card .cta.neutral:hover,
.wphp-card .cta.neutral:hover { background: var(--blue-cta); border-color: var(--blue-cta); color: #fff; }

/* ══════════════════════════════════════════════════
   7. FEATURE MATRIX
   ══════════════════════════════════════════════════ */
.wpcp-matrix-outer {
  overflow-x: auto; border-radius: var(--r);
  border: 1px solid var(--neutral); box-shadow: var(--shadow);
}
.wpcp-matrix {
  border-collapse: collapse; width: 100%; min-width: 780px;
  background: var(--white); font-size: 14px;
}
.wpcp-matrix td:first-child,
.wpcp-matrix th:first-child {
  position: sticky; left: 0; z-index: 2; background: var(--surface-2);
}
.wpcp-matrix tbody td:first-child { background: var(--white); border-right: 1px solid var(--neutral); }
.wpcp-matrix tbody tr:nth-child(even) td:first-child { background: var(--surface-2); }
.wpcp-matrix thead th {
  font-family: var(--font-sora); font-size: 12px; font-weight: 600;
  letter-spacing: .05em; text-transform: uppercase; color: var(--muted);
  padding: 14px 18px; background: var(--surface-2);
  border-bottom: 1px solid var(--neutral); text-align: center; white-space: nowrap;
}
.wpcp-matrix thead th:first-child { text-align: left; min-width: 220px; }
.wpcp-matrix thead th.col-hi { background: var(--surface-2); color: var(--muted); }
.wpcp-matrix .group-row td {
  font-family: var(--font-sora); font-size: 11px; font-weight: 600;
  letter-spacing: .07em; text-transform: uppercase; color: var(--muted);
  background: var(--surface-2) !important; padding: 10px 18px;
  border-top: 1px solid var(--neutral); border-bottom: 1px solid var(--neutral);
}
.wpcp-matrix tbody td {
  padding: 11px 18px; border-bottom: 1px solid var(--neutral);
  color: var(--text); text-align: center; vertical-align: middle;
}
.wpcp-matrix tbody td:first-child { text-align: left; font-size: 14px; }
.wpcp-matrix tbody td.col-hi { background: transparent; }
.wpcp-matrix tbody tr:nth-child(even) td { background: var(--surface-2); }
.wpcp-matrix tbody tr:nth-child(even) td.col-hi { background: var(--surface-2); }
.wpcp-matrix tbody tr:last-child td { border-bottom: none; }
.wpcp-matrix .chk { color: var(--protection); font-weight: 700; font-size: 14px; }
.wpcp-matrix .crs { color: var(--neutral); font-size: 14px; }
.wpcp-matrix .val { font-size: 13px; font-weight: 500; color: var(--text); }
.wpcp-matrix th.col-hover { background: var(--blue-very-light) !important; color: var(--blue-cta) !important; }
.wpcp-matrix td.col-hover { background: rgba(37,99,235,.03) !important; }
.wpcp-matrix tr:nth-child(even) td.col-hover { background: rgba(37,99,235,.06) !important; }
.wpcp-matrix .add {
  font-size: 11px; font-weight: 600; color: var(--blue-cta);
  background: var(--blue-very-light); border-radius: 5px; padding: 2px 7px; white-space: nowrap;
}

/* ══════════════════════════════════════════════════
   8. ADD-ON PACK CARDS
   ══════════════════════════════════════════════════ */
.wpcp-pack-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 20px; align-items: stretch;
}
.wpcp-pack-card {
  background: var(--white); border: 1px solid var(--neutral);
  border-radius: var(--r); box-shadow: var(--shadow);
  padding: 32px 28px; display: flex; flex-direction: column; height: 100%;
}
.wpcp-pack-card .pack-line { width: 28px; height: 3px; border-radius: 2px; margin-bottom: 16px; }
.wpcp-pack-card .pack-for {
  font-size: 11px; font-weight: 600; letter-spacing: .08em;
  text-transform: uppercase; color: var(--muted); margin-bottom: 4px;
}
.wpcp-pack-card h3.pack-name {
  font-family: var(--font-sora); font-weight: 600; font-size: 22px;
  color: var(--text); margin-bottom: 6px; letter-spacing: -.01em;
}
.wpcp-pack-card .pack-price {
  font-family: var(--font-sora); font-weight: 600; font-size: 28px;
  color: var(--text); letter-spacing: -.02em; margin-bottom: 2px;
}
.wpcp-pack-card .pack-price-note { font-size: 13px; color: var(--muted); margin-bottom: 20px; }
.wpcp-pack-card .pack-price-note .hl { color: var(--blue-cta); font-weight: 600; }
.wpcp-pack-card .pack-divider { border: none; border-top: 1px solid var(--neutral); margin: 16px 0; }
.wpcp-pack-card .pack-feats { list-style: none; padding: 0; flex: 1; }
.wpcp-pack-card .pack-feats li {
  display: flex; align-items: flex-start; gap: 9px;
  font-size: 14px; color: var(--text); margin-bottom: 8px; line-height: 1.45;
}
.wpcp-pack-card .pack-feats li .ico { flex: none; font-size: 13px; font-weight: 700; margin-top: 1px; color: var(--protection); }
.wpcp-pack-card .pack-note {
  margin-top: 16px; padding: 12px 14px; border-radius: var(--r);
  font-size: 13px; color: var(--muted); line-height: 1.5;
  background: var(--surface-2); border: 1px solid var(--neutral);
}
.wpcp-pack-card .pack-note strong { color: var(--text); }

/* ══════════════════════════════════════════════════
   9. TABLES (volume + add-ons)
   ══════════════════════════════════════════════════ */
.wpcp-table-wrap {
  overflow-x: auto; border-radius: var(--r);
  border: 1px solid var(--neutral); box-shadow: var(--shadow);
}
.wpcp-table {
  border-collapse: collapse; width: 100%; min-width: 480px;
  background: var(--white); font-size: 14px;
}
.wpcp-table thead th {
  font-family: var(--font-sora); font-size: 12px; font-weight: 600;
  letter-spacing: .05em; text-transform: uppercase; color: var(--muted);
  padding: 13px 20px; background: var(--surface-2);
  border-bottom: 1px solid var(--neutral); text-align: left; white-space: nowrap;
}
.wpcp-table tbody td { padding: 12px 20px; border-bottom: 1px solid var(--neutral); color: var(--text); vertical-align: middle; }
.wpcp-table tbody tr:last-child td { border-bottom: none; }
.wpcp-table tbody tr:nth-child(even) td { background: var(--surface-2); }
.wpcp-table .disc {
  font-size: 12px; font-weight: 600; color: var(--protection-text);
  background: var(--protection-soft); border-radius: 99px; padding: 2px 9px;
}
.wpcp-table .price { font-family: var(--font-sora); font-weight: 600; color: var(--text); }

/* ══════════════════════════════════════════════════
   10. DARK CTA SECTION
   ══════════════════════════════════════════════════ */
.wpcp-cta {
  background: var(--dark); padding: 100px 0; text-align: center;
  position: relative; overflow: hidden;
}
.wpcp-cta::before {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(ellipse 60% 70% at 50% 100%, rgba(37,99,235,.10) 0%, transparent 70%);
}
.wpcp-cta .inner { position: relative; z-index: 1; }
.wpcp-cta h2 {
  font-family: var(--font-sora); font-weight: 600; color: #fff;
  font-size: 48px; letter-spacing: -.02em; margin-bottom: 14px; line-height: 1.1;
}
.wpcp-cta p { color: rgba(255,255,255,.65); font-size: 18px; max-width: 520px; margin: 0 auto 32px; }
.wpcp-cta-row { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; }
.wpcp-cta a.btn-pri {
  display: inline-flex; align-items: center;
  background: var(--blue-cta); color: #fff; font-weight: 500; font-size: 16px;
  padding: 14px 24px; border-radius: var(--r); text-decoration: none; transition: background .15s;
}
.wpcp-cta a.btn-pri:hover { background: var(--blue-cta-hover); }
.wpcp-cta a.btn-sec {
  display: inline-flex; align-items: center;
  background: transparent; color: rgba(255,255,255,.82); font-weight: 500; font-size: 16px;
  border: 1px solid rgba(255,255,255,.25); padding: 14px 24px; border-radius: var(--r);
  text-decoration: none; transition: .15s;
}
.wpcp-cta a.btn-sec:hover { background: var(--blue-cta); border-color: var(--blue-cta); color: #fff; }

/* More link (homepage widget) */
.wpcw-more,
.wphp-more { text-align: center; padding: 0; font-size: 16px; color: var(--muted); }
.wpcw-more a,
.wphp-more a { color: var(--blue-cta); font-weight: 500; text-decoration: none; display: inline-flex; align-items: center; gap: 6px; }
.wpcw-more a:hover,
.wphp-more a:hover { text-decoration: underline; }

/* ══════════════════════════════════════════════════
   11. RESPONSIVE
   max 1300px / tablet 975px / mobile 765px
   ══════════════════════════════════════════════════ */
@media (max-width: 1300px) {
  .wpcp-card, .wpcw-card, .wphp-card { width: 320px; flex: 0 0 320px; }
}
@media (max-width: 975px) {
  .wpcp-section { padding: 80px 0; }
  .wpcp-hero { padding: 80px 0 64px; }
  .wpcp-cards-section, .wpcw-cards, .wphp-cards { padding: 0 0 80px; }
  .wpcp-cta { padding: 80px 0; }
  .wpcp-section-head h2, .wpcp-hero h1, .wpcp-cta h2,
  .wpcw-head h2, .wphp-head h2 { font-size: 40px; }
  .wpcp-card, .wpcw-card, .wphp-card { width: calc(50% - 10px); flex: 0 0 calc(50% - 10px); }
  .wpcp-pack-grid { grid-template-columns: 1fr; }
  .wpcp-seg-row, .wpcw-seg-row, .wphp-seg-row { flex-direction: column; width: 100%; }
  .wpcp-seg-btn, .wpcw-seg-btn, .wphp-seg-btn { text-align: left; }
  .wpcp-seg-section, .wpcw-seg-section, .wphp-seg-section { padding: 32px 0 0; }
}
@media (max-width: 765px) {
  .wpcp-section-head h2, .wpcp-hero h1, .wpcp-cta h2,
  .wpcw-head h2, .wphp-head h2 { font-size: 32px; }
  .wpcp-section-head .lede, .wpcp-hero .lede, .wpcp-cta p,
  .wpcw-head p, .wphp-head p { font-size: 16px; }
  .wpcp-card, .wpcw-card, .wphp-card { width: 100%; flex: 0 0 100%; }
  .wpcp-grid, .wpcw-grid, .wphp-grid { flex-direction: column; }
}
@media (prefers-reduced-motion: reduce) {
  .wpcp *, .wpcw *, .wphp * { transition: none !important; animation: none !important; }
}

/* ── Astra theme override — remove link underline from CTA buttons ── */
.wpcp a.cta,
.wpcw a.cta,
.wphp a.cta,
.wpcp-card a,
.wpcw-card a,
.wphp-card a,
.wpcp-cta a,
.wpcw-more a { text-decoration: none !important; }