/* ============================================================
   NOVARA VITA — COMPLIANCE & CLINICAL DISCLAIMER STYLES
   css/compliance.css

   Per clinical reviewer requirements — all disclaimers must be
   visually prominent and immediately recognizable.

   CLINICAL HARD REQUIREMENTS implemented here:
   1. Service page disclaimer banner (required on all Rx/treatment pages)
   2. Research page visual treatment — DISTINCT sage color treatment
   3. FTC testimonial disclosure
   4. No-CTA enforcement on research pages
   5. Rx badge styling
   6. State availability messaging
   ============================================================ */

/* ══════════════════════════════════════
   SERVICE PAGE DISCLAIMER BANNER
   REQUIRED on all Rx/treatment service pages — near hero
══════════════════════════════════════ */

.nv-disclaimer-banner {
  background-color: rgba(28, 43, 58, 0.05);
  border: 1px solid var(--nv-border-medium);
  border-left: 4px solid var(--nv-navy);
  border-radius: 0 4px 4px 0;
  padding: 16px 20px;
  margin: 24px 0;
  font-size: 13px;
  line-height: 1.6;
  color: var(--nv-charcoal);
}

.nv-disclaimer-banner--critical {
  border-left-color: var(--nv-color-error);
  background-color: rgba(185, 74, 59, 0.04);
}

.nv-disclaimer-banner strong {
  font-weight: 600;
  color: var(--nv-navy);
}

/* Admin compliance warning for missing disclaimers */
.nv-admin-disclaimer-warning {
  background: #fdecea;
  border: 2px solid var(--nv-color-error);
  padding: 16px 20px;
  border-radius: 4px;
  font-size: 14px;
  font-weight: 600;
  color: var(--nv-color-error);
  margin: 20px 0;
}

/* ══════════════════════════════════════
   RESEARCH / EDUCATIONAL PAGE BANNER
   REQUIRED on peptide and research content pages
   Uses SAGE color — distinctly different from gold/navy treatment pages
══════════════════════════════════════ */

.nv-research-banner {
  background-color: rgba(139, 168, 136, 0.10);
  border: 1.5px solid var(--nv-sage);
  border-radius: var(--nv-radius-card);
  padding: 20px 24px;
  margin-bottom: 32px;
  display: flex;
  gap: 16px;
  align-items: flex-start;
}

.nv-research-banner__icon {
  flex-shrink: 0;
  width: 24px;
  color: var(--nv-sage);
  margin-top: 2px;
  font-size: 18px;
}

.nv-research-banner__content {
  font-size: 14px;
  line-height: 1.6;
  color: var(--nv-charcoal);
}

.nv-research-banner__title {
  font-weight: 600;
  color: var(--nv-navy);
  margin-bottom: 4px;
  font-size: 14px;
}

/* ══════════════════════════════════════
   RESEARCH PAGE VISUAL TREATMENT
   Clinical hard requirement: research pages must NOT look like
   treatment/service pages. Sage color system instead of gold.
══════════════════════════════════════ */

body.nv-page-research {
  /* Override all gold accents with sage on research pages */
  --nv-gold: var(--nv-sage);
  --wd-primary-color: var(--nv-sage);
  --btn-bgcolor: var(--nv-sage);
  --btn-bgcolor-hover: #6d8f6a;
  --btn-color: #FFFFFF;
}

body.nv-page-research .nv-page-hero,
body.nv-page-research .nv-treatment-hero {
  background-color: var(--nv-sage);
}

body.nv-page-research .nv-page-hero h1,
body.nv-page-research .nv-treatment-hero h1 {
  color: #FFFFFF;
}

body.nv-page-research .nv-eyebrow {
  color: rgba(255, 255, 255, 0.85);
}

body.nv-page-research .nv-service-card__rule {
  background-color: var(--nv-sage);
}

body.nv-page-research .nv-pull-quote {
  border-color: var(--nv-sage);
}

/* ══════════════════════════════════════
   NO-CTA ENFORCEMENT ON RESEARCH PAGES
   Clinical hard requirement: research/peptide educational pages
   must NOT contain any conversion CTAs.
══════════════════════════════════════ */

body.nv-page-research .nv-sticky-cta-bar,
body.nv-page-research .nv-cta-band,
body.nv-page-research .nv-cta-band--gold,
body.nv-page-research .nv-inline-cta,
body.nv-page-research [data-nv-cta-block],
body.nv-page-research .nv-treatment-cta-section {
  display: none !important;
}

/* Research pages may show a muted education link — not a conversion CTA */
body.nv-page-research .nv-research-sidebar__cta {
  display: block; /* This educational sidebar CTA is allowed */
}

/* ══════════════════════════════════════
   FTC TESTIMONIAL DISCLOSURE
   REQUIRED adjacent to every testimonial block
══════════════════════════════════════ */

.nv-testimonial-disclaimer {
  font-size: 11px;
  color: var(--nv-stone);
  text-align: center;
  margin-top: 24px;
  font-style: italic;
  line-height: 1.5;
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}

/* ══════════════════════════════════════
   TRUST SIGNALS (service pages)
══════════════════════════════════════ */

.nv-trust-signals {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin: 24px 0;
}

.nv-trust-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background-color: var(--nv-cream);
  border: 1px solid var(--nv-border-light);
  border-radius: var(--nv-radius-pill);
  padding: 7px 16px;
  font-family: var(--wd-text-font);
  font-size: 12px;
  font-weight: 500;
  color: var(--nv-navy);
  letter-spacing: 0.04em;
}

.nv-trust-badge svg {
  width: 14px;
  height: 14px;
  color: var(--nv-sage);
}

/* ══════════════════════════════════════
   FOOTER MEDICAL DISCLAIMER
══════════════════════════════════════ */

.nv-footer-disclaimer {
  border-top: 1px solid rgba(255, 255, 255, 0.06);
  padding-top: 20px;
  margin-top: 20px;
  font-size: 11px;
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.40);
}

/* ══════════════════════════════════════
   "Rx REQUIRED" SERVICE INDICATOR
══════════════════════════════════════ */

.nv-rx-required {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background-color: rgba(28, 43, 58, 0.06);
  border-radius: var(--nv-radius-pill);
  padding: 4px 12px;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.06em;
  color: var(--nv-navy);
  text-transform: uppercase;
  margin-bottom: 12px;
}

.nv-rx-required::before {
  content: 'Rx';
  background-color: var(--nv-navy);
  color: #FFFFFF;
  font-size: 9px;
  font-weight: 700;
  padding: 2px 5px;
  border-radius: 2px;
}

/* OTC badge (supplement/non-Rx products) */
.nv-otc-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background-color: rgba(139, 168, 136, 0.12);
  border: 1px solid rgba(139, 168, 136, 0.3);
  border-radius: var(--nv-radius-pill);
  padding: 4px 12px;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.06em;
  color: var(--nv-sage);
  text-transform: uppercase;
  margin-bottom: 12px;
}

/* "Coming Soon" badge for IV therapy / partner referral pages */
.nv-coming-soon-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background-color: rgba(194, 138, 58, 0.10);
  border: 1px solid rgba(194, 138, 58, 0.30);
  border-radius: var(--nv-radius-pill);
  padding: 4px 12px;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.06em;
  color: var(--nv-color-warning);
  text-transform: uppercase;
  margin-bottom: 12px;
}

/* ══════════════════════════════════════
   STATE GATING UI
══════════════════════════════════════ */

.nv-state-gate {
  background: var(--nv-cream);
  border: 1px solid var(--nv-border-medium);
  border-radius: var(--nv-radius-card);
  padding: 32px;
  text-align: center;
  margin: 40px 0;
}

.nv-state-gate__title {
  font-family: var(--wd-title-font);
  font-size: 24px;
  color: var(--nv-navy);
  margin-bottom: 8px;
}

.nv-state-gate__text {
  font-size: 15px;
  color: var(--nv-charcoal);
  margin-bottom: 24px;
  max-width: none;
}

.nv-state-unavailable-message {
  background: rgba(185, 74, 59, 0.06);
  border: 1.5px solid rgba(185, 74, 59, 0.20);
  border-radius: var(--nv-radius-card);
  padding: 20px 24px;
  margin-top: 16px;
}

.nv-state-unavailable-message p {
  color: var(--nv-color-error);
  font-size: 14px;
  margin-bottom: 12px;
  max-width: none;
}

/* ══════════════════════════════════════
   COOKIE CONSENT NOTICE
   Ensure CookieYes renders above all other elements
══════════════════════════════════════ */

.cky-consent-container,
.cky-modal-open,
#cky-overlay {
  z-index: 99999 !important;
}

/* ══════════════════════════════════════
   PIXEL-PROTECTED PAGE INDICATOR
   Dev-mode only — hidden in production
══════════════════════════════════════ */

body.nv-pixel-protected::before {
  content: '🔒 Tracking disabled on this page';
  display: none; /* Enable in dev by setting display:block */
  position: fixed;
  bottom: 80px;
  right: 16px;
  background: var(--nv-navy);
  color: #fff;
  padding: 8px 16px;
  border-radius: var(--nv-radius-pill);
  font-size: 11px;
  z-index: 99998;
}
