/*
 * CompareWegovyPrices — Product UI Design System
 * File: assets/css/cwp-product-ui.css
 *
 * Namespaced CWP design system. All classes are prefixed cwp-.
 * Does not override WordPress core or other themes.
 */

/* ==========================================================================
   1. DESIGN TOKENS
   ========================================================================== */

:root {
  --cwp-ink:         #06152f;
  --cwp-navy:        #071a36;
  --cwp-navy-2:      #0b2345;
  --cwp-text:        #10213f;
  --cwp-muted:       #5c6b82;
  --cwp-soft:        #f7f4ee;
  --cwp-card:        #ffffff;
  --cwp-line:        #dfe6ef;
  --cwp-bg:          #f4f6fa;
  --cwp-live:        #22a55a;
  --cwp-live-soft:   #e8f8ef;
  --cwp-alert:       #ff654f;
  --cwp-alert-dark:  #e64d39;
  --cwp-warning:     #f59e0b;
  --cwp-danger:      #ef4444;
  --cwp-blue:        #3b82f6;
  --cwp-preorder:    #d97706;
  --cwp-preorder-bg: #fff3df;
  --cwp-soon:        #1d4ed8;
  --cwp-soon-bg:     #eaf2ff;
  --cwp-watch:       #7c3aed;
  --cwp-watch-bg:    #f1eaff;

  --cwp-radius-sm:   10px;
  --cwp-radius:      16px;
  --cwp-radius-lg:   24px;
  --cwp-radius-xl:   32px;

  --cwp-shadow-card: 0 14px 35px rgba(6,21,47,.08);
  --cwp-shadow-soft: 0 8px 24px rgba(6,21,47,.06);
  --cwp-shadow-btn:  0 4px 14px rgba(255,101,79,.35);

  --cwp-max:         1180px;
  --cwp-pad:         clamp(16px, 4vw, 40px);

  --cwp-font-body:   'Plus Jakarta Sans', system-ui, -apple-system, sans-serif;
  --cwp-font-mono:   'Tabular', 'JetBrains Mono', monospace;
}


/* ==========================================================================
   2. BASE RESETS (CWP scope only)
   ========================================================================== */

.cwp-shell *,
.cwp-shell *::before,
.cwp-shell *::after {
  box-sizing: border-box;
}

.cwp-shell {
  font-family: var(--cwp-font-body);
  color: var(--cwp-text);
  -webkit-font-smoothing: antialiased;
}


/* ==========================================================================
   3. LAYOUT UTILITIES
   ========================================================================== */

.cwp-container {
  width: 100%;
  max-width: var(--cwp-max);
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--cwp-pad);
  padding-right: var(--cwp-pad);
}

.cwp-section {
  padding: 56px 0;
}

.cwp-section--sm {
  padding: 32px 0;
}

.cwp-section--lg {
  padding: 80px 0;
}

.cwp-grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}

.cwp-grid-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.cwp-grid-4 {
  display: grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 20px;
}

.cwp-flex {
  display: flex;
  align-items: center;
}

.cwp-flex-between {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.cwp-sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}


/* ==========================================================================
   4. FRESHNESS STRIP
   ========================================================================== */

.cwp-top-strip {
  background: var(--cwp-navy);
  color: rgba(255,255,255,.82);
  font-size: 11.5px;
  font-weight: 600;
  letter-spacing: .02em;
  padding: 7px 0;
  line-height: 1;
}

.cwp-top-strip__inner {
  max-width: var(--cwp-max);
  margin: 0 auto;
  padding: 0 var(--cwp-pad);
  display: flex;
  align-items: center;
  gap: 20px;
  justify-content: space-between;
}

.cwp-top-strip__items {
  display: flex;
  align-items: center;
  gap: 20px;
}

.cwp-top-strip__item {
  display: flex;
  align-items: center;
  gap: 6px;
}

.cwp-top-strip__dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--cwp-live);
  animation: cwp-pulse 2s infinite;
  flex-shrink: 0;
}

.cwp-top-strip__right {
  display: flex;
  align-items: center;
  gap: 16px;
}

.cwp-top-strip__flag {
  font-size: 16px;
  line-height: 1;
}

@keyframes cwp-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: .4; }
}


/* ==========================================================================
   5. NAVIGATION
   ========================================================================== */

.cwp-header {
  background: #fff;
  border-bottom: 1px solid var(--cwp-line);
  position: sticky;
  top: 0;
  z-index: 200;
}

.cwp-header__inner {
  max-width: var(--cwp-max);
  margin: 0 auto;
  padding: 0 var(--cwp-pad);
  height: 60px;
  display: flex;
  align-items: center;
  gap: 32px;
}

.cwp-logo {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  flex-shrink: 0;
}

.cwp-logo__text {
  font-size: 15px;
  font-weight: 700;
  color: var(--cwp-ink);
  letter-spacing: -.02em;
}

.cwp-logo__text strong {
  color: var(--cwp-alert);
}

.cwp-nav {
  display: flex;
  align-items: center;
  gap: 4px;
  margin: 0;
  padding: 0;
  list-style: none;
  flex: 1;
}

.cwp-nav a {
  display: block;
  padding: 8px 12px;
  font-size: 13.5px;
  font-weight: 600;
  color: var(--cwp-muted);
  text-decoration: none;
  border-radius: 8px;
  transition: color .15s, background .15s;
  white-space: nowrap;
}

.cwp-nav a:hover,
.cwp-nav a.active {
  color: var(--cwp-text);
  background: var(--cwp-bg);
}

.cwp-nav__actions {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-left: auto;
  flex-shrink: 0;
}


/* ==========================================================================
   6. BUTTONS
   ========================================================================== */

.cwp-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 11px 22px;
  border-radius: 10px;
  font-size: 14px;
  font-weight: 700;
  text-decoration: none;
  cursor: pointer;
  border: none;
  transition: transform .15s, box-shadow .15s, background .15s;
  white-space: nowrap;
  line-height: 1;
}

.cwp-btn:active {
  transform: translateY(1px);
}

.cwp-btn--primary {
  background: var(--cwp-alert);
  color: #fff;
  box-shadow: var(--cwp-shadow-btn);
}

.cwp-btn--primary:hover {
  background: var(--cwp-alert-dark);
  box-shadow: 0 6px 18px rgba(255,101,79,.42);
  color: #fff;
}

.cwp-btn--navy {
  background: var(--cwp-navy);
  color: #fff;
}

.cwp-btn--navy:hover {
  background: var(--cwp-navy-2);
  color: #fff;
}

.cwp-btn--outline {
  background: transparent;
  color: var(--cwp-text);
  border: 1.5px solid var(--cwp-line);
}

.cwp-btn--outline:hover {
  border-color: var(--cwp-text);
  color: var(--cwp-text);
}

.cwp-btn--outline-white {
  background: transparent;
  color: #fff;
  border: 1.5px solid rgba(255,255,255,.4);
}

.cwp-btn--outline-white:hover {
  background: rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.7);
  color: #fff;
}

.cwp-btn--sm {
  padding: 8px 16px;
  font-size: 12.5px;
}

.cwp-btn--lg {
  padding: 15px 30px;
  font-size: 15px;
  border-radius: 12px;
}


/* ==========================================================================
   7. IMAGE SYSTEM
   ========================================================================== */

.cwp-img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.cwp-image-panel {
  position: relative;
  overflow: hidden;
  border-radius: var(--cwp-radius-lg);
  background: var(--cwp-line);
  isolation: isolate;
}

.cwp-image-panel img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 700ms ease;
}

.cwp-image-panel::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(7,26,54,.62), rgba(7,26,54,.10) 48%, rgba(7,26,54,0)),
    linear-gradient(180deg, rgba(7,26,54,0), rgba(7,26,54,.12));
  z-index: 1;
}

.cwp-image-panel:hover img {
  transform: scale(1.035);
}

.cwp-image-panel--hero {
  min-height: 360px;
}

.cwp-image-panel--wide {
  aspect-ratio: 16 / 6;
}

.cwp-image-panel--split {
  aspect-ratio: 16 / 9;
}

.cwp-image-panel--thumbnail {
  aspect-ratio: 16 / 10;
  border-radius: 14px;
}

.cwp-image-panel--thumbnail::after {
  background: linear-gradient(180deg, rgba(7,26,54,0), rgba(7,26,54,.20));
}

.cwp-image-panel--no-overlay::after {
  display: none;
}

.cwp-image-panel--light::after {
  background: linear-gradient(90deg, rgba(255,255,255,.65) 0%, rgba(255,255,255,.18) 60%, rgba(255,255,255,0));
}

.cwp-img-pos-center { object-position: center center; }
.cwp-img-pos-top    { object-position: center top; }
.cwp-img-pos-left   { object-position: left center; }
.cwp-img-pos-right  { object-position: right center; }


/* ==========================================================================
   8. HERO — IMAGE BACKGROUND BASE
   ========================================================================== */

.cwp-hero--image-bg {
  position: relative;
  overflow: hidden;
  background: var(--cwp-navy);
  color: #fff;
}

.cwp-hero--image-bg::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: var(--cwp-hero-image);
  background-size: cover;
  background-position: center;
  opacity: .38;
  transform: scale(1.01);
}

.cwp-hero--image-bg::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(7,26,54,.94) 0%, rgba(7,26,54,.76) 38%, rgba(7,26,54,.20) 75%),
    linear-gradient(180deg, rgba(7,26,54,.16), rgba(7,26,54,.38));
  pointer-events: none;
}

.cwp-hero--image-bg > * {
  position: relative;
  z-index: 2;
}

/* Dark hero variant — stronger overlay */
.cwp-hero--dark {
  background: var(--cwp-navy);
  color: #fff;
}

.cwp-hero--dark::before {
  opacity: .52;
}


/* ==========================================================================
   9. STATUS PILLS
   ========================================================================== */

.cwp-status-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 11.5px;
  font-weight: 800;
  line-height: 1;
  white-space: nowrap;
  letter-spacing: .01em;
}

.cwp-status-pill::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
  flex-shrink: 0;
}

.cwp-status-pill--live {
  color: #08783b;
  background: var(--cwp-live-soft);
}

.cwp-status-pill--preorder {
  color: #8a4d00;
  background: var(--cwp-preorder-bg);
}

.cwp-status-pill--soon {
  color: var(--cwp-soon);
  background: var(--cwp-soon-bg);
}

.cwp-status-pill--watching {
  color: #6d28d9;
  background: var(--cwp-watch-bg);
}

.cwp-status-pill--out {
  color: #b42318;
  background: #ffecea;
}

.cwp-status-pill--none {
  color: var(--cwp-muted);
  background: #eef2f7;
}

.cwp-status-pill--lg {
  font-size: 13px;
  padding: 6px 14px;
}

.cwp-status-pill--lg::before {
  width: 8px;
  height: 8px;
}


/* ==========================================================================
   10. METRIC CARDS
   ========================================================================== */

.cwp-metric-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 16px;
}

.cwp-metric-card {
  background: var(--cwp-card);
  border: 1px solid var(--cwp-line);
  border-radius: var(--cwp-radius);
  padding: 20px 22px;
  box-shadow: var(--cwp-shadow-soft);
}

.cwp-metric-card--highlight {
  background: var(--cwp-navy);
  border-color: transparent;
  color: #fff;
}

.cwp-metric-card--live {
  border-left: 3px solid var(--cwp-live);
}

.cwp-metric-card--preorder {
  border-left: 3px solid var(--cwp-preorder);
}

.cwp-metric-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--cwp-muted);
  margin: 0 0 8px;
}

.cwp-metric-card--highlight .cwp-metric-label {
  color: rgba(255,255,255,.6);
}

.cwp-metric-value {
  font-size: 28px;
  font-weight: 800;
  color: var(--cwp-ink);
  line-height: 1;
  font-variant-numeric: tabular-nums;
  letter-spacing: -.03em;
  margin: 0 0 6px;
}

.cwp-metric-card--highlight .cwp-metric-value {
  color: #fff;
}

.cwp-metric-sub {
  font-size: 11.5px;
  color: var(--cwp-muted);
  margin: 0;
}

.cwp-metric-card--highlight .cwp-metric-sub {
  color: rgba(255,255,255,.55);
}


/* ==========================================================================
   11. VERIFIED PRICE BOARD
   ========================================================================== */

.cwp-price-board {
  background: var(--cwp-navy);
  border-radius: var(--cwp-radius-xl);
  overflow: hidden;
}

.cwp-price-board__header {
  padding: 22px 28px;
  border-bottom: 1px solid rgba(255,255,255,.1);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.cwp-price-board__title {
  font-size: 15px;
  font-weight: 700;
  color: #fff;
  margin: 0;
}

.cwp-price-board__updated {
  font-size: 11.5px;
  color: rgba(255,255,255,.5);
}

.cwp-price-table {
  width: 100%;
  border-collapse: collapse;
}

.cwp-price-table th {
  font-size: 10.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: rgba(255,255,255,.45);
  padding: 10px 28px;
  text-align: left;
}

.cwp-price-table td {
  padding: 13px 28px;
  font-size: 13.5px;
  color: rgba(255,255,255,.88);
  border-top: 1px solid rgba(255,255,255,.06);
  vertical-align: middle;
}

.cwp-price-table tr:hover td {
  background: rgba(255,255,255,.04);
}

.cwp-price-table .cwp-table-name {
  font-weight: 700;
  color: #fff;
}

.cwp-price-table .cwp-table-price {
  font-size: 15px;
  font-weight: 800;
  color: #fff;
  font-variant-numeric: tabular-nums;
  letter-spacing: -.02em;
}

.cwp-price-table .cwp-table-price--tbc {
  color: rgba(255,255,255,.4);
  font-size: 12px;
  font-weight: 500;
}

.cwp-price-board__footer {
  padding: 16px 28px;
  border-top: 1px solid rgba(255,255,255,.1);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.cwp-price-board__disclaimer {
  font-size: 11px;
  color: rgba(255,255,255,.4);
  margin: 0;
}


/* ==========================================================================
   12. PROVIDER CARDS (CWP namespaced)
   ========================================================================== */

.cwp-provider-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 20px;
}

.cwp-provider-card {
  background: var(--cwp-card);
  border: 1px solid var(--cwp-line);
  border-radius: var(--cwp-radius-lg);
  overflow: hidden;
  box-shadow: var(--cwp-shadow-soft);
  display: flex;
  flex-direction: column;
  transition: box-shadow .2s, transform .2s;
}

.cwp-provider-card:hover {
  box-shadow: var(--cwp-shadow-card);
  transform: translateY(-2px);
}

.cwp-provider-card--dim {
  opacity: .75;
}

.cwp-provider-card__top {
  padding: 20px 20px 0;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.cwp-provider-card__logo-wrap {
  min-height: 36px;
  display: flex;
  align-items: center;
}

.cwp-provider-card__logo {
  max-width: 110px;
  max-height: 36px;
  width: auto;
  height: auto;
  object-fit: contain;
  object-position: left center;
}

.cwp-provider-card__initials {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  background: var(--cwp-navy);
  color: #fff;
  font-size: 13px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  letter-spacing: -.02em;
}

.cwp-provider-card__body {
  padding: 14px 20px 0;
  flex: 1;
}

.cwp-provider-card__name {
  font-size: 15px;
  font-weight: 700;
  color: var(--cwp-ink);
  margin: 0 0 10px;
  line-height: 1.25;
}

.cwp-provider-card__name a {
  color: inherit;
  text-decoration: none;
}

.cwp-provider-card__name a:hover {
  color: var(--cwp-alert);
}

.cwp-provider-card__price {
  font-size: 22px;
  font-weight: 800;
  color: var(--cwp-ink);
  font-variant-numeric: tabular-nums;
  letter-spacing: -.03em;
  line-height: 1;
  margin: 0 0 4px;
}

.cwp-provider-card__price--tbc {
  font-size: 13px;
  color: var(--cwp-muted);
  font-style: italic;
  font-weight: 400;
}

.cwp-provider-card__detail {
  font-size: 12px;
  color: var(--cwp-muted);
  margin: 0 0 12px;
  line-height: 1.4;
}

.cwp-provider-card__footer {
  padding: 14px 20px;
  border-top: 1px solid var(--cwp-line);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-top: auto;
}

.cwp-provider-card__last-checked {
  font-size: 11px;
  color: var(--cwp-muted);
}

.cwp-provider-card__cta {
  display: inline-flex;
  align-items: center;
  padding: 9px 18px;
  border-radius: 8px;
  font-size: 12.5px;
  font-weight: 700;
  text-decoration: none;
  transition: background .15s, box-shadow .15s;
  white-space: nowrap;
}

.cwp-provider-card__cta--live {
  background: var(--cwp-alert);
  color: #fff;
  box-shadow: 0 3px 10px rgba(255,101,79,.3);
}

.cwp-provider-card__cta--live:hover {
  background: var(--cwp-alert-dark);
  color: #fff;
}

.cwp-provider-card__cta--muted {
  background: var(--cwp-bg);
  color: var(--cwp-muted);
  border: 1px solid var(--cwp-line);
}

.cwp-provider-card__cta--muted:hover {
  color: var(--cwp-text);
  border-color: var(--cwp-text);
}


/* ==========================================================================
   13. HOMEPAGE HERO
   ========================================================================== */

.cwp-home-hero {
  background: var(--cwp-navy);
  color: #fff;
  padding: 56px 0 0;
}

.cwp-home-hero__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(420px, 0.88fr);
  gap: 40px;
  align-items: stretch;
}

.cwp-home-hero__content {
  padding-bottom: 56px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.cwp-home-hero__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--cwp-alert);
  margin: 0 0 18px;
}

.cwp-home-hero__h1 {
  font-size: clamp(28px, 4.5vw, 50px);
  font-weight: 800;
  line-height: 1.08;
  letter-spacing: -.03em;
  color: #fff;
  margin: 0 0 18px;
}

.cwp-home-hero__h1 em {
  font-style: normal;
  color: var(--cwp-alert);
}

.cwp-home-hero__sub {
  font-size: 16px;
  color: rgba(255,255,255,.72);
  line-height: 1.55;
  margin: 0 0 30px;
  max-width: 520px;
}

.cwp-home-hero__ctas {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.cwp-home-hero__metrics {
  display: flex;
  align-items: center;
  gap: 28px;
  margin-top: 36px;
  padding-top: 28px;
  border-top: 1px solid rgba(255,255,255,.12);
  flex-wrap: wrap;
}

.cwp-home-hero__metric {
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.cwp-home-hero__metric-val {
  font-size: 22px;
  font-weight: 800;
  color: #fff;
  font-variant-numeric: tabular-nums;
  letter-spacing: -.03em;
  line-height: 1;
}

.cwp-home-hero__metric-label {
  font-size: 11px;
  color: rgba(255,255,255,.5);
  line-height: 1.2;
}

.cwp-home-hero__media {
  min-height: 440px;
  border-radius: 40px 0 0 0;
  overflow: hidden;
  position: relative;
}

.cwp-home-hero__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 20%;
  display: block;
}

.cwp-home-hero__media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(7,26,54,.35), rgba(7,26,54,.05) 60%, rgba(7,26,54,0));
  pointer-events: none;
}


/* ==========================================================================
   14. DASHBOARD MODULES — PRICE BOARD + SIDEBAR
   ========================================================================== */

.cwp-dashboard-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.55fr) minmax(0, 1fr);
  gap: 24px;
  align-items: start;
}

.cwp-sidebar-stack {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.cwp-module {
  background: var(--cwp-card);
  border: 1px solid var(--cwp-line);
  border-radius: var(--cwp-radius-lg);
  overflow: hidden;
  box-shadow: var(--cwp-shadow-soft);
}

.cwp-module__head {
  padding: 16px 22px;
  border-bottom: 1px solid var(--cwp-line);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.cwp-module__title {
  font-size: 13px;
  font-weight: 700;
  color: var(--cwp-ink);
  margin: 0;
  display: flex;
  align-items: center;
  gap: 8px;
}

.cwp-module__view-all {
  font-size: 11.5px;
  font-weight: 600;
  color: var(--cwp-alert);
  text-decoration: none;
}

.cwp-module__view-all:hover {
  text-decoration: underline;
}

.cwp-module__body {
  padding: 18px 22px;
}

/* Discount code watch */
.cwp-code-item {
  padding: 12px 0;
  border-bottom: 1px solid var(--cwp-line);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.cwp-code-item:last-child {
  border-bottom: none;
}

.cwp-code-item__name {
  font-size: 13px;
  font-weight: 600;
  color: var(--cwp-text);
  margin: 0;
}

.cwp-code-item__code {
  font-family: var(--cwp-font-mono, monospace);
  font-size: 12px;
  font-weight: 700;
  background: var(--cwp-live-soft);
  color: #07783b;
  padding: 3px 8px;
  border-radius: 6px;
  letter-spacing: .04em;
}

.cwp-code-item__no-code {
  font-size: 12px;
  color: var(--cwp-muted);
  font-style: italic;
}

/* First month calculator */
.cwp-calc-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 9px 0;
  border-bottom: 1px solid var(--cwp-line);
  font-size: 13px;
}

.cwp-calc-row:last-child {
  border-bottom: none;
  font-weight: 700;
  color: var(--cwp-ink);
}

.cwp-calc-label {
  color: var(--cwp-muted);
}

.cwp-calc-value {
  font-weight: 600;
  color: var(--cwp-text);
  font-variant-numeric: tabular-nums;
}

.cwp-calc-total {
  font-size: 20px;
  font-weight: 800;
  color: var(--cwp-ink);
  letter-spacing: -.03em;
  font-variant-numeric: tabular-nums;
}

/* Launch Radar mini */
.cwp-radar-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 0;
  border-bottom: 1px solid var(--cwp-line);
}

.cwp-radar-item:last-child {
  border-bottom: none;
}

.cwp-radar-item__name {
  font-size: 13px;
  font-weight: 600;
  color: var(--cwp-text);
}

.cwp-radar-item__date {
  font-size: 11px;
  color: var(--cwp-muted);
  margin-top: 2px;
}


/* ==========================================================================
   15. LIFESTYLE CONFIDENCE BAND
   ========================================================================== */

.cwp-confidence-band {
  position: relative;
  overflow: hidden;
  border-radius: var(--cwp-radius-xl);
  background: var(--cwp-navy);
  color: #fff;
}

.cwp-confidence-band::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: var(--cwp-band-image);
  background-size: cover;
  background-position: center;
  opacity: .35;
}

.cwp-confidence-band::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(7,26,54,.94) 0%, rgba(7,26,54,.78) 44%, rgba(7,26,54,.30) 100%);
}

.cwp-confidence-band__inner {
  position: relative;
  z-index: 2;
  padding: 56px var(--cwp-pad);
  max-width: var(--cwp-max);
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
}

.cwp-confidence-band__copy h2 {
  font-size: clamp(22px, 3.5vw, 34px);
  font-weight: 800;
  color: #fff;
  margin: 0 0 10px;
  letter-spacing: -.03em;
  line-height: 1.15;
}

.cwp-confidence-band__copy p {
  font-size: 15px;
  color: rgba(255,255,255,.7);
  margin: 0;
  max-width: 440px;
  line-height: 1.5;
}

.cwp-confidence-band__form {
  display: flex;
  gap: 10px;
  flex-shrink: 0;
  max-width: 420px;
  width: 100%;
}

.cwp-confidence-band__input {
  flex: 1;
  padding: 12px 18px;
  border-radius: 10px;
  border: 1.5px solid rgba(255,255,255,.25);
  background: rgba(255,255,255,.12);
  color: #fff;
  font-size: 14px;
  outline: none;
  transition: border-color .15s;
}

.cwp-confidence-band__input::placeholder {
  color: rgba(255,255,255,.4);
}

.cwp-confidence-band__input:focus {
  border-color: rgba(255,255,255,.6);
}


/* ==========================================================================
   16. GUIDES SECTION
   ========================================================================== */

.cwp-guides-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 20px;
}

.cwp-guide-card {
  background: var(--cwp-card);
  border: 1px solid var(--cwp-line);
  border-radius: var(--cwp-radius-lg);
  overflow: hidden;
  box-shadow: var(--cwp-shadow-soft);
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
  transition: box-shadow .2s, transform .2s;
}

.cwp-guide-card:hover {
  box-shadow: var(--cwp-shadow-card);
  transform: translateY(-2px);
  color: inherit;
}

.cwp-guide-card__media {
  aspect-ratio: 16 / 10;
  overflow: hidden;
  position: relative;
  background: var(--cwp-line);
}

.cwp-guide-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 600ms ease;
}

.cwp-guide-card:hover .cwp-guide-card__media img {
  transform: scale(1.04);
}

.cwp-guide-card__body {
  padding: 18px 20px 20px;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.cwp-guide-card__cat {
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--cwp-alert);
  margin: 0 0 8px;
}

.cwp-guide-card__title {
  font-size: 14.5px;
  font-weight: 700;
  color: var(--cwp-ink);
  line-height: 1.35;
  margin: 0 0 8px;
}

.cwp-guide-card__excerpt {
  font-size: 12.5px;
  color: var(--cwp-muted);
  line-height: 1.5;
  margin: 0;
  flex: 1;
}

.cwp-guide-card__arrow {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 12px;
  font-weight: 700;
  color: var(--cwp-alert);
  margin-top: 14px;
}

/* Guides hub — grouped text cards (no media) */
.cwp-guide-group {
  scroll-margin-top: 90px;
}

.cwp-guide-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 18px;
  margin-top: 20px;
}

.cwp-guide-grid .cwp-guide-card {
  padding: 20px 22px;
}

.cwp-guide-card__desc {
  font-size: 13px;
  color: var(--cwp-muted);
  line-height: 1.55;
  margin: 8px 0 0;
  flex: 1;
}

.cwp-guide-card__cta {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 12.5px;
  font-weight: 700;
  color: var(--cwp-alert);
  margin-top: 16px;
}


/* ==========================================================================
   17. TRUST STRIP
   ========================================================================== */

.cwp-trust-strip {
  display: flex;
  align-items: center;
  gap: 32px;
  justify-content: center;
  flex-wrap: wrap;
  padding: 28px 0;
  border-top: 1px solid var(--cwp-line);
  border-bottom: 1px solid var(--cwp-line);
}

.cwp-trust-item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 12.5px;
  font-weight: 600;
  color: var(--cwp-muted);
}

.cwp-trust-item__icon {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--cwp-live-soft);
  color: var(--cwp-live);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
  flex-shrink: 0;
}


/* ==========================================================================
   18. ALERT CTA BLOCK
   ========================================================================== */

.cwp-alert-cta {
  position: relative;
  overflow: hidden;
  border-radius: var(--cwp-radius-xl);
  background: var(--cwp-navy);
  color: #fff;
  padding: 52px var(--cwp-pad);
  text-align: center;
}

.cwp-alert-cta--image {
  color: #fff;
}

.cwp-alert-cta--image::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: var(--cwp-cta-image, none);
  background-size: cover;
  background-position: center;
  opacity: .42;
}

.cwp-alert-cta--image::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(7,26,54,.96), rgba(7,26,54,.72) 52%, rgba(7,26,54,.18));
}

.cwp-alert-cta__inner {
  position: relative;
  z-index: 2;
  max-width: 620px;
  margin: 0 auto;
}

.cwp-alert-cta h2 {
  font-size: clamp(20px, 3vw, 30px);
  font-weight: 800;
  color: #fff;
  margin: 0 0 10px;
  letter-spacing: -.03em;
}

.cwp-alert-cta p {
  font-size: 15px;
  color: rgba(255,255,255,.72);
  margin: 0 0 28px;
  line-height: 1.5;
}

.cwp-alert-cta__form {
  display: flex;
  gap: 10px;
  max-width: 440px;
  margin: 0 auto;
}

.cwp-alert-cta__input {
  flex: 1;
  padding: 13px 18px;
  border-radius: 10px;
  border: 1.5px solid rgba(255,255,255,.25);
  background: rgba(255,255,255,.12);
  color: #fff;
  font-size: 14px;
  outline: none;
}

.cwp-alert-cta__input::placeholder { color: rgba(255,255,255,.4); }
.cwp-alert-cta__input:focus { border-color: rgba(255,255,255,.6); }

.cwp-alert-cta__ctas {
  display: flex;
  align-items: center;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
}


/* ==========================================================================
   19. COMPARE PRICES PAGE
   ========================================================================== */

.cwp-compare-hero {
  display: grid;
  grid-template-columns: minmax(0, 0.92fr) minmax(360px, 0.78fr);
  gap: 28px;
  align-items: stretch;
}

.cwp-compare-hero .cwp-image-panel {
  aspect-ratio: 16 / 8.5;
  min-height: 260px;
}

.cwp-compare-hero__content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 32px 0;
}

.cwp-compare-hero__h1 {
  font-size: clamp(26px, 3.8vw, 42px);
  font-weight: 800;
  color: var(--cwp-ink);
  margin: 0 0 14px;
  letter-spacing: -.03em;
  line-height: 1.1;
}

.cwp-compare-hero__sub {
  font-size: 15px;
  color: var(--cwp-muted);
  margin: 0 0 24px;
  line-height: 1.55;
}

/* Filter bar */
.cwp-filter-bar {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  padding: 16px 0;
}

.cwp-filter-select {
  padding: 9px 14px;
  border-radius: 8px;
  border: 1.5px solid var(--cwp-line);
  font-size: 13px;
  color: var(--cwp-text);
  background: #fff;
  font-weight: 600;
  outline: none;
  cursor: pointer;
}

.cwp-filter-select:focus {
  border-color: var(--cwp-alert);
}

.cwp-filter-search {
  flex: 1;
  min-width: 200px;
  padding: 9px 14px;
  border-radius: 8px;
  border: 1.5px solid var(--cwp-line);
  font-size: 13px;
  color: var(--cwp-text);
  background: #fff;
  outline: none;
}

.cwp-filter-search:focus {
  border-color: var(--cwp-alert);
}

/* Compare table */
.cwp-compare-table-wrap {
  overflow-x: auto;
  border-radius: var(--cwp-radius-lg);
  box-shadow: var(--cwp-shadow-soft);
}

.cwp-compare-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  background: #fff;
  border: 1px solid var(--cwp-line);
  border-radius: var(--cwp-radius-lg);
  overflow: hidden;
}

.cwp-compare-table thead th {
  background: var(--cwp-bg);
  padding: 12px 18px;
  text-align: left;
  font-size: 10.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--cwp-muted);
  border-bottom: 1px solid var(--cwp-line);
  white-space: nowrap;
}

.cwp-compare-table tbody td {
  padding: 15px 18px;
  font-size: 13.5px;
  color: var(--cwp-text);
  border-bottom: 1px solid var(--cwp-line);
  vertical-align: middle;
}

.cwp-compare-table tbody tr:last-child td {
  border-bottom: none;
}

.cwp-compare-table tbody tr:hover td {
  background: rgba(244,246,250,.6);
}

.cwp-compare-table__provider-name {
  font-weight: 700;
  color: var(--cwp-ink);
  white-space: nowrap;
}

.cwp-compare-table__price {
  font-size: 16px;
  font-weight: 800;
  color: var(--cwp-ink);
  font-variant-numeric: tabular-nums;
  letter-spacing: -.02em;
  white-space: nowrap;
}

.cwp-compare-table__price--tbc {
  font-size: 12px;
  font-weight: 500;
  color: var(--cwp-muted);
}

.cwp-compare-table__action {
  white-space: nowrap;
}

/* Mobile provider list (replaces table on small screens) */
.cwp-mobile-provider-list {
  display: none;
}

.cwp-mobile-provider-item {
  background: var(--cwp-card);
  border: 1px solid var(--cwp-line);
  border-radius: var(--cwp-radius);
  padding: 18px;
  margin-bottom: 12px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.cwp-mobile-provider-item__row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
}

.cwp-mobile-provider-item__name {
  font-weight: 700;
  color: var(--cwp-ink);
  font-size: 14px;
}

.cwp-mobile-provider-item__price {
  font-size: 17px;
  font-weight: 800;
  color: var(--cwp-ink);
  font-variant-numeric: tabular-nums;
}

.cwp-mobile-provider-item__meta {
  font-size: 12px;
  color: var(--cwp-muted);
}


/* ==========================================================================
   20. PROVIDERS ARCHIVE
   ========================================================================== */

.cwp-providers-hero {
  position: relative;
  overflow: hidden;
  border-radius: var(--cwp-radius-xl);
  background: #fff;
  border: 1px solid var(--cwp-line);
  min-height: 180px;
  display: flex;
  align-items: center;
}

.cwp-providers-hero__image {
  position: absolute;
  inset: 0 0 0 38%;
  z-index: 0;
}

.cwp-providers-hero__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.cwp-providers-hero__image::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, #fff 0%, rgba(255,255,255,.88) 24%, rgba(255,255,255,.15) 100%);
}

.cwp-providers-hero__content {
  position: relative;
  z-index: 1;
  padding: 40px var(--cwp-pad);
  max-width: 55%;
}

.cwp-providers-hero__h1 {
  font-size: clamp(22px, 3.5vw, 36px);
  font-weight: 800;
  color: var(--cwp-ink);
  margin: 0 0 12px;
  letter-spacing: -.03em;
  line-height: 1.15;
}

.cwp-providers-hero__sub {
  font-size: 14px;
  color: var(--cwp-muted);
  margin: 0;
  line-height: 1.5;
}

/* Status count bar */
.cwp-status-counts {
  display: grid;
  grid-template-columns: repeat(5, minmax(0,1fr));
  gap: 12px;
  margin: 24px 0;
}

.cwp-status-count-card {
  background: var(--cwp-card);
  border: 1px solid var(--cwp-line);
  border-radius: var(--cwp-radius);
  padding: 16px;
  text-align: center;
  box-shadow: var(--cwp-shadow-soft);
}

.cwp-status-count-card__num {
  font-size: 26px;
  font-weight: 800;
  color: var(--cwp-ink);
  line-height: 1;
  font-variant-numeric: tabular-nums;
  letter-spacing: -.03em;
}

.cwp-status-count-card__label {
  font-size: 11px;
  color: var(--cwp-muted);
  margin-top: 4px;
  font-weight: 600;
}

/* Filter tabs (status) */
.cwp-filter-tabs {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin: 20px 0;
}

.cwp-filter-tab {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  border-radius: 999px;
  font-size: 12.5px;
  font-weight: 700;
  text-decoration: none;
  background: var(--cwp-card);
  color: var(--cwp-muted);
  border: 1.5px solid var(--cwp-line);
  transition: border-color .15s, color .15s, background .15s;
}

.cwp-filter-tab:hover {
  border-color: var(--cwp-text);
  color: var(--cwp-text);
}

.cwp-filter-tab.active {
  background: var(--cwp-navy);
  color: #fff;
  border-color: var(--cwp-navy);
}

.cwp-filter-tab__count {
  background: rgba(255,255,255,.2);
  border-radius: 999px;
  padding: 2px 7px;
  font-size: 10.5px;
}

.cwp-filter-tab.active .cwp-filter-tab__count {
  background: rgba(255,255,255,.2);
}

.cwp-filter-tab:not(.active) .cwp-filter-tab__count {
  background: var(--cwp-bg);
  color: var(--cwp-muted);
}

/* Tier divider */
.cwp-tier-divider {
  grid-column: 1 / -1;
  padding: 12px 16px;
  background: var(--cwp-bg);
  border-radius: 8px;
  font-size: 11.5px;
  font-weight: 700;
  color: var(--cwp-muted);
  letter-spacing: .04em;
  text-transform: uppercase;
}


/* ==========================================================================
   21. SINGLE PROVIDER — INTELLIGENCE TEMPLATE
   ========================================================================== */

.cwp-provider-hero {
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(340px, .75fr);
  gap: 0;
  background: #fff;
  border: 1px solid var(--cwp-line);
  border-radius: var(--cwp-radius-xl);
  overflow: hidden;
  box-shadow: var(--cwp-shadow-card);
  margin-bottom: 32px;
}

.cwp-provider-hero__content {
  padding: 36px 36px 32px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.cwp-provider-hero__logo {
  margin-bottom: 16px;
}

.cwp-provider-hero__logo img {
  max-width: 180px;
  max-height: 52px;
  object-fit: contain;
  object-position: left;
}

.cwp-provider-hero__initials-badge {
  width: 52px;
  height: 52px;
  border-radius: 14px;
  background: var(--cwp-navy);
  color: #fff;
  font-size: 18px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 16px;
}

.cwp-provider-hero__name {
  font-size: clamp(22px, 3vw, 30px);
  font-weight: 800;
  color: var(--cwp-ink);
  margin: 0 0 10px;
  letter-spacing: -.03em;
  line-height: 1.15;
}

.cwp-provider-hero__trust {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 14px 0;
}

.cwp-trust-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  font-weight: 600;
  color: var(--cwp-muted);
  background: var(--cwp-bg);
  padding: 4px 10px;
  border-radius: 999px;
}

.cwp-trust-chip--live {
  color: #07783b;
  background: var(--cwp-live-soft);
}

.cwp-provider-hero__price {
  font-size: 38px;
  font-weight: 800;
  color: var(--cwp-ink);
  letter-spacing: -.04em;
  font-variant-numeric: tabular-nums;
  line-height: 1;
  margin: 20px 0 6px;
}

.cwp-provider-hero__price-note {
  font-size: 12.5px;
  color: var(--cwp-muted);
  margin: 0 0 24px;
}

.cwp-provider-hero__ctas {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.cwp-provider-hero__media {
  min-height: 330px;
  position: relative;
  overflow: hidden;
}

.cwp-provider-hero__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 20%;
}

.cwp-provider-hero__media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(255,255,255,.14), rgba(7,26,54,.08));
  pointer-events: none;
}

/* What you'll actually pay */
.cwp-pay-table {
  background: var(--cwp-card);
  border: 1px solid var(--cwp-line);
  border-radius: var(--cwp-radius-lg);
  overflow: hidden;
  box-shadow: var(--cwp-shadow-soft);
}

.cwp-pay-table__header {
  padding: 18px 22px;
  background: var(--cwp-bg);
  border-bottom: 1px solid var(--cwp-line);
}

.cwp-pay-table__title {
  font-size: 14px;
  font-weight: 700;
  color: var(--cwp-ink);
  margin: 0;
}

.cwp-pay-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 22px;
  border-bottom: 1px solid var(--cwp-line);
  gap: 12px;
}

.cwp-pay-row:last-child {
  border-bottom: none;
}

.cwp-pay-row--total {
  background: var(--cwp-soft);
  font-weight: 700;
}

.cwp-pay-row__label {
  font-size: 13.5px;
  color: var(--cwp-muted);
}

.cwp-pay-row--total .cwp-pay-row__label {
  color: var(--cwp-ink);
  font-size: 14px;
}

.cwp-pay-row__value {
  font-size: 14px;
  font-weight: 600;
  color: var(--cwp-text);
  font-variant-numeric: tabular-nums;
}

.cwp-pay-row--total .cwp-pay-row__value {
  font-size: 20px;
  font-weight: 800;
  color: var(--cwp-ink);
  letter-spacing: -.03em;
}

/* Ordering checklist */
.cwp-checklist {
  background: var(--cwp-card);
  border: 1px solid var(--cwp-line);
  border-radius: var(--cwp-radius-lg);
  overflow: hidden;
  box-shadow: var(--cwp-shadow-soft);
}

.cwp-checklist__header {
  padding: 18px 22px;
  background: var(--cwp-bg);
  border-bottom: 1px solid var(--cwp-line);
}

.cwp-checklist__title {
  font-size: 14px;
  font-weight: 700;
  color: var(--cwp-ink);
  margin: 0;
}

.cwp-checklist-item {
  display: flex;
  gap: 14px;
  padding: 16px 22px;
  border-bottom: 1px solid var(--cwp-line);
}

.cwp-checklist-item:last-child {
  border-bottom: none;
}

.cwp-checklist-item__icon {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--cwp-live-soft);
  color: var(--cwp-live);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  flex-shrink: 0;
  margin-top: 1px;
}

.cwp-checklist-item__title {
  font-size: 13px;
  font-weight: 700;
  color: var(--cwp-text);
  margin: 0 0 3px;
}

.cwp-checklist-item__desc {
  font-size: 12.5px;
  color: var(--cwp-muted);
  margin: 0;
  line-height: 1.4;
}

/* Similar providers */
.cwp-similar-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.cwp-similar-card {
  background: var(--cwp-card);
  border: 1px solid var(--cwp-line);
  border-radius: var(--cwp-radius);
  padding: 18px;
  box-shadow: var(--cwp-shadow-soft);
  text-decoration: none;
  display: block;
  transition: box-shadow .2s, transform .2s;
}

.cwp-similar-card:hover {
  box-shadow: var(--cwp-shadow-card);
  transform: translateY(-2px);
  color: inherit;
}

.cwp-similar-card__name {
  font-size: 13px;
  font-weight: 700;
  color: var(--cwp-ink);
  margin: 0 0 8px;
}

.cwp-similar-card__price {
  font-size: 16px;
  font-weight: 800;
  color: var(--cwp-ink);
  letter-spacing: -.02em;
  font-variant-numeric: tabular-nums;
  margin: 0 0 8px;
  display: block;
}

/* Single provider layout */
.cwp-provider-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) 340px;
  gap: 28px;
  align-items: start;
}

.cwp-provider-sidebar {
  display: flex;
  flex-direction: column;
  gap: 20px;
  position: sticky;
  top: 80px;
}


/* ==========================================================================
   22. DISCOUNT CODES PAGE
   ========================================================================== */

.cwp-discount-hero {
  --cwp-hero-image: url("../images/lifestyle-price-alert.jpg");
}

.cwp-discount-hero__inner {
  padding: 64px var(--cwp-pad) 56px;
  max-width: var(--cwp-max);
  margin: 0 auto;
}

.cwp-discount-hero h1 {
  font-size: clamp(28px, 4vw, 48px);
  font-weight: 800;
  color: #fff;
  margin: 0 0 14px;
  letter-spacing: -.03em;
  line-height: 1.1;
}

.cwp-discount-hero p {
  font-size: 16px;
  color: rgba(255,255,255,.72);
  margin: 0 0 28px;
  max-width: 540px;
  line-height: 1.55;
}

.cwp-code-status-card {
  background: var(--cwp-card);
  border: 1px solid var(--cwp-line);
  border-radius: var(--cwp-radius-xl);
  padding: 40px;
  box-shadow: var(--cwp-shadow-card);
  text-align: center;
}

.cwp-code-status-card__shield {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: var(--cwp-live-soft);
  color: var(--cwp-live);
  font-size: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 20px;
}

.cwp-code-status-card h2 {
  font-size: 22px;
  font-weight: 800;
  color: var(--cwp-ink);
  margin: 0 0 8px;
  letter-spacing: -.03em;
}

.cwp-code-status-card p {
  font-size: 14px;
  color: var(--cwp-muted);
  margin: 0 0 28px;
  line-height: 1.55;
}

.cwp-code-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  text-align: left;
  border-top: 1px solid var(--cwp-line);
  padding-top: 24px;
}

.cwp-code-stat__val {
  font-size: 26px;
  font-weight: 800;
  color: var(--cwp-ink);
  letter-spacing: -.03em;
  font-variant-numeric: tabular-nums;
  line-height: 1;
}

.cwp-code-stat__label {
  font-size: 11px;
  color: var(--cwp-muted);
  font-weight: 600;
  margin-top: 4px;
}

/* What counts as a verified code */
.cwp-verified-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}

.cwp-verified-item {
  background: var(--cwp-card);
  border: 1px solid var(--cwp-line);
  border-radius: var(--cwp-radius);
  padding: 20px;
  box-shadow: var(--cwp-shadow-soft);
}

.cwp-verified-item__icon {
  font-size: 22px;
  margin-bottom: 10px;
}

.cwp-verified-item__title {
  font-size: 13px;
  font-weight: 700;
  color: var(--cwp-ink);
  margin: 0 0 6px;
}

.cwp-verified-item__desc {
  font-size: 12px;
  color: var(--cwp-muted);
  margin: 0;
  line-height: 1.45;
}

/* Code table (example / empty state) */
.cwp-code-table-wrap {
  background: var(--cwp-card);
  border: 1px solid var(--cwp-line);
  border-radius: var(--cwp-radius-lg);
  overflow: hidden;
  box-shadow: var(--cwp-shadow-soft);
}

.cwp-code-table {
  width: 100%;
  border-collapse: collapse;
}

.cwp-code-table th {
  background: var(--cwp-bg);
  padding: 12px 18px;
  text-align: left;
  font-size: 10.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--cwp-muted);
  border-bottom: 1px solid var(--cwp-line);
}

.cwp-code-table td {
  padding: 14px 18px;
  font-size: 13px;
  color: var(--cwp-text);
  border-bottom: 1px solid var(--cwp-line);
  vertical-align: middle;
}

.cwp-code-table tr:last-child td {
  border-bottom: none;
}

.cwp-code-badge {
  font-family: monospace;
  font-size: 12px;
  font-weight: 700;
  background: var(--cwp-live-soft);
  color: #07783b;
  padding: 3px 9px;
  border-radius: 6px;
  letter-spacing: .04em;
}

.cwp-code-badge--expired {
  background: #ffecea;
  color: #b42318;
  text-decoration: line-through;
}

.cwp-example-label {
  display: inline-block;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--cwp-muted);
  background: var(--cwp-bg);
  padding: 3px 8px;
  border-radius: 4px;
}


/* ==========================================================================
   23. LAUNCH RADAR PAGE
   ========================================================================== */

.cwp-launch-hero {
  --cwp-hero-image: url("../images/lifestyle-woman-desk.jpg");
}

.cwp-launch-hero__inner {
  padding: 64px var(--cwp-pad) 56px;
  max-width: var(--cwp-max);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 40px;
  align-items: center;
}

.cwp-launch-hero h1 {
  font-size: clamp(28px, 4.5vw, 52px);
  font-weight: 800;
  color: #fff;
  margin: 0 0 14px;
  letter-spacing: -.03em;
  line-height: 1.08;
}

.cwp-launch-hero p {
  font-size: 16px;
  color: rgba(255,255,255,.72);
  margin: 0 0 24px;
  max-width: 540px;
  line-height: 1.55;
}

.cwp-launch-hero__metrics {
  display: flex;
  gap: 24px;
  flex-wrap: wrap;
}

.cwp-launch-hero__metric {
  text-align: center;
}

.cwp-launch-hero__metric-val {
  font-size: 28px;
  font-weight: 800;
  color: #fff;
  letter-spacing: -.04em;
  font-variant-numeric: tabular-nums;
  display: block;
  line-height: 1;
}

.cwp-launch-hero__metric-label {
  font-size: 11px;
  color: rgba(255,255,255,.5);
  margin-top: 3px;
}

/* Status overview grid */
.cwp-launch-status-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0,1fr));
  gap: 16px;
}

.cwp-launch-status-card {
  background: var(--cwp-card);
  border: 1px solid var(--cwp-line);
  border-radius: var(--cwp-radius-lg);
  padding: 22px 18px;
  text-align: center;
  box-shadow: var(--cwp-shadow-soft);
}

.cwp-launch-status-card__num {
  font-size: 32px;
  font-weight: 800;
  color: var(--cwp-ink);
  letter-spacing: -.04em;
  font-variant-numeric: tabular-nums;
  line-height: 1;
  margin-bottom: 6px;
}

.cwp-launch-status-card__label {
  font-size: 11.5px;
  font-weight: 600;
  color: var(--cwp-muted);
}

.cwp-launch-status-card--live {
  border-left: 3px solid var(--cwp-live);
}

.cwp-launch-status-card--live .cwp-launch-status-card__num {
  color: var(--cwp-live);
}

.cwp-launch-status-card--preorder {
  border-left: 3px solid var(--cwp-preorder);
}

.cwp-launch-status-card--soon {
  border-left: 3px solid var(--cwp-soon);
}

/* Dashboard three-column */
.cwp-launch-dash-grid {
  display: grid;
  grid-template-columns: 1fr 280px 280px;
  gap: 22px;
  align-items: start;
}

/* Timeline */
.cwp-timeline {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.cwp-timeline-item {
  display: flex;
  gap: 16px;
  padding: 0 0 20px;
  position: relative;
}

.cwp-timeline-item::before {
  content: "";
  position: absolute;
  left: 19px;
  top: 28px;
  bottom: 0;
  width: 2px;
  background: var(--cwp-line);
}

.cwp-timeline-item:last-child::before {
  display: none;
}

.cwp-timeline-item__dot {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--cwp-bg);
  border: 2px solid var(--cwp-line);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 15px;
  position: relative;
  z-index: 1;
}

.cwp-timeline-item--live .cwp-timeline-item__dot {
  background: var(--cwp-live-soft);
  border-color: var(--cwp-live);
}

.cwp-timeline-item--preorder .cwp-timeline-item__dot {
  background: var(--cwp-preorder-bg);
  border-color: var(--cwp-preorder);
}

.cwp-timeline-item__body {
  padding-top: 8px;
  flex: 1;
}

.cwp-timeline-item__name {
  font-size: 13.5px;
  font-weight: 700;
  color: var(--cwp-ink);
  margin: 0 0 3px;
}

.cwp-timeline-item__date {
  font-size: 11.5px;
  color: var(--cwp-muted);
  margin: 0;
}

/* Market pulse (simple SVG chart) */
.cwp-pulse-card {
  background: var(--cwp-card);
  border: 1px solid var(--cwp-line);
  border-radius: var(--cwp-radius-lg);
  padding: 22px;
  box-shadow: var(--cwp-shadow-soft);
}

.cwp-pulse-card__title {
  font-size: 13px;
  font-weight: 700;
  color: var(--cwp-ink);
  margin: 0 0 16px;
}

.cwp-pulse-bar-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
}

.cwp-pulse-bar-label {
  font-size: 11px;
  color: var(--cwp-muted);
  width: 80px;
  flex-shrink: 0;
}

.cwp-pulse-bar-track {
  flex: 1;
  height: 8px;
  background: var(--cwp-line);
  border-radius: 999px;
  overflow: hidden;
}

.cwp-pulse-bar-fill {
  height: 100%;
  border-radius: 999px;
  background: var(--cwp-alert);
  transition: width .5s ease;
}

.cwp-pulse-bar-fill--live   { background: var(--cwp-live); }
.cwp-pulse-bar-fill--preorder { background: var(--cwp-preorder); }
.cwp-pulse-bar-fill--soon   { background: var(--cwp-soon); }
.cwp-pulse-bar-fill--watch  { background: var(--cwp-watch); }

.cwp-pulse-bar-val {
  font-size: 11px;
  font-weight: 700;
  color: var(--cwp-text);
  width: 30px;
  text-align: right;
  flex-shrink: 0;
}


/* ==========================================================================
   24. GUIDE ARTICLE TEMPLATE
   ========================================================================== */

.cwp-guide-hero {
  display: grid;
  grid-template-columns: minmax(0, .95fr) minmax(340px, .75fr);
  gap: 32px;
  align-items: center;
  margin-bottom: 40px;
}

.cwp-guide-hero__content {
  padding: 20px 0;
}

.cwp-guide-hero__cat {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .07em;
  text-transform: uppercase;
  color: var(--cwp-alert);
  margin: 0 0 10px;
}

.cwp-guide-hero__h1 {
  font-size: clamp(24px, 3.5vw, 38px);
  font-weight: 800;
  color: var(--cwp-ink);
  margin: 0 0 14px;
  letter-spacing: -.03em;
  line-height: 1.1;
}

.cwp-guide-hero__sub {
  font-size: 15px;
  color: var(--cwp-muted);
  margin: 0 0 18px;
  line-height: 1.55;
}

.cwp-guide-hero__meta {
  display: flex;
  align-items: center;
  gap: 16px;
  font-size: 12px;
  color: var(--cwp-muted);
  flex-wrap: wrap;
}

.cwp-guide-hero__media {
  aspect-ratio: 16 / 9;
  border-radius: var(--cwp-radius-lg);
  overflow: hidden;
  box-shadow: var(--cwp-shadow-card);
}

.cwp-guide-hero__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Fast answer box */
.cwp-fast-answer {
  background: var(--cwp-soft);
  border: 1px solid var(--cwp-line);
  border-left: 4px solid var(--cwp-alert);
  border-radius: 0 var(--cwp-radius) var(--cwp-radius) 0;
  padding: 22px 24px;
  margin-bottom: 32px;
}

.cwp-fast-answer__label {
  font-size: 10.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--cwp-alert);
  margin: 0 0 8px;
}

.cwp-fast-answer p {
  font-size: 14.5px;
  color: var(--cwp-text);
  margin: 0;
  line-height: 1.55;
  font-weight: 500;
}

/* Table of contents */
.cwp-toc {
  background: var(--cwp-card);
  border: 1px solid var(--cwp-line);
  border-radius: var(--cwp-radius);
  padding: 22px 24px;
  margin-bottom: 32px;
  box-shadow: var(--cwp-shadow-soft);
}

.cwp-toc__title {
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--cwp-muted);
  margin: 0 0 12px;
}

.cwp-toc__list {
  margin: 0;
  padding: 0 0 0 0;
  list-style: none;
  counter-reset: toc;
}

.cwp-toc__list li {
  counter-increment: toc;
  margin: 0;
}

.cwp-toc__list a {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 0;
  font-size: 13.5px;
  color: var(--cwp-text);
  text-decoration: none;
  border-bottom: 1px solid var(--cwp-line);
  transition: color .15s;
}

.cwp-toc__list li:last-child a {
  border-bottom: none;
}

.cwp-toc__list a:hover {
  color: var(--cwp-alert);
}

.cwp-toc__list a::before {
  content: counter(toc);
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--cwp-bg);
  color: var(--cwp-muted);
  font-size: 11px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

/* Article body */
.cwp-article-body {
  font-size: 15px;
  line-height: 1.7;
  color: var(--cwp-text);
}

.cwp-article-body h2 {
  font-size: 22px;
  font-weight: 800;
  color: var(--cwp-ink);
  margin: 36px 0 14px;
  letter-spacing: -.03em;
}

.cwp-article-body h3 {
  font-size: 17px;
  font-weight: 700;
  color: var(--cwp-ink);
  margin: 28px 0 10px;
}

.cwp-article-body p {
  margin: 0 0 18px;
}

.cwp-article-body ul,
.cwp-article-body ol {
  margin: 0 0 18px;
  padding-left: 22px;
}

.cwp-article-body li {
  margin-bottom: 8px;
}

/* Callout box */
.cwp-callout {
  background: var(--cwp-live-soft);
  border-left: 4px solid var(--cwp-live);
  border-radius: 0 var(--cwp-radius-sm) var(--cwp-radius-sm) 0;
  padding: 18px 22px;
  margin: 24px 0;
  font-size: 14px;
  color: var(--cwp-text);
  line-height: 1.55;
}

.cwp-callout--warning {
  background: #fff8e6;
  border-color: var(--cwp-warning);
}

.cwp-callout--info {
  background: var(--cwp-soon-bg);
  border-color: var(--cwp-soon);
}

/* In-content price CTA */
.cwp-incontent-cta {
  background: var(--cwp-navy);
  color: #fff;
  border-radius: var(--cwp-radius-lg);
  padding: 28px 30px;
  margin: 36px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}

.cwp-incontent-cta h3 {
  font-size: 16px;
  font-weight: 700;
  color: #fff;
  margin: 0 0 5px;
}

.cwp-incontent-cta p {
  font-size: 13px;
  color: rgba(255,255,255,.65);
  margin: 0;
}

/* Related guides */
.cwp-related-guides {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

/* Medical disclaimer */
.cwp-disclaimer {
  background: #f8f8f8;
  border: 1px solid var(--cwp-line);
  border-radius: var(--cwp-radius);
  padding: 20px 22px;
  font-size: 12.5px;
  color: var(--cwp-muted);
  line-height: 1.55;
  margin-top: 40px;
}

.cwp-disclaimer strong {
  color: var(--cwp-text);
}

/* Guide layout */
.cwp-guide-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 300px;
  gap: 36px;
  align-items: start;
}

.cwp-guide-sidebar {
  position: sticky;
  top: 80px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}


/* ==========================================================================
   25. METHODOLOGY PAGE
   ========================================================================== */

.cwp-method-hero {
  --cwp-hero-image: url("../images/page-prescription-room.jpg");
}

.cwp-method-hero__inner {
  padding: 64px var(--cwp-pad) 56px;
  max-width: var(--cwp-max);
  margin: 0 auto;
}

.cwp-method-hero h1 {
  font-size: clamp(28px, 4vw, 46px);
  font-weight: 800;
  color: #fff;
  margin: 0 0 14px;
  letter-spacing: -.03em;
  line-height: 1.1;
}

.cwp-method-hero p {
  font-size: 16px;
  color: rgba(255,255,255,.72);
  margin: 0 0 28px;
  max-width: 540px;
  line-height: 1.55;
}

.cwp-method-hero__badges {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.cwp-method-badge {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: rgba(255,255,255,.12);
  color: rgba(255,255,255,.9);
  border: 1px solid rgba(255,255,255,.2);
  border-radius: 999px;
  padding: 7px 14px;
  font-size: 12.5px;
  font-weight: 700;
}

/* What we check grid */
.cwp-check-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.cwp-check-card {
  background: var(--cwp-card);
  border: 1px solid var(--cwp-line);
  border-radius: var(--cwp-radius);
  padding: 22px;
  box-shadow: var(--cwp-shadow-soft);
}

.cwp-check-card__icon {
  font-size: 24px;
  margin-bottom: 10px;
}

.cwp-check-card__title {
  font-size: 14px;
  font-weight: 700;
  color: var(--cwp-ink);
  margin: 0 0 6px;
}

.cwp-check-card__desc {
  font-size: 12.5px;
  color: var(--cwp-muted);
  margin: 0;
  line-height: 1.5;
}

/* 6-step process */
.cwp-trust-process {
  display: grid;
  grid-template-columns: repeat(6, minmax(0,1fr));
  gap: 0;
  position: relative;
  margin: 40px 0;
}

.cwp-trust-process::before {
  content: "";
  position: absolute;
  top: 28px;
  left: 60px;
  right: 60px;
  height: 2px;
  background: var(--cwp-line);
  z-index: 0;
}

.cwp-process-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  position: relative;
  z-index: 1;
  padding: 0 10px;
}

.cwp-process-step__num {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--cwp-card);
  border: 2px solid var(--cwp-line);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  font-weight: 800;
  color: var(--cwp-ink);
  margin-bottom: 14px;
  box-shadow: var(--cwp-shadow-soft);
}

.cwp-process-step--active .cwp-process-step__num {
  background: var(--cwp-alert);
  border-color: var(--cwp-alert);
  color: #fff;
  box-shadow: var(--cwp-shadow-btn);
}

.cwp-process-step__label {
  font-size: 12px;
  font-weight: 700;
  color: var(--cwp-ink);
  margin: 0 0 5px;
}

.cwp-process-step__desc {
  font-size: 11px;
  color: var(--cwp-muted);
  margin: 0;
  line-height: 1.4;
}

/* Trust points */
.cwp-trust-points {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}

.cwp-trust-point {
  display: flex;
  gap: 16px;
  padding: 20px;
  background: var(--cwp-card);
  border: 1px solid var(--cwp-line);
  border-radius: var(--cwp-radius);
  box-shadow: var(--cwp-shadow-soft);
}

.cwp-trust-point__icon {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: var(--cwp-live-soft);
  color: var(--cwp-live);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  flex-shrink: 0;
}

.cwp-trust-point__title {
  font-size: 14px;
  font-weight: 700;
  color: var(--cwp-ink);
  margin: 0 0 5px;
}

.cwp-trust-point__desc {
  font-size: 12.5px;
  color: var(--cwp-muted);
  margin: 0;
  line-height: 1.45;
}

/* Transparency band */
.cwp-transparency-band {
  background: var(--cwp-soft);
  border: 1px solid var(--cwp-line);
  border-radius: var(--cwp-radius-xl);
  padding: 40px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 32px;
  align-items: center;
}

.cwp-transparency-band__copy h3 {
  font-size: 20px;
  font-weight: 800;
  color: var(--cwp-ink);
  margin: 0 0 8px;
  letter-spacing: -.03em;
}

.cwp-transparency-band__copy p {
  font-size: 14px;
  color: var(--cwp-muted);
  margin: 0;
  line-height: 1.55;
}

.cwp-transparency-band__image {
  width: 240px;
  border-radius: var(--cwp-radius-lg);
  overflow: hidden;
  aspect-ratio: 4 / 3;
  flex-shrink: 0;
}

.cwp-transparency-band__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}


/* ==========================================================================
   26. FOOTER CTA
   ========================================================================== */

.cwp-footer-cta {
  background: var(--cwp-navy);
  color: #fff;
  padding: 52px var(--cwp-pad);
  text-align: center;
}

.cwp-footer-cta h2 {
  font-size: clamp(20px, 3vw, 28px);
  font-weight: 800;
  color: #fff;
  margin: 0 0 10px;
  letter-spacing: -.03em;
}

.cwp-footer-cta p {
  font-size: 14px;
  color: rgba(255,255,255,.6);
  margin: 0 0 24px;
}

.cwp-footer-cta__ctas {
  display: flex;
  align-items: center;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
}

/* Compliance note near CTAs */
.cwp-compliance-note {
  font-size: 11.5px;
  color: var(--cwp-muted);
  text-align: center;
  margin-top: 14px;
  line-height: 1.5;
}

.cwp-compliance-note--white {
  color: rgba(255,255,255,.4);
}


/* ==========================================================================
   27. SECTION HEADINGS
   ========================================================================== */

.cwp-section-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 24px;
  gap: 12px;
}

.cwp-section-title {
  font-size: clamp(18px, 2.5vw, 24px);
  font-weight: 800;
  color: var(--cwp-ink);
  margin: 0;
  letter-spacing: -.03em;
  line-height: 1.2;
}

.cwp-section-link {
  font-size: 13px;
  font-weight: 700;
  color: var(--cwp-alert);
  text-decoration: none;
  white-space: nowrap;
  flex-shrink: 0;
}

.cwp-section-link:hover {
  text-decoration: underline;
}

.cwp-section-eyebrow {
  font-size: 10.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--cwp-alert);
  margin: 0 0 8px;
  display: block;
}


/* ==========================================================================
   28. BREADCRUMB
   ========================================================================== */

.cwp-breadcrumb {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12.5px;
  color: var(--cwp-muted);
  margin-bottom: 28px;
  flex-wrap: wrap;
}

.cwp-breadcrumb a {
  color: var(--cwp-muted);
  text-decoration: none;
}

.cwp-breadcrumb a:hover {
  color: var(--cwp-alert);
}

.cwp-breadcrumb__sep {
  color: var(--cwp-line);
  font-size: 14px;
}

.cwp-breadcrumb__current {
  color: var(--cwp-text);
  font-weight: 600;
}


/* ==========================================================================
   29. PAGE WRAPPERS
   ========================================================================== */

.cwp-page {
  background: var(--cwp-bg);
  min-height: 60vh;
}

.cwp-page--white {
  background: #fff;
}


/* ==========================================================================
   30. MOBILE — RESPONSIVE BREAKPOINTS
   ========================================================================== */

@media (max-width: 1100px) {
  .cwp-launch-dash-grid {
    grid-template-columns: 1fr 240px;
  }

  .cwp-launch-dash-grid > :last-child {
    display: none;
  }
}

@media (max-width: 960px) {
  .cwp-metric-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .cwp-dashboard-grid {
    grid-template-columns: 1fr;
  }

  .cwp-trust-process {
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
  }

  .cwp-trust-process::before {
    display: none;
  }

  .cwp-check-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .cwp-verified-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .cwp-guide-layout {
    grid-template-columns: 1fr;
  }

  .cwp-guide-sidebar {
    position: static;
  }

  .cwp-launch-status-grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .cwp-launch-hero__inner {
    grid-template-columns: 1fr;
  }

  .cwp-code-stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .cwp-status-counts {
    grid-template-columns: repeat(3, 1fr);
  }

  .cwp-provider-layout {
    grid-template-columns: 1fr;
  }

  .cwp-provider-sidebar {
    position: static;
  }

  .cwp-similar-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .cwp-transparency-band {
    grid-template-columns: 1fr;
  }

  .cwp-transparency-band__image {
    width: 100%;
    max-width: 300px;
  }
}

@media (max-width: 760px) {
  .cwp-home-hero__grid {
    grid-template-columns: 1fr;
  }

  .cwp-home-hero__media {
    min-height: 240px;
    border-radius: 20px;
    order: -1;
  }

  .cwp-home-hero {
    padding: 32px 0 0;
  }

  .cwp-compare-hero {
    grid-template-columns: 1fr;
  }

  .cwp-compare-table-wrap {
    display: none;
  }

  .cwp-mobile-provider-list {
    display: block;
  }

  .cwp-provider-hero {
    grid-template-columns: 1fr;
  }

  .cwp-provider-hero__media {
    min-height: 220px;
    order: -1;
  }

  .cwp-guide-hero {
    grid-template-columns: 1fr;
  }

  .cwp-guide-hero__media {
    order: -1;
  }

  .cwp-grid-2,
  .cwp-grid-3,
  .cwp-grid-4 {
    grid-template-columns: 1fr;
  }

  .cwp-metric-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
  }

  .cwp-trust-process {
    grid-template-columns: repeat(2, 1fr);
  }

  .cwp-related-guides {
    grid-template-columns: 1fr;
  }

  .cwp-similar-grid {
    grid-template-columns: 1fr;
  }

  .cwp-check-grid {
    grid-template-columns: 1fr;
  }

  .cwp-verified-grid {
    grid-template-columns: 1fr;
  }

  .cwp-confidence-band__inner {
    flex-direction: column;
  }

  .cwp-confidence-band__form {
    flex-direction: column;
    max-width: 100%;
  }

  .cwp-alert-cta__form {
    flex-direction: column;
  }

  .cwp-launch-status-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .cwp-launch-dash-grid {
    grid-template-columns: 1fr;
  }

  .cwp-code-stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .cwp-status-counts {
    grid-template-columns: repeat(2, 1fr);
  }

  .cwp-top-strip__items {
    gap: 10px;
  }

  .cwp-top-strip__item:nth-child(3) {
    display: none;
  }

  .cwp-providers-hero__content {
    max-width: 100%;
    padding: 28px 20px;
  }

  .cwp-providers-hero__image {
    display: none;
  }

  .cwp-incontent-cta {
    flex-direction: column;
    text-align: center;
  }

  .cwp-trust-points {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 480px) {
  .cwp-metric-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .cwp-home-hero__metrics {
    gap: 18px;
  }

  .cwp-trust-process {
    grid-template-columns: 1fr;
  }

  .cwp-launch-status-grid {
    grid-template-columns: 1fr 1fr;
  }

  .cwp-code-stats {
    grid-template-columns: 1fr 1fr;
  }

  .cwp-nav {
    display: none;
  }
}

/* Print */
@media print {
  .cwp-top-strip,
  .cwp-alert-cta,
  .cwp-footer-cta {
    display: none;
  }
}

/* ==========================================================================
   QUICK ANSWER + FAQ (GEO / AI-Overview blocks)
   ========================================================================== */

.cwp-quick-answer {
  background: var(--cwp-navy);
  color: #fff;
  border-radius: var(--cwp-radius-lg);
  padding: 22px 26px;
  margin: 0 0 28px;
  border-left: 4px solid var(--cwp-alert);
}
.cwp-quick-answer__label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--cwp-alert);
  margin: 0 0 8px;
}
.cwp-quick-answer__text {
  font-size: 15.5px;
  line-height: 1.6;
  margin: 0;
  color: rgba(255, 255, 255, .92);
}

.cwp-faq {
  margin: 40px 0;
}
.cwp-faq__heading {
  font-size: 1.5rem;
  font-weight: 800;
  margin: 0 0 18px;
}
.cwp-faq__list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.cwp-faq__item {
  background: var(--cwp-surface);
  border: 1px solid var(--cwp-border);
  border-radius: var(--cwp-radius);
  overflow: hidden;
}
.cwp-faq__q {
  cursor: pointer;
  list-style: none;
  padding: 16px 20px;
  font-size: 15px;
  font-weight: 700;
  color: var(--cwp-ink);
  position: relative;
  padding-right: 44px;
}
.cwp-faq__q::-webkit-details-marker { display: none; }
.cwp-faq__q::after {
  content: "+";
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 22px;
  font-weight: 400;
  color: var(--cwp-alert);
  line-height: 1;
}
.cwp-faq__item[open] .cwp-faq__q::after { content: "\2212"; }
.cwp-faq__a {
  padding: 0 20px 18px;
  font-size: 14px;
  line-height: 1.65;
  color: var(--cwp-muted);
}
.cwp-faq__a p { margin: 0 0 10px; }
.cwp-faq__a p:last-child { margin: 0; }

/* Scaffold tool pages — shared bits */
.cwp-winner-card {
  background: linear-gradient(135deg, var(--cwp-navy) 0%, var(--cwp-navy-2) 100%);
  color: #fff;
  border-radius: var(--cwp-radius-lg);
  padding: 28px 30px;
  display: flex;
  align-items: center;
  gap: 28px;
  flex-wrap: wrap;
  box-shadow: var(--cwp-shadow-card);
}
.cwp-winner-card__badge {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--cwp-alert);
  margin: 0 0 6px;
}
.cwp-winner-card__price {
  font-size: clamp(2.2rem, 6vw, 3.2rem);
  font-weight: 800;
  line-height: 1;
}
.cwp-winner-card__name { font-size: 1.1rem; font-weight: 700; margin: 4px 0 0; }
.cwp-winner-card__meta { font-size: 12.5px; color: rgba(255,255,255,.6); margin: 6px 0 0; }

.cwp-data-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--cwp-surface);
  border: 1px solid var(--cwp-border);
  border-radius: var(--cwp-radius-lg);
  overflow: hidden;
}
.cwp-data-table thead tr { background: var(--cwp-navy); color: #fff; }
.cwp-data-table th {
  text-align: left;
  padding: 13px 18px;
  font-size: 12.5px;
  font-weight: 700;
}
.cwp-data-table td {
  padding: 13px 18px;
  font-size: 14px;
  border-top: 1px solid var(--cwp-border);
}
.cwp-data-table tbody tr:nth-child(even) { background: var(--cwp-bg); }
.cwp-data-table .cwp-td-price { font-weight: 800; color: var(--cwp-ink); }

/* ==========================================================================
   MOBILE REFINEMENTS — price table overflow + scaffold components
   ========================================================================== */

.cwp-price-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }

@media (max-width: 600px) {
  /* Homepage price board: keep table readable, allow horizontal scroll */
  .cwp-price-table { min-width: 460px; }
  .cwp-price-table th,
  .cwp-price-table td { padding-left: 12px; padding-right: 12px; }

  /* Best-price winner card stacks cleanly */
  .cwp-winner-card { flex-direction: column; align-items: flex-start; gap: 18px; padding: 22px; }
  .cwp-winner-card > div:last-child { margin-left: 0 !important; width: 100%; }
  .cwp-winner-card > div:last-child .cwp-btn { flex: 1 1 auto; text-align: center; }
  .cwp-winner-card__price { font-size: 2.4rem; }

  /* Scaffold data tables: comfortable on small screens (already in overflow wrappers) */
  .cwp-data-table { min-width: 480px; }
  .cwp-data-table th,
  .cwp-data-table td { padding: 11px 13px; font-size: 13px; }

  /* GEO blocks */
  .cwp-quick-answer { padding: 18px 18px; }
  .cwp-quick-answer__text { font-size: 14.5px; }
  .cwp-faq__heading { font-size: 1.3rem; }
  .cwp-faq__q { font-size: 14px; padding-right: 40px; }

  /* Calculator select shouldn't overflow its card header */
  #cwp-calc .cwp-filter-select { max-width: 100%; }
}
