/* PivCSS demo 首页 — 狗粮薄层（Hero 等；其余区块 batch 2–5 逐步迁移） */

.pvs-landing-dot {
  display: inline-block;
  width: 0.55rem;
  height: 0.55rem;
  border-radius: 50%;
}

.pvs-landing-dot--red {
  background: #f87171;
}

.pvs-landing-dot--amber {
  background: #fbbf24;
}

.pvs-landing-dot--green {
  background: #4ade80;
}

html:not([data-pvs-theme='dark']) .pvs-landing-hero .pvs-text-muted {
  color: var(--pvs-gray-600);
}

html:not([data-pvs-theme='dark']) .pvs-landing-hero .pvs-cmd {
  color: var(--pvs-gray-600);
  background: rgb(255 255 255 / 88%);
  border-color: var(--pvs-gray-300);
}

html:not([data-pvs-theme='dark']) .pvs-landing-hero .pvs-cmd code[data-pvs-typewriter] {
  color: var(--pvs-gray-800);
}

html:not([data-pvs-theme='dark']) .pvs-landing-hero .pvs-btn--outline {
  border-color: color-mix(in srgb, var(--pvs-primary) 35%, var(--pvs-border-color));
  color: var(--pvs-gray-800);
}

/* ── 营销页分块 · 线条网格底 ── */
.pvs-landing-block {
  --pvs-landing-grid: color-mix(in srgb, var(--pvs-border-color) 34%, transparent);
  position: relative;
  isolation: isolate;
  border-block: 1px solid color-mix(in srgb, var(--pvs-border-color) 48%, transparent);
}

.pvs-landing-block::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background-image:
    linear-gradient(to right, var(--pvs-landing-grid) 1px, transparent 1px),
    linear-gradient(to bottom, var(--pvs-landing-grid) 1px, transparent 1px);
  background-size: 2rem 2rem;
  background-position: center center;
  mask-image:
    linear-gradient(90deg, transparent 0%, #000 5%, #000 95%, transparent 100%),
    linear-gradient(180deg, transparent 0%, #000 6%, #000 94%, transparent 100%);
  mask-composite: intersect;
  -webkit-mask-composite: source-in;
}

.pvs-landing-block > .pvs-container {
  position: relative;
  z-index: 1;
}

.pvs-landing-block--hero {
  border-block-start: 0;
}

.pvs-landing-block--hero::before {
  --pvs-landing-grid: color-mix(in srgb, var(--pvs-primary) 11%, transparent);
}

.pvs-landing-block--muted::before {
  --pvs-landing-grid: color-mix(in srgb, var(--pvs-primary) 9%, var(--pvs-border-color));
}

.pvs-landing-block--accent {
  background-color: color-mix(in srgb, var(--pvs-primary) 4%, var(--pvs-body-bg));
}

.pvs-landing-block--accent::before {
  --pvs-landing-grid: color-mix(in srgb, var(--pvs-primary) 13%, transparent);
}

html[data-pvs-theme='dark'] .pvs-landing-block--accent {
  background-color: color-mix(in srgb, var(--pvs-primary) 8%, var(--pvs-body-bg));
}

html[data-pvs-theme='dark'] .pvs-landing-block::before {
  --pvs-landing-grid: color-mix(in srgb, var(--pvs-border-color) 22%, transparent);
}

html:not([data-pvs-theme='dark']) .pvs-band--inverse.pvs-landing-hero.pvs-landing-block {
  background-image: linear-gradient(
    165deg,
    #f8fafc 0%,
    color-mix(in srgb, var(--pvs-primary) 6%, #fff) 100%
  );
  color: var(--pvs-gray-900);
}
