/* ============================================================
   Privacy Scanner Website — PDF demo (§7.7) styles

   Token substitutions: --motion-fast → --dur-fast
   ============================================================ */

.redact {
  background: var(--bg-1);
  padding-block: var(--sp-10);
}
.redact-inner {
  max-width: var(--maxw-wide);
  margin-inline: auto;
  padding-inline: var(--gutter-mobile);
}
@media (min-width: 600px)  { .redact-inner { padding-inline: var(--gutter-tablet); } }
@media (min-width: 1024px) { .redact-inner { padding-inline: var(--gutter-desktop); } }

.redact-head {
  max-width: 56ch;
  margin-block-end: var(--sp-6);
}
.redact-h2 {
  margin: 0 0 var(--sp-4);
  font-family: var(--font-sans);
  font-size: var(--fs-h2);
  font-weight: var(--fw-semibold);
  line-height: var(--lh-heading);
  letter-spacing: var(--ls-heading);
  color: var(--text);
  text-wrap: balance;
}
:lang(ja) .redact-h2,
:lang(zh-Hans) .redact-h2,
:lang(ko) .redact-h2 {
  line-height: 1.3; letter-spacing: 0; text-wrap: auto;
}
.redact-lede {
  margin: 0;
  max-width: 60ch;
  font-size: var(--fs-body-lg);
  line-height: var(--lh-body);
  color: var(--text-soft);
}


/* ============================================================
   Segmented tabs
   ============================================================ */
.redact-tabs {
  display: inline-flex;
  margin: var(--sp-7) 0 var(--sp-6);
  padding: 4px;
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: var(--r-pill);
}
@media (max-width: 767px) {
  .redact-tabs {
    display: flex;
    width: 100%;
  }
}
.redact-tab {
  appearance: none;
  -webkit-appearance: none;
  background: transparent;
  border: 0;
  padding: var(--sp-2) var(--sp-5);
  font-family: var(--font-mono);
  font-size: var(--fs-mono-sm);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
  color: var(--text-soft);
  border-radius: var(--r-pill);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out),
              color var(--dur-fast) var(--ease-out);
}
@media (max-width: 767px) {
  .redact-tab { flex: 1; padding-inline: var(--sp-3); }
}
.redact-tab:hover:not([aria-selected="true"]) { color: var(--text); }
.redact-tab[aria-selected="true"] {
  background: var(--bg-base);
  color: var(--text);
  box-shadow: var(--shadow-sm);
}
.redact-tab:focus-visible {
  outline: none;
  box-shadow: var(--focus-ring);
}


/* ============================================================
   Tabpanels
   ============================================================ */
.redact-panel[hidden] {
  display: none;
}
.redact-panel:focus-visible {
  outline: none;
  box-shadow: var(--focus-ring);
  border-radius: var(--r-md);
}


/* ============================================================
   Comparison columns
   ============================================================ */
.compare {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-5);
  margin: 0;
}
@media (max-width: 767px) {
  .compare {
    grid-template-columns: 1fr;
    gap: var(--sp-6);
  }
}

.compare-col {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}

.compare-label {
  margin: 0;
  font-family: var(--font-mono);
  font-size: var(--fs-mono-sm);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-caps);
  text-transform: uppercase;
}
.compare-label--before { color: var(--risk-critical); }
.compare-label--after  { color: var(--risk-safe); }

.compare-col img {
  display: block;
  width: 100%;
  height: auto;
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
}

.compare-count {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--fs-body-sm);
  font-weight: var(--fw-medium);
  color: var(--text-dim);
}
