@import url('tokens.css');

/* ============================================================
   NaturaPeak — public site styles (editorial review template)
   Calm, Healthline/Examine-style. No framework. No runtime JS
   (the only interactivity is native <details>).
   ============================================================ */

* { box-sizing: border-box; margin: 0; padding: 0; }

html { -webkit-text-size-adjust: 100%; }

body {
  font-family: var(--font-sans);
  background: var(--color-bg);
  color: var(--color-text-primary);
  line-height: var(--leading-normal);
  font-size: var(--text-base);
}

a { color: var(--color-link); text-decoration: none; }
a:hover { color: var(--color-link-hover); text-decoration: underline; }

/* ── Page header ── */
.site-header {
  border-bottom: 1px solid var(--color-border);
  background: var(--color-bg-raised);
}
.site-header-inner {
  max-width: var(--container-wide);
  margin: 0 auto;
  padding: var(--space-md) var(--space-lg);
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.site-logo {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-family: var(--font-serif);
  font-size: var(--text-md);
  color: var(--color-text-primary);
}
.site-logo:hover { text-decoration: none; }
.site-logo strong { color: var(--color-brand); font-weight: 700; }
.site-logo-mark { font-size: 1.3rem; }

/* ── Review shell ── */
.review {
  max-width: var(--container-body);
  margin: 0 auto;
  padding: var(--space-xl) var(--space-lg) var(--space-2xl);
}

/* ── 1. Meta-bar ── */
.meta-bar {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm) var(--space-md);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  padding-bottom: var(--space-md);
  border-bottom: 1px solid var(--color-border);
  margin-bottom: var(--space-lg);
}
.meta-bar .sep { color: var(--color-border-strong); }

/* ── Title ── */
.review-title {
  font-family: var(--font-serif);
  font-size: var(--text-2xl);
  line-height: var(--leading-tight);
  color: var(--color-text-primary);
  margin-bottom: var(--space-md);
}

/* ── 2. Badge row ── */
.badge-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
  margin-bottom: var(--space-xl);
}
.badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: var(--text-xs);
  font-weight: 600;
  padding: 5px 12px;
  border-radius: 100px;
  border: 1px solid transparent;
}
.badge-positive { background: var(--color-positive-bg); color: var(--color-positive); border-color: var(--color-positive-border); }
.badge-attention { background: var(--color-attention-bg); color: var(--color-attention); border-color: var(--color-attention-border); }
.badge-info { background: var(--color-info-bg); color: var(--color-info); border-color: var(--color-info-border); }
.badge-neutral { background: var(--color-neutral-bg); color: var(--color-text-secondary); border-color: var(--color-neutral-border); }

/* ── Hero: product image + TL;DR card side-by-side ── */
.hero { margin-bottom: var(--space-2xl); }
.hero-with-image {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: var(--space-lg);
  align-items: start;
}
.hero .tldr { margin-bottom: 0; }

/* ── Product / label images ── */
.review-images {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md);
  margin-bottom: var(--space-xl);
}
.review-images img {
  max-width: 220px;
  height: auto;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg-raised);
}
.hero-with-image .review-images { margin-bottom: 0; }
.hero-with-image .review-images img { max-width: 100%; }

/* ── 3. TL;DR card ── */
.tldr {
  background: var(--color-bg-raised);
  border: 1px solid var(--color-border);
  border-left: 4px solid var(--color-brand);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  margin-bottom: var(--space-2xl);
}
.tldr-label {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-weight: 700;
  color: var(--color-brand);
  margin-bottom: var(--space-md);
}
.tldr dl { display: grid; grid-template-columns: max-content 1fr; gap: var(--space-sm) var(--space-md); }
.tldr dt { font-size: var(--text-sm); color: var(--color-text-muted); font-weight: 600; }
.tldr dd { font-size: var(--text-sm); color: var(--color-text-secondary); }

/* ── Sections ── */
.section { margin-bottom: var(--space-2xl); }
.section-title {
  font-family: var(--font-serif);
  font-size: var(--text-xl);
  color: var(--color-text-primary);
  line-height: var(--leading-tight);
  margin-bottom: var(--space-lg);
}
.section p { margin-bottom: var(--space-md); color: var(--color-text-secondary); line-height: var(--leading-relaxed); }
.section p:last-child { margin-bottom: 0; }

/* ── 4. Composition table ── */
.composition-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
  margin-bottom: var(--space-md);
}
.composition-table th,
.composition-table td {
  text-align: left;
  padding: 12px 14px;
  border-bottom: 1px solid var(--color-border);
}
.composition-table th {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-text-muted);
  background: var(--color-bg-sunken);
}
.composition-table .dose { font-family: var(--font-mono); font-size: var(--text-xs); }
.match-tag {
  display: inline-block;
  font-size: var(--text-xs);
  font-weight: 600;
  padding: 3px 9px;
  border-radius: 100px;
}
.match-full { background: var(--color-positive-bg); color: var(--color-positive); }
.match-partial { background: var(--color-neutral-bg); color: var(--color-text-secondary); }
.match-low { background: var(--color-attention-bg); color: var(--color-attention); }
.match-na { color: var(--color-text-muted); }
.composition-note {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  background: var(--color-neutral-bg);
  border-radius: var(--radius-sm);
  padding: 10px 14px;
  margin-bottom: var(--space-md);
}
.composition-meta { font-size: var(--text-sm); color: var(--color-text-muted); line-height: var(--leading-normal); }
.composition-meta p { margin-bottom: var(--space-sm); }

/* ── 5. Ingredient evidence ── */
.evidence-item {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-lg);
  margin-bottom: var(--space-md);
  background: var(--color-bg-raised);
}
.evidence-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-md);
  margin-bottom: var(--space-sm);
}
.evidence-name { font-family: var(--font-serif); font-size: var(--text-md); color: var(--color-text-primary); }
.evidence-level {
  font-size: var(--text-xs);
  font-weight: 600;
  padding: 4px 11px;
  border-radius: 100px;
  flex-shrink: 0;
}
.ev-consistent { background: var(--color-positive-bg); color: var(--color-positive); }
.ev-preliminary { background: var(--color-info-bg); color: var(--color-info); }
.ev-mechanistic { background: var(--color-neutral-bg); color: var(--color-text-secondary); }
.ev-traditional { background: var(--color-attention-bg); color: var(--color-attention); }
.evidence-summary { font-size: var(--text-sm); color: var(--color-text-secondary); line-height: var(--leading-relaxed); }
.evidence-pending { font-size: var(--text-sm); color: var(--color-text-muted); font-style: italic; }
.evidence-item details { margin-top: var(--space-md); }
.evidence-item summary {
  cursor: pointer;
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-link);
}
.evidence-item summary:hover { color: var(--color-link-hover); }
.evidence-studies { list-style: none; margin-top: var(--space-md); display: flex; flex-direction: column; gap: var(--space-md); }
.evidence-studies li { font-size: var(--text-sm); color: var(--color-text-secondary); line-height: var(--leading-normal); }
.evidence-studies .study-summary { color: var(--color-text-muted); margin-top: 4px; }
.blend-line { font-size: var(--text-sm); color: var(--color-text-secondary); padding: var(--space-md) 0; }

/* ── Safety profile (neutral, descriptive — not alarming) ── */
.safety-profile p { color: var(--color-text-secondary); }

/* ── 6. Factual observations ── */
.observations {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-lg);
}
.obs-col {
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  border: 1px solid;
}
.obs-positive { background: var(--color-positive-bg); border-color: var(--color-positive-border); }
.obs-attention { background: var(--color-attention-bg); border-color: var(--color-attention-border); }
.obs-title { font-family: var(--font-serif); font-size: var(--text-md); margin-bottom: var(--space-md); }
.obs-positive .obs-title { color: var(--color-positive); }
.obs-attention .obs-title { color: var(--color-attention); }
.obs-list { list-style: none; display: flex; flex-direction: column; gap: var(--space-md); }
.obs-list li { font-size: var(--text-sm); color: var(--color-text-secondary); line-height: var(--leading-normal); }

/* ── 7. CTA / Where to buy ── */
.cta-block {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-xl);
  background: var(--color-bg-raised);
  margin-bottom: var(--space-md);
}
.cta-headline { font-family: var(--font-serif); font-size: var(--text-lg); margin-bottom: var(--space-md); color: var(--color-text-primary); }
.cta-single { text-align: left; }
.cta-price { font-size: var(--text-md); color: var(--color-text-secondary); margin-bottom: var(--space-lg); }
.cta-tiers { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-md); }
.cta-tier {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-lg);
  text-align: center;
  background: var(--color-bg);
}
.cta-tier-bottles { font-size: var(--text-sm); color: var(--color-text-muted); margin-bottom: var(--space-sm); }
.cta-tier-total { font-family: var(--font-serif); font-size: var(--text-lg); color: var(--color-text-primary); }
.cta-tier-per { font-size: var(--text-xs); color: var(--color-text-muted); margin-bottom: var(--space-md); }
.cta-button {
  display: inline-block;
  background: var(--color-brand);
  color: var(--color-text-inverse);
  padding: 11px 22px;
  border-radius: var(--radius-sm);
  font-size: var(--text-sm);
  font-weight: 600;
}
.cta-button:hover { background: var(--color-brand-deep); color: var(--color-text-inverse); text-decoration: none; }
.cta-pending {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  font-style: italic;
  padding: var(--space-md) 0;
}
.cta-disclosure {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  line-height: var(--leading-normal);
  margin-bottom: var(--space-2xl);
}

/* ── Cross-content ── */
.cross { margin-bottom: var(--space-2xl); }
.cross-title {
  font-family: var(--font-serif);
  font-size: var(--text-lg);
  color: var(--color-text-primary);
  margin-bottom: var(--space-lg);
}
.compare-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--space-md); }
.compare-card {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-lg);
  background: var(--color-bg-raised);
}
.compare-card h3 { font-family: var(--font-serif); font-size: var(--text-md); margin-bottom: var(--space-sm); }
.compare-card ul { list-style: none; font-size: var(--text-sm); color: var(--color-text-secondary); margin-bottom: var(--space-md); }
.compare-card li { margin-bottom: 4px; }
.related-list { list-style: none; display: flex; flex-direction: column; gap: var(--space-md); }
.related-list a { font-weight: 600; }
.related-meta { font-size: var(--text-xs); color: var(--color-text-muted); }

/* ── Newsletter ── */
.newsletter {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-xl);
  background: var(--color-bg-sunken);
  margin-bottom: var(--space-2xl);
}
.newsletter h2 { font-family: var(--font-serif); font-size: var(--text-lg); color: var(--color-text-primary); margin-bottom: var(--space-sm); }
.newsletter p { font-size: var(--text-sm); color: var(--color-text-muted); margin-bottom: var(--space-md); }
.newsletter form { display: flex; gap: var(--space-sm); flex-wrap: wrap; }
.newsletter input[type="email"] {
  flex: 1;
  min-width: 220px;
  padding: 11px 14px;
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius-sm);
  font-family: inherit;
  font-size: var(--text-sm);
  background: var(--color-bg-raised);
}
.newsletter button {
  background: var(--color-brand);
  color: var(--color-text-inverse);
  border: none;
  padding: 11px 22px;
  border-radius: var(--radius-sm);
  font-size: var(--text-sm);
  font-weight: 600;
  cursor: pointer;
}
.newsletter button:hover { background: var(--color-brand-deep); }
.newsletter button[disabled] { opacity: 0.55; cursor: wait; }
.newsletter-privacy {
  margin-top: var(--space-sm);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}
.newsletter-privacy a { color: var(--color-text-muted); text-decoration: underline; }
.newsletter-message {
  margin-top: var(--space-sm);
  font-size: var(--text-sm);
  padding: var(--space-sm) var(--space-md);
  border-radius: var(--radius-sm);
  display: none;
}
.newsletter-message.is-success {
  display: block;
  background: var(--color-bg-raised);
  border: 1px solid var(--color-border);
  color: var(--color-text-primary);
}
.newsletter-message.is-error {
  display: block;
  background: var(--color-bg-raised);
  border: 1px solid var(--color-border-strong);
  color: var(--color-text-primary);
}

/* ── Disclaimers footer ── */
.disclaimers {
  border-top: 1px solid var(--color-border);
  padding-top: var(--space-lg);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  line-height: var(--leading-normal);
}
.disclaimers p { margin-bottom: var(--space-md); }
.disclaimers .signature { font-style: normal; color: var(--color-text-secondary); font-weight: 600; }

/* ── Homepage (minimal editorial root) ── */
.home {
  max-width: var(--container-body);
  margin: 0 auto;
  padding: var(--space-xl) var(--space-lg) var(--space-2xl);
}
.home-hero {
  padding-bottom: var(--space-xl);
  border-bottom: 1px solid var(--color-border);
  margin-bottom: var(--space-2xl);
}
.home-title {
  font-family: var(--font-serif);
  font-size: var(--text-2xl);
  line-height: var(--leading-tight);
  color: var(--color-text-primary);
  margin-bottom: var(--space-sm);
}
.home-subtitle {
  font-size: var(--text-md);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-lg);
}
.home-intro {
  font-size: var(--text-base);
  color: var(--color-text-secondary);
  line-height: var(--leading-relaxed);
  max-width: 60ch;
}
.home-reviews {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--space-lg);
}
.home-review-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  background: var(--color-bg-raised);
  color: inherit;
}
.home-review-card:hover {
  text-decoration: none;
  border-color: var(--color-border-strong);
}
.home-review-cat {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 700;
  color: var(--color-text-muted);
}
.home-review-name {
  font-family: var(--font-serif);
  font-size: var(--text-md);
  color: var(--color-text-primary);
}
.home-review-desc {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  line-height: var(--leading-normal);
}
.home-review-cta {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-link);
  margin-top: var(--space-xs);
}
.home-empty { font-size: var(--text-sm); color: var(--color-text-muted); }
.home-footer {
  border-top: 1px solid var(--color-border);
  margin-top: var(--space-2xl);
  padding-top: var(--space-lg);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}
.home-footer-links { margin-bottom: var(--space-sm); }
.home-footer-links .sep { color: var(--color-border-strong); margin: 0 var(--space-sm); }
.home-footer-signature { color: var(--color-text-secondary); font-weight: 600; }

/* ── Responsive ── */
@media (max-width: 720px) {
  .review { padding: var(--space-lg) var(--space-md) var(--space-xl); }
  .home { padding: var(--space-lg) var(--space-md) var(--space-xl); }
  .observations { grid-template-columns: 1fr; }
  .cta-tiers { grid-template-columns: 1fr; }
  .tldr dl { grid-template-columns: 1fr; gap: 2px var(--space-md); }
  .tldr dt { margin-top: var(--space-sm); }
  .hero-with-image { grid-template-columns: 1fr; }
  .hero-with-image .review-images img { max-width: 220px; }
}
