/* Dead Simple Email — Docs & Integrations pages (docs.html, integrations/*) */

:root {
  --px-paper: #f7f1e8;
  --px-paper-deep: #ebdfcf;
  --px-mist: #dbe7f0;
  --px-sky: #6d9bc8;
  --px-sky-deep: #4775a6;
  --px-sky-dark: #2d5178;
  --px-ink: #171f2b;
  --px-ink-soft: #314157;
  --px-glow: #a7f4ff;
  --px-line: rgba(31, 46, 68, 0.12);
  --px-line-strong: rgba(31, 46, 68, 0.22);
  --px-shadow: 0 24px 60px rgba(39, 53, 74, 0.12);
  --px-shadow-soft: 0 12px 30px rgba(39, 53, 74, 0.08);
}

body.px-page {
  font-family: 'Public Sans', sans-serif;
  color: var(--px-ink-soft);
  background:
    radial-gradient(circle at top, rgba(255,255,255,0.95), rgba(247,241,232,0.86) 42%, rgba(236,228,216,0.96)),
    linear-gradient(180deg, #fbf8f2 0%, #f2ebe0 100%);
  min-height: 100vh;
}

.px-page h1,
.px-page h2,
.px-page h3,
.px-page h4 {
  font-family: 'Space Grotesk', sans-serif;
  color: var(--px-ink);
  letter-spacing: -0.02em;
}

.px-noise {
  pointer-events: none;
  position: fixed;
  inset: 0;
  opacity: 0.12;
  z-index: 0;
  background-image:
    radial-gradient(circle at 20% 20%, rgba(255,255,255,0.8), transparent 18%),
    radial-gradient(circle at 80% 8%, rgba(109,155,200,0.08), transparent 24%),
    radial-gradient(circle at 78% 78%, rgba(167,244,255,0.12), transparent 18%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180' viewBox='0 0 180 180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.95' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='180' height='180' filter='url(%23n)' opacity='.2'/%3E%3C/svg%3E");
  background-size: auto, auto, auto, 190px 190px;
}

.px-page .nav,
.px-page main,
.px-page .footer {
  position: relative;
  z-index: 1;
}

.px-page .nav {
  background: rgba(247, 241, 232, 0.82);
  border-bottom: 1px solid rgba(45, 81, 120, 0.11);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

.px-page .nav--scrolled {
  box-shadow: 0 12px 30px rgba(39, 53, 74, 0.08);
}

.px-page .nav__links a,
.px-page .nav__hamburger,
.px-page .nav__mobile a {
  color: var(--px-ink-soft);
}

.px-page .nav__mobile {
  background: rgba(247, 241, 232, 0.98);
}

/* ---------- Scroll reveal ---------- */

body.has-reveal .reveal {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 640ms ease, transform 640ms ease;
}

body.has-reveal .reveal--delay {
  transition-delay: 120ms;
}

body.has-reveal .reveal.is-visible {
  opacity: 1;
  transform: none;
}

/* ---------- Page header ---------- */

.px-page .page-header__eyebrow {
  display: inline-flex;
  align-items: center;
  padding: 7px 13px;
  border-radius: 999px;
  border: 1px solid var(--px-line);
  background: rgba(255,255,255,0.48);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.7);
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--px-sky-dark);
}

.px-page .page-header__title {
  letter-spacing: -0.03em;
  line-height: 1.04;
}

.px-page .page-header__support-label {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--px-sky-dark);
}

/* ---------- Section headers ---------- */

.px-page .section-header__label {
  display: inline-flex;
  align-items: center;
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid var(--px-line);
  background: rgba(255,255,255,0.48);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.7);
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--px-sky-dark);
}

.px-page .section-header__title {
  letter-spacing: -0.03em;
}

/* ---------- Cards (blog-card grids) ---------- */

.px-page .blog-card {
  position: relative;
  border: 1px solid var(--px-line);
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(255,255,255,0.6), rgba(255,253,249,0.42));
  box-shadow: var(--px-shadow-soft);
  overflow: hidden;
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

.px-page .blog-card::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 44px;
  height: 44px;
  background: linear-gradient(225deg, rgba(219, 231, 240, 0.9) 0%, rgba(219, 231, 240, 0.9) 50%, transparent 50%);
  border-bottom-left-radius: 18px;
  pointer-events: none;
  transition: background 180ms ease;
  z-index: 1;
}

.px-page .blog-card:hover {
  transform: translateY(-4px);
  border-color: var(--px-line-strong);
  box-shadow: var(--px-shadow);
}

.px-page .blog-card:hover::after {
  background: linear-gradient(225deg, rgba(167, 244, 255, 0.65) 0%, rgba(167, 244, 255, 0.65) 50%, transparent 50%);
}

.px-page .blog-card__tag {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--px-sky-dark);
}

.px-page .blog-card__title {
  transition: color 160ms ease;
}

.px-page .blog-card:hover .blog-card__title {
  color: var(--px-sky-dark);
}

.px-page .blog-card__meta {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.72rem;
  letter-spacing: 0.04em;
  color: rgba(49, 65, 87, 0.72);
}

/* ---------- Body copy (article__body reuse) ---------- */

.px-page .article__body {
  color: var(--px-ink-soft);
}

.px-page .article__body a {
  color: var(--px-sky-deep);
  text-decoration: underline;
  text-decoration-color: rgba(71, 117, 166, 0.36);
  text-underline-offset: 3px;
  transition: color 140ms ease, text-decoration-color 140ms ease;
}

.px-page .article__body a:hover {
  color: var(--px-sky-dark);
  text-decoration-color: var(--px-sky-deep);
}

.px-page .article__body h2 {
  letter-spacing: -0.025em;
}

.px-page .article__body strong {
  color: var(--px-ink);
}

.px-page .article__body li::marker {
  color: var(--px-sky-deep);
}

.px-page .article__body blockquote {
  border-left: 3px solid var(--px-sky);
  border-radius: 0 18px 18px 0;
  background: linear-gradient(180deg, rgba(255,255,255,0.62), rgba(255,253,249,0.4));
  box-shadow: var(--px-shadow-soft);
  font-family: 'Space Grotesk', sans-serif;
  font-style: normal;
  color: var(--px-ink);
}

.px-page .article__body code,
.px-page code {
  font-family: 'IBM Plex Mono', monospace;
}

.px-page .article__body code {
  font-size: 0.85em;
  padding: 2px 7px;
  border-radius: 6px;
  border: 1px solid var(--px-line);
  background: rgba(235, 223, 207, 0.55);
  color: var(--px-sky-dark);
}

/* ---------- Code panels (dark ink) ---------- */

.px-page .code-block,
.px-page .article__body > pre {
  border-radius: 18px;
  border: 1px solid rgba(16, 24, 36, 0.85);
  background:
    radial-gradient(circle at 84% 10%, rgba(167, 244, 255, 0.1), transparent 44%),
    radial-gradient(circle at 8% 96%, rgba(109, 155, 200, 0.18), transparent 50%),
    linear-gradient(180deg, #22314a 0%, #141c29 100%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.08),
    0 28px 60px rgba(23, 31, 43, 0.28);
  overflow: hidden;
}

.px-page .code-block__header {
  background: rgba(10, 16, 26, 0.5);
  border-bottom: 1px solid rgba(159, 178, 200, 0.14);
  padding: 12px 16px;
}

.px-page .code-block__dot,
.px-page .code-block__dot--red,
.px-page .code-block__dot--yellow,
.px-page .code-block__dot--green {
  width: 8px;
  height: 8px;
  background: rgba(159, 178, 200, 0.24);
}

.px-page .code-block__title {
  color: #9fb2c8;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.68rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.px-page .code-block__body {
  padding: 20px 24px 22px;
}

.px-page .code-block pre {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.85rem;
  line-height: 1.75;
  color: #dfe9f5;
  background: none;
  margin: 0;
  padding: 0;
  border-radius: 0;
}

.px-page .code-block .kw { color: #f0c36a; }
.px-page .code-block .fn { color: #a7f4ff; }
.px-page .code-block .str { color: #6fcf97; }
.px-page .code-block .cm { color: #7e91a8; font-style: italic; }
.px-page .code-block .op { color: #d8e2ee; }
.px-page .code-block .num { color: #f0c36a; }
.px-page .code-block .var { color: #e8eef6; }
.px-page .code-block .res { color: #8fa3bb; }

/* ---------- Tables ---------- */

.px-page .table-responsive {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.px-page .article__body table,
.px-page .table-responsive table,
.px-page .comparison-table {
  width: 100%;
  margin: 24px 0;
  border-collapse: separate;
  border-spacing: 0;
  border: 1px solid var(--px-line);
  border-radius: 18px;
  overflow: hidden;
  background: linear-gradient(180deg, rgba(255,255,255,0.6), rgba(255,253,249,0.42));
  box-shadow: var(--px-shadow-soft);
  font-size: 0.92rem;
}

.px-page .article__body th,
.px-page .article__body td,
.px-page .table-responsive th,
.px-page .table-responsive td,
.px-page .comparison-table th,
.px-page .comparison-table td {
  padding: 13px 18px;
  text-align: left;
  border-bottom: 1px solid var(--px-line);
  background: transparent;
}

.px-page .article__body thead th,
.px-page .table-responsive thead th,
.px-page .comparison-table thead th {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--px-sky-dark);
  background: rgba(219, 231, 240, 0.5);
  border-bottom: 1px solid var(--px-line-strong);
}

.px-page .article__body tbody tr:last-child td,
.px-page .table-responsive tbody tr:last-child td,
.px-page .comparison-table tbody tr:last-child td {
  border-bottom: none;
}

.px-page .article__body tbody td:first-child,
.px-page .table-responsive tbody td:first-child,
.px-page .comparison-table tbody td:first-child {
  font-weight: 600;
  color: var(--px-ink);
}

.px-page .comparison-table .check {
  color: #2e7d5b;
  font-weight: 700;
}

.px-page .comparison-table .cross {
  color: rgba(49, 65, 87, 0.32);
}

/* ---------- CTA banner (dark ink panel) ---------- */

.px-page .cta-banner {
  position: relative;
  padding: 52px 40px;
  border-radius: 30px;
  border: 1px solid rgba(16, 24, 36, 0.85);
  background:
    radial-gradient(circle at 82% 18%, rgba(167, 244, 255, 0.14), transparent 42%),
    radial-gradient(circle at 12% 88%, rgba(109, 155, 200, 0.24), transparent 48%),
    linear-gradient(180deg, #22314a 0%, #141c29 100%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.08),
    0 40px 80px rgba(23, 31, 43, 0.32);
  overflow: hidden;
}

.px-page .cta-banner::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 96px;
  height: 96px;
  background: linear-gradient(225deg, rgba(167, 244, 255, 0.1) 0%, rgba(167, 244, 255, 0.1) 50%, transparent 50%);
  border-bottom-left-radius: 30px;
  pointer-events: none;
}

.px-page .cta-banner h2 {
  color: #f2f7fd;
  font-size: clamp(1.5rem, 2.4vw, 2rem);
  letter-spacing: -0.03em;
}

.px-page .cta-banner p {
  color: #b6c5d8;
  font-size: 0.98rem;
  line-height: 1.66;
}

.px-page .signup-form__input {
  border-radius: 999px;
  border: 1px solid rgba(159, 178, 200, 0.3);
  background: rgba(255,255,255,0.08);
}

.px-page .signup-form__input:focus {
  border-color: rgba(167, 244, 255, 0.6);
}

.px-page .signup-form button {
  border-radius: 999px;
  font-family: 'IBM Plex Mono', monospace;
  letter-spacing: 0.04em;
}

.px-page .signup-form__success {
  color: var(--px-glow);
}

/* ---------- Footer harmonizing ---------- */

.px-page .footer {
  background: transparent;
  border-top: 1px solid var(--px-line);
}

/* ---------- Responsive / motion ---------- */

@media (max-width: 768px) {
  .px-page .cta-banner {
    padding: 40px 24px;
  }

  .px-page .article__body table,
  .px-page .comparison-table {
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}

@media (prefers-reduced-motion: reduce) {
  .px-page .blog-card,
  .px-page .blog-card__title {
    transition: none;
  }
}
